mirror of
https://github.com/the-djmaze/snappymail.git
synced 2024-11-15 04:04:50 +08:00
44 lines
1.2 KiB
JavaScript
44 lines
1.2 KiB
JavaScript
import { KeyState } from 'Common/Enums';
|
|
|
|
import { popup } from 'Knoin/Knoin';
|
|
import { AbstractViewNext } from 'Knoin/AbstractViewNext';
|
|
|
|
@popup({
|
|
name: 'View/Popup/KeyboardShortcutsHelp',
|
|
templateID: 'PopupsKeyboardShortcutsHelp'
|
|
})
|
|
class KeyboardShortcutsHelpPopupView extends AbstractViewNext {
|
|
constructor() {
|
|
super();
|
|
this.sDefaultKeyScope = KeyState.PopupKeyboardShortcutsHelp;
|
|
}
|
|
|
|
onBuild(dom) {
|
|
dom.querySelectorAll('a[data-toggle="tab"]').forEach(node => node.Tab || new BSN.Tab(node));
|
|
|
|
key(
|
|
'tab, shift+tab, left, right',
|
|
KeyState.PopupKeyboardShortcutsHelp,
|
|
((event, handler)=>{
|
|
if (event && handler) {
|
|
const tabs = dom.querySelectorAll('.nav.nav-tabs > li'),
|
|
last = tabs.length - 1;
|
|
let next = 0;
|
|
tabs.forEach((node, index) => {
|
|
if (node.matches('.active')) {
|
|
if (['tab','right'].includes(handler.shortcut)) {
|
|
next = index < last ? index+1 : 0;
|
|
} else {
|
|
next = index ? index-1 : last;
|
|
}
|
|
}
|
|
});
|
|
|
|
tabs[next].querySelector('a[data-toggle="tab"]').Tab.show();
|
|
}
|
|
}).throttle(100)
|
|
);
|
|
}
|
|
}
|
|
|
|
export { KeyboardShortcutsHelpPopupView, KeyboardShortcutsHelpPopupView as default };
|