]> git.r.bdr.sh - rbdr/nota.nvim/blob - lua/notes.lua
f5a4b00f25c1c92d1759fb08950d749b1f97e5fb
[rbdr/nota.nvim] / lua / notes.lua
1 -------------------------------------------------------------------------------
2 -- Tools to deal with notes
3 -------------------------------------------------------------------------------
4 local Notes = {}
5
6 local Util = require('util')
7 local Configuration = require('configuration')
8 local api = vim.api
9 -------------------------------------------------------------------------------
10 -- Internal Functions
11 -------------------------------------------------------------------------------
12 local function open_or_create_from_template(type, file_path)
13
14 local journal_file = io.open(file_path, 'r')
15 if not journal_file then
16 local template_contents = Configuration.load_template(type)
17
18 journal_file = io.open(file_path, 'w')
19 journal_file:write(template_contents)
20 journal_file:close()
21 end
22 vim.cmd('edit ' .. file_path)
23 end
24
25 local function open_periodic_note(type, filename)
26 local file_directory_path = Configuration.path_for(Configuration.configuration.periodic_locations[type])
27
28 Util.ensure_directory_exists(file_directory_path)
29 local file_path = Util.join(file_directory_path, filename)
30
31 open_or_create_from_template(type, file_path)
32 end
33
34 -------------------------------------------------------------------------------
35 -- Public Interface
36 -------------------------------------------------------------------------------
37
38 --- Opens the daily note
39 function Notes.open_daily(date)
40 date = date or os.date('%Y-%m-%d')
41 local filename = date .. '.md'
42 open_periodic_note('daily', filename)
43 end
44
45 --- Opens the weekly note
46 function Notes.open_weekly()
47 local filename = os.date('%Y-w%V')
48 open_periodic_note('weekly', filename)
49 end
50
51 --- Opens the monthly note
52 function Notes.open_monthly()
53 local filename = os.date('%Y-%m') .. '.md'
54 open_periodic_note('monthly', filename)
55 end
56
57 --- Opens the seasonal note
58 function Notes.open_seasonal()
59 local year = os.date('%Y')
60 local month = tonumber(os.date('%m'))
61 local season = math.ceil(month / 3)
62
63 local filename = year .. '-s' .. season .. '.md'
64 open_periodic_note('seasonal', filename)
65 end
66
67 --- Opens the yearly note
68 function Notes.open_yearly()
69 local filename = os.date('%Y') .. '.md'
70 open_periodic_note('yearly', filename)
71 end
72
73 --- Opens an arbitrary note
74 function Notes.open()
75 local success, module = pcall(require, 'fzf-lua')
76 if success then
77 local notes_path = Configuration.path_for()
78 Util.ensure_directory_exists(notes_path)
79 module.files({ cwd = notes_path })
80 else
81 api.nvim_err_writeln('This feature requires optional dependency fzf-lua')
82 end
83 end
84
85 return Notes