4.0 KiB
4.0 KiB
Project: Media File Renamer and Metadata Editor (Python TUI with Textual)
TODO Steps:
- ✅ Set up Python project structure with UV package manager
- ✅ Install dependencies: textual, mutagen, pymediainfo, python-magic, pathlib for file handling
- ✅ Implement recursive directory scanning for video files (*.mkv, *.avi, *.mov, *.mp4, *.wmv, *.flv, *.webm, etc.)
- ✅ Detect real media container type using mutagen and python-magic
- ✅ Create Textual TUI application with split layout (left: file tree, right: file details)
- ✅ Implement file tree display with navigation (keyboard arrows, mouse support)
- ✅ Add bottom command bar with 'quit', 'open directory', 'scan' commands
- ✅ Display file details on right side: file size, extension from filename, extension from metadata, file date
- ✅ Add functionality to select files in the tree and update right panel
- ✅ Implement detailed metadata display including video/audio/subtitle tracks with colors
- ✅ Add custom tree styling with file icons and colored guides
- ✅ Add scrollable details panel
- ✅ Handle markup escaping for file names with brackets
- ✅ Implement file renaming functionality with confirmation dialog
- ✅ Add proposed name generation based on metadata extraction
- ✅ Add help screen with key bindings and usage information
- ✅ Add tree expansion/collapse toggle functionality
- ✅ Add file refresh functionality to reload metadata for selected file
- ✅ Optimize tree updates to avoid full reloads after renaming
- ✅ Add loading indicators for metadata extraction
- ✅ Add error handling for file operations and metadata extraction
- 🔄 Implement blue highlighting for changed parts in proposed filename display (show differences between current and proposed names)
- 🔄 Implement build script to exclude dev commands (bump-version, release) from distributed package
- Implement metadata editing capabilities (future enhancement)
- Add batch rename operations (future enhancement)
- Add configuration file support (future enhancement)
- Add plugin system for custom extractors/formatters (future enhancement)
Media Catalog Mode Implementation Plan
New big app evolution step: Add media catalog mode with settings, caching, and enhanced TMDB display.
Phase 1: Settings Management Foundation
- ✅ Create settings module (
renamer/settings.py) for JSON config in~/.config/renamer/config.jsonwith schema: mode, cache TTLs - ✅ Integrate settings into app startup (load/save on launch/exit)
- ✅ Add settings window to UI with fields for mode and TTLs
- ✅ Add "Open Settings" command to command panel
- ✅ Order setting menu item in the action bar by right side, close to the sysytem menu item ^p palette
Phase 2: Mode Toggle and UI Switching
- ✅ Add "Toggle Mode" command to switch between "technical" and "catalog" modes
- ✅ Modify right pane for mode-aware display (technical vs catalog info)
- ✅ Persist and restore mode state from settings
Phase 3: Caching System
- ✅ Create caching module (
renamer/cache.py) for file-based cache with TTL support - ✅ Integrate caching into extractors (check cache first, store results)
- ✅ Add refresh command to force re-extraction and cache update
- ✅ Handle cache cleanup on file rename (invalidate old filename)
Phase 4: Media Catalog Display
- ✅ Update TMDB extractor for catalog data: title, year, duration, rates, overview, genres codes, poster_path
- ✅ Create catalog formatter (
formatters/catalog_formatter.py) for beautiful display - ✅ Integrate catalog display into right pane
Phase 5: Poster Handling and Display
- ✅ Add poster caching (images in cache dir with 1-month TTL)
- ✅ Implement terminal image display (research rich-pixels or alternatives, add poster_display.py)
Additional TODOs from Plan
- Retrieve full movie details from TMDB (future)
- Expand genres to full names instead of codes (future)
- Optimize poster quality and display (future)