Skip to content

Commit

Permalink
Improve SettingsUserStore handling
Browse files Browse the repository at this point in the history
  • Loading branch information
djmaze committed Mar 18, 2021
1 parent ce74b2e commit 97d5f87
Show file tree
Hide file tree
Showing 8 changed files with 50 additions and 97 deletions.
10 changes: 5 additions & 5 deletions dev/App/User.js
Original file line number Diff line number Diff line change
Expand Up @@ -130,10 +130,6 @@ class AppUser extends AbstractApp {
const fn = (ev=>$htmlCL.toggle('rl-ctrl-key-pressed', ev.ctrlKey)).debounce(500);
['keydown','keyup'].forEach(t => doc.addEventListener(t, fn));

['touchstart','mousedown','mousemove','keydown'].forEach(
t => doc.addEventListener(t, SettingsUserStore.delayLogout, {passive:true})
);

shortcuts.add('escape,enter', '', Scope.All, () => rl.Dropdowns.detectVisibility());
}

Expand Down Expand Up @@ -884,7 +880,6 @@ class AppUser extends AbstractApp {

addEventListener('resize', () => leftPanelDisabled(ThemeStore.isMobile() || 1000 > innerWidth));

SettingsUserStore.populate();
NotificationUserStore.populate();
AccountUserStore.populate();
ContactUserStore.populate();
Expand Down Expand Up @@ -1011,6 +1006,11 @@ class AppUser extends AbstractApp {
}, 500);
}

['touchstart','mousedown','mousemove','keydown'].forEach(
t => doc.addEventListener(t, SettingsUserStore.delayLogout, {passive:true})
);
SettingsUserStore.delayLogout();

