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(document, '.combo-markdown-editor:not(.custom-init)', (el) => initComboMarkdownEditor(el)); }