mirror of
https://github.com/go-gitea/gitea.git
synced 2024-12-31 01:14:22 +08:00
0f4b0cf892
1. correct the modal usage on "admin email list" page (then `web_src/js/features/admin/emails.ts` is removed) 2. use `addDelegatedEventListener` instead of `jQuery().on` 3. more jQuery related changes and remove jQuery from `web_src/js/features/common-button.ts` 4. improve `confirmModal` to make it support header, and remove incorrect double-escaping 5. fix more typescript related types 6. fine tune devtest pages and add more tests
34 lines
1.1 KiB
TypeScript
34 lines
1.1 KiB
TypeScript
import {svg} from '../../svg.ts';
|
|
import {htmlEscape} from 'escape-goat';
|
|
import {createElementFromHTML} from '../../utils/dom.ts';
|
|
import {fomanticQuery} from '../../modules/fomantic/base.ts';
|
|
|
|
const {i18n} = window.config;
|
|
|
|
export function confirmModal({header = '', content = '', confirmButtonColor = 'primary'} = {}) {
|
|
return new Promise((resolve) => {
|
|
const headerHtml = header ? `<div class="header">${htmlEscape(header)}</div>` : '';
|
|
const modal = createElementFromHTML(`
|
|
<div class="ui g-modal-confirm modal">
|
|
${headerHtml}
|
|
<div class="content">${htmlEscape(content)}</div>
|
|
<div class="actions">
|
|
<button class="ui cancel button">${svg('octicon-x')} ${htmlEscape(i18n.modal_cancel)}</button>
|
|
<button class="ui ${confirmButtonColor} ok button">${svg('octicon-check')} ${htmlEscape(i18n.modal_confirm)}</button>
|
|
</div>
|
|
</div>
|
|
`);
|
|
document.body.append(modal);
|
|
const $modal = fomanticQuery(modal);
|
|
$modal.modal({
|
|
onApprove() {
|
|
resolve(true);
|
|
},
|
|
onHidden() {
|
|
$modal.remove();
|
|
resolve(false);
|
|
},
|
|
}).modal('show');
|
|
});
|
|
}
|