setTimeout(() => this.initVerticalLayoutResizer(), 1);
} else {
this.logout();
Expand Down
14 changes: 6 additions & 8 deletions dev/Remote/User/Fetch.js
Original file line number Diff line number Diff line change
Expand Up @@ -583,15 +583,13 @@ class RemoteUserFetch extends AbstractFetchRemote {

/**
* @param {string} key
* @param {?Function} valueFn
* @param {?Function} fn
* @param {?scalar} value
* @param {?Function} fCallback
*/
saveSettingsHelper(key, valueFn, fn) {
return (value) => {
this.saveSettings(fn || null, {
[key]: valueFn ? valueFn(value) : value
});
};
saveSetting(key, value, fCallback) {
this.saveSettings(fCallback, {
[key]: value
});
}

/**
Expand Down
2 changes: 0 additions & 2 deletions dev/Screen/User/MailBox.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import { i18n } from 'Common/Translator';

import { AppUserStore } from 'Stores/User/App';
import { AccountUserStore } from 'Stores/User/Account';
import { SettingsUserStore } from 'Stores/User/Settings';
import { FolderUserStore } from 'Stores/User/Folder';
import { MessageUserStore } from 'Stores/User/Message';
import { ThemeStore } from 'Stores/Theme';
Expand Down Expand Up @@ -89,7 +88,6 @@ export class MailBoxUserScreen extends AbstractScreen {
onStart() {
if (!this.__started) {
super.onStart();
setTimeout(() => SettingsUserStore.layout.valueHasMutated(), 50);
setTimeout(() => warmUpScreenPopup(ComposePopupView), 500);

addEventListener('mailbox.inbox-unread-count', e => {
Expand Down
52 changes: 17 additions & 35 deletions dev/Settings/User/General.js
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,6 @@ export class GeneralUserSettings {
];
});


const fReloadLanguageHelper = (saveSettingsStep) => () => {
this.languageTrigger(saveSettingsStep);
setTimeout(() => this.languageTrigger(SaveSettingsStep.Idle), 1000);
Expand All @@ -93,56 +92,39 @@ export class GeneralUserSettings {
language: value => {
this.languageTrigger(SaveSettingsStep.Animate);
translatorReload(false, value)
.then(fReloadLanguageHelper(SaveSettingsStep.TrueResult), fReloadLanguageHelper(SaveSettingsStep.FalseResult))
.then(() => {
Remote.saveSettings(null, {
'Language': value
});
});
.then(fReloadLanguageHelper(SaveSettingsStep.TrueResult),
fReloadLanguageHelper(SaveSettingsStep.FalseResult))
.then(() => Remote.saveSetting('Language', value));
},

editorDefaultType:
Remote.saveSettingsHelper('EditorDefaultType', null,
settingsSaveHelperSimpleFunction(this.editorDefaultTypeTrigger, this)),
editorDefaultType: value => Remote.saveSetting('EditorDefaultType', value,
settingsSaveHelperSimpleFunction(this.editorDefaultTypeTrigger, this)),

messagesPerPage: Remote.saveSettingsHelper('MPP', null, settingsSaveHelperSimpleFunction(this.mppTrigger, this)),
messagesPerPage: value => Remote.saveSetting('MPP', value,
settingsSaveHelperSimpleFunction(this.mppTrigger, this)),

showImages: Remote.saveSettingsHelper('ShowImages', v=>v?'1':'0'),
showImages: value => Remote.saveSetting('ShowImages', value ? 1 : 0),

removeColors: Remote.saveSettingsHelper('RemoveColors', v=>v?'1':'0'),
removeColors: value => {
Remote.saveSetting('RemoveColors', value ? 1 : 0);
},

useCheckboxesInList: Remote.saveSettingsHelper('UseCheckboxesInList', v=>v?'1':'0'),
useCheckboxesInList: value => Remote.saveSetting('UseCheckboxesInList', value ? 1 : 0),

enableDesktopNotification: (value =>
Remote.saveSettings(null, {
'DesktopNotifications': value ? 1 : 0
})
).debounce(3000),
enableDesktopNotification: value => Remote.saveSetting('DesktopNotifications', value ? 1 : 0),

enableSoundNotification: (value =>
Remote.saveSettings(null, {
'SoundNotification': value ? 1 : 0
})
).debounce(3000),
enableSoundNotification: value => Remote.saveSetting('SoundNotification', value ? 1 : 0),

replySameFolder: (value =>
Remote.saveSettings(null, {
'ReplySameFolder': value ? 1 : 0
})
).debounce(3000),
replySameFolder: value => Remote.saveSetting('ReplySameFolder', value ? 1 : 0),

useThreads: value => {
MessageUserStore.list([]);
Remote.saveSettings(null, {
'UseThreads': value ? 1 : 0
});
Remote.saveSetting('UseThreads', value ? 1 : 0);
},

layout: value => {
MessageUserStore.list([]);
Remote.saveSettings(settingsSaveHelperSimpleFunction(this.layoutTrigger, this), {
'Layout': value
});
Remote.saveSetting('Layout', value, settingsSaveHelperSimpleFunction(this.layoutTrigger, this));
}
});
}
Expand Down
8 changes: 2 additions & 6 deletions dev/Settings/User/OpenPgp.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@ export class OpenPgpUserSettings {
this.openPgpKeyForDeletion = ko.observable(null).deleteAccessHelper();

this.allowDraftAutosave = SettingsUserStore.allowDraftAutosave;

this.allowDraftAutosave.subscribe(value => Remote.saveSetting('AllowDraftAutosave', value ? 1 : 0))
}

addOpenPgpKey() {
Expand Down Expand Up @@ -61,10 +63,4 @@ export class OpenPgpUserSettings {
}
}
}

onBuild() {
setTimeout(() => {
this.allowDraftAutosave.subscribe(Remote.saveSettingsHelper('AllowDraftAutosave', v=>v?'1':'0'));
}, 50);
}
}
20 changes: 8 additions & 12 deletions dev/Settings/User/Security.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export class SecurityUserSettings {
this.capaTwoFactor = Settings.capa(Capa.TwoFactor);

this.autoLogout = SettingsUserStore.autoLogout;
this.autoLogout.trigger = ko.observable(SaveSettingsStep.Idle);
this.autoLogoutTrigger = ko.observable(SaveSettingsStep.Idle);

let i18nLogout = (key, params) => i18n('SETTINGS_SECURITY/AUTOLOGIN_' + key, params);
this.autoLogoutOptions = ko.computed(() => {
Expand All @@ -35,20 +35,16 @@ export class SecurityUserSettings {
{ 'id': 60 * 10, 'name': i18nLogout('HOURS_OPTION_NAME', { 'HOURS': 10 }) }
];
});

if (this.capaAutoLogout) {
this.autoLogout.subscribe(value => Remote.saveSetting(
'AutoLogout', pInt(value),
settingsSaveHelperSimpleFunction(this.autoLogoutTrigger, this)
));
}
}

configureTwoFactor() {
showScreenPopup(TwoFactorConfigurationPopupView);
}

onBuild() {
if (this.capaAutoLogout) {
setTimeout(() =>
this.autoLogout.subscribe(Remote.saveSettingsHelper(
'AutoLogout', pInt,
settingsSaveHelperSimpleFunction(this.autoLogout.trigger, this)
))
);
}
}
}
39 changes: 11 additions & 28 deletions dev/Stores/User/Settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ import { ThemeStore } from 'Stores/Theme';
export const SettingsUserStore = new class {
constructor() {
this.layout = ko
.observable(Layout.SidePreview)
.observable(pInt(SettingsGet('Layout')))
.extend({ limitedList: [Layout.SidePreview, Layout.BottomPreview, Layout.NoPreview] });

this.editorDefaultType = ko.observable(EditorDefaultType.Html).extend({
this.editorDefaultType = ko.observable(SettingsGet('EditorDefaultType')).extend({
limitedList: [
EditorDefaultType.Html,
EditorDefaultType.Plain,
Expand All @@ -21,17 +21,17 @@ export const SettingsUserStore = new class {
]
});

this.messagesPerPage = ko.observable(20).extend({ limitedList: MESSAGES_PER_PAGE_VALUES });
this.messagesPerPage = ko.observable(SettingsGet('MPP')).extend({ limitedList: MESSAGES_PER_PAGE_VALUES });

addObservablesTo(this, {
showImages: false,
removeColors: false,
useCheckboxesInList: true,
allowDraftAutosave: true,
useThreads: false,
replySameFolder: false,

autoLogout: 30
showImages: !!SettingsGet('ShowImages'),
removeColors: !!SettingsGet('RemoveColors'),
useCheckboxesInList: !!(ThemeStore.isMobile() || SettingsGet('UseCheckboxesInList')),
allowDraftAutosave: !!SettingsGet('AllowDraftAutosave'),
useThreads: !!SettingsGet('UseThreads'),
replySameFolder: !!SettingsGet('ReplySameFolder'),

autoLogout: pInt(SettingsGet('AutoLogout'))
});

this.usePreviewPane = ko.computed(() => Layout.NoPreview !== this.layout() && !ThemeStore.isMobile());
Expand All @@ -54,21 +54,4 @@ export const SettingsUserStore = new class {
}
}).throttle(5000);
}

populate() {
this.layout(pInt(SettingsGet('Layout')));
this.editorDefaultType(SettingsGet('EditorDefaultType'));

this.autoLogout(pInt(SettingsGet('AutoLogout')));
this.messagesPerPage(SettingsGet('MPP'));

this.showImages(!!SettingsGet('ShowImages'));
this.removeColors(!!SettingsGet('RemoveColors'));
this.useCheckboxesInList(!!(ThemeStore.isMobile() || SettingsGet('UseCheckboxesInList')));
this.allowDraftAutosave(!!SettingsGet('AllowDraftAutosave'));
this.useThreads(!!SettingsGet('UseThreads'));
this.replySameFolder(!!SettingsGet('ReplySameFolder'));

this.delayLogout();
}
};
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
inline: true,
options: autoLogoutOptions,
value: autoLogout,
trigger: autoLogout.trigger,
trigger: autoLogoutTrigger,
optionsText: 'name',
optionsValue: 'id'
}
Expand Down

0 comments on commit 97d5f87

Please sign in to comment.