Add default tags and default folder to apply to a newly saved

meeting-note.

Refs: pbek/QOwnNotes#807
This commit is contained in:
Sander Boom 2017-12-05 17:02:17 +01:00
parent 160d9a8eaf
commit 08b7eade5e
2 changed files with 54 additions and 6 deletions

View File

@ -2,8 +2,8 @@
"name": "Meeting note",
"identifier": "meeting-note",
"script": "meeting-note.qml",
"authors": ["@pbek"],
"version": "0.0.1",
"authors": ["@pbek", "@sanderboom"],
"version": "1.0.0",
"minAppVersion": "17.05.7",
"description" : "This script creates a menu item and a button to create or jump to the current date's meeting note."
}

View File

@ -6,6 +6,8 @@ import com.qownnotes.noteapi 1.0
*/
QtObject {
property string headlinePrefix;
property string defaultFolder;
property string defaultTags;
// register your settings variables so the user can set them in the script settings
property variant settingsVariables: [
@ -16,6 +18,20 @@ QtObject {
"type": "string",
"default": "Teammeeting",
},
{
"identifier": "defaultFolder",
"name": "Default folder",
"description": "The default folder where the newly created meeting note should be placed. Specify the path to the folder relative to the note folder. Make sure that the full path exists. Examples: to place new meeting notes in the subfolder 'Meeting' enter: \"Meeting\"; to place new meeting notes in the subfolder 'Meeting' in the subfolder 'Work' enter: \"Work/Meeting\". Leave blank to disable (notes will be created in the currently active folder).",
"type": "string",
"default": "",
},
{
"identifier": "defaultTags",
"name": "Default tags",
"description": "One or more default tags (separated by commas) to assign to a newly created meeting note. Leave blank to disable auto-tagging.",
"type": "string",
"default": "meeting",
},
];
/**
@ -28,7 +44,7 @@ QtObject {
/**
* 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) {
@ -41,6 +57,17 @@ QtObject {
var headline = headlinePrefix + " " + m.getFullYear() + "-" + ("0" + (m.getMonth()+1)).slice(-2) + "-" + ("0" + m.getDate()).slice(-2);
var fileName = headline + ".md";
// Check if we already have a meeting note for today.
// When a default folder is set, make sure to search in that folder.
// This has the highest chance of finding an existing meeting note.
// Right now we can not search the whole database for a note with this
// name / filename.
if (defaultFolder && defaultFolder !== '') {
script.jumpToNoteSubFolder(defaultFolder);
}
var note = script.fetchNoteByFileName(fileName);
// check if note was found
@ -52,11 +79,32 @@ QtObject {
// 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);
// Default folder.
if (defaultFolder && defaultFolder !== '') {
var msg = 'Jump to default folder \'' + defaultFolder + '\' before creating a new meeting note.';
script.log('Attempt: ' + msg);
var jump = script.jumpToNoteSubFolder(defaultFolder);
if (jump) {
script.log('Success: ' + msg);
} else {
script.log('Failed: ' + msg);
}
}
// Create the new meeting note.
script.createNote(headline + "\n====================\n\n");
// tag the current note
script.tagCurrentNote("meeting");
script.tagCurrentNote("fuf");
// Default tags.
if (defaultTags && defaultTags !== '') {
defaultTags
// Split on 0..* ws, 1..* commas, 0..* ws.
.split(/\s*,+\s*/)
.forEach(function(i) {
script.log('Tag the new meeting note with default tag: ' + i);
script.tagCurrentNote(i);
});
}
}
}
}