|
2 months ago | |
---|---|---|
.cursor/rules | 2 months ago | |
.github/workflows | 2 months ago | |
android | 2 months ago | |
config/assets | 2 months ago | |
doc | 2 months ago | |
docker | 3 months ago | |
docs | 2 months ago | |
electron | 3 months ago | |
ios | 2 months ago | |
public | 10 months ago | |
resources | 2 months ago | |
scripts | 2 months ago | |
src | 2 months ago | |
sw_scripts | 3 months ago | |
test-playwright | 2 months ago | |
test-scripts | 7 months ago | |
.browserslistrc | 3 years ago | |
.cursor-markdown-rules.md | 4 months ago | |
.dockerignore | 3 months ago | |
.env.development | 2 months ago | |
.env.production | 2 months ago | |
.env.test | 2 months ago | |
.eslintrc.js | 2 months ago | |
.gitignore | 2 months ago | |
.markdownlint.json | 4 months ago | |
.node-version | 2 months ago | |
.npmrc | 4 months ago | |
.nvmrc | 2 months ago | |
BUILDING.md | 2 months ago | |
CHANGELOG.md | 2 months ago | |
CONTRIBUTING.md | 1 year ago | |
Dockerfile | 3 months ago | |
Gemfile | 3 months ago | |
Gemfile.lock | 3 months ago | |
LICENSE | 11 months ago | |
README.md | 2 months ago | |
TASK_storage.md | 5 months ago | |
build.sh | 6 months ago | |
capacitor-assets.config.json | 2 months ago | |
capacitor.config.json | 3 months ago | |
capacitor.config.ts | 2 months ago | |
docker-compose.yml | 4 months ago | |
index.html | 3 months ago | |
jest.config.js | 4 months ago | |
package-lock.json | 2 months ago | |
package.json | 2 months ago | |
pkgx.yaml | 5 months ago | |
playwright.config-local.ts | 2 months ago | |
postcss.config.js | 3 years ago | |
project.task.yaml | 2 years ago | |
tailwind.config.js | 3 years ago | |
tsconfig.json | 5 months ago | |
tsconfig.node.json | 3 months ago | |
vite.config.capacitor.mts | 8 months ago | |
vite.config.common.mts | 2 months ago | |
vite.config.dev.mts | 8 months ago | |
vite.config.electron.mts | 3 months ago | |
vite.config.optimized.mts | 3 months ago | |
vite.config.utils.mts | 8 months ago | |
vite.config.web.mts | 3 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.
Roadmap
See ClickUp for current priorities.
Setup & Building
Quick start:
- For setup, we recommend pkgx, which installs what you need (either automatically or with the
dev
command). 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 build:web:serve -- --test
To be able to make submissions: go to "profile" (bottom left), go to the bottom and expand "Show Advanced Settings", go to the bottom and to the "Test Page", and finally "Become User 0" to see all the functionality.
See BUILDING.md for comprehensive build instructions for all platforms (Web, Electron, iOS, Android, Docker).
Development Database Clearing
TimeSafari provides a simple script-based approach to clear the local database (not the claim server) for development purposes.
Logging Configuration
TimeSafari supports configurable logging levels via the VITE_LOG_LEVEL
environment variable. This allows developers to control console output verbosity without modifying code.
Quick Usage
# Show only errors
VITE_LOG_LEVEL=error npm run dev
# Show warnings and errors
VITE_LOG_LEVEL=warn npm run dev
# Show info, warnings, and errors (default)
VITE_LOG_LEVEL=info npm run dev
# Show all log levels including debug
VITE_LOG_LEVEL=debug npm run dev
Available Levels
error
: Critical errors onlywarn
: Warnings and errors (default for production web)info
: Info, warnings, and errors (default for development/capacitor)debug
: All log levels including verbose debugging
See Logging Configuration Guide for complete details.
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
Domain Configuration
TimeSafari uses a centralized domain configuration system to ensure consistent URL generation across all environments. This prevents localhost URLs from appearing in shared links during development.
Key Features
- ✅ Production URLs for Sharing: All copy link buttons use production domain
- ✅ Environment-Specific Internal URLs: Internal operations use appropriate environment URLs
- ✅ Single Point of Control: Change domain in one place for entire app
- ✅ Type-Safe Configuration: Full TypeScript support
Quick Reference
// For sharing functionality (environment-specific)
import { APP_SERVER } from "@/constants/app";
const shareLink = `${APP_SERVER}/deep-link/claim/123`;
// For internal operations (environment-specific)
import { APP_SERVER } from "@/constants/app";
const apiUrl = `${APP_SERVER}/api/claim/123`;
Documentation
- Constants and Configuration - Core constants
Tests
See TESTING.md for detailed test instructions.
Asset Management
TimeSafari uses a standardized asset configuration system for consistent icon and splash screen generation across all platforms.
Asset Sources
- Single source of truth:
resources/
directory (Capacitor default) - Source files:
icon.png
,splash.png
,splash_dark.png
- Format: PNG or SVG files for optimal quality
Asset Generation
- Configuration:
config/assets/capacitor-assets.config.json
- Schema validation:
config/assets/schema.json
- Build-time generation: Platform assets generated via
capacitor-assets
- No VCS commits: Generated assets are never committed to version control
Development Commands
# Generate/update asset configurations
npm run assets:config
# Validate asset configurations
npm run assets:validate
# Clean generated platform assets (local dev only)
npm run assets:clean
# Build with asset generation
npm run build:native
Platform Support
- Android: Adaptive icons with foreground/background, monochrome support
- iOS: LaunchScreen storyboard preferred, splash assets when needed
- Web: PWA icons generated during build to
dist/
(not committed)
Font Awesome Icons
To add a Font Awesome icon, add to fontawesome.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
publicPath
in 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 definitionsdeepLinks.ts
- Deep linking type system and Zod validation schemasgive.ts
- Give-related interfaces and type definitionsclaims.ts
- Claim-related interfaces and verifiable credentialscommon.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 definitionsrc/services/PlatformServiceFactory.ts
- Platform-specific service factorysrc/services/AbsurdSqlDatabaseService.ts
- SQLite implementationsrc/utils/PlatformServiceMixin.ts
- Vue mixin for database access with cachingsrc/db/
- Legacy Dexie database (migration in progress)
Development Guidelines:
- Always use
PlatformServiceMixin
for database operations in components - 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