import React from 'dom-chef'; import select from 'select-dom'; import delegate from 'delegate-it'; import domLoaded from 'dom-loaded'; import elementReady from 'element-ready'; import * as pageDetect from 'github-url-detection'; import features from '.'; import looseParseInt from '../helpers/loose-parse-int'; const confirmationRequiredCount = 10; function getUrlFromItem(checkbox: Element): string { return checkbox .closest('.js-issue-row')! .querySelector('.js-navigation-open')! .href; } function openIssues(): void { const modifier = pageDetect.isGlobalConversationList() ? '' : ' + div '; const issues = select.all([ `#js-issues-toolbar.triage-mode ${modifier} [name="issues[]"]:checked`, // Get checked checkboxes `#js-issues-toolbar:not(.triage-mode) ${modifier} .js-issue-row` // Or all items ]); if ( issues.length >= confirmationRequiredCount && !confirm(`This will open ${issues.length} new tabs. Continue?`) ) { return; } void browser.runtime.sendMessage({ openUrls: issues.map(getUrlFromItem) }); } async function init(): Promise { if (!await elementReady('.js-issue-row + .js-issue-row')) { return false; } delegate(document, '.rgh-batch-open-issues', 'click', openIssues); // Add button to open all visible conversations select('.table-list-header-toggle:not(.states)')?.prepend( ); // Add button to open selected conversations const triageFiltersBar = select('.table-list-triage > .text-gray'); if (triageFiltersBar) { triageFiltersBar.classList.add('table-list-header-toggle'); // Handles link :hover style triageFiltersBar.append( ); } else if (!pageDetect.isEnterprise() && pageDetect.isRepoConversationList()) { // Enterprise has the pre-"Repository refresh" layout // GitHub doesn't have the checkboxes when the current user can't edit the repo, so let's add them const issuesToolbar = select('#js-issues-toolbar')!; issuesToolbar.prepend(
); issuesToolbar.append(
1 {' selected '}
); await domLoaded; for (const conversation of select.all('.js-issue-row')) { const number = looseParseInt(conversation.id); conversation.firstElementChild!.prepend( ); } } } void features.add(__filebasename, { include: [ pageDetect.isConversationList ], awaitDomReady: false, init });