|  | 4 months ago | |
|---|---|---|
| .cursor/rules | 4 months ago | |
| .github/workflows | 1 year ago | |
| android | 4 months ago | |
| assets | 4 months ago | |
| dev-dist | 4 months ago | |
| doc | 4 months ago | |
| docker | 4 months ago | |
| docs | 4 months ago | |
| electron | 4 months ago | |
| ios | 4 months ago | |
| public | 10 months ago | |
| scripts | 4 months ago | |
| src | 4 months ago | |
| sw_scripts | 11 months ago | |
| test-playwright | 4 months ago | |
| test-scripts | 7 months ago | |
| .browserslistrc | 3 years ago | |
| .cursor-markdown-rules.md | 4 months ago | |
| .dockerignore | 4 months ago | |
| .env.development | 4 months ago | |
| .env.production | 4 months ago | |
| .env.test | 4 months ago | |
| .eslintrc.js | 5 months ago | |
| .gitignore | 4 months ago | |
| .markdownlint.json | 4 months ago | |
| .npmrc | 4 months ago | |
| BUILDING.md | 4 months ago | |
| CHANGELOG.md | 4 months ago | |
| CONTRIBUTING.md | 1 year ago | |
| Dockerfile | 4 months ago | |
| Gemfile | 8 months ago | |
| Gemfile.lock | 8 months ago | |
| LICENSE | 11 months ago | |
| README.md | 4 months ago | |
| TASK_storage.md | 5 months ago | |
| WORKER_ONLY_DATABASE_IMPLEMENTATION.md | 4 months ago | |
| build.sh | 6 months ago | |
| capacitor.config.json | 4 months ago | |
| docker-compose.yml | 4 months ago | |
| experiment.sh | 4 months ago | |
| index.html | 4 months ago | |
| jest.config.js | 4 months ago | |
| package-lock.json | 4 months ago | |
| package.json | 4 months ago | |
| pkgx.yaml | 5 months ago | |
| playwright.config-local.ts | 4 months ago | |
| playwright.config.ts | 10 months ago | |
| postcss.config.js | 3 years ago | |
| project.task.yaml | 2 years ago | |
| sw_combine.js | 2 years ago | |
| tailwind.config.js | 3 years ago | |
| temp.har | 4 months ago | |
| tsconfig.json | 5 months ago | |
| tsconfig.node.json | 6 months ago | |
| vite.config.capacitor.mts | 8 months ago | |
| vite.config.common.mts | 4 months ago | |
| vite.config.dev.mts | 8 months ago | |
| vite.config.electron.mts | 4 months ago | |
| vite.config.mts | 4 months ago | |
| vite.config.optimized.mts | 4 months ago | |
| vite.config.ts | 4 months ago | |
| vite.config.utils.mts | 8 months ago | |
| vite.config.web.mts | 4 months ago | |
		
			
				
				README.md
			
		
		
	
	TimeSafari.app - Crowd-Funder for Time - PWA
