2024-06-04 10:52:52 +02:00
|
|
|
import { CommandRuntime, CommandDeclaration, CommandContext } from '@joplin/lib/services/CommandService';
|
|
|
|
import Logger from '@joplin/utils/Logger';
|
2024-12-16 11:49:46 +02:00
|
|
|
import goToNote, { GotoNoteOptions } from './util/goToNote';
|
2024-06-04 10:52:52 +02:00
|
|
|
import Note from '@joplin/lib/models/Note';
|
|
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
|
|
|
|
|
|
const logger = Logger.create('newNoteCommand');
|
|
|
|
|
|
|
|
export const declaration: CommandDeclaration = {
|
|
|
|
name: 'newNote',
|
|
|
|
};
|
|
|
|
|
|
|
|
export const runtime = (): CommandRuntime => {
|
|
|
|
return {
|
2024-12-16 11:49:46 +02:00
|
|
|
execute: async (_context: CommandContext, body = '', todo = false, options: GotoNoteOptions = null) => {
|
2024-06-04 10:52:52 +02:00
|
|
|
const folderId = Setting.value('activeFolderId');
|
|
|
|
if (!folderId) {
|
|
|
|
logger.warn('Not creating new note -- no active folder ID.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const note = await Note.save({
|
|
|
|
body,
|
|
|
|
parent_id: folderId,
|
|
|
|
is_todo: todo ? 1 : 0,
|
|
|
|
}, { provisional: true });
|
|
|
|
|
|
|
|
logger.info(`Navigating to note ${note.id}`);
|
2024-12-16 11:49:46 +02:00
|
|
|
await goToNote(note.id, '', options);
|
2024-06-04 10:52:52 +02:00
|
|
|
},
|
|
|
|
};
|
|
|
|
};
|