Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
65 lines
8.4 KiB
Markdown
65 lines
8.4 KiB
Markdown
# Scratchpad — Board-level live ticket timer toggle
|
|
|
|
- Plan slug: `ticket-board-live-timer-toggle`
|
|
- Created: `2026-03-29`
|
|
|
|
## What This Is
|
|
|
|
Keep a lightweight, continuously-updated log of discoveries and decisions made while implementing this plan.
|
|
|
|
Prefer short bullets. Append new entries as you learn things, and also *update earlier notes* when a decision changes or an open question is resolved.
|
|
|
|
## Decisions
|
|
|
|
- (2026-03-29) Scope is a board-level boolean for live ticket timer enablement, not a user preference or per-ticket toggle. Rationale: simpler MSP admin mental model and lower-risk v1.
|
|
- (2026-03-29) Disabling the board setting hides only the live timer and tracked intervals. Manual time entry remains available.
|
|
- (2026-03-29) Board change behavior should apply immediately after a successful save in the current ticket details view.
|
|
|
|
## Discoveries / Constraints
|
|
|
|
- (2026-03-29) [`TicketDetails.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketDetails.tsx) owns timer lifecycle, lock replacement, and auto-start gating through `useTicketTimeTracking`.
|
|
- (2026-03-29) Tracked intervals are rendered in [`TicketProperties.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketProperties.tsx), not directly in `TicketDetails.tsx`.
|
|
- (2026-03-29) Boards settings save flows currently pass board fields through `createBoard` and `updateBoard` in [`BoardsSettings.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/components/settings/general/BoardsSettings.tsx:516).
|
|
- (2026-03-29) Shared board typing currently lives in [`packages/types/src/interfaces/board.interface.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/types/src/interfaces/board.interface.ts).
|
|
|
|
## Commands / Runbooks
|
|
|
|
- (2026-03-29) Inspect ticket timer lifecycle: `rg -n "useTicketTimeTracking|renderIntervalManagement|autoStart" packages/tickets packages/ui`
|
|
- (2026-03-29) Inspect board settings save path: `sed -n '500,560p' server/src/components/settings/general/BoardsSettings.tsx`
|
|
- (2026-03-29) Validate plan JSON files: `node -e "JSON.parse(require('fs').readFileSync('docs/plans/2026-03-29-ticket-board-live-timer-toggle/features.json','utf8')); JSON.parse(require('fs').readFileSync('docs/plans/2026-03-29-ticket-board-live-timer-toggle/tests.json','utf8')); console.log('json ok')"`
|
|
|
|
## Links / References
|
|
|
|
- [`BoardsSettings.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/components/settings/general/BoardsSettings.tsx)
|
|
- [`TicketDetails.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketDetails.tsx)
|
|
- [`TicketProperties.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketProperties.tsx)
|
|
- [`board.interface.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/types/src/interfaces/board.interface.ts)
|
|
|
|
## Open Questions
|
|
|
|
- Whether a future v2 should evolve the boolean into richer per-board timer modes.
|
|
|
|
## Implementation Log
|
|
|
|
- (2026-03-29) Completed `F001` via migration [`20260329120000_add_enable_live_ticket_timer_to_boards.cjs`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/migrations/20260329120000_add_enable_live_ticket_timer_to_boards.cjs) to add `boards.enable_live_ticket_timer`, backfill existing rows to `true`, and enforce non-null + default semantics.
|
|
- (2026-03-29) Completed `F002` by extending shared board typings in [`packages/types/src/interfaces/board.interface.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/types/src/interfaces/board.interface.ts) and [`server/src/interfaces/board.interface.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/interfaces/board.interface.ts).
|
|
- (2026-03-29) Completed `F003` by adding `Enable live ticket timer` toggle UI + helper copy in Board Configuration for both create and edit flows in [`BoardsSettings.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/components/settings/general/BoardsSettings.tsx).
|
|
- (2026-03-29) Completed `F004` by persisting `enable_live_ticket_timer` through board create/update payloads in [`BoardsSettings.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/components/settings/general/BoardsSettings.tsx) and [`boardActions.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/actions/board-actions/boardActions.ts).
|
|
- (2026-03-29) Completed `F005` with enabled fallback semantics (`null`/`undefined` => `true`) in board read surfaces via normalization in [`boardActions.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/actions/board-actions/boardActions.ts).
|
|
- (2026-03-29) Completed `F006` by ensuring ticket board metadata includes the new field for both initial and refreshed board state in [`optimizedTicketActions.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/actions/optimizedTicketActions.ts) and board refresh in [`TicketDetails.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketDetails.tsx).
|
|
- (2026-03-29) Completed `F007`/`F008` by deriving board timer policy in [`boardLiveTicketTimer.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/lib/boardLiveTicketTimer.ts), gating auto-start and timer presentation in [`TicketDetails.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketDetails.tsx).
|
|
- (2026-03-29) Completed `F009`/`F010` by hiding tracked intervals and live timer controls when disabled while preserving `Add Time Entry` in [`TicketProperties.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketProperties.tsx).
|
|
- (2026-03-29) Completed `F011` by refreshing board metadata after board changes and enforcing immediate in-view timer shutdown/reset when destination board disables live timing in [`TicketDetails.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/TicketDetails.tsx).
|
|
|
|
## Test Coverage Added
|
|
|
|
- (2026-03-29) Completed `T001` with DB-backed integration coverage in [`boardLiveTicketTimerSetting.integration.test.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/test/integration/boardLiveTicketTimerSetting.integration.test.ts) for default-enabled create semantics and explicit disable/readback behavior.
|
|
- (2026-03-29) Completed `T002` in [`BoardsSettings.copyStatuses.test.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/server/src/components/settings/general/BoardsSettings.copyStatuses.test.tsx) to assert create/edit toggle rendering and save payload inclusion.
|
|
- (2026-03-29) Completed `T003`/`T005` contract coverage in [`TicketDetails.liveTimerPolicy.contract.test.ts`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/__tests__/TicketDetails.liveTimerPolicy.contract.test.ts) for auto-start gating and immediate stop/reset policy wiring.
|
|
- (2026-03-29) Completed `T004`/`T006` UI coverage in [`TicketProperties.liveTimerPolicy.test.tsx`](/Users/roberisaacs/alga-psa.worktrees/feature/time-entry-counter-auto-start-toggle/packages/tickets/src/components/ticket/__tests__/TicketProperties.liveTimerPolicy.test.tsx) for disabled/ enabled rendering behavior.
|
|
|
|
## Verification Commands
|
|
|
|
- (2026-03-29) `cd packages/tickets && npx vitest run --config vitest.config.ts src/components/ticket/__tests__/TicketDetails.liveTimerPolicy.contract.test.ts src/components/ticket/__tests__/TicketProperties.liveTimerPolicy.test.tsx`
|
|
- (2026-03-29) `cd server && npx vitest run src/components/settings/general/BoardsSettings.copyStatuses.test.tsx src/test/integration/boardLiveTicketTimerSetting.integration.test.ts`
|