snappymail/dev/View/User/Settings/Menu.js

82 lines
1.6 KiB
JavaScript
Raw Normal View History

import _ from '_';
import $ from '$';
import key from 'key';
import {KeyState, Magics} from 'Common/Enums';
import {leftPanelDisabled} from 'Common/Globals';
import {settings, inbox} from 'Common/Links';
import {getFolderInboxName} from 'Common/Cache';
import * as Settings from 'Storage/Settings';
import {view, ViewType, setHash} from 'Knoin/Knoin';
import {AbstractViewNext} from 'Knoin/AbstractViewNext';
@view({
name: 'View/User/Settings/Menu',
type: ViewType.Left,
templateID: 'SettingsMenu'
})
class MenuSettingsUserView extends AbstractViewNext
2016-06-30 08:02:45 +08:00
{
/**
* @param {Object} screen
*/
constructor(screen) {
super();
this.leftPanelDisabled = leftPanelDisabled;
this.mobile = Settings.appSettingsGet('mobile');
this.menu = screen.menu;
}
onBuild(dom) {
if (this.mobile)
{
dom.on('click', '.b-settings-menu .e-item.selectable', () => {
leftPanelDisabled(true);
2016-06-30 08:02:45 +08:00
});
}
2016-05-01 09:07:10 +08:00
key('up, down', KeyState.Settings, _.throttle((event, handler) => {
2015-02-16 05:55:59 +08:00
const
up = handler && 'up' === handler.shortcut,
$items = $('.b-settings-menu .e-item', dom);
2015-02-16 05:55:59 +08:00
if (event && $items.length)
2015-02-16 05:55:59 +08:00
{
let iIndex = $items.index($items.filter('.selected'));
if (up && 0 < iIndex)
{
iIndex -= 1;
}
else if (!up && iIndex < $items.length - 1)
{
iIndex += 1;
}
const sH = $items.eq(iIndex).attr('href');
if (sH)
{
setHash(sH, false, true);
}
2015-02-16 05:55:59 +08:00
}
}, Magics.Time200ms));
}
link(sRoute) {
return settings(sRoute);
}
backToMailBoxClick() {
setHash(inbox(getFolderInboxName()));
}
}
export {MenuSettingsUserView, MenuSettingsUserView as default};