From 60d98e9f58309799fa55d83fb5553fc729e9754f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Crist=C3=B3bal=20Gajardo=20Vera?= Date: Tue, 10 Sep 2024 22:41:28 -0300 Subject: [PATCH] doc(templates): update custom variables substitution docs --- README.md | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index d5d382b62..ab4ace71c 100644 --- a/README.md +++ b/README.md @@ -712,20 +712,35 @@ Date created: 2023-03-01-Wed above the cursor position. -You can also define custom template substitutions with the configuration field `templates.substitutions`. For example, to automatically substitute the template variable `{{yesterday}}` when inserting a template, you could add this to your config: +You can also define custom template substitutions with the configuration field `templates.substitutions`. + +For example, to automatically substitute the template variable `{{watermark}}`, `{{yesterday}}`, `{{normalized_title}}` +when inserting a template, you could add this to your config: ```lua { -- other fields ... templates = { substitutions = { + watermark = "Obsidian.nvim", yesterday = function() return os.date("%Y-%m-%d", os.time() - 86400) - end + end, + ---Format `title` field of `Note` to a more human-readable string. + ---For a `title` "# 17823674-My-note-title", it will returns "My note title" + ---@param note obsidian.Note + ---@return string normalized_title Title without timestamp nor dashes + normalized_title = function(note) + return note.title and note.title:gsub("%d+-?", ""):gsub("-", " ") or "" + end, } } ``` +> [!NOTE] +> You could set substitution keys to `string` or `function`. +> The `function` receives the related `Note` as the first parameter. + ### Usage outside of a workspace or vault It's possible to configure obsidian.nvim to work on individual markdown files outside of a regular workspace / Obsidian vault by configuring a "dynamic" workspace. To do so you just need to add a special workspace with a function for the `path` field (instead of a string), which should return a *parent* directory of the current buffer. This tells obsidian.nvim to use that directory as the workspace `path` and `root` (vault root) when the buffer is not located inside another fixed workspace.