A powerful terminal-based task and note management application built with Python and Textual. Organize your tasks and notes into projects with a modern, keyboard-driven interface.
Project description
A powerful terminal-based task and note management application built with Python and Textual.
Features
- Project-Based Organization: Group related tasks and notes into separate projects with custom titles and descriptions
- Task Management:
- Create, edit, and delete tasks with titles and markdown content
- Track task status with 5 different states: Not started, In progress, Under review, Done, and Canceled
- Search tasks in real-time as you type
- Visual status indicators (○, ◐, ◎, ✓, ✗)
- Rich Text Support: Write task content in Markdown with syntax highlighting
- Project Import/Export: Share and backup projects across systems
- Keyboard-Driven Interface: Navigate and manage tasks efficiently without touching the mouse
- Persistent Storage: SQLite database ensures your data is saved automatically
- Modern Terminal UI: Beautiful interface powered by Textual framework
Installation
- Using pip
pip install xnoted
- Using pipx
pipx install xnoted
Requirements
- Python >= 3.11
- Dependencies:
- textual >= 6.6.0
- textual-dev >= 1.8.0
Development
- Clone the repository:
git clone git@github.com:babucarr32/xnoted.git
cd xnoted
- Install dependencies using uv:
uv sync
Or using pip:
pip install -e .
Or using requirements.txt:
pip install -r requirements.txt
Usage
Starting the Application
- Activate the virtual environment:
macOS/Linux (Bash/Zsh):
source .venv/bin/activate
Windows (Command Prompt):
.venv\Scripts\activate.bat
- Run the application:
textual run --dev main.py
Or for production use:
python main.py
Running in Development Mode
Textual provides excellent development tools:
# Run with live reload and dev console
textual run --dev main.py
# Open the development console in another terminal
textual console
The dev console shows real-time logs and application state for debugging.
Build
- Install hatch
- To build your project with Hatch, change to the directory containing your pyproject.toml and run the hatch build subcommand:
cd textual-calculator
hatch build
- The output will be in the
distfolder
For more info see Package with Hatch
To install the local build
pipx install --force .
or
pip install --force .
Quick Start Guide
- First Launch: The app creates a default project automatically
- Create a Task: Press
Ctrl+nto open the task creation modal - Navigate Tasks: Use
jandkto move up and down the task list - View Task Content: Select a task with
Enterto view its content in the right panel - Edit a Task: Highlight a task and press
eto edit it - Change Status: Use arrow keys (
←/→) to cycle through task statuses - Create Projects: Press
Ctrl+bto create new projects - Switch Projects: Press
Ctrl+lto select a different project
Keyboard Shortcuts
Global Application Shortcuts
| Shortcut | Action | Description |
|---|---|---|
ctrl+n |
Create new task | Opens modal to create a new task in current project |
ctrl+b |
Create new project | Opens modal to create a new project |
ctrl+l |
Select project | Opens project selector to switch between projects |
ctrl+o |
Import/Export | Opens modal to import or export projects |
ctrl+r |
Show readme | Displays the README in the content panel |
ctrl+d |
Scroll down | Scrolls the content panel down |
ctrl+u |
Scroll up | Scrolls the content panel up |
u |
Unlock tasks | Unlock all locked tasks |
ctrl+p |
Command pallette | Display command pallette |
s |
Command pallette | Display command pallette |
L |
Create password / Edit password | Create or edit password |
Task List Navigation
| Shortcut | Action | Description |
|---|---|---|
j |
Move down | Move cursor down in task list |
k |
Move up | Move cursor up in task list |
enter |
Select task | View the selected task's content |
e |
Edit task | Edit the highlighted task |
c |
Copy task | Copy the highlighted task |
l |
Lock task / Permanently unlock task | Lock or permanently unlock the highlighted task |
d |
Delete task | Delete the highlighted task (with confirmation) |
← |
Previous status | Cycle task status backward |
→ |
Next status | Cycle task status forward |
/ |
Search | Search the tasks |
Form(s) Shortcuts
| Shortcut | Action | Description |
|---|---|---|
enter |
Save | Save the current changes |
esc |
Cancel | Close modal without saving |
Task Status Indicators
- ○ Not started - Task hasn't been started yet
- ◐ In progress - Task is actively being worked on
- ◎ Under review - Task is waiting for review
- ✓ Done - Task is verified complete
- ✗ Canceled - Task was canceled or won't be done
Import Project(s)
Project data structure sample
{
"version": "1.0",
"exported_at": "2026-01-18T14:30:00.000000",
"project": {
"id": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
"title": "Website Redesign",
"description": "Complete redesign of company website with modern UI/UX",
"type": "tasks",
"createdAt": "2025-12-15 10:00:00"
},
"tasks": [
{
"id": "task-001-uuid-1234",
"title": "Research competitor websites",
"content": "Analyze top 5 competitor websites and document design patterns, user flows, and features. Focus on:\n- Navigation structure\n- Color schemes\n- Typography choices\n- Mobile responsiveness\n- Accessibility features",
"is_protected": 1,
"status": 1,
"createdAt": "2025-12-15 10:15:00"
}
],
"task_count": 8
}
Development
Architecture Overview
xNoted is built with Textual, a modern Python framework for building terminal user interfaces. The app follows a component-based architecture:
Core Components
-
XNotedApp (
src/xnoted/app.py): Main application class that handles:- Global keyboard bindings
- Screen navigation and modal management
- Database initialization
-
Database (
src/xnoted/utils/database.py): SQLite wrapper providing:- Project and task CRUD operations
- Automatic schema initialization
- Current project context management
- Default project creation on first run
-
Screens (
src/xnoted/screens/): Modal overlays for user interactions:- Task creation and editing
- Project creation and selection
- Import/export functionality
- Confirmation dialogs
-
Components (
src/xnoted/components/): Reusable UI building blocks:- Task list with search and navigation
- Markdown content viewer
- Form inputs for tasks and projects
Data Model
The SQLite database contains two main tables:
Projects:
id(TEXT, PRIMARY KEY): Unique project identifiertitle(TEXT): Project namedescription(TEXT): Project descriptiontype(TEXT): Project type (e.g., "task", "other")createdAt(TEXT): Creation timestamp
Tasks:
id(TEXT, PRIMARY KEY): Unique task identifierproject_id(TEXT, FOREIGN KEY): Reference to parent projecttitle(TEXT): Task titlecontent(TEXT): Task content in Markdownstatus(INTEGER): Status index (0-5)createdAt(TEXT): Creation timestamp
Database Path
Linux:~/.local/share/xnoted/macOS:~/Library/Application Support/xnoted/Windows:C:\Users\YourName\AppData\Roaming\xnoted\
Logs Path
Linux:~/.local/share/xnoted/log.txtmacOS:~/Library/Application Support/xnoted/log.txtWindows:C:\Users\YourName\AppData\Roaming\xnoted\log.txt
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xnoted-0.2.2.tar.gz.
File metadata
- Download URL: xnoted-0.2.2.tar.gz
- Upload date:
- Size: 545.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Hatch/1.16.3 cpython/3.14.2 HTTPX/0.28.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d233d5303035938257f32b6844397e0401f3da7fb1282d907a5b160ed4859bb5
|
|
| MD5 |
5f78ec46fc2459352c880732d1ade36f
|
|
| BLAKE2b-256 |
8f52f01edd6432fa19075992f6e070b88896a7fa565d9ad1fba0f61d1e07387e
|
File details
Details for the file xnoted-0.2.2-py3-none-any.whl.
File metadata
- Download URL: xnoted-0.2.2-py3-none-any.whl
- Upload date:
- Size: 60.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: Hatch/1.16.3 cpython/3.14.2 HTTPX/0.28.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8297ae32647317b83d81f1a1d530e0e96a724e27e28b8f35fdd313d2c3c29bca
|
|
| MD5 |
be389a593c17d9116925c41831748eaa
|
|
| BLAKE2b-256 |
48784a2e0286087fbc5f94b726cfa8df601a1679717a6ae8be07ac8eda85edd7
|