2021-11-11 17:33:37 +02:00
|
|
|
import { CommandContext, CommandDeclaration, CommandRuntime } from '@joplin/lib/services/CommandService';
|
|
|
|
import { setNotesSortOrder } from '../../../services/sortOrder/notesSortOrderUtils';
|
|
|
|
import { _ } from '@joplin/lib/locale';
|
|
|
|
|
|
|
|
export const declaration: CommandDeclaration = {
|
|
|
|
name: 'toggleNotesSortOrderField',
|
|
|
|
label: () => _('Toggle sort order field'),
|
|
|
|
parentLabel: () => _('Notes'),
|
|
|
|
};
|
|
|
|
|
|
|
|
export const runtime = (): CommandRuntime => {
|
|
|
|
return {
|
2024-04-05 13:16:49 +02:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-06-30 10:16:08 +02:00
|
|
|
execute: async (_context: CommandContext, field?: string | any[], reverse?: boolean) => {
|
2021-11-11 17:33:37 +02:00
|
|
|
// field: Sort order's field. undefined means switching a field.
|
|
|
|
// reverse: whether the sort order is reversed or not. undefined means toggling.
|
|
|
|
//
|
|
|
|
// To support CommandService.scheduleExecute(), field accepts an size-two Array,
|
|
|
|
// which means [field, reverse].
|
|
|
|
if (typeof field !== 'object') {
|
|
|
|
setNotesSortOrder(field, reverse);
|
|
|
|
} else {
|
|
|
|
setNotesSortOrder(field[0], field[1]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|