kanban-python

所属分类:Python编程
开发工具:Python
文件大小:0KB
下载次数:1
上传日期:2023-12-18 22:00:29
上 传 者sh-1993
说明:  用Python编写的看板终端应用程序
(Kanban Terminal App written in Python)

文件列表:
docs/
images/
src/kanban_python/
tests/
.coveragerc
.isort.cfg
.pre-commit-config.yaml
.readthedocs.yml
AUTHORS.md
CHANGELOG.md
CONTRIBUTING.md
LICENSE.txt
pyproject.toml
setup.cfg
setup.py
tox.ini

[![Project generated with PyScaffold](https://img.shields.io/badge/-PyScaffold-005CA0?logo=pyscaffold)](https://pyscaffold.org/) [![PyPI-Server](https://img.shields.io/pypi/v/kanban-python.svg)](https://pypi.org/project/kanban-python/) [![Downloads](https://static.pepy.tech/badge/kanban-python)](https://pepy.tech/project/kanban-python) [![Coverage Status](https://coveralls.io/repos/github/Zaloog/kanban-python/badge.svg?branch=refs/tags/v0.3.8)](https://coveralls.io/github/Zaloog/kanban-python?branch=refs/tags/v0.3.8) # kanban-python > A Terminal Kanban Application written in Python to boost your productivity :rocket: ## Introduction Welcome to **kanban-python**, your Terminal Kanban-Board Manager. ![header](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_header.PNG) The [clikan] Kanban App inspired me to write my own Terminal Kanban Application since I preferred a more simple and guided workflow. **kanban-python** also comes with more features, like custom column creation, automatic scanning and customizable config file to support you being productive. This package was developed with [pyscaffold], which provides awesome project templates and takes over much of the boilerplate for python packaging. It was a great help for developing my first package and I can highly recommend it. ## Features
Colorful and Interactive - kanban-python uses [rich] under the hood to process user input and display nice looking kanban-boards to the terminal. - Each task has a unique `ID` per board and also has an optional `Tag` and `Due Date` associated with it, which are displayed alongside its `Title`
Following the XDG basedir convention - kanban-python utilizes [platformdirs] `user_config_dir` to save the config file and `user_data_dir` for the board specific task files. After creating your first board, you can use `kanban configure` to show the current settings table. The config path in the table caption and the path for the task files can be found in the kanban_boards section.
Scanning of Files for automatic Task Creation - kanban-python can scan files of defined types for specific patterns at start of line. Check [Automatic Task Creation](#automatic-task-creation) for more Infos.
Customizable Configfile - A `pykanban.ini` file gets created on first initialization in a `kanban-python` folder in your `user_config_dir`-Directory. This can be edited manually or within the kanban-python application. It tracks the location for all your created boards. \ ![configfile](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_config.PNG) * `Active_Board`: current board that is shown when using `kanban`-command * `Done_Limit`: If the amount of tasks exceed this number in the Done column, the first task of that column gets its status updated to Archived and is moved into that column. (default: `10`) * `Column_Min_Width`: Sets the minimum width of columns. (default: `40`) * `Show_Footer`: Shows the table footer with package name and version. (default: `True`) * `Files`: Space seperated filetypes to search for patterns to create tasks. (default: `.py .md`) * `Patterns`: Comma seperated patterns to search for start of line to create tasks.
(default: `# TODO,#TODO,# BUG`)
Task Storage File for each Board - Each created board comes with its own name and `pykanban.json` file, which stores all tasks for that board. The files are stored in board specific folders under `$USER_DATA_DIR/kanban-python/kanban_boards/`. When changing Boards you also get an overview over tasks in visible columns for each board and the most urgent or overdue task on that board. ![change_view](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban_change.PNG)
Customizable Columns - kanban-python comes with 5 pre-defined colored columns: [Ready, Doing, Done, Archived, Deleted] More column can be added manually in the `pykanban.ini`, the visibility can be configured in the settings with `kanban configure`.
Time Tracking of Task duration in Doing - For each task it is tracked, how long it was in the Doing column, based on the moments when you update the task status. The initial Task structure on creation looks as follows: ![task](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_task_example.PNG)
Report Creation for completed Tasks - When you use [kanban report](#create-report) a github-like contribution map is displayed for the current year, Also a markdown file is created with all tasks comleted based on the moment, when the tasks were moved to Done Column. ![task](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban_report_document.PNG)
## Installation You can install kanban-python with: ```bash python -m pip install kanban-python ``` ## Usage After Installation of kanban-python, there are 5 commands available: ### Create new Boards ```bash kanban init ``` Is used to create a new kanban board i.e. it asks for a name and then creates a `pykanban.json` file with a Welcome Task. On first use of any command, the `pykanban.ini` configfile and the `kanban-python` folder will be created automatically. ![init_file](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban_init.PNG) ### Interact with Tasks/Boards ```bash kanban ``` This is your main command to interact with your boards and tasks. It also gives the option to show the current settings and adjust them. Adjusting the settings can also be done directly by using the command `kanban configure`: ![kanban](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban.PNG) Use `Ctrl-C` or `Ctrl-D` to exit the application at any time. :warning: If you exit in the middle of creating/updating a task, or changing settings, your progress wont be saved. ### Automatic Task Creation ```bash kanban scan ``` After executing this command, kanban-python scans your current Directory recursively for the defined filetypes and searches for lines that start with the pattern provided. ![scan_view](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_scan_view.PNG) After confirmation to add the found tasks to table they will be added to the board. The alphanumeric Part of the Pattern will be used as tag. The filepath were the task was found will be added as description of the task. ![scan_table](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_scan_table.PNG) ### Create Report ```bash kanban report ``` Goes over all your Boards and creates a single markdown file by checking the `Completion Dates` of your tasks. Also shows a nice github-like contribution table for the current year. ![report](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban_report.PNG) ### Change Settings ```bash kanban configure ``` ![settings](https://raw.githubusercontent.com/Zaloog/kanban-python/main/images/image_kanban_configure.PNG) To create a new custom Columns, you have to edit the `pykanban.ini` manually and add a new column name + visibility status under the `settings.columns.visible` section. The other options are all customizable now via the new settings menu. ## Feedback and Issues Feel free to reach out and share your feedback, or open an Issue, if something doesnt work as expected. Also check the [Changelog](https://github.com/Zaloog/kanban-python/blob/main/CHANGELOG.md) for new updates. :warning: With release v0.3.0 kanban-python switched to the [XDG] Basedir Spec. So some file migrations and config edits might be needed to continue working with your already created boards if you update from `v0.2.X` to `v0.3.X` ## Note This project has been set up using PyScaffold 4.5. For details and usage information on PyScaffold see https://pyscaffold.org/. [XDG]: https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html [platformdirs]: https://platformdirs.readthedocs.io/en/latest/ [clikan]: https://github.com/kitplummer/clikan [pyscaffold]: https://pyscaffold.org/ [rich]: https://github.com/Textualize/rich

近期下载者

相关文件


收藏者