1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-08 13:06:15 +02:00
joplin/packages/app-desktop/services/sortOrder/notesSortOrderUtils.ts

68 lines
2.2 KiB
TypeScript
Raw Normal View History

import Setting from '@joplin/lib/models/Setting';
let fields: string[] = null;
let perFieldReverse: { [field: string]: boolean } = null;
export const notesSortOrderFieldArray = (): string[] => {
// The order of the fields is strictly determinate.
2022-07-23 11:33:12 +02:00
if (fields === null) {
fields = Setting.enumOptionValues('notes.sortOrder.field').sort().reverse();
}
return fields;
};
export const notesSortOrderNextField = (currentField: string) => {
const fields = notesSortOrderFieldArray();
const index = fields.indexOf(currentField);
if (index < 0) {
return currentField;
} else {
return fields[(index + 1) % fields.length];
}
};
export const setNotesSortOrder = (field?: string, reverse?: boolean) => {
// field: Sort order's field. undefined means changing a field cyclically.
// reverse: whether the sort order is reversed or not. undefined means toggling.
let nextField = field;
let nextReverse = reverse;
const currentField = Setting.value('notes.sortOrder.field');
const currentReverse = Setting.value('notes.sortOrder.reverse');
const enabled = Setting.value('notes.perFieldReversalEnabled');
if (enabled) {
if (perFieldReverse === null) {
perFieldReverse = { ...Setting.value('notes.perFieldReverse') };
}
}
if (typeof field === 'undefined') {
if (typeof reverse === 'undefined') {
// If both arguments are undefined, the next field is selected.
nextField = notesSortOrderNextField(currentField);
} else {
nextField = currentField;
}
}
if (typeof reverse === 'undefined') {
if (enabled && perFieldReverse.hasOwnProperty(nextField)) {
nextReverse = !!perFieldReverse[nextField];
} else {
nextReverse = currentReverse;
}
}
if (currentField !== nextField) {
Setting.setValue('notes.sortOrder.field', nextField);
}
if (currentReverse !== nextReverse) {
Setting.setValue('notes.sortOrder.reverse', nextReverse);
}
if (enabled) {
// nextField is sane here.
nextReverse = !!nextReverse;
if (perFieldReverse[nextField] !== nextReverse) {
perFieldReverse[nextField] = nextReverse;
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Partial refactor of old code before rule was applied
Setting.setValue('notes.perFieldReverse', { ...perFieldReverse } as any);
}
}
};