Files
thechart/CONSOLIDATED_DOCS.md
William Valentin 8fc87788f9 feat: Consolidate documentation into a single comprehensive guide
- Created `CONSOLIDATED_DOCS.md` to serve as the primary documentation source, integrating user and developer guides, API references, and troubleshooting sections.
- Updated `README.md` to reference the new consolidated documentation.
- Preserved existing documentation files for backward compatibility, including `USER_GUIDE.md`, `DEVELOPER_GUIDE.md`, and others.
- Enhanced navigation structure in `docs/README.md` to facilitate easier access to documentation.
- Implemented UI flickering fixes, including auto-save optimizations, debounced filter updates, and efficient tree updates to improve user experience.
- Added verification script `verify_docs_consolidation.py` to ensure successful documentation consolidation and integrity.
2025-08-06 15:02:49 -07:00

505 lines
15 KiB
Markdown

# TheChart - Comprehensive Documentation
> **Modern medication tracking application with advanced UI/UX for monitoring treatment progress and symptom evolution.**
## 📋 Table of Contents
1. [Quick Start](#-quick-start)
2. [User Guide](#-user-guide)
3. [Developer Guide](#-developer-guide)
4. [Features & Capabilities](#-features--capabilities)
5. [Technical Architecture](#-technical-architecture)
6. [Recent Improvements](#-recent-improvements)
7. [API Reference](#-api-reference)
8. [Troubleshooting](#-troubleshooting)
9. [Contributing](#-contributing)
---
## 🚀 Quick Start
### Installation
```bash
# Clone the repository
git clone <repository-url>
cd thechart
# Install dependencies
make install
# Run the application
make run
```
### First Steps
1. **Launch TheChart** using `make run` or `python src/main.py`
2. **Add your first entry** using Ctrl+S
3. **Explore features** with the keyboard shortcuts (F1 for help)
4. **Customize settings** with F2 or through the Theme menu
---
## 👤 User Guide
### Core Features
#### 📊 Data Tracking
- **Daily Entries**: Track medications and symptoms with date-based entries
- **Medicine Management**: Configure medications with dosage information and colors
- **Pathology Tracking**: Monitor symptoms using customizable 0-10 scales
- **Notes System**: Add detailed notes to each entry
#### 🎨 Modern UI/UX (v1.9.5+)
- **Professional Themes**: Multiple built-in themes (Dark, Light, Arc, etc.)
- **Smart Tooltips**: Context-sensitive help throughout the interface
- **Responsive Design**: Optimized layouts for different screen sizes
- **Smooth Interactions**: Debounced updates and flicker-free scrolling
#### ⌨️ Keyboard Shortcuts
##### File Operations
- **Ctrl+S**: Save/Add new entry
- **Ctrl+Q**: Quit application
- **Ctrl+E**: Export data
##### Data Management
- **Ctrl+N**: Clear entries
- **Ctrl+R / F5**: Refresh data
- **Ctrl+F**: Toggle search/filter
##### Window Management
- **Ctrl+M**: Manage medicines
- **Ctrl+P**: Manage pathologies
##### Table Operations
- **Delete**: Delete selected entry
- **Escape**: Clear selection
- **Double-click**: Edit entry
##### Help
- **F1**: Show keyboard shortcuts
- **F2**: Open settings window
#### 🔍 Search & Filter System
- **Text Search**: Search across all entry data
- **Date Range Filtering**: Filter by specific date ranges
- **Medicine Filters**: Show entries where medicines were taken/not taken
- **Pathology Range Filters**: Filter by symptom severity ranges
- **Quick Filters**: Pre-configured filters (last week, high symptoms, etc.)
#### 📈 Visualization
- **Interactive Graphs**: Line charts showing symptom trends over time
- **Medicine Dose Charts**: Bar charts displaying daily medication intake
- **Toggle Controls**: Show/hide specific symptoms or medicines
- **Professional Styling**: Clean, medical-grade visualization
#### 💾 Data Management
- **Auto-save**: Automatic data saving every 5 minutes
- **Backup System**: Automatic backups on startup/shutdown
- **Export Options**: JSON, PDF, XML export formats
- **Data Validation**: Comprehensive input validation and error handling
### Settings & Customization
#### Theme Management
- **Built-in Themes**: Dark, Light, Arc, Clam, Default, Alt
- **Dynamic Switching**: Change themes without restart
- **Persistent Settings**: Theme preferences saved automatically
- **Accessibility**: High contrast options available
#### Medicine Configuration
- **Add/Edit/Delete**: Full CRUD operations for medicines
- **Dosage Information**: Track dosage details and instructions
- **Color Coding**: Visual identification with custom colors
- **Quick Doses**: Pre-configured common dose amounts
#### Pathology Configuration
- **Symptom Scales**: Customizable 0-10 symptom tracking scales
- **Display Names**: User-friendly symptom names
- **Scale Descriptions**: Helpful descriptions for each scale level
- **Color Themes**: Visual feedback with color coding
---
## 🛠️ Developer Guide
### Development Environment Setup
#### Prerequisites
- **Python 3.13+**
- **uv** package manager
- **Virtual environment support**
#### Setup Commands
```bash
# Create virtual environment
python -m venv .venv
source .venv/bin/activate # or .venv/bin/activate.fish
# Install dependencies
uv sync
# Install development dependencies
uv sync --group dev
# Run tests
uv run pytest
# Run with coverage
uv run pytest --cov=src --cov-report=html
```
### Project Structure
```
thechart/
├── src/ # Source code
│ ├── main.py # Application entry point
│ ├── ui_manager.py # UI component management
│ ├── data_manager.py # Data persistence
│ ├── theme_manager.py # Theme and styling
│ ├── medicine_manager.py # Medicine CRUD operations
│ ├── pathology_manager.py # Pathology management
│ ├── graph_manager.py # Visualization
│ ├── export_manager.py # Data export
│ ├── search_filter*.py # Search and filtering
│ └── auto_save.py # Auto-save functionality
├── tests/ # Test suite
├── docs/ # Documentation
├── scripts/ # Utility scripts
└── logs/ # Application logs
```
### Architecture Overview
#### Core Components
- **MedTrackerApp**: Main application class coordinating all components
- **UIManager**: Creates and manages all UI elements
- **DataManager**: Handles CSV data operations with pandas
- **ThemeManager**: Manages application themes and styling
- **GraphManager**: Creates interactive matplotlib visualizations
#### Design Patterns
- **Manager Pattern**: Separate managers for different concerns
- **Observer Pattern**: UI updates based on data changes
- **Strategy Pattern**: Different export formats and themes
- **Factory Pattern**: Dynamic UI component creation
### Testing Strategy
#### Test Organization
- **Unit Tests**: Individual component testing
- **Integration Tests**: Cross-component functionality
- **UI Tests**: User interface behavior testing
- **Performance Tests**: Load and stress testing
#### Running Tests
```bash
# All tests
make test
# Specific test categories
uv run pytest tests/unit/
uv run pytest tests/integration/
uv run pytest tests/ui/
# With coverage
uv run pytest --cov=src --cov-report=html --cov-report=term-missing
```
### Code Quality
#### Linting and Formatting
- **ruff**: Primary linter and formatter
- **Type Hints**: Full type annotation coverage
- **PEP8 Compliance**: Enforced code style
- **Docstrings**: Comprehensive documentation
#### Pre-commit Hooks
```bash
# Install pre-commit hooks
pre-commit install
# Run all hooks
pre-commit run --all-files
```
---
## 🌟 Features & Capabilities
### Data Management Features
- **Dynamic Medicine System**: Add/remove medicines without code changes
- **Flexible Pathology Tracking**: Customizable symptom scales
- **Robust Data Validation**: Comprehensive input validation
- **Data Export**: Multiple export formats (JSON, PDF, XML)
- **Backup & Recovery**: Automatic backup system
### User Interface Features
- **Modern Theme Engine**: Professional styling system
- **Smart Tooltip System**: Context-sensitive help
- **Responsive Layouts**: Adaptive UI components
- **Keyboard Navigation**: Full keyboard accessibility
- **Visual Feedback**: Status updates and progress indicators
### Technical Features
- **Performance Optimization**: Efficient data handling and UI updates
- **Error Handling**: Comprehensive error recovery
- **Logging System**: Detailed application logging
- **Cross-platform**: Works on Windows, macOS, and Linux
- **Modular Architecture**: Easy to extend and maintain
---
## 🏗️ Technical Architecture
### Data Layer
- **CSV Storage**: Primary data persistence using pandas
- **JSON Configuration**: Medicine and pathology configurations
- **Backup System**: Automatic backup creation and management
- **Data Validation**: Input validation and error handling
### Business Logic Layer
- **Manager Classes**: Encapsulated business logic
- **Event Handling**: User interaction processing
- **Auto-save**: Background data persistence
- **Export Processing**: Data transformation for export
### Presentation Layer
- **Tkinter UI**: Native desktop interface
- **Theme System**: Dynamic styling and theming
- **Interactive Components**: Responsive UI elements
- **Visualization**: Matplotlib integration for charts
### Recent Technical Improvements
#### UI Flickering Fix (Latest)
- **Auto-save Optimization**: Removed unnecessary UI refreshes during auto-save
- **Debounced Filter Updates**: 300ms debouncing for search/filter changes
- **Efficient Tree Updates**: Scroll position preservation and batch operations
- **Optimized Scroll Handling**: Reduced scrollbar update frequency
- **Performance Improvements**: Eliminated redundant data loading
#### Key Optimizations
1. **Memory Efficiency**: Single data load with copies instead of multiple loads
2. **Scroll Performance**: Threshold-based scroll updates to reduce CPU usage
3. **UI Responsiveness**: Batch UI operations using `update_idletasks()`
4. **User Experience**: Preserved scroll position during data updates
---
## 📈 Recent Improvements
### Version 1.9.5 - UI/UX Overhaul
- **Professional Theme Engine**: Complete theming system with 6+ themes
- **Smart Tooltip System**: Context-sensitive help throughout the interface
- **Enhanced Settings Window**: Comprehensive configuration interface
- **Modern UI Components**: Improved styling and layout
- **Performance Optimizations**: Faster loading and smoother interactions
### Latest Fixes - UI Flickering Resolution
- **Smooth Scrolling**: Eliminated flickering during table scrolling
- **Debounced Updates**: Reduced filter update frequency
- **Preserved Context**: Maintain scroll position during updates
- **Auto-save Optimization**: Non-intrusive background saving
- **Performance Gains**: Reduced CPU usage during UI operations
### Previous Improvements
- **Search & Filter System**: Advanced filtering capabilities
- **Export Enhancements**: Multiple export formats with customization
- **Keyboard Shortcuts**: Comprehensive keyboard navigation
- **Data Validation**: Robust input validation and error handling
- **Auto-save & Backup**: Automatic data protection
---
## 📖 API Reference
### Core Classes
#### MedTrackerApp
```python
class MedTrackerApp:
"""Main application class."""
def __init__(self, root: tk.Tk) -> None:
"""Initialize the application."""
def add_new_entry(self) -> None:
"""Add a new data entry."""
def refresh_data_display(self, apply_filters: bool = False) -> None:
"""Refresh the data display."""
```
#### UIManager
```python
class UIManager:
"""Manages UI components and creation."""
def create_input_frame(self, parent_frame: ttk.Frame) -> dict[str, Any]:
"""Create the input form."""
def create_table_frame(self, parent_frame: ttk.Frame) -> dict[str, Any]:
"""Create the data table."""
def update_status(self, message: str, message_type: str = "info") -> None:
"""Update the status bar."""
```
#### DataManager
```python
class DataManager:
"""Handles data persistence and operations."""
def load_data(self) -> pd.DataFrame:
"""Load data from CSV file."""
def add_entry(self, entry: list) -> bool:
"""Add a new entry to the data."""
def update_entry(self, date: str, values: list) -> bool:
"""Update an existing entry."""
```
### Configuration APIs
#### Medicine Management
```python
class MedicineManager:
"""Manages medicine configurations."""
def add_medicine(self, medicine: Medicine) -> bool:
"""Add a new medicine."""
def get_medicine(self, key: str) -> Medicine | None:
"""Get medicine by key."""
def get_medicine_keys(self) -> list[str]:
"""Get all medicine keys."""
```
#### Pathology Management
```python
class PathologyManager:
"""Manages pathology configurations."""
def add_pathology(self, pathology: Pathology) -> bool:
"""Add a new pathology."""
def get_pathology(self, key: str) -> Pathology | None:
"""Get pathology by key."""
def get_pathology_keys(self) -> list[str]:
"""Get all pathology keys."""
```
---
## 🚨 Troubleshooting
### Common Issues
#### Application Won't Start
```bash
# Check Python version
python --version # Should be 3.13+
# Verify virtual environment
source .venv/bin/activate
which python
# Reinstall dependencies
uv sync --reinstall
```
#### UI Flickering (Resolved)
The UI flickering issue during scrolling has been resolved in the latest version through:
- Auto-save optimization
- Debounced filter updates
- Efficient tree updates
- Scroll position preservation
#### Data Not Saving
1. Check file permissions in the project directory
2. Verify CSV file is not locked by another application
3. Check logs in `logs/app.log` for error messages
4. Ensure sufficient disk space
#### Theme Issues
1. Restart the application after theme changes
2. Check theme configuration in settings
3. Reset to default theme if issues persist
4. Verify tkinter supports the selected theme
#### Export Problems
1. Check output directory permissions
2. Verify required libraries are installed
3. Check for large dataset memory issues
4. Review export logs for specific errors
### Debug Mode
Enable debug logging by setting the log level in `src/constants.py`:
```python
LOG_LEVEL = "DEBUG"
```
### Log Files
- **`logs/app.log`**: General application logs
- **`logs/app.error.log`**: Error messages only
- **`logs/app.warning.log`**: Warning messages only
---
## 🤝 Contributing
### Development Workflow
1. **Fork** the repository
2. **Create** a feature branch: `git checkout -b feature-name`
3. **Make** your changes following the coding guidelines
4. **Test** your changes: `make test`
5. **Lint** your code: `ruff check src/`
6. **Submit** a pull request
### Coding Standards
- **Follow PEP8** for Python code style
- **Use type hints** for all functions and variables
- **Write docstrings** for all public methods and classes
- **Add tests** for new functionality
- **Update documentation** for user-facing changes
### Testing Requirements
- **Unit tests** for all new functions
- **Integration tests** for cross-component features
- **UI tests** for user interface changes
- **Performance tests** for optimization changes
### Documentation Updates
- **Update user guide** for new features
- **Add API documentation** for new classes/methods
- **Update changelog** with version information
- **Include troubleshooting** for known issues
---
## 📄 License & Credits
### License
This project is licensed under [LICENSE] - see the LICENSE file for details.
### Credits
- **UI Framework**: Tkinter (Python standard library)
- **Data Processing**: pandas
- **Visualization**: matplotlib
- **Themes**: ttkthemes integration
- **Package Management**: uv
### Version Information
- **Current Version**: 1.13.7
- **Latest UI Update**: v1.9.5 (UI/UX Overhaul)
- **Latest Fix**: UI Flickering Resolution
---
*For the most up-to-date information, check the [CHANGELOG.md](CHANGELOG.md) and [README.md](README.md) files.*