saravanakumardb1
8731cf38fd
fix(backend): add NODE_ENV=test auto-selection and sync setProvider with global singleton
2026-03-02 01:49:11 -08:00
saravanakumardb1
03d4b7def9
refactor(backend): migrate ChronoMind repositories to @bytelyst/datastore
2026-03-02 01:45:16 -08:00
saravanakumardb1
d6b1bb6f63
fix(sync): fix BatchResult.errors type mismatch — backend returns {id,error} objects not strings
2026-03-01 21:27:44 -08:00
saravanakumardb1
48b88d3a29
fix(sync): add x-product-id header and fix pullDelta response decode mismatch
2026-03-01 21:26:12 -08:00
saravanakumardb1
8cd0ea7fa7
fix(backend): use config.JWT_SECRET instead of direct process.env read
2026-03-01 21:21:12 -08:00
saravanakumardb1
f10b83c122
feat(backend): scaffold product-specific Fastify backend (port 4011)
...
Add backend/ directory with Fastify 5 + TypeScript ESM service:
- Modules: timers, routines, households, shared-timers, webhooks (migrated from platform-service)
- Cosmos containers: timers, routines, households, shared_timers, webhook_subscriptions, webhook_events
- JWT verification via jose (matches platform-service issuer)
- Shared @bytelyst/* packages via file: refs
- 171 Vitest tests passing
Update AGENTS.md: update backend integration section with product backend details
2026-03-01 20:39:08 -08:00
saravanakumardb1
6b82ca1b33
feat(android): migrate auth, telemetry, feature flags to ByteLyst Kotlin Platform SDK
2026-03-01 18:16:13 -08:00
saravanakumardb1
b7688b55d1
fix(security): move PlatformSyncManager auth token from UserDefaults to Keychain
2026-03-01 16:37:39 -08:00
saravanakumardb1
e0c7f24954
fix(tests): stats.test.ts topCategory test broken on Sundays — wrong Monday calculation
2026-03-01 16:37:07 -08:00
saravanakumardb1
3adab843cd
refactor(ios): migrate CrashReporter to ByteLystPlatformSDK's BLCrashReporter
...
Replaced standalone MetricKit crash reporter (153 lines) with thin wrapper (34 lines)
delegating to SDK's BLCrashReporter. Preserves existing call-site API.
2026-02-28 22:38:55 -08:00
saravanakumardb1
d1b4534b22
refactor(ios): migrate Cloud/ files to ByteLystPlatformSDK — eliminate duplicated platform code
...
Replaced standalone implementations with thin wrappers over shared SDK:
- KeychainHelper → delegates to BLKeychain (53→27 lines)
- TelemetryService → delegates to BLTelemetryClient (139→55 lines)
- FeatureFlagService → delegates to BLFeatureFlagClient (72→39 lines)
- AuthService → delegates to BLAuthClient (359→171 lines)
- project.yml → added ByteLystPlatformSDK local package dependency
Total: 623 lines of duplicated code → 292 lines of thin wrappers.
PlatformSyncManager kept as-is (product-specific timer DTOs).
All existing call-site APIs preserved — zero breaking changes.
2026-02-28 22:12:37 -08:00
saravanakumardb1
3596a8f350
feat(sync): wire platform sync into timer and routine stores, extend fullSync for routines, add error/not-found pages
2026-02-28 20:24:53 -08:00
saravanakumardb1
fe75bc30de
test(web): add 21 tests for exportAll/importRoutines/parseImportData
2026-02-28 19:29:39 -08:00
saravanakumardb1
141fcc2a38
feat(web): wire routine export/import into history page UI
2026-02-28 19:28:37 -08:00
saravanakumardb1
77254b751e
fix(telemetry): lowercase osFamily to match server enum
2026-02-28 19:26:52 -08:00
saravanakumardb1
75927d00e2
chore(ios): add TelemetryService + FeatureFlagService to Xcode project
2026-02-28 19:25:01 -08:00
saravanakumardb1
e5d18b1c9c
feat(web): gate routines nav behind feature flag
2026-02-28 19:14:01 -08:00
saravanakumardb1
672acadba6
feat(android): add telemetry client, feature flags client, wire into DI + ViewModel
2026-02-28 19:12:15 -08:00
saravanakumardb1
180c98160b
feat(ios): add telemetry client, feature flags client, Settings login/register form
2026-02-28 19:10:08 -08:00
saravanakumardb1
ef27f9dcc6
fix(web): beacon transport, remove dead sync wrappers, add routine export/import
2026-02-28 19:07:14 -08:00
saravanakumardb1
a5aec74e4d
feat(web): add billing/subscription client stub for Pro tier
...
- billing-client.ts: getMySubscription, cancelSubscription, getUsageSummary
- Calls platform-service /subscriptions + /usage endpoints
2026-02-28 14:24:55 -08:00
saravanakumardb1
95f71f4625
feat(web): add feature flag client with platform-service polling
2026-02-28 14:18:06 -08:00
saravanakumardb1
09ded150f4
feat(web): add routine sync operations to platform-sync client
...
- SyncRoutineDTO + SyncRoutineStepDTO types
- pullRoutineDelta, pushRoutine, updateRemoteRoutine, deleteRemoteRoutine, batchUpsertRoutines
- routineToDTO / dtoToRoutinePatch conversion functions
- OfflineQueueItem now supports entityType (timer|routine)
2026-02-28 13:54:43 -08:00
saravanakumardb1
6e339c6cf0
feat(web): accept snooze suggestion to auto-adjust timer timing
...
- Accept button on snooze suggestions shifts matching active timers
- Applies suggestedDelayMinutes to targetTime of pattern-matched timers
- Dismiss still available alongside Accept
2026-02-28 13:53:06 -08:00
saravanakumardb1
ad4bc946a8
feat(web): wire TimerChain[] into Zustand store with auto-start
...
- chains[] persisted alongside timers in localStorage
- addChain/removeChain with linkedTimerId bookkeeping
- removeTimer auto-cleans chain references
- complete() auto-starts next timer in chain via getNextInChain
- 373/373 tests pass
2026-02-28 13:52:20 -08:00
saravanakumardb1
233fde8f99
docs(roadmap): mark completed items from web polish session
...
- Zod form validation (02ac682 )
- 3-step onboarding walkthrough + tooltip hints (4e1a22f )
- Ambient background sounds in focus mode (4e1a22f )
- Custom pre-warning messages per timer (d3b55a2 )
- Routine preview timeline in editor (c5c8000 )
- Chain badge on TimerCard (existing)
2026-02-28 13:46:15 -08:00
saravanakumardb1
c5c800077c
feat(web): add routine preview timeline in editor
...
- Visual horizontal bar chart showing step durations proportionally
- Color-coded segments with golden-angle hue distribution
- Time markers (start/end) and step legend
- Updates live as steps are added, removed, or reordered
2026-02-28 13:38:48 -08:00
saravanakumardb1
d3b55a2135
feat(web): add custom pre-warning messages per timer
...
- Add customMessage field to Timer interface + all Create*Params
- Custom message input in CreateTimerModal (optional, non-pomodoro)
- TimerCard shows custom message, falls back to auto-generated prep tips
- 373/373 tests pass, 0 type errors
2026-02-28 13:37:42 -08:00
saravanakumardb1
4e1a22f869
feat(web): add onboarding walkthrough + ambient sounds for focus mode
...
- OnboardingOverlay: 3-step walkthrough for first-time users (localStorage flag)
- ambient-sounds.ts: Web Audio API noise generators (rain, white noise, brown noise, coffee shop)
- FocusView: ambient sound picker with volume slider, auto-stops on session end
2026-02-28 13:35:06 -08:00
saravanakumardb1
02ac682c52
feat(web): wire Zod form validation into CreateTimerModal + add event schema
...
- Import and validate against alarmSchema, countdownSchema, pomodoroSchema, eventSchema
- Show inline error messages below form fields (label, time, duration, event date)
- Error border color highlights invalid fields
- Errors clear on tab switch and successful creation
2026-02-28 13:30:56 -08:00
saravanakumardb1
3d70a7c197
docs: add Docker/CI build instructions for tarball prep workflow
2026-02-28 13:17:31 -08:00
saravanakumardb1
b12d4236b0
chore: add repo workflow files (backup, push, sync, commit)
2026-02-28 12:56:16 -08:00
saravanakumardb1
b124009053
chore: add docker-prep script + gitignore entries for portable builds
2026-02-28 12:32:28 -08:00
saravanakumardb1
8ef44788e1
refactor(web): deduplicate getBaseUrl() — export from auth-api.ts, import in auth-context.tsx
2026-02-28 12:11:26 -08:00
saravanakumardb1
f80602d2b1
refactor(web): DRY platform-sync.ts — remove 88 lines of hand-rolled auth, delegate to auth-client
2026-02-28 11:49:06 -08:00
saravanakumardb1
8a5a40676a
refactor(web): wire @bytelyst/react-auth into auth-context, clean platform-sync auth plumbing
2026-02-28 11:28:14 -08:00
saravanakumardb1
bde5cb792d
refactor(web): wire @bytelyst/auth-client + telemetry-client into ChronoMind
...
- auth-api.ts: lazy-init shared auth client singleton
- platform-sync.ts: delegate auth ops to @bytelyst/auth-client
- telemetry.ts: delegate to @bytelyst/telemetry-client
- All 373 tests pass
2026-02-28 04:50:00 -08:00
saravanakumardb1
e3add90f87
feat(auth): add forgot password, reset password, change password, delete account, email verify, token refresh
...
Web:
- platform-sync.ts: Added forgotPassword, resetPassword, changePassword, verifyEmail, resendVerification, deleteAccount API functions
- auth-context.tsx: Added forgotPassword, resetPassword, changePassword, deleteAccount actions + successMessage state + 45min auto-refresh timer
- settings/page.tsx: Added forgot password link, change password form, delete account form with confirmation
- reset-password/page.tsx: New page for password reset via email token
- verify-email/page.tsx: New page for email verification via token
iOS:
- AuthService.swift: Added forgotPassword, changePassword, deleteAccount methods
- SettingsView.swift: Added change password, delete account, forgot password UI sections
Android:
- AuthService.kt: Added forgotPassword, changePassword, deleteAccount methods
2026-02-28 04:08:58 -08:00
saravanakumardb1
6a41cc9f48
feat(mobile): add auth login/register flow for iOS and Android
...
- iOS: Add KeychainHelper.swift for secure token storage
- iOS: Add AuthService.swift (CMAuthService) with login/register/refresh/logout
- iOS: Add LoginView.swift (CMLoginView) with ChronoMind theme
- iOS: Wire auth gate in ChronoMindApp.swift (LoginView vs ContentView)
- iOS: Add Account section to SettingsView with email/plan/sign-out
- iOS: Add Cloud group + 3 files to Xcode project.pbxproj
- Android: Add AuthService.kt with Hilt @Singleton, login/register/refresh/logout
- Android: Add LoginScreen.kt with Compose login/register form
- Android: Wire auth gate in MainActivity via Hilt-injected AuthService
- Android: Add Account section to SettingsScreen via HiltViewModel
- Android: Add x-product-id header to PlatformApiClient
2026-02-28 03:22:23 -08:00
saravanakumardb1
5e8cbbf556
feat(auth): implement refresh token flow with 401 auto-retry and dedup
2026-02-28 02:44:56 -08:00
saravanakumardb1
8ad31af72a
chore(telemetry): add tracing headers to flush + .env.example
2026-02-28 02:36:55 -08:00
saravanakumardb1
1f18c53b76
fix(auth): enable sync on login/logout + fix data copy + wire page-view tracking
2026-02-28 02:33:19 -08:00
saravanakumardb1
9d50a196bc
feat(analytics): bridge analytics.ts to platform telemetry client
2026-02-28 02:15:45 -08:00
saravanakumardb1
1713ce058b
feat(web): add platform-service telemetry client
2026-02-28 02:04:08 -08:00
saravanakumardb1
1fc1d6478a
feat(web): add auth flow via platform-service + productId header
2026-02-28 02:01:27 -08:00
saravanakumardb1
375d3a7ec0
feat(web): wire useSync hook into Dashboard with cloud sync status indicator
2026-02-28 01:54:40 -08:00
saravanakumardb1
bf2f7cde50
feat(wear): expand Wear OS with quick timer creation, timer detail, dismiss/snooze actions, navigation
2026-02-28 01:53:28 -08:00
saravanakumardb1
3ac658a89e
docs(roadmap): mark iOS Swift ports, routine models, routine views, and Android RoutineScreen as complete
2026-02-28 01:51:46 -08:00
saravanakumardb1
11e50295ea
feat: fix web build, add repo infra, port iOS engine modules, add routine screens
...
- fix(web): cast window through unknown in platform-sync.ts (TS2352)
- docs: add AGENTS.md, README.md, CLAUDE.md, .windsurfrules, .cursorrules, env.example
- feat(ios): port Recurrence.swift from web/src/lib/recurrence.ts
- feat(ios): port NLParser.swift from web/src/lib/nl-parser.ts
- feat(ios): port ContextMessages.swift from web/src/lib/context-messages.ts
- feat(ios): add CMRoutine model + Routines.swift engine with state machine + templates
- feat(ios): add RoutineListView, RoutineRunnerView, RoutineEditorView
- feat(android): add RoutineScreen.kt with list, runner, templates, step controls
Web: 373 tests passing, build succeeds with --webpack flag
2026-02-28 01:50:35 -08:00
saravanakumardb1
af33a2c86d
feat(sync): add cross-platform sync managers for iOS, Android, and Web
...
- iOS: PlatformSyncManager — URLSession, delta sync, batch upload, offline queue, HMAC auth
- Android: PlatformApiClient + SyncRepository — HttpURLConnection, Room integration, offline queue
- Web: platform-sync.ts + use-sync.ts — fetch client, localStorage queue, React hook with 60s auto-sync
All consume platform-service /timers/*, /routines/*, /households/* endpoints.
Sync protocol: syncVersion optimistic concurrency, delta sync via ?since=, batch upsert for offline flush.
2026-02-28 00:25:35 -08:00