QOwnNotes/docs/scripting/examples/meeting-note.qml
2020-10-08 18:56:02 +02:00

49 lines
1.6 KiB
QML

import QtQml 2.0
import QOwnNotesTypes 1.0
/**
* This script creates a menu item and a button to create or jump to the current date's meeting note
*/
QtObject {
/**
* Initializes the custom action
*/
function init() {
script.registerCustomAction("meetingNote", "Create or open a meeting note", "Meeting", "document-new");
}
/**
* This function is invoked when a custom action is triggered
* in the menu or via button
*
* @param identifier string the identifier defined in registerCustomAction
*/
function customActionInvoked(identifier) {
if (identifier != "meetingNote") {
return;
}
// get the date headline
var m = new Date();
var headline = "Teammeeting " + m.getFullYear() + "-" + ("0" + (m.getMonth()+1)).slice(-2) + "-" + ("0" + m.getDate()).slice(-2);
var fileName = headline + ".md";
var note = script.fetchNoteByFileName(fileName);
// check if note was found
if (note.id > 0) {
// jump to the note if it was found
script.log("found meeting note: " + headline);
script.setCurrentNote(note);
} else {
// create a new meeting note if it wasn't found
// keep in mind that the note will not be created instantly on the disk
script.log("creating new meeting note: " + headline);
script.createNote(headline + "\n====================\n\n");
// tag the current note
script.tagCurrentNote("meeting");
script.tagCurrentNote("fuf");
}
}
}