Time Safari allows people to ease into collaboration: start with expressions of gratitude and expand to crowd-fund with time & money, then record and see the impact of contributions.
Database Migration Status
Current Status: The application is undergoing a migration from Dexie (IndexedDB) to SQLite using absurd-sql. This migration is in Phase 2 with a well-defined migration fence in place.
Migration Progress
- ✅ SQLite Database Service: Fully implemented with absurd-sql
- ✅ Platform Service Layer: Unified database interface across platforms
- ✅ Settings Migration: Core user settings transferred
- ✅ Account Migration: Identity and key management
- 🔄 Contact Migration: User contact data (via import interface)
- 📋 Code Cleanup: Remove unused Dexie imports
Migration Fence
The migration is controlled by a migration fence that separates legacy Dexie code from the new SQLite implementation. See Migration Fence Definition for complete details.
Key Points:
- Legacy Dexie database is disabled by default
- All database operations go through PlatformServiceMixin
- Migration tools provide controlled access to both databases
- Clear separation between legacy and new code
Migration Documentation
- Migration Guide - Complete migration process
- Migration Fence Definition - Fence boundaries and rules
- Database Migration Guide - User-facing migration tools
Roadmap
See project.task.yaml for current priorities. (Numbers at the beginning of lines are estimated hours. See taskyaml.org for details.)
Setup & Building
Quick start:
- For setup, we recommend pkgx, which installs what you need (either automatically or with the devcommand). Core dependencies are typescript & npm; when building for other platforms, you'll need other things such as those in the pkgx.yaml & BUILDING.md files.
npm install
npm run dev
See BUILDING.md for more details.
Development Database Clearing
TimeSafari provides a simple script-based approach to clear the database for development purposes.
Quick Usage
# Run the database clearing script
./scripts/clear-database.sh
# Then restart your development server
npm run build:electron:dev  # For Electron
npm run build:web:dev       # For Web
What It Does
Electron (Desktop App)
- Automatically finds and clears the SQLite database files
- Works on Linux, macOS, and Windows
- Clears all data and forces fresh migrations on next startup
Web Browser
- Provides instructions for using custom browser data directories
- Shows manual clearing via browser DevTools
- Ensures reliable database clearing without browser complications
Safety Features
- ✅ Interactive Script: Guides you through the process
- ✅ Platform Detection: Automatically detects your OS
- ✅ Clear Instructions: Step-by-step guidance for each platform
- ✅ Safe Paths: Only clears TimeSafari-specific data
Manual Commands (if needed)
Electron Database Location
# Linux
rm -rf ~/.config/TimeSafari/*
# macOS  
rm -rf ~/Library/Application\ Support/TimeSafari/*
# Windows
rmdir /s /q %APPDATA%\TimeSafari
Web Browser (Custom Data Directory)
# Create isolated browser profile
mkdir ~/timesafari-dev-data
# Start browser with custom profile
google-chrome --user-data-dir=~/timesafari-dev-data
# Clear when needed
rm -rf ~/timesafari-dev-data
See the script for complete platform-specific instructions.
Build Systems
TimeSafari supports comprehensive build systems for all platforms with unified patterns and consistent tooling.
Quick Start Commands
# Web Development (starts dev server)
npm run build:web:dev
# Android Development (builds debug APK)
npm run build:android:dev
# iOS Development (builds debug app)
npm run build:ios:dev
# Electron Development (runs app directly)
npm run build:electron:dev
# Deploy Android to connected device
npm run build:android:deploy
# Deploy iOS to connected device
npm run build:ios:deploy
Platform-Specific Builds
Web Builds
- Development: Hot reload server at http://localhost:8080
- Production: Optimized static files with PWA support
- Docker: Containerized deployment images
npm run build:web:dev      # Development server
npm run build:web:prod     # Production build
npm run build:web:docker:prod  # Docker deployment
Android Builds
- Development: Debug APK with development optimizations
- Production: Release APK/AAB for app store distribution
- Deployment: Direct installation to connected devices
npm run build:android:dev      # Development build
npm run build:android:prod     # Production build
npm run build:android:deploy   # Build and deploy to device
iOS Builds
- Development: Debug app with development optimizations
- Production: Release app/IPA for app store distribution
- Deployment: Direct installation to connected devices
npm run build:ios:dev          # Development build
npm run build:ios:prod         # Production build
npm run build:ios:deploy       # Build and deploy to device
Electron Builds
- Development: Runs app directly for development
- Packages: Creates distributable executables
- Cross-Platform: Windows, macOS, Linux support
npm run build:electron:dev         # Runs app directly
npm run build:electron:appimage:prod  # Linux AppImage
npm run build:electron:dmg:prod    # macOS DMG
npm run build:electron:deb:prod    # Linux DEB
Build System Features
- ✅ Unified Environment Management: Consistent dev/test/prod modes
- ✅ PWA Support: Progressive Web App functionality across platforms
- ✅ Asset Generation: Automatic icon and splash screen generation
- ✅ Docker Integration: Containerized deployment options
- ✅ Performance Optimization: Build-time and runtime optimizations
- ✅ Error Handling: Comprehensive error reporting and recovery
- ✅ Legacy Compatibility: Backward-compatible script aliases
Comprehensive Documentation
- Build Systems Overview - Complete guide to all build systems
- Web Build Scripts - Web/PWA builds with Docker support
- Android Build Scripts - Mobile builds with device deployment
- iOS Build Scripts - iOS builds with Xcode integration
- Electron Build Scripts - Desktop builds with package creation
- Database Clearing - Development database management
- Build Troubleshooting - Comprehensive troubleshooting guide
Tests
See TESTING.md for detailed test instructions.
Icons
Application icons are in the assets directory, processed by the capacitor-assets command.
To add a Font Awesome icon, add to main.ts and reference with font-awesome element and icon attribute with the hyphenated name.
Other
Reference Material
- 
Notifications can be type of toast(self-dismiss),info,success,warning, anddanger. They are done via notiwind and set up in App.vue.
- 
If you are deploying in a subdirectory, add it to publicPathin vue.config.js, eg:publicPath: "/app/time-tracker/",
Code Organization
The project uses a centralized approach to type definitions and interfaces:
- src/interfaces/- Contains all TypeScript interfaces and type definitions- deepLinks.ts- Deep linking type system and Zod validation schemas
- give.ts- Give-related interfaces and type definitions
- claims.ts- Claim-related interfaces and verifiable credentials
- common.ts- Shared interfaces and utility types
- Other domain-specific interface files
 
Key principles:
- All interfaces and types are defined in the interfaces folder
- Zod schemas are used for runtime validation and type generation
- Domain-specific interfaces are separated into their own files
- Common interfaces are shared through common.ts
- Type definitions are generated from Zod schemas where possible
Database Architecture
The application uses a platform-agnostic database layer with Vue mixins for service access:
- src/services/PlatformService.ts- Database interface definition
- src/services/PlatformServiceFactory.ts- Platform-specific service factory
- src/services/AbsurdSqlDatabaseService.ts- SQLite implementation
- src/utils/PlatformServiceMixin.ts- Vue mixin for database access with caching
- src/db/- Legacy Dexie database (migration in progress)
Development Guidelines:
- Always use PlatformServiceMixinfor database operations in components
- Never import Dexie directly in application code
- Test with PlatformServiceMixin for new features
- Use migration tools for data transfer between systems
- Leverage mixin's ultra-concise methods: $db(),$exec(),$one(),$contacts(),$settings()
Architecture Decision: The project uses Vue mixins over Composition API composables for platform service access. See Architecture Decisions for detailed rationale.
Kudos
Gifts make the world go 'round!
- WebStorm by JetBrains for the free open-source license
- Máximo Fernández for the 3D code and explanatory post
- Many tools & libraries such as Nodejs.org, IntelliJ Idea, Veramo.io, Vuejs.org, threejs.org
- Bush 3D model
- Forest floor image
- Time Safari logo assisted by DALL-E in ChatGPT
- DiceBear and Avataaars for human-looking identicons
- Some gratitude prompts thanks to Develop Good Habits