mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-18 02:50:58 +01:00
385969e9f5
* fix(frontend): 直前のパターンを記録するように * fix(frontend): フォーカス/タブ移動に関する挙動を調整 (#226) Cherry-pick commit e8c030673326871edf3623cf2b8675d68f9e1b13 Co-authored-by: taiyme <53635909+taiyme@users.noreply.github.com> * focusのデザイン修正 * move scripts * Modalにfocus trapを追加 * 記録するホットキーはレートリミット式にする * escキーのハンドリングをMkModalに統一 * fix * enterで子メニューを開けるように * lint * fix focus trap * improve switch accessibility * 一部のmodalのフォーカストラップが外れない問題を修正 * fix * fix * Revert "記録するホットキーはレートリミット式にする" This reverts commit40a7509286
. * Revert "fix(frontend): 直前のパターンを記録するように" This reverts commit5372b25940
. * Revert "Revert "fix(frontend): 直前のパターンを記録するように"" This reverts commita9bb52e799
. * Revert "Revert "記録するホットキーはレートリミット式にする"" This reverts commitbdac34273e
. * 試験的にCypressでのFocustrapを無効化 * fix * fix focus-trap * Update Changelog * ✌️ * fix focustrap invocation logic * スクロールがsticky headerを考慮するように * 🎨 * スタイルの微調整 * 🎨 * remove deprecated key aliases * focusElementが足りなかったので修正 * preview系にfocus時スタイルが足りなかったので修正 * `returnFocusElement` -> `returnFocusTo` * lint * Update packages/frontend/src/components/MkModalWindow.vue * Apply suggestions from code review Co-authored-by: taiy <53635909+taiyme@users.noreply.github.com> * keydownイベントをまとめる * use correct pesudo-element selector * fix * rename --------- Co-authored-by: taiyme <53635909+taiyme@users.noreply.github.com> Co-authored-by: syuilo <4439005+syuilo@users.noreply.github.com>
29 lines
722 B
TypeScript
29 lines
722 B
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import { Directive } from 'vue';
|
|
import { makeHotkey } from '@/scripts/hotkey.js';
|
|
|
|
export default {
|
|
mounted(el, binding) {
|
|
el._hotkey_global = binding.modifiers.global === true;
|
|
|
|
el._keyHandler = makeHotkey(binding.value);
|
|
|
|
if (el._hotkey_global) {
|
|
document.addEventListener('keydown', el._keyHandler, { passive: false });
|
|
} else {
|
|
el.addEventListener('keydown', el._keyHandler, { passive: false });
|
|
}
|
|
},
|
|
|
|
unmounted(el) {
|
|
if (el._hotkey_global) {
|
|
document.removeEventListener('keydown', el._keyHandler);
|
|
} else {
|
|
el.removeEventListener('keydown', el._keyHandler);
|
|
}
|
|
},
|
|
} as Directive;
|