mirror of
https://github.com/go-gitea/gitea.git
synced 2026-06-22 19:19:57 +00:00
- Bump `eslint`, `typescript-eslint` and `eslint-plugin-unicorn` (to v68), and configure the rules added in unicorn v66/v67/v68. - Remove `eslint-plugin-github` and its workarounds (rules, type stub, pnpm peer override, in-code `eslint-disable` comments); the rules worth keeping are covered by `unicorn` equivalents. - Apply the resulting fixes and autofixes across the JS codebase. _Prepared with Claude (Opus 4.8)._ --------- Signed-off-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
33 lines
1.4 KiB
TypeScript
33 lines
1.4 KiB
TypeScript
import {applyAreYouSure, initAreYouSure} from '../vendor/jquery.are-you-sure.ts';
|
|
import {handleGlobalEnterQuickSubmit} from './comp/QuickSubmit.ts';
|
|
import {queryElems} from '../utils/dom.ts';
|
|
import {initComboMarkdownEditor} from './comp/ComboMarkdownEditor.ts';
|
|
|
|
export function initGlobalFormDirtyLeaveConfirm() {
|
|
initAreYouSure(window.jQuery);
|
|
// Warn users that try to leave a page after entering data into a form.
|
|
// Except on sign-in pages, and for forms marked as 'ignore-dirty'.
|
|
if (!document.querySelector('.page-content.user.signin')) {
|
|
applyAreYouSure('form:not(.ignore-dirty)');
|
|
}
|
|
}
|
|
|
|
export function initGlobalEnterQuickSubmit() {
|
|
document.addEventListener('keydown', (e) => {
|
|
if (e.isComposing) return;
|
|
if (e.key !== 'Enter') return;
|
|
const el = e.target as HTMLElement;
|
|
const hasCtrlOrMeta = ((e.ctrlKey || e.metaKey) && !e.altKey);
|
|
const isCtrlEnterInTextarea = hasCtrlOrMeta && el.matches('textarea');
|
|
// an input in a normal form could handle Enter key by default, so we only handle the input outside a form
|
|
const isEnterInBareInput = el.matches('input') && !el.closest('form');
|
|
if ((isCtrlEnterInTextarea || isEnterInBareInput) && handleGlobalEnterQuickSubmit(el)) {
|
|
e.preventDefault();
|
|
}
|
|
});
|
|
}
|
|
|
|
export function initGlobalComboMarkdownEditor() {
|
|
queryElems<HTMLElement>(document, '.combo-markdown-editor:not(.custom-init)', (el) => initComboMarkdownEditor(el));
|
|
}
|