weekly templates, findings, ...

This commit is contained in:
Rene Schallner
2021-11-21 20:55:58 +01:00
parent 6a9bf31bd6
commit 2d5d318952
3 changed files with 213 additions and 48 deletions

View File

@@ -1,10 +1,13 @@
# Backlog # Backlog
- create new note dialog: choose template - [ ] find weekly note
- extend markdown syntax highlights for [[links]] - extend markdown syntax highlights for [[links]]
- get rid of `daily_finder.sh` - get rid of `daily_finder.sh`
- maybe choose template in create note
## Dones ## Dones
- [x] goto week
- [x] create note, use default template
- [x] follow links: create non-existing ones - [x] follow links: create non-existing ones
- [x] ,[ to insert link --> we can escape out and type double brackets - [x] ,[ to insert link --> we can escape out and type double brackets
- [x] shortcuts for todo and done in init.vim - [x] shortcuts for todo and done in init.vim

View File

@@ -32,6 +32,7 @@ lua << END
require('telekasten').setup({ require('telekasten').setup({
home = vim.fn.expand("~/zettelkasten"), home = vim.fn.expand("~/zettelkasten"),
dailies = vim.fn.expand("~/zettelkasten/daily"), dailies = vim.fn.expand("~/zettelkasten/daily"),
weeklies = vim.fn.expand("~/zettelkasten/weekly"),
extension = ".md", extension = ".md",
daily_finder = "daily_finder.sh", daily_finder = "daily_finder.sh",
@@ -46,12 +47,15 @@ require('telekasten').setup({
-- following a link to a non-existing note will create it -- following a link to a non-existing note will create it
follow_creates_nonexisting = true, follow_creates_nonexisting = true,
dailies_create_nonexisting = true, dailies_create_nonexisting = true,
weeklies_create_nonexisting = true,
-- templates for new notes -- template for new notes (new_note, follow_link)
template_new_note = ZkCfg.home .. '/' .. 'templates/new_note.md', template_new_note = ZkCfg.home .. '/' .. 'templates/new_note.md',
-- currently unused, hardcoded in daily_finder.sh:
-- template for newly created daily notes (goto_today)
template_new_daily = ZkCfg.home .. '/' .. 'templates/daily.md', template_new_daily = ZkCfg.home .. '/' .. 'templates/daily.md',
-- currently unused
-- template for newly created weekly notes (goto_thisweek)
template_new_weekly= ZkCfg.home .. '/' .. 'templates/weekly.md', template_new_weekly= ZkCfg.home .. '/' .. 'templates/weekly.md',
}) })
END END
@@ -72,8 +76,10 @@ This will download the daily finder into the `bin/` folder of your home director
The plugin defines the following functions. The plugin defines the following functions.
- `new_note` : prompts for title and creates new note by template, then shows it in Telescope
- `find_notes()` : find notes by file name (title), via Telescope - `find_notes()` : find notes by file name (title), via Telescope
- `find_daily_notes()` : find daily notes by date (file names, sorted, most recent first), via Telescope. If today's daily note is not present, it will be created, honoring the configured template - `find_daily_notes()` : find daily notes by date (file names, sorted, most recent first), via Telescope. If today's daily note is not present, it can be created optionally, honoring the configured template
- `find_weekly_notes()` : find weekly notes by week (file names, sorted, most recent first), via Telescope. If this week's weekly note is not present, it can be created optionally, honoring the configured template
- `search_notes()`: live grep for word under cursor in all notes (search in notes), via Telescope - `search_notes()`: live grep for word under cursor in all notes (search in notes), via Telescope
- `insert_link()` : select a note by name, via Telescope, and place a `[[link]]` at the current cursor position - `insert_link()` : select a note by name, via Telescope, and place a `[[link]]` at the current cursor position
- `follow_link()`: take text between brackets (linked note) and open a Telescope file finder with it: selects note to open (incl. preview) - optional note creation for non-existing notes - `follow_link()`: take text between brackets (linked note) and open a Telescope file finder with it: selects note to open (incl. preview) - optional note creation for non-existing notes
@@ -89,15 +95,18 @@ To use one of the functions above, just run them with the `:lua ...` command.
### Note templates ### Note templates
The functions `find_daily_notes`, `goto_today`, and `follow_link` can create non-existing notes. This allows you to 'go to today' without having to create today's note beforehand. When you just type `[[some link]]` and then call `follow_link`, the 'some link' note can be generated. The functions `goto_today`, `goto_thisweek`, `find_daily_notes`, `find_weekly_notes`, and `follow_link` can create non-existing notes. This allows you to 'go to today' without having to create today's note beforehand. When you just type `[[some link]]` and then call `follow_link`, the 'some link' note can be generated.
The following table shows which command relies on what config option: The following table shows which command relies on what config option:
| telekasten function | config option | | telekasten function | config option | creates what |
| --- | --- | | --- | --- | --- |
| `goto_today` | `dailies_create_nonexisting` | | `goto_today` | `dailies_create_nonexisting` | today's daily note |
| `find_daily_notes` | `dailies_create_nonexisting` | | `find_daily_notes` | `dailies_create_nonexisting` | today's daily note |
| `goto_thisweek` | `weeklies_create_nonexisting` | this week's weekly note |
| `find_weekly_notes` | `weeklies_create_nonexisting` | this week's weekly note |
| `follow_link` | `follow_creates_nonexisting` | | `follow_link` | `follow_creates_nonexisting` |
| `new_note` | always true |
If the associated option is `true`, non-existing notes will be created. If the associated option is `true`, non-existing notes will be created.
@@ -112,6 +121,8 @@ Currently, the following substitutions will be made during new note creation:
| `{{title}}` | the title of the note | My new note | | `{{title}}` | the title of the note | My new note |
| `{{date}}` | date in iso format | 2021-11-21 | | `{{date}}` | date in iso format | 2021-11-21 |
| `{{hdate}}` | date in human-readable format | Sunday, November 21st, 2021 | | `{{hdate}}` | date in human-readable format | Sunday, November 21st, 2021 |
| `{{week}}` | week of the year | 46 |
| `{{year}}` | year | 2021 |
As an example, this is my template for new notes: As an example, this is my template for new notes:
@@ -130,6 +141,31 @@ title: {{hdate}}
--- ---
``` ```
And finally, the weekly notes (that I don't use a lot):
```markdown
---
title: {{year}}-W{{week}}
date: {{hdate}}
---
# Review Week {{week}} / {{year}}
---
## Highlights
- **this**!
- that!
## Monday link
## Tuesday link
## Wednesday link
## Thursday link
## Friday link
## Saturday link
## Sunday link
```
## Bind it ## Bind it
Usually, you would set up some key bindings, though: Usually, you would set up some key bindings, though:

View File

@@ -13,6 +13,7 @@ local vim = vim
ZkCfg = { ZkCfg = {
home = vim.fn.expand("~/zettelkasten"), home = vim.fn.expand("~/zettelkasten"),
dailies = vim.fn.expand("~/zettelkasten/daily"), dailies = vim.fn.expand("~/zettelkasten/daily"),
weeklies = vim.fn.expand("~/zettelkasten/weekly"),
extension = ".md", extension = ".md",
daily_finder = "daily_finder.sh", daily_finder = "daily_finder.sh",
@@ -27,13 +28,14 @@ ZkCfg = {
-- following a link to a non-existing note will create it -- following a link to a non-existing note will create it
follow_creates_nonexisting = true, follow_creates_nonexisting = true,
dailies_create_nonexisting = true, dailies_create_nonexisting = true,
weeklies_create_nonexisting = true,
-- templates for new notes -- templates for new notes
template_new_note = ZkCfg.home .. '/' .. 'templates/new_note.md', template_new_note = ZkCfg.home .. '/' .. 'templates/new_note.md',
-- currently unused, hardcoded in daily_finder.sh: -- currently unused, hardcoded in daily_finder.sh:
template_new_daily = ZkCfg.home .. '/' .. 'templates/daily_tk.md', template_new_daily = ZkCfg.home .. '/' .. 'templates/daily_tk.md',
-- currently unused -- currently unused
template_new_weekly= ZkCfg.home .. '/' .. 'templates/weekly.md', template_new_weekly= ZkCfg.home .. '/' .. 'templates/weekly_tk.md',
} }
-- ---------------------------------------------------------------------------- -- ----------------------------------------------------------------------------
@@ -49,6 +51,50 @@ local note_type_templates = {
} }
local function file_exists(fname)
local f=io.open(fname,"r")
if f~=nil then io.close(f) return true else return false end
end
local function daysuffix(day)
if((day == '1') or (day == '21') or (day == '31')) then return 'st' end
if((day == '2') or (day == '22')) then return 'nd' end
if((day == '3') or (day == '33')) then return 'rd' end
return 'th'
end
local function linesubst(line, title)
local substs = {
date = os.date('%Y-%m-%d'),
hdate = os.date('%A, %B %dx, %Y'):gsub('x', daysuffix(os.date('%d'))),
week = os.date('%V'),
year = os.date('%Y'),
title = title,
}
for k, v in pairs(substs) do
line = line:gsub("{{"..k.."}}", v)
end
return line
end
local create_note_from_template = function (title, filepath, templatefn)
-- first, read the template file
local lines = {}
for line in io.lines(templatefn) do
lines[#lines+1] = line
end
-- now write the output file, substituting vars line by line
local ofile = io.open(filepath, 'a')
for _, line in pairs(lines) do
ofile:write(linesubst(line, title) .. '\n')
end
ofile:close()
end
-- --
-- InstallDailyFinder: -- InstallDailyFinder:
@@ -97,6 +143,14 @@ end
-- --
FindDailyNotes = function(opts) FindDailyNotes = function(opts)
opts = {} or opts opts = {} or opts
local today = os.date("%Y-%m-%d")
local fname = ZkCfg.dailies .. '/' .. today .. ZkCfg.extension
local fexists = file_exists(fname)
if ((fexists ~= true) and ((opts.dailies_create_nonexisting == true) or ZkCfg.dailies_create_nonexisting == true)) then
create_note_from_template(today, fname, note_type_templates.daily)
end
if (check_local_finder() == true) then if (check_local_finder() == true) then
builtin.find_files({ builtin.find_files({
prompt_title = "Find daily note", prompt_title = "Find daily note",
@@ -111,6 +165,36 @@ end
--
-- FindWeeklyNotes:
-- ---------------
--
-- Select from daily notes
--
FindWeeklyNotes = function(opts)
opts = {} or opts
local title = os.date("%Y-W%V")
local fname = ZkCfg.weeklies .. '/' .. title .. ZkCfg.extension
local fexists = file_exists(fname)
if ((fexists ~= true) and ((opts.weeklies_create_nonexisting == true) or ZkCfg.weeklies_create_nonexisting == true)) then
create_note_from_template(title, fname, note_type_templates.weekly)
end
if (check_local_finder() == true) then
builtin.find_files({
prompt_title = "Find weekly note",
cwd = ZkCfg.weeklies,
find_command = { ZkCfg.daily_finder },
entry_maker = zk_entry_maker,
})
else
print("Daily finder not found. Try :lua require('telekasten').install_daily_finder()")
end
end
-- --
-- InsertLink: -- InsertLink:
-- ----------- -- -----------
@@ -149,46 +233,12 @@ end
-- --
-- find the file linked to by the word under the cursor -- find the file linked to by the word under the cursor
-- --
local function file_exists(fname)
local f=io.open(fname,"r")
if f~=nil then io.close(f) return true else return false end
end
local function linesubst(line, title)
local substs = {
date = os.date('%Y-%m-%d'),
title = title,
}
for k, v in pairs(substs) do
line = line:gsub("{{"..k.."}}", v)
end
return line
end
local create_note_from_template = function (title, filepath, templatefn)
-- first, read the template file
local lines = {}
for line in io.lines(templatefn) do
lines[#lines+1] = line
end
-- now write the output file, substituting vars line by line
local ofile = io.open(filepath, 'a')
for _, line in pairs(lines) do
ofile:write(linesubst(line, title) .. '\n')
end
ofile:close()
end
FollowLink = function(opts) FollowLink = function(opts)
opts = {} or opts opts = {} or opts
vim.cmd('normal yi]') vim.cmd('normal yi]')
local title = vim.fn.getreg('"0') local title = vim.fn.getreg('"0')
local fname = ZkCfg.home .. '/' .. title .. ZkCfg.extension
local fname = ZkCfg.home .. '/' .. title .. ZkCfg.extension
local fexists = file_exists(fname) local fexists = file_exists(fname)
if ((fexists ~= true) and ((opts.follow_creates_nonexisting == true) or ZkCfg.follow_creates_nonexisting == true)) then if ((fexists ~= true) and ((opts.follow_creates_nonexisting == true) or ZkCfg.follow_creates_nonexisting == true)) then
create_note_from_template(title, fname, note_type_templates.normal) create_note_from_template(title, fname, note_type_templates.normal)
@@ -216,13 +266,18 @@ end
-- find today's daily note and create it if necessary. -- find today's daily note and create it if necessary.
-- --
GotoToday = function(opts) GotoToday = function(opts)
print('local version')
opts = {} or opts opts = {} or opts
local word = os.date("%Y-%m-%d") local word = os.date("%Y-%m-%d")
local fname = ZkCfg.dailies .. '/' .. word .. ZkCfg.extension
local fexists = file_exists(fname)
if ((fexists ~= true) and ((opts.follow_creates_nonexisting == true) or ZkCfg.follow_creates_nonexisting == true)) then
create_note_from_template(word, fname, note_type_templates.daily)
end
if (check_local_finder() == true) then if (check_local_finder() == true) then
builtin.find_files({ builtin.find_files({
prompt_title = "Follow link to note...", prompt_title = "Goto today",
cwd = ZkCfg.home, cwd = ZkCfg.home,
default_text = word, default_text = word,
find_command = { ZkCfg.daily_finder }, find_command = { ZkCfg.daily_finder },
@@ -277,6 +332,74 @@ end
--
-- CreateNote:
-- ------------
--
-- find the file linked to by the word under the cursor
--
local function on_create(title)
if (title == nil) then return end
local fname = ZkCfg.home .. '/' .. title .. ZkCfg.extension
local fexists = file_exists(fname)
if (fexists ~= true) then
create_note_from_template(title, fname, note_type_templates.normal)
end
if (check_local_finder() == true) then
builtin.find_files({
prompt_title = "Created note...",
cwd = ZkCfg.home,
default_text = title,
find_command = { ZkCfg.daily_finder },
entry_maker = zk_entry_maker,
})
else
print("Daily finder not found. Try :lua require('telekasten').install_daily_finder()")
end
end
CreateNote = function(opts)
opts = {} or opts
vim.ui.input({prompt = 'Title: '}, on_create)
end
--
-- GotoThisWeek:
-- ----------
--
-- find this week's weekly note and create it if necessary.
--
GotoThisWeek = function(opts)
print('local version')
opts = {} or opts
local title = os.date("%Y-W%V")
local fname = ZkCfg.weeklies .. '/' .. title .. ZkCfg.extension
local fexists = file_exists(fname)
if ((fexists ~= true) and ((opts.weeklies_create_nonexisting == true) or ZkCfg.weeklies_create_nonexisting == true)) then
create_note_from_template(title, fname, note_type_templates.weekly)
end
if (check_local_finder() == true) then
builtin.find_files({
prompt_title = "Goto this week:",
cwd = ZkCfg.weeklies,
default_text = title,
find_command = { ZkCfg.daily_finder },
entry_maker = zk_entry_maker,
})
else
print("Daily finder not found. Try :lua require('telekasten').install_daily_finder()")
end
end
-- Setup(cfg) -- Setup(cfg)
-- --
-- Overrides config with elements from cfg -- Overrides config with elements from cfg
@@ -304,6 +427,9 @@ local M = {
setup = Setup, setup = Setup,
install_daily_finder = InstallDailyFinder, install_daily_finder = InstallDailyFinder,
goto_today = GotoToday, goto_today = GotoToday,
new_note = CreateNote,
goto_thisweek = GotoThisWeek,
find_weekly_notes = FindWeeklyNotes,
} }
print('local version') print('local version')
return M return M