fix(buffer): conceal in all modes, forge EOL labels, remove dash prefix (#167)
* fix(buffer): keep conceal active in all modes and add `%l` EOL forge labels Problem: `concealcursor` was missing `i` and `v`, so concealed text (task IDs, forge tokens) leaked in insert and visual modes. Forge labels only rendered for the first span when multiple refs existed. Solution: set `concealcursor = 'nicv'` to keep conceal in all modes. Add `%l` EOL format specifier that renders all forge spans with independent highlights. Update default `eol_format` to include `%l`. * refactor: remove `- ` prefix from task line rendering Problem: task lines rendered as `- [ ] description` with a redundant markdown list marker prefix that added visual noise. Solution: render task lines as `[ ] description` instead. Update all line generation in `views.lua`, parsing patterns in `buffer.lua`, `diff.lua`, `textobj.lua`, syntax rules, and corresponding specs.
This commit is contained in:
parent
1266eaedd8
commit
98e4abffc7
12 changed files with 156 additions and 141 deletions
|
|
@ -230,7 +230,7 @@ describe('filter', function()
|
|||
end
|
||||
local hidden_ids = { [hidden_task.id] = true }
|
||||
local lines = {
|
||||
'/1/- [ ] Visible task',
|
||||
'/1/[ ] Visible task',
|
||||
}
|
||||
diff.apply(lines, s, hidden_ids)
|
||||
s:load()
|
||||
|
|
@ -254,7 +254,7 @@ describe('filter', function()
|
|||
end
|
||||
end
|
||||
local lines = {
|
||||
'/' .. keep_task.id .. '/- [ ] Keep task',
|
||||
'/' .. keep_task.id .. '/[ ] Keep task',
|
||||
}
|
||||
diff.apply(lines, s, {})
|
||||
s:load()
|
||||
|
|
@ -270,7 +270,7 @@ describe('filter', function()
|
|||
local task = tasks[1]
|
||||
local lines = {
|
||||
'FILTER: cat:Work',
|
||||
'/' .. task.id .. '/- [ ] My task',
|
||||
'/' .. task.id .. '/[ ] My task',
|
||||
}
|
||||
diff.apply(lines, s, {})
|
||||
s:load()
|
||||
|
|
@ -281,7 +281,7 @@ describe('filter', function()
|
|||
it('parse_buffer skips FILTER: header line', function()
|
||||
local lines = {
|
||||
'FILTER: overdue',
|
||||
'/1/- [ ] A task',
|
||||
'/1/[ ] A task',
|
||||
}
|
||||
local result = diff.parse_buffer(lines)
|
||||
assert.are.equal(1, #result)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue