Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/drmargarido/TodoTreeView
Todo View for https://github.com/rxi/lite
https://github.com/drmargarido/TodoTreeView
Last synced: about 1 month ago
JSON representation
Todo View for https://github.com/rxi/lite
- Host: GitHub
- URL: https://github.com/drmargarido/TodoTreeView
- Owner: drmargarido
- License: mit
- Created: 2020-04-22T21:16:56.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-04-01T23:01:15.000Z (9 months ago)
- Last Synced: 2024-04-02T00:22:21.937Z (9 months ago)
- Language: Lua
- Homepage:
- Size: 146 KB
- Stars: 28
- Watchers: 2
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# TodoTreeView
TODO View for https://github.com/rxi/lite
## Base Functionality
This plugin will display notes that are in the code which start with:
* TODO
* FIX
* FIXME
* BUG
* IMPROVEMENT
Extra tags can be added if you add them to the `todo_tags` config. You can also
configure their colors using the `tag_colors` field if wanted.You can select between two modes:
* tag - To display the notes organized by the note type
* file - To display the notes organized by file
* file_tag - To display the notes organized by file and note typeYou can also define between two scopes:
* all - Will display all the notes in the project and opened files all the time
* focused - Will display the notes only for the currently opened file or all files
if no file is open or focused.The plugin registers the following key bindings:
* ctrl+shift+t - Toggles the visibility of the view
* ctrl+shift+e - Expands all the groups
* ctrl+shift+h - Hides all the groups
* ctrl+shift+b - Filters the notesYou can ignore specific directories or files by using the `ignore_paths` config.
## Demo
Example of the `tag` view
![Todo plugin demo](/lite-todo-view.png)## Instructions
1. To install the plugin just copy the `todotreeview.lua` file (or the
`todotreeview-xl.lua` if you are using lite-xl) to the folder `data/plugins/`
of the lite editor.
2. If you want to register extra tags or change the display mode or update any
other of the settings you can edit your `data/user/init.lua` file.
3. If you are using lite-xl run the `core:open-user-module` command to open the
user file. Also use `config.plugins.todotreeview` instead of just `config` to
modify the multiple settings.
```lua
local config = require "core.config"
local common = require "core.common"-- Add extra tags
table.insert(config.todo_tags, "CLEANUP")-- Set colors for the new tag
config.tag_colors = {
CLEANUP = {
tag={common.color("#008000")},
tag_hover={common.color("#00d000")},
text={common.color("#004000")},
text_hover={common.color("#008000")},
}
}-- Set the file color when in file mode
config.todo_file_color = {
name={common.color("#A267d9")},
hover={common.color("#6DaE46")},
}-- Change display mode
config.todo_mode = "file" -- Or "file_tag"-- Change scope
config.todo_scope = "focused"-- Change the separator between the tag and the text in file mode
config.todo_separator = " -> "-- Change the default text if the note is empty
config.todo_default_text = "---"-- Ignore directory and ignore specific file
table.insert(config.ignore_paths, "winlib/")
table.insert(config.ignore_paths, "README.md")
```