timesafari
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Matthew Raymer 797db7069c Fix image CORS violations with comprehensive proxy and component updates 4 months ago
.cursor/rules Fix image CORS violations with comprehensive proxy and component updates 4 months ago
.github/workflows Playwright install 1 year ago
android Fix worker-only database architecture and Vue Proxy serialization 4 months ago
assets chore: commit stray files that should have been with the previous commit 4 months ago
doc Remove unused usePlatformService composable and document mixin architecture 4 months ago
docker Fix worker-only database architecture and Vue Proxy serialization 4 months ago
electron Fix worker-only database architecture and Vue Proxy serialization 4 months ago
ios on mobile: bump version to 1.0.2 and build to 35 4 months ago
public add another sample boundary frame for the certificate view of a claim 10 months ago
scripts feat(build): add automated Android resource detection and generation 4 months ago
src Fix image CORS violations with comprehensive proxy and component updates 4 months ago
sw_scripts switch the encryption secret from localStorage to IndexedDB (because localStorage gets lost so often) 11 months ago
test-playwright refactor: Remove debug messages from offer dismissal test 4 months ago
test-scripts rename app ID from app.timesafari.app to app.timesafari & adjust tests (Java 20 works) 7 months ago
.browserslistrc init 3 years ago
.dockerignore migration: move to bash based build scripts 4 months ago
.env.development remove relative URL references in different target because mobile chokes 5 months ago
.env.production fix console error about "window" unavailable due to service worker 5 months ago
.env.staging fix console error about "window" unavailable due to service worker 5 months ago
.eslintrc.js fix: update ESLint and VS Code settings 5 months ago
.gitignore feat: Add Electron dependencies and development scripts 4 months ago
.npmrc WIP: Fix Electron build issues and migrate to @nostr/tools 4 months ago
BUILDING.md Add automated iOS build script with version management 4 months ago
CHANGELOG.md bump to version 1.0.3-beta 4 months ago
CONTRIBUTING.md add recipient description to offers in user's list 1 year ago
Dockerfile migration: move to bash based build scripts 4 months ago
Gemfile feat: Add Fastlane configuration for mobile app deployment 8 months ago
Gemfile.lock feat(ios): enhance iOS test automation and fix dependencies 8 months ago
LICENSE add license file 11 months ago
README.md Remove unused usePlatformService composable and document mixin architecture 4 months ago
TASK_storage.md add documentation for some new work: storage 5 months ago
WORKER_ONLY_DATABASE_IMPLEMENTATION.md Fix worker-only database architecture and Vue Proxy serialization 4 months ago
build.sh feature: adding Dockerfile for online testing or deployment to docker 6 months ago
capacitor.config.json feat(build): add automated Android resource detection and generation 4 months ago
docker-compose.yml migration: move to bash based build scripts 4 months ago
experiment.sh migration: move to bash based build scripts 4 months ago
index.html Fix worker-only database architecture and Vue Proxy serialization 4 months ago
package-lock.json Fix image CORS violations with comprehensive proxy and component updates 4 months ago
package.json feat: Add clean:ios script to remove iOS build artifacts 4 months ago
pkgx.yaml disable SQLite in Java & Swift (since they don't compile) & add SQL queueing on startup 5 months ago
playwright.config-local.ts refactor: improve feed loading and infinite scroll reliability 7 months ago
playwright.config.ts Refatored vite.config to be a bit more streamlined before adding alternate build options. This did end up requiring me to remove @ from imports for some reason. Tests came out fine. 10 months ago
postcss.config.js Adding Tailwind and start application views 3 years ago
project.task.yaml update ClickUp link to a public link 2 years ago
sw_combine.js combine all service-worker scripts into a single file to try and ensure included scripts aren't lost 2 years ago
tailwind.config.js Fix config 3 years ago
temp.har WIP: Electron asset path and renderer build fixes 4 months ago
tsconfig.json WIP: fix(AbsurdSqlDatabaseService) fixes to typing and other curious beasts 5 months ago
tsconfig.node.json refactor(electron): improve build process and configuration 6 months ago
vite.config.capacitor.mts refactor: reorganize Vite config into modular files 8 months ago
vite.config.common.mts Fix image CORS violations with comprehensive proxy and component updates 4 months ago
vite.config.dev.mts WIP: certificate view and dependency updates 8 months ago
vite.config.mts WIP: Fix Electron build issues and migrate to @nostr/tools 4 months ago
vite.config.ts WIP: Fix Electron build issues and migrate to @nostr/tools 4 months ago
vite.config.utils.mts refactor: reorganize Vite config into modular files 8 months ago
vite.config.web.mts Fix worker-only database architecture and Vue Proxy serialization 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 (USE_DEXIE_DB = false)
  • All database operations go through PlatformService
  • Migration tools provide controlled access to both databases
  • Clear separation between legacy and new code

Migration Documentation

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 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 dev

See BUILDING.md for more details.

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, and danger. They are done via notiwind and set up in App.vue.

  • Customize Vue configuration.

  • 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 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 PlatformServiceMixin for database operations in components
  • Never import Dexie directly in application code
  • Test with USE_DEXIE_DB = false 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!