@elizaos/plugin-personal-assistant 2.0.3-beta.5 → 2.0.3-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/app-block.d.ts +15 -0
- package/dist/actions/app-block.d.ts.map +1 -0
- package/dist/actions/app-block.js +349 -0
- package/dist/actions/app-block.js.map +1 -0
- package/dist/actions/autofill.d.ts +20 -0
- package/dist/actions/autofill.d.ts.map +1 -0
- package/dist/actions/autofill.js +370 -0
- package/dist/actions/autofill.js.map +1 -0
- package/dist/actions/block.d.ts +30 -0
- package/dist/actions/block.d.ts.map +1 -0
- package/dist/actions/block.js +326 -0
- package/dist/actions/block.js.map +1 -0
- package/dist/actions/book-travel.d.ts +10 -0
- package/dist/actions/book-travel.d.ts.map +1 -0
- package/dist/actions/book-travel.js +467 -0
- package/dist/actions/book-travel.js.map +1 -0
- package/dist/actions/brief.d.ts +60 -0
- package/dist/actions/brief.d.ts.map +1 -0
- package/dist/actions/brief.js +485 -0
- package/dist/actions/brief.js.map +1 -0
- package/dist/actions/calendar.d.ts +22 -0
- package/dist/actions/calendar.d.ts.map +1 -0
- package/dist/actions/calendar.js +832 -0
- package/dist/actions/calendar.js.map +1 -0
- package/dist/actions/conflict-detect.d.ts +67 -0
- package/dist/actions/conflict-detect.d.ts.map +1 -0
- package/dist/actions/conflict-detect.js +310 -0
- package/dist/actions/conflict-detect.js.map +1 -0
- package/dist/actions/connector.d.ts +5 -0
- package/dist/actions/connector.d.ts.map +1 -0
- package/dist/actions/connector.js +1354 -0
- package/dist/actions/connector.js.map +1 -0
- package/dist/actions/credentials.d.ts +14 -0
- package/dist/actions/credentials.d.ts.map +1 -0
- package/dist/actions/credentials.js +191 -0
- package/dist/actions/credentials.js.map +1 -0
- package/dist/actions/document.d.ts +36 -0
- package/dist/actions/document.d.ts.map +1 -0
- package/dist/actions/document.js +613 -0
- package/dist/actions/document.js.map +1 -0
- package/dist/actions/entity.d.ts +20 -0
- package/dist/actions/entity.d.ts.map +1 -0
- package/dist/actions/entity.js +785 -0
- package/dist/actions/entity.js.map +1 -0
- package/dist/actions/health.d.ts +4 -0
- package/dist/actions/health.d.ts.map +1 -0
- package/dist/actions/health.js +37 -0
- package/dist/actions/health.js.map +1 -0
- package/dist/actions/inbox.d.ts +12 -0
- package/dist/actions/inbox.d.ts.map +1 -0
- package/dist/actions/inbox.js +13 -0
- package/dist/actions/inbox.js.map +1 -0
- package/dist/actions/lib/calendly-handler.d.ts +3 -0
- package/dist/actions/lib/calendly-handler.d.ts.map +1 -0
- package/dist/actions/lib/calendly-handler.js +506 -0
- package/dist/actions/lib/calendly-handler.js.map +1 -0
- package/dist/actions/lib/extract-goal-plan.d.ts +69 -0
- package/dist/actions/lib/extract-goal-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-goal-plan.js +488 -0
- package/dist/actions/lib/extract-goal-plan.js.map +1 -0
- package/dist/actions/lib/extract-life-operation.d.ts +18 -0
- package/dist/actions/lib/extract-life-operation.d.ts.map +1 -0
- package/dist/actions/lib/extract-life-operation.js +318 -0
- package/dist/actions/lib/extract-life-operation.js.map +1 -0
- package/dist/actions/lib/extract-task-plan.d.ts +78 -0
- package/dist/actions/lib/extract-task-plan.d.ts.map +1 -0
- package/dist/actions/lib/extract-task-plan.js +355 -0
- package/dist/actions/lib/extract-task-plan.js.map +1 -0
- package/dist/actions/lib/extract-update-fields.d.ts +27 -0
- package/dist/actions/lib/extract-update-fields.d.ts.map +1 -0
- package/dist/actions/lib/extract-update-fields.js +172 -0
- package/dist/actions/lib/extract-update-fields.js.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts +68 -0
- package/dist/actions/lib/lifeops-deferred-draft.d.ts.map +1 -0
- package/dist/actions/lib/lifeops-deferred-draft.js +315 -0
- package/dist/actions/lib/lifeops-deferred-draft.js.map +1 -0
- package/dist/actions/lib/messaging-helpers.d.ts +20 -0
- package/dist/actions/lib/messaging-helpers.d.ts.map +1 -0
- package/dist/actions/lib/messaging-helpers.js +103 -0
- package/dist/actions/lib/messaging-helpers.js.map +1 -0
- package/dist/actions/lib/owner-policy-writes.d.ts +49 -0
- package/dist/actions/lib/owner-policy-writes.d.ts.map +1 -0
- package/dist/actions/lib/owner-policy-writes.js +157 -0
- package/dist/actions/lib/owner-policy-writes.js.map +1 -0
- package/dist/actions/lib/prompt-format.d.ts +3 -0
- package/dist/actions/lib/prompt-format.d.ts.map +1 -0
- package/dist/actions/lib/prompt-format.js +42 -0
- package/dist/actions/lib/prompt-format.js.map +1 -0
- package/dist/actions/lib/scheduling-handler.d.ts +93 -0
- package/dist/actions/lib/scheduling-handler.d.ts.map +1 -0
- package/dist/actions/lib/scheduling-handler.js +868 -0
- package/dist/actions/lib/scheduling-handler.js.map +1 -0
- package/dist/actions/life.d.ts +13 -0
- package/dist/actions/life.d.ts.map +1 -0
- package/dist/actions/life.js +2524 -0
- package/dist/actions/life.js.map +1 -0
- package/dist/actions/money.d.ts +24 -0
- package/dist/actions/money.d.ts.map +1 -0
- package/dist/actions/money.js +41 -0
- package/dist/actions/money.js.map +1 -0
- package/dist/actions/owner-surfaces.d.ts +11 -0
- package/dist/actions/owner-surfaces.d.ts.map +1 -0
- package/dist/actions/owner-surfaces.js +493 -0
- package/dist/actions/owner-surfaces.js.map +1 -0
- package/dist/actions/password-manager.d.ts +10 -0
- package/dist/actions/password-manager.d.ts.map +1 -0
- package/dist/actions/password-manager.js +195 -0
- package/dist/actions/password-manager.js.map +1 -0
- package/dist/actions/payments.d.ts +10 -0
- package/dist/actions/payments.d.ts.map +1 -0
- package/dist/actions/payments.js +5 -0
- package/dist/actions/payments.js.map +1 -0
- package/dist/actions/prioritize.d.ts +49 -0
- package/dist/actions/prioritize.d.ts.map +1 -0
- package/dist/actions/prioritize.js +313 -0
- package/dist/actions/prioritize.js.map +1 -0
- package/dist/actions/remote-desktop.d.ts +13 -0
- package/dist/actions/remote-desktop.d.ts.map +1 -0
- package/dist/actions/remote-desktop.js +11 -0
- package/dist/actions/remote-desktop.js.map +1 -0
- package/dist/actions/resolve-request.d.ts +12 -0
- package/dist/actions/resolve-request.d.ts.map +1 -0
- package/dist/actions/resolve-request.js +427 -0
- package/dist/actions/resolve-request.js.map +1 -0
- package/dist/actions/schedule.d.ts +10 -0
- package/dist/actions/schedule.d.ts.map +1 -0
- package/dist/actions/schedule.js +113 -0
- package/dist/actions/schedule.js.map +1 -0
- package/dist/actions/scheduled-task.d.ts +32 -0
- package/dist/actions/scheduled-task.d.ts.map +1 -0
- package/dist/actions/scheduled-task.js +661 -0
- package/dist/actions/scheduled-task.js.map +1 -0
- package/dist/actions/screen-time.d.ts +4 -0
- package/dist/actions/screen-time.d.ts.map +1 -0
- package/dist/actions/screen-time.js +47 -0
- package/dist/actions/screen-time.js.map +1 -0
- package/dist/actions/subscriptions.d.ts +8 -0
- package/dist/actions/subscriptions.d.ts.map +1 -0
- package/dist/actions/subscriptions.js +327 -0
- package/dist/actions/subscriptions.js.map +1 -0
- package/dist/actions/voice-call.d.ts +16 -0
- package/dist/actions/voice-call.d.ts.map +1 -0
- package/dist/actions/voice-call.js +756 -0
- package/dist/actions/voice-call.js.map +1 -0
- package/dist/actions/website-block.d.ts +15 -0
- package/dist/actions/website-block.d.ts.map +1 -0
- package/dist/actions/website-block.js +719 -0
- package/dist/actions/website-block.js.map +1 -0
- package/dist/actions/work-thread.d.ts +5 -0
- package/dist/actions/work-thread.d.ts.map +1 -0
- package/dist/actions/work-thread.js +556 -0
- package/dist/actions/work-thread.js.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts +28 -0
- package/dist/activity-profile/activity-tracker-repo.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-repo.js +61 -0
- package/dist/activity-profile/activity-tracker-repo.js.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts +52 -0
- package/dist/activity-profile/activity-tracker-reporting.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-reporting.js +119 -0
- package/dist/activity-profile/activity-tracker-reporting.js.map +1 -0
- package/dist/activity-profile/activity-tracker-service.d.ts +36 -0
- package/dist/activity-profile/activity-tracker-service.d.ts.map +1 -0
- package/dist/activity-profile/activity-tracker-service.js +187 -0
- package/dist/activity-profile/activity-tracker-service.js.map +1 -0
- package/dist/activity-profile/analyzer.d.ts +23 -0
- package/dist/activity-profile/analyzer.d.ts.map +1 -0
- package/dist/activity-profile/analyzer.js +485 -0
- package/dist/activity-profile/analyzer.js.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts +14 -0
- package/dist/activity-profile/presence-signal-bridge-service.d.ts.map +1 -0
- package/dist/activity-profile/presence-signal-bridge-service.js +159 -0
- package/dist/activity-profile/presence-signal-bridge-service.js.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts +3 -0
- package/dist/activity-profile/proactive-inbox-digest.d.ts.map +1 -0
- package/dist/activity-profile/proactive-inbox-digest.js +21 -0
- package/dist/activity-profile/proactive-inbox-digest.js.map +1 -0
- package/dist/activity-profile/proactive-planner.d.ts +150 -0
- package/dist/activity-profile/proactive-planner.d.ts.map +1 -0
- package/dist/activity-profile/proactive-planner.js +529 -0
- package/dist/activity-profile/proactive-planner.js.map +1 -0
- package/dist/activity-profile/proactive-worker.d.ts +33 -0
- package/dist/activity-profile/proactive-worker.d.ts.map +1 -0
- package/dist/activity-profile/proactive-worker.js +779 -0
- package/dist/activity-profile/proactive-worker.js.map +1 -0
- package/dist/activity-profile/profile-metadata.d.ts +10 -0
- package/dist/activity-profile/profile-metadata.d.ts.map +1 -0
- package/dist/activity-profile/profile-metadata.js +16 -0
- package/dist/activity-profile/profile-metadata.js.map +1 -0
- package/dist/activity-profile/redactor.d.ts +15 -0
- package/dist/activity-profile/redactor.d.ts.map +1 -0
- package/dist/activity-profile/redactor.js +22 -0
- package/dist/activity-profile/redactor.js.map +1 -0
- package/dist/activity-profile/service.d.ts +11 -0
- package/dist/activity-profile/service.d.ts.map +1 -0
- package/dist/activity-profile/service.js +272 -0
- package/dist/activity-profile/service.js.map +1 -0
- package/dist/activity-profile/types.d.ts +97 -0
- package/dist/activity-profile/types.d.ts.map +1 -0
- package/dist/activity-profile/types.js +36 -0
- package/dist/activity-profile/types.js.map +1 -0
- package/dist/agent-lifeops.d.ts +2 -0
- package/dist/agent-lifeops.d.ts.map +1 -0
- package/dist/agent-lifeops.js +2 -0
- package/dist/agent-lifeops.js.map +1 -0
- package/dist/api/client-lifeops.d.ts +319 -0
- package/dist/api/client-lifeops.d.ts.map +1 -0
- package/dist/api/client-lifeops.js +794 -0
- package/dist/api/client-lifeops.js.map +1 -0
- package/dist/automation-node-contributor.d.ts +2 -0
- package/dist/automation-node-contributor.d.ts.map +1 -0
- package/dist/automation-node-contributor.js +184 -0
- package/dist/automation-node-contributor.js.map +1 -0
- package/dist/client.d.ts +16 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +18 -0
- package/dist/client.js.map +1 -0
- package/dist/components/AppBlockerSettingsCard.d.ts +3 -0
- package/dist/components/AppBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/AppBlockerSettingsCard.js +538 -0
- package/dist/components/AppBlockerSettingsCard.js.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts +3 -0
- package/dist/components/WebsiteBlockerSettingsCard.d.ts.map +1 -0
- package/dist/components/WebsiteBlockerSettingsCard.js +148 -0
- package/dist/components/WebsiteBlockerSettingsCard.js.map +1 -0
- package/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/lifeops.d.ts +2 -0
- package/dist/contracts/lifeops.d.ts.map +1 -0
- package/dist/contracts/lifeops.js +2 -0
- package/dist/contracts/lifeops.js.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts +17 -0
- package/dist/default-packs/autofill-whitelist-pack.d.ts.map +1 -0
- package/dist/default-packs/autofill-whitelist-pack.js +56 -0
- package/dist/default-packs/autofill-whitelist-pack.js.map +1 -0
- package/dist/default-packs/consolidation-policies.d.ts +14 -0
- package/dist/default-packs/consolidation-policies.d.ts.map +1 -0
- package/dist/default-packs/consolidation-policies.js +17 -0
- package/dist/default-packs/consolidation-policies.js.map +1 -0
- package/dist/default-packs/contract-types.d.ts +200 -0
- package/dist/default-packs/contract-types.d.ts.map +1 -0
- package/dist/default-packs/contract-types.js +1 -0
- package/dist/default-packs/contract-types.js.map +1 -0
- package/dist/default-packs/daily-rhythm.d.ts +28 -0
- package/dist/default-packs/daily-rhythm.d.ts.map +1 -0
- package/dist/default-packs/daily-rhythm.js +136 -0
- package/dist/default-packs/daily-rhythm.js.map +1 -0
- package/dist/default-packs/escalation-ladders.d.ts +18 -0
- package/dist/default-packs/escalation-ladders.d.ts.map +1 -0
- package/dist/default-packs/escalation-ladders.js +17 -0
- package/dist/default-packs/escalation-ladders.js.map +1 -0
- package/dist/default-packs/executive-assistant.d.ts +50 -0
- package/dist/default-packs/executive-assistant.d.ts.map +1 -0
- package/dist/default-packs/executive-assistant.js +745 -0
- package/dist/default-packs/executive-assistant.js.map +1 -0
- package/dist/default-packs/followup-starter.d.ts +49 -0
- package/dist/default-packs/followup-starter.d.ts.map +1 -0
- package/dist/default-packs/followup-starter.js +104 -0
- package/dist/default-packs/followup-starter.js.map +1 -0
- package/dist/default-packs/habit-starters.d.ts +37 -0
- package/dist/default-packs/habit-starters.d.ts.map +1 -0
- package/dist/default-packs/habit-starters.js +255 -0
- package/dist/default-packs/habit-starters.js.map +1 -0
- package/dist/default-packs/inbox-triage-starter.d.ts +23 -0
- package/dist/default-packs/inbox-triage-starter.d.ts.map +1 -0
- package/dist/default-packs/inbox-triage-starter.js +61 -0
- package/dist/default-packs/inbox-triage-starter.js.map +1 -0
- package/dist/default-packs/index.d.ts +54 -0
- package/dist/default-packs/index.d.ts.map +1 -0
- package/dist/default-packs/index.js +150 -0
- package/dist/default-packs/index.js.map +1 -0
- package/dist/default-packs/lint.d.ts +62 -0
- package/dist/default-packs/lint.d.ts.map +1 -0
- package/dist/default-packs/lint.js +161 -0
- package/dist/default-packs/lint.js.map +1 -0
- package/dist/default-packs/morning-brief.d.ts +44 -0
- package/dist/default-packs/morning-brief.d.ts.map +1 -0
- package/dist/default-packs/morning-brief.js +69 -0
- package/dist/default-packs/morning-brief.js.map +1 -0
- package/dist/default-packs/quiet-user-watcher.d.ts +49 -0
- package/dist/default-packs/quiet-user-watcher.d.ts.map +1 -0
- package/dist/default-packs/quiet-user-watcher.js +92 -0
- package/dist/default-packs/quiet-user-watcher.js.map +1 -0
- package/dist/default-packs/registry-types.d.ts +51 -0
- package/dist/default-packs/registry-types.d.ts.map +1 -0
- package/dist/default-packs/registry-types.js +1 -0
- package/dist/default-packs/registry-types.js.map +1 -0
- package/dist/default-packs/task-definitions.d.ts +88 -0
- package/dist/default-packs/task-definitions.d.ts.map +1 -0
- package/dist/default-packs/task-definitions.js +87 -0
- package/dist/default-packs/task-definitions.js.map +1 -0
- package/dist/events/index.d.ts +34 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +30 -0
- package/dist/events/index.js.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts +3 -0
- package/dist/followup/actions/listOverdueFollowups.d.ts.map +1 -0
- package/dist/followup/actions/listOverdueFollowups.js +90 -0
- package/dist/followup/actions/listOverdueFollowups.js.map +1 -0
- package/dist/followup/actions/markFollowupDone.d.ts +3 -0
- package/dist/followup/actions/markFollowupDone.d.ts.map +1 -0
- package/dist/followup/actions/markFollowupDone.js +171 -0
- package/dist/followup/actions/markFollowupDone.js.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts +3 -0
- package/dist/followup/actions/setFollowupThreshold.d.ts.map +1 -0
- package/dist/followup/actions/setFollowupThreshold.js +171 -0
- package/dist/followup/actions/setFollowupThreshold.js.map +1 -0
- package/dist/followup/followup-tracker.d.ts +83 -0
- package/dist/followup/followup-tracker.d.ts.map +1 -0
- package/dist/followup/followup-tracker.js +311 -0
- package/dist/followup/followup-tracker.js.map +1 -0
- package/dist/followup/index.d.ts +5 -0
- package/dist/followup/index.d.ts.map +1 -0
- package/dist/followup/index.js +39 -0
- package/dist/followup/index.js.map +1 -0
- package/dist/hooks/connector-error.d.ts +2 -0
- package/dist/hooks/connector-error.d.ts.map +1 -0
- package/dist/hooks/connector-error.js +13 -0
- package/dist/hooks/connector-error.js.map +1 -0
- package/dist/hooks/useDiscordConnector.d.ts +11 -0
- package/dist/hooks/useDiscordConnector.d.ts.map +1 -0
- package/dist/hooks/useDiscordConnector.js +95 -0
- package/dist/hooks/useDiscordConnector.js.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts +23 -0
- package/dist/hooks/useGoogleLifeOpsConnector.d.ts.map +1 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js +630 -0
- package/dist/hooks/useGoogleLifeOpsConnector.js.map +1 -0
- package/dist/hooks/useIMessageConnector.d.ts +10 -0
- package/dist/hooks/useIMessageConnector.d.ts.map +1 -0
- package/dist/hooks/useIMessageConnector.js +57 -0
- package/dist/hooks/useIMessageConnector.js.map +1 -0
- package/dist/hooks/useInbox.d.ts +36 -0
- package/dist/hooks/useInbox.d.ts.map +1 -0
- package/dist/hooks/useInbox.js +96 -0
- package/dist/hooks/useInbox.js.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts +2 -0
- package/dist/hooks/useLifeOpsActivitySignals.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsActivitySignals.js +358 -0
- package/dist/hooks/useLifeOpsActivitySignals.js.map +1 -0
- package/dist/hooks/useLifeOpsAppState.d.ts +9 -0
- package/dist/hooks/useLifeOpsAppState.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsAppState.js +79 -0
- package/dist/hooks/useLifeOpsAppState.js.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts +8 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js +60 -0
- package/dist/hooks/useLifeOpsCapabilitiesStatus.js.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts +11 -0
- package/dist/hooks/useLifeOpsXConnector.d.ts.map +1 -0
- package/dist/hooks/useLifeOpsXConnector.js +92 -0
- package/dist/hooks/useLifeOpsXConnector.js.map +1 -0
- package/dist/hooks/useSignalConnector.d.ts +14 -0
- package/dist/hooks/useSignalConnector.d.ts.map +1 -0
- package/dist/hooks/useSignalConnector.js +89 -0
- package/dist/hooks/useSignalConnector.js.map +1 -0
- package/dist/hooks/useTelegramConnector.d.ts +14 -0
- package/dist/hooks/useTelegramConnector.d.ts.map +1 -0
- package/dist/hooks/useTelegramConnector.js +97 -0
- package/dist/hooks/useTelegramConnector.js.map +1 -0
- package/dist/hooks/useWhatsAppConnector.d.ts +8 -0
- package/dist/hooks/useWhatsAppConnector.d.ts.map +1 -0
- package/dist/hooks/useWhatsAppConnector.js +62 -0
- package/dist/hooks/useWhatsAppConnector.js.map +1 -0
- package/dist/inbox/message-fetcher.d.ts +11 -0
- package/dist/inbox/message-fetcher.d.ts.map +1 -0
- package/dist/inbox/message-fetcher.js +13 -0
- package/dist/inbox/message-fetcher.js.map +1 -0
- package/dist/inbox/repository.d.ts +11 -0
- package/dist/inbox/repository.d.ts.map +1 -0
- package/dist/inbox/repository.js +5 -0
- package/dist/inbox/repository.js.map +1 -0
- package/dist/inbox/types.d.ts +10 -0
- package/dist/inbox/types.d.ts.map +1 -0
- package/dist/inbox/types.js +2 -0
- package/dist/inbox/types.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +188 -0
- package/dist/index.js.map +1 -0
- package/dist/lifeops/access.d.ts +29 -0
- package/dist/lifeops/access.d.ts.map +1 -0
- package/dist/lifeops/access.js +56 -0
- package/dist/lifeops/access.js.map +1 -0
- package/dist/lifeops/app-state.d.ts +22 -0
- package/dist/lifeops/app-state.d.ts.map +1 -0
- package/dist/lifeops/app-state.js +67 -0
- package/dist/lifeops/app-state.js.map +1 -0
- package/dist/lifeops/apple-reminders.d.ts +67 -0
- package/dist/lifeops/apple-reminders.d.ts.map +1 -0
- package/dist/lifeops/apple-reminders.js +396 -0
- package/dist/lifeops/apple-reminders.js.map +1 -0
- package/dist/lifeops/approval-queue.d.ts +38 -0
- package/dist/lifeops/approval-queue.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.js +575 -0
- package/dist/lifeops/approval-queue.js.map +1 -0
- package/dist/lifeops/approval-queue.types.d.ts +172 -0
- package/dist/lifeops/approval-queue.types.d.ts.map +1 -0
- package/dist/lifeops/approval-queue.types.js +27 -0
- package/dist/lifeops/approval-queue.types.js.map +1 -0
- package/dist/lifeops/autofill-whitelist.d.ts +20 -0
- package/dist/lifeops/autofill-whitelist.d.ts.map +1 -0
- package/dist/lifeops/autofill-whitelist.js +59 -0
- package/dist/lifeops/autofill-whitelist.js.map +1 -0
- package/dist/lifeops/background-planner-dispatch.d.ts +60 -0
- package/dist/lifeops/background-planner-dispatch.d.ts.map +1 -0
- package/dist/lifeops/background-planner-dispatch.js +113 -0
- package/dist/lifeops/background-planner-dispatch.js.map +1 -0
- package/dist/lifeops/background-planner.d.ts +140 -0
- package/dist/lifeops/background-planner.d.ts.map +1 -0
- package/dist/lifeops/background-planner.js +359 -0
- package/dist/lifeops/background-planner.js.map +1 -0
- package/dist/lifeops/bill-extraction.d.ts +46 -0
- package/dist/lifeops/bill-extraction.d.ts.map +1 -0
- package/dist/lifeops/bill-extraction.js +325 -0
- package/dist/lifeops/bill-extraction.js.map +1 -0
- package/dist/lifeops/browser-constants.d.ts +4 -0
- package/dist/lifeops/browser-constants.d.ts.map +1 -0
- package/dist/lifeops/browser-constants.js +27 -0
- package/dist/lifeops/browser-constants.js.map +1 -0
- package/dist/lifeops/browser-extension-store.d.ts +61 -0
- package/dist/lifeops/browser-extension-store.d.ts.map +1 -0
- package/dist/lifeops/browser-extension-store.js +176 -0
- package/dist/lifeops/browser-extension-store.js.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts +57 -0
- package/dist/lifeops/browser-session-lifecycle.d.ts.map +1 -0
- package/dist/lifeops/browser-session-lifecycle.js +308 -0
- package/dist/lifeops/browser-session-lifecycle.js.map +1 -0
- package/dist/lifeops/bulk-review.d.ts +333 -0
- package/dist/lifeops/bulk-review.d.ts.map +1 -0
- package/dist/lifeops/bulk-review.js +1120 -0
- package/dist/lifeops/bulk-review.js.map +1 -0
- package/dist/lifeops/calendar-gate.d.ts +20 -0
- package/dist/lifeops/calendar-gate.d.ts.map +1 -0
- package/dist/lifeops/calendar-gate.js +30 -0
- package/dist/lifeops/calendar-gate.js.map +1 -0
- package/dist/lifeops/channels/contract.d.ts +47 -0
- package/dist/lifeops/channels/contract.d.ts.map +1 -0
- package/dist/lifeops/channels/contract.js +1 -0
- package/dist/lifeops/channels/contract.js.map +1 -0
- package/dist/lifeops/channels/default-pack.d.ts +26 -0
- package/dist/lifeops/channels/default-pack.d.ts.map +1 -0
- package/dist/lifeops/channels/default-pack.js +243 -0
- package/dist/lifeops/channels/default-pack.js.map +1 -0
- package/dist/lifeops/channels/index.d.ts +5 -0
- package/dist/lifeops/channels/index.d.ts.map +1 -0
- package/dist/lifeops/channels/index.js +23 -0
- package/dist/lifeops/channels/index.js.map +1 -0
- package/dist/lifeops/channels/priority-posture.d.ts +36 -0
- package/dist/lifeops/channels/priority-posture.d.ts.map +1 -0
- package/dist/lifeops/channels/priority-posture.js +27 -0
- package/dist/lifeops/channels/priority-posture.js.map +1 -0
- package/dist/lifeops/channels/registry.d.ts +7 -0
- package/dist/lifeops/channels/registry.d.ts.map +1 -0
- package/dist/lifeops/channels/registry.js +49 -0
- package/dist/lifeops/channels/registry.js.map +1 -0
- package/dist/lifeops/checkin/checkin-service.d.ts +66 -0
- package/dist/lifeops/checkin/checkin-service.d.ts.map +1 -0
- package/dist/lifeops/checkin/checkin-service.js +1084 -0
- package/dist/lifeops/checkin/checkin-service.js.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts +17 -0
- package/dist/lifeops/checkin/schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/checkin/schedule-resolver.js +26 -0
- package/dist/lifeops/checkin/schedule-resolver.js.map +1 -0
- package/dist/lifeops/checkin/types.d.ts +106 -0
- package/dist/lifeops/checkin/types.d.ts.map +1 -0
- package/dist/lifeops/checkin/types.js +1 -0
- package/dist/lifeops/checkin/types.js.map +1 -0
- package/dist/lifeops/connectors/_helpers.d.ts +51 -0
- package/dist/lifeops/connectors/_helpers.d.ts.map +1 -0
- package/dist/lifeops/connectors/_helpers.js +104 -0
- package/dist/lifeops/connectors/_helpers.js.map +1 -0
- package/dist/lifeops/connectors/calendly.d.ts +11 -0
- package/dist/lifeops/connectors/calendly.d.ts.map +1 -0
- package/dist/lifeops/connectors/calendly.js +61 -0
- package/dist/lifeops/connectors/calendly.js.map +1 -0
- package/dist/lifeops/connectors/contract.d.ts +88 -0
- package/dist/lifeops/connectors/contract.d.ts.map +1 -0
- package/dist/lifeops/connectors/contract.js +1 -0
- package/dist/lifeops/connectors/contract.js.map +1 -0
- package/dist/lifeops/connectors/default-pack.d.ts +35 -0
- package/dist/lifeops/connectors/default-pack.d.ts.map +1 -0
- package/dist/lifeops/connectors/default-pack.js +37 -0
- package/dist/lifeops/connectors/default-pack.js.map +1 -0
- package/dist/lifeops/connectors/discord.d.ts +8 -0
- package/dist/lifeops/connectors/discord.d.ts.map +1 -0
- package/dist/lifeops/connectors/discord.js +53 -0
- package/dist/lifeops/connectors/discord.js.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts +75 -0
- package/dist/lifeops/connectors/dispatch-policy.d.ts.map +1 -0
- package/dist/lifeops/connectors/dispatch-policy.js +35 -0
- package/dist/lifeops/connectors/dispatch-policy.js.map +1 -0
- package/dist/lifeops/connectors/duffel.d.ts +11 -0
- package/dist/lifeops/connectors/duffel.d.ts.map +1 -0
- package/dist/lifeops/connectors/duffel.js +74 -0
- package/dist/lifeops/connectors/duffel.js.map +1 -0
- package/dist/lifeops/connectors/google.d.ts +27 -0
- package/dist/lifeops/connectors/google.d.ts.map +1 -0
- package/dist/lifeops/connectors/google.js +80 -0
- package/dist/lifeops/connectors/google.js.map +1 -0
- package/dist/lifeops/connectors/imessage.d.ts +11 -0
- package/dist/lifeops/connectors/imessage.d.ts.map +1 -0
- package/dist/lifeops/connectors/imessage.js +55 -0
- package/dist/lifeops/connectors/imessage.js.map +1 -0
- package/dist/lifeops/connectors/index.d.ts +5 -0
- package/dist/lifeops/connectors/index.d.ts.map +1 -0
- package/dist/lifeops/connectors/index.js +23 -0
- package/dist/lifeops/connectors/index.js.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts +54 -0
- package/dist/lifeops/connectors/mockoon-redirect.d.ts.map +1 -0
- package/dist/lifeops/connectors/mockoon-redirect.js +71 -0
- package/dist/lifeops/connectors/mockoon-redirect.js.map +1 -0
- package/dist/lifeops/connectors/registry.d.ts +7 -0
- package/dist/lifeops/connectors/registry.d.ts.map +1 -0
- package/dist/lifeops/connectors/registry.js +55 -0
- package/dist/lifeops/connectors/registry.js.map +1 -0
- package/dist/lifeops/connectors/signal.d.ts +8 -0
- package/dist/lifeops/connectors/signal.d.ts.map +1 -0
- package/dist/lifeops/connectors/signal.js +60 -0
- package/dist/lifeops/connectors/signal.js.map +1 -0
- package/dist/lifeops/connectors/telegram.d.ts +12 -0
- package/dist/lifeops/connectors/telegram.d.ts.map +1 -0
- package/dist/lifeops/connectors/telegram.js +65 -0
- package/dist/lifeops/connectors/telegram.js.map +1 -0
- package/dist/lifeops/connectors/twilio.d.ts +15 -0
- package/dist/lifeops/connectors/twilio.d.ts.map +1 -0
- package/dist/lifeops/connectors/twilio.js +126 -0
- package/dist/lifeops/connectors/twilio.js.map +1 -0
- package/dist/lifeops/connectors/whatsapp.d.ts +10 -0
- package/dist/lifeops/connectors/whatsapp.d.ts.map +1 -0
- package/dist/lifeops/connectors/whatsapp.js +56 -0
- package/dist/lifeops/connectors/whatsapp.js.map +1 -0
- package/dist/lifeops/connectors/x.d.ts +8 -0
- package/dist/lifeops/connectors/x.d.ts.map +1 -0
- package/dist/lifeops/connectors/x.js +62 -0
- package/dist/lifeops/connectors/x.js.map +1 -0
- package/dist/lifeops/contact-route-policy.d.ts +27 -0
- package/dist/lifeops/contact-route-policy.d.ts.map +1 -0
- package/dist/lifeops/contact-route-policy.js +153 -0
- package/dist/lifeops/contact-route-policy.js.map +1 -0
- package/dist/lifeops/continuity-probe.d.ts +49 -0
- package/dist/lifeops/continuity-probe.d.ts.map +1 -0
- package/dist/lifeops/continuity-probe.js +161 -0
- package/dist/lifeops/continuity-probe.js.map +1 -0
- package/dist/lifeops/cross-channel-search.d.ts +108 -0
- package/dist/lifeops/cross-channel-search.d.ts.map +1 -0
- package/dist/lifeops/cross-channel-search.js +888 -0
- package/dist/lifeops/cross-channel-search.js.map +1 -0
- package/dist/lifeops/defaults.d.ts +30 -0
- package/dist/lifeops/defaults.d.ts.map +1 -0
- package/dist/lifeops/defaults.js +206 -0
- package/dist/lifeops/defaults.js.map +1 -0
- package/dist/lifeops/device-bus-service.d.ts +16 -0
- package/dist/lifeops/device-bus-service.d.ts.map +1 -0
- package/dist/lifeops/device-bus-service.js +20 -0
- package/dist/lifeops/device-bus-service.js.map +1 -0
- package/dist/lifeops/device-identity.d.ts +31 -0
- package/dist/lifeops/device-identity.d.ts.map +1 -0
- package/dist/lifeops/device-identity.js +94 -0
- package/dist/lifeops/device-identity.js.map +1 -0
- package/dist/lifeops/document-review.d.ts +264 -0
- package/dist/lifeops/document-review.d.ts.map +1 -0
- package/dist/lifeops/document-review.js +925 -0
- package/dist/lifeops/document-review.js.map +1 -0
- package/dist/lifeops/email-classifier.d.ts +9 -0
- package/dist/lifeops/email-classifier.d.ts.map +1 -0
- package/dist/lifeops/email-classifier.js +15 -0
- package/dist/lifeops/email-classifier.js.map +1 -0
- package/dist/lifeops/email-curation.d.ts +13 -0
- package/dist/lifeops/email-curation.d.ts.map +1 -0
- package/dist/lifeops/email-curation.js +2 -0
- package/dist/lifeops/email-curation.js.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts +7 -0
- package/dist/lifeops/email-unsubscribe-types.d.ts.map +1 -0
- package/dist/lifeops/email-unsubscribe-types.js +1 -0
- package/dist/lifeops/email-unsubscribe-types.js.map +1 -0
- package/dist/lifeops/enforcement-windows.d.ts +34 -0
- package/dist/lifeops/enforcement-windows.d.ts.map +1 -0
- package/dist/lifeops/enforcement-windows.js +80 -0
- package/dist/lifeops/enforcement-windows.js.map +1 -0
- package/dist/lifeops/engine.d.ts +8 -0
- package/dist/lifeops/engine.d.ts.map +1 -0
- package/dist/lifeops/engine.js +540 -0
- package/dist/lifeops/engine.js.map +1 -0
- package/dist/lifeops/entities/index.d.ts +4 -0
- package/dist/lifeops/entities/index.d.ts.map +1 -0
- package/dist/lifeops/entities/index.js +29 -0
- package/dist/lifeops/entities/index.js.map +1 -0
- package/dist/lifeops/entities/merge.d.ts +9 -0
- package/dist/lifeops/entities/merge.d.ts.map +1 -0
- package/dist/lifeops/entities/merge.js +17 -0
- package/dist/lifeops/entities/merge.js.map +1 -0
- package/dist/lifeops/entities/store.d.ts +13 -0
- package/dist/lifeops/entities/store.d.ts.map +1 -0
- package/dist/lifeops/entities/store.js +7 -0
- package/dist/lifeops/entities/store.js.map +1 -0
- package/dist/lifeops/entities/types.d.ts +9 -0
- package/dist/lifeops/entities/types.d.ts.map +1 -0
- package/dist/lifeops/entities/types.js +13 -0
- package/dist/lifeops/entities/types.js.map +1 -0
- package/dist/lifeops/entities/voice-attribution.d.ts +70 -0
- package/dist/lifeops/entities/voice-attribution.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-attribution.js +121 -0
- package/dist/lifeops/entities/voice-attribution.js.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts +32 -0
- package/dist/lifeops/entities/voice-observer-bridge.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer-bridge.js +68 -0
- package/dist/lifeops/entities/voice-observer-bridge.js.map +1 -0
- package/dist/lifeops/entities/voice-observer.d.ts +72 -0
- package/dist/lifeops/entities/voice-observer.d.ts.map +1 -0
- package/dist/lifeops/entities/voice-observer.js +97 -0
- package/dist/lifeops/entities/voice-observer.js.map +1 -0
- package/dist/lifeops/escalation-ladders.d.ts +28 -0
- package/dist/lifeops/escalation-ladders.d.ts.map +1 -0
- package/dist/lifeops/escalation-ladders.js +17 -0
- package/dist/lifeops/escalation-ladders.js.map +1 -0
- package/dist/lifeops/fda-probe.d.ts +23 -0
- package/dist/lifeops/fda-probe.d.ts.map +1 -0
- package/dist/lifeops/fda-probe.js +59 -0
- package/dist/lifeops/fda-probe.js.map +1 -0
- package/dist/lifeops/feature-flags.d.ts +24 -0
- package/dist/lifeops/feature-flags.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.js +261 -0
- package/dist/lifeops/feature-flags.js.map +1 -0
- package/dist/lifeops/feature-flags.types.d.ts +156 -0
- package/dist/lifeops/feature-flags.types.d.ts.map +1 -0
- package/dist/lifeops/feature-flags.types.js +129 -0
- package/dist/lifeops/feature-flags.types.js.map +1 -0
- package/dist/lifeops/first-run/defaults.d.ts +57 -0
- package/dist/lifeops/first-run/defaults.d.ts.map +1 -0
- package/dist/lifeops/first-run/defaults.js +159 -0
- package/dist/lifeops/first-run/defaults.js.map +1 -0
- package/dist/lifeops/first-run/questions.d.ts +74 -0
- package/dist/lifeops/first-run/questions.d.ts.map +1 -0
- package/dist/lifeops/first-run/questions.js +184 -0
- package/dist/lifeops/first-run/questions.js.map +1 -0
- package/dist/lifeops/first-run/replay.d.ts +41 -0
- package/dist/lifeops/first-run/replay.d.ts.map +1 -0
- package/dist/lifeops/first-run/replay.js +34 -0
- package/dist/lifeops/first-run/replay.js.map +1 -0
- package/dist/lifeops/first-run/service.d.ts +147 -0
- package/dist/lifeops/first-run/service.d.ts.map +1 -0
- package/dist/lifeops/first-run/service.js +455 -0
- package/dist/lifeops/first-run/service.js.map +1 -0
- package/dist/lifeops/first-run/state.d.ts +36 -0
- package/dist/lifeops/first-run/state.d.ts.map +1 -0
- package/dist/lifeops/first-run/state.js +128 -0
- package/dist/lifeops/first-run/state.js.map +1 -0
- package/dist/lifeops/global-pause/store.d.ts +22 -0
- package/dist/lifeops/global-pause/store.d.ts.map +1 -0
- package/dist/lifeops/global-pause/store.js +18 -0
- package/dist/lifeops/global-pause/store.js.map +1 -0
- package/dist/lifeops/goal-grounding.d.ts +9 -0
- package/dist/lifeops/goal-grounding.d.ts.map +1 -0
- package/dist/lifeops/goal-grounding.js +19 -0
- package/dist/lifeops/goal-grounding.js.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts +8 -0
- package/dist/lifeops/goal-semantic-evaluator.d.ts.map +1 -0
- package/dist/lifeops/goal-semantic-evaluator.js +7 -0
- package/dist/lifeops/goal-semantic-evaluator.js.map +1 -0
- package/dist/lifeops/google/format-helpers.d.ts +63 -0
- package/dist/lifeops/google/format-helpers.d.ts.map +1 -0
- package/dist/lifeops/google/format-helpers.js +597 -0
- package/dist/lifeops/google/format-helpers.js.map +1 -0
- package/dist/lifeops/google-plugin-delegates.d.ts +59 -0
- package/dist/lifeops/google-plugin-delegates.d.ts.map +1 -0
- package/dist/lifeops/google-plugin-delegates.js +408 -0
- package/dist/lifeops/google-plugin-delegates.js.map +1 -0
- package/dist/lifeops/google-scopes.d.ts +15 -0
- package/dist/lifeops/google-scopes.d.ts.map +1 -0
- package/dist/lifeops/google-scopes.js +118 -0
- package/dist/lifeops/google-scopes.js.map +1 -0
- package/dist/lifeops/handoff/store.d.ts +23 -0
- package/dist/lifeops/handoff/store.d.ts.map +1 -0
- package/dist/lifeops/handoff/store.js +20 -0
- package/dist/lifeops/handoff/store.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts +16 -0
- package/dist/lifeops/i18n/localized-examples-provider.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-provider.js +33 -0
- package/dist/lifeops/i18n/localized-examples-provider.js.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts +32 -0
- package/dist/lifeops/i18n/localized-examples-resolver.d.ts.map +1 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js +28 -0
- package/dist/lifeops/i18n/localized-examples-resolver.js.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts +64 -0
- package/dist/lifeops/i18n/prompt-registry.d.ts.map +1 -0
- package/dist/lifeops/i18n/prompt-registry.js +283 -0
- package/dist/lifeops/i18n/prompt-registry.js.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts +7 -0
- package/dist/lifeops/imessage-outbound-probe.d.ts.map +1 -0
- package/dist/lifeops/imessage-outbound-probe.js +81 -0
- package/dist/lifeops/imessage-outbound-probe.js.map +1 -0
- package/dist/lifeops/index.d.ts +24 -0
- package/dist/lifeops/index.d.ts.map +1 -0
- package/dist/lifeops/index.js +24 -0
- package/dist/lifeops/index.js.map +1 -0
- package/dist/lifeops/intent-sync.d.ts +64 -0
- package/dist/lifeops/intent-sync.d.ts.map +1 -0
- package/dist/lifeops/intent-sync.js +321 -0
- package/dist/lifeops/intent-sync.js.map +1 -0
- package/dist/lifeops/messaging/index.d.ts +2 -0
- package/dist/lifeops/messaging/index.d.ts.map +1 -0
- package/dist/lifeops/messaging/index.js +5 -0
- package/dist/lifeops/messaging/index.js.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts +3 -0
- package/dist/lifeops/messaging/owner-send-policy.d.ts.map +1 -0
- package/dist/lifeops/messaging/owner-send-policy.js +83 -0
- package/dist/lifeops/messaging/owner-send-policy.js.map +1 -0
- package/dist/lifeops/notifications-push.d.ts +37 -0
- package/dist/lifeops/notifications-push.d.ts.map +1 -0
- package/dist/lifeops/notifications-push.js +95 -0
- package/dist/lifeops/notifications-push.js.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts +5 -0
- package/dist/lifeops/optimized-prompt-instructions.d.ts.map +1 -0
- package/dist/lifeops/optimized-prompt-instructions.js +48 -0
- package/dist/lifeops/optimized-prompt-instructions.js.map +1 -0
- package/dist/lifeops/owner/fact-store.d.ts +143 -0
- package/dist/lifeops/owner/fact-store.d.ts.map +1 -0
- package/dist/lifeops/owner/fact-store.js +446 -0
- package/dist/lifeops/owner/fact-store.js.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts +3 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.d.ts.map +1 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js +241 -0
- package/dist/lifeops/owner/profile-extraction-evaluator.js.map +1 -0
- package/dist/lifeops/owner-profile.d.ts +61 -0
- package/dist/lifeops/owner-profile.d.ts.map +1 -0
- package/dist/lifeops/owner-profile.js +407 -0
- package/dist/lifeops/owner-profile.js.map +1 -0
- package/dist/lifeops/pending-prompts/store.d.ts +23 -0
- package/dist/lifeops/pending-prompts/store.d.ts.map +1 -0
- package/dist/lifeops/pending-prompts/store.js +16 -0
- package/dist/lifeops/pending-prompts/store.js.map +1 -0
- package/dist/lifeops/policy-memory.d.ts +190 -0
- package/dist/lifeops/policy-memory.d.ts.map +1 -0
- package/dist/lifeops/policy-memory.js +1026 -0
- package/dist/lifeops/policy-memory.js.map +1 -0
- package/dist/lifeops/priority-scoring.d.ts +51 -0
- package/dist/lifeops/priority-scoring.d.ts.map +1 -0
- package/dist/lifeops/priority-scoring.js +305 -0
- package/dist/lifeops/priority-scoring.js.map +1 -0
- package/dist/lifeops/privacy-egress.d.ts +92 -0
- package/dist/lifeops/privacy-egress.d.ts.map +1 -0
- package/dist/lifeops/privacy-egress.js +230 -0
- package/dist/lifeops/privacy-egress.js.map +1 -0
- package/dist/lifeops/privacy.d.ts +49 -0
- package/dist/lifeops/privacy.d.ts.map +1 -0
- package/dist/lifeops/privacy.js +66 -0
- package/dist/lifeops/privacy.js.map +1 -0
- package/dist/lifeops/redact-sensitive-data.d.ts +32 -0
- package/dist/lifeops/redact-sensitive-data.d.ts.map +1 -0
- package/dist/lifeops/redact-sensitive-data.js +98 -0
- package/dist/lifeops/redact-sensitive-data.js.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts +13 -0
- package/dist/lifeops/registries/app-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/app-blocker-contribution.js +73 -0
- package/dist/lifeops/registries/app-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/blocker-registry.d.ts +76 -0
- package/dist/lifeops/registries/blocker-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/blocker-registry.js +40 -0
- package/dist/lifeops/registries/blocker-registry.js.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts +57 -0
- package/dist/lifeops/registries/event-kind-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/event-kind-registry.js +82 -0
- package/dist/lifeops/registries/event-kind-registry.js.map +1 -0
- package/dist/lifeops/registries/family-registry.d.ts +72 -0
- package/dist/lifeops/registries/family-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/family-registry.js +98 -0
- package/dist/lifeops/registries/family-registry.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts +32 -0
- package/dist/lifeops/registries/feature-flag-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js +36 -0
- package/dist/lifeops/registries/feature-flag-default-pack.js.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts +76 -0
- package/dist/lifeops/registries/feature-flag-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/feature-flag-registry.js +68 -0
- package/dist/lifeops/registries/feature-flag-registry.js.map +1 -0
- package/dist/lifeops/registries/index.d.ts +24 -0
- package/dist/lifeops/registries/index.d.ts.map +1 -0
- package/dist/lifeops/registries/index.js +115 -0
- package/dist/lifeops/registries/index.js.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts +21 -0
- package/dist/lifeops/registries/website-blocker-contribution.d.ts.map +1 -0
- package/dist/lifeops/registries/website-blocker-contribution.js +76 -0
- package/dist/lifeops/registries/website-blocker-contribution.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts +30 -0
- package/dist/lifeops/registries/workflow-step-default-pack.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js +315 -0
- package/dist/lifeops/registries/workflow-step-default-pack.js.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts +101 -0
- package/dist/lifeops/registries/workflow-step-registry.d.ts.map +1 -0
- package/dist/lifeops/registries/workflow-step-registry.js +56 -0
- package/dist/lifeops/registries/workflow-step-registry.js.map +1 -0
- package/dist/lifeops/relationships/extraction.d.ts +77 -0
- package/dist/lifeops/relationships/extraction.d.ts.map +1 -0
- package/dist/lifeops/relationships/extraction.js +146 -0
- package/dist/lifeops/relationships/extraction.js.map +1 -0
- package/dist/lifeops/relationships/index.d.ts +4 -0
- package/dist/lifeops/relationships/index.d.ts.map +1 -0
- package/dist/lifeops/relationships/index.js +19 -0
- package/dist/lifeops/relationships/index.js.map +1 -0
- package/dist/lifeops/relationships/mapping.d.ts +34 -0
- package/dist/lifeops/relationships/mapping.d.ts.map +1 -0
- package/dist/lifeops/relationships/mapping.js +87 -0
- package/dist/lifeops/relationships/mapping.js.map +1 -0
- package/dist/lifeops/relationships/store.d.ts +12 -0
- package/dist/lifeops/relationships/store.d.ts.map +1 -0
- package/dist/lifeops/relationships/store.js +5 -0
- package/dist/lifeops/relationships/store.js.map +1 -0
- package/dist/lifeops/relationships/types.d.ts +9 -0
- package/dist/lifeops/relationships/types.d.ts.map +1 -0
- package/dist/lifeops/relationships/types.js +11 -0
- package/dist/lifeops/relationships/types.js.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts +13 -0
- package/dist/lifeops/relative-schedule-resolver.d.ts.map +1 -0
- package/dist/lifeops/relative-schedule-resolver.js +107 -0
- package/dist/lifeops/relative-schedule-resolver.js.map +1 -0
- package/dist/lifeops/relative-time.d.ts +15 -0
- package/dist/lifeops/relative-time.d.ts.map +1 -0
- package/dist/lifeops/relative-time.js +191 -0
- package/dist/lifeops/relative-time.js.map +1 -0
- package/dist/lifeops/repository.d.ts +638 -0
- package/dist/lifeops/repository.d.ts.map +1 -0
- package/dist/lifeops/repository.js +6289 -0
- package/dist/lifeops/repository.js.map +1 -0
- package/dist/lifeops/runtime-cache.d.ts +4 -0
- package/dist/lifeops/runtime-cache.d.ts.map +1 -0
- package/dist/lifeops/runtime-cache.js +7 -0
- package/dist/lifeops/runtime-cache.js.map +1 -0
- package/dist/lifeops/runtime-service-delegates.d.ts +236 -0
- package/dist/lifeops/runtime-service-delegates.d.ts.map +1 -0
- package/dist/lifeops/runtime-service-delegates.js +839 -0
- package/dist/lifeops/runtime-service-delegates.js.map +1 -0
- package/dist/lifeops/runtime.d.ts +13 -0
- package/dist/lifeops/runtime.d.ts.map +1 -0
- package/dist/lifeops/runtime.js +104 -0
- package/dist/lifeops/runtime.js.map +1 -0
- package/dist/lifeops/schedule-insight.d.ts +133 -0
- package/dist/lifeops/schedule-insight.d.ts.map +1 -0
- package/dist/lifeops/schedule-insight.js +726 -0
- package/dist/lifeops/schedule-insight.js.map +1 -0
- package/dist/lifeops/schedule-state.d.ts +39 -0
- package/dist/lifeops/schedule-state.d.ts.map +1 -0
- package/dist/lifeops/schedule-state.js +671 -0
- package/dist/lifeops/schedule-state.js.map +1 -0
- package/dist/lifeops/schedule-sync-config.d.ts +3 -0
- package/dist/lifeops/schedule-sync-config.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-config.js +23 -0
- package/dist/lifeops/schedule-sync-config.js.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts +2 -0
- package/dist/lifeops/schedule-sync-contracts.d.ts.map +1 -0
- package/dist/lifeops/schedule-sync-contracts.js +2 -0
- package/dist/lifeops/schedule-sync-contracts.js.map +1 -0
- package/dist/lifeops/scheduled-task/index.d.ts +13 -0
- package/dist/lifeops/scheduled-task/index.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/index.js +14 -0
- package/dist/lifeops/scheduled-task/index.js.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts +33 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js +334 -0
- package/dist/lifeops/scheduled-task/runtime-wiring.js.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts +28 -0
- package/dist/lifeops/scheduled-task/scheduler.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/scheduler.js +202 -0
- package/dist/lifeops/scheduled-task/scheduler.js.map +1 -0
- package/dist/lifeops/scheduled-task/service.d.ts +61 -0
- package/dist/lifeops/scheduled-task/service.d.ts.map +1 -0
- package/dist/lifeops/scheduled-task/service.js +64 -0
- package/dist/lifeops/scheduled-task/service.js.map +1 -0
- package/dist/lifeops/scheduler-task.d.ts +19 -0
- package/dist/lifeops/scheduler-task.d.ts.map +1 -0
- package/dist/lifeops/scheduler-task.js +201 -0
- package/dist/lifeops/scheduler-task.js.map +1 -0
- package/dist/lifeops/schema.d.ts +28068 -0
- package/dist/lifeops/schema.d.ts.map +1 -0
- package/dist/lifeops/schema.js +1689 -0
- package/dist/lifeops/schema.js.map +1 -0
- package/dist/lifeops/screen-context.d.ts +66 -0
- package/dist/lifeops/screen-context.d.ts.map +1 -0
- package/dist/lifeops/screen-context.js +347 -0
- package/dist/lifeops/screen-context.js.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts +113 -0
- package/dist/lifeops/seed-routine-migration/migrator.d.ts.map +1 -0
- package/dist/lifeops/seed-routine-migration/migrator.js +142 -0
- package/dist/lifeops/seed-routine-migration/migrator.js.map +1 -0
- package/dist/lifeops/seed-routines.d.ts +24 -0
- package/dist/lifeops/seed-routines.d.ts.map +1 -0
- package/dist/lifeops/seed-routines.js +140 -0
- package/dist/lifeops/seed-routines.js.map +1 -0
- package/dist/lifeops/send-policy/contract.d.ts +81 -0
- package/dist/lifeops/send-policy/contract.d.ts.map +1 -0
- package/dist/lifeops/send-policy/contract.js +1 -0
- package/dist/lifeops/send-policy/contract.js.map +1 -0
- package/dist/lifeops/send-policy/index.d.ts +3 -0
- package/dist/lifeops/send-policy/index.d.ts.map +1 -0
- package/dist/lifeops/send-policy/index.js +13 -0
- package/dist/lifeops/send-policy/index.js.map +1 -0
- package/dist/lifeops/send-policy/registry.d.ts +7 -0
- package/dist/lifeops/send-policy/registry.d.ts.map +1 -0
- package/dist/lifeops/send-policy/registry.js +62 -0
- package/dist/lifeops/send-policy/registry.js.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts +46 -0
- package/dist/lifeops/sensitive-request-delivery.d.ts.map +1 -0
- package/dist/lifeops/sensitive-request-delivery.js +103 -0
- package/dist/lifeops/sensitive-request-delivery.js.map +1 -0
- package/dist/lifeops/service-constants.d.ts +10 -0
- package/dist/lifeops/service-constants.d.ts.map +1 -0
- package/dist/lifeops/service-constants.js +129 -0
- package/dist/lifeops/service-constants.js.map +1 -0
- package/dist/lifeops/service-helpers-browser.d.ts +41 -0
- package/dist/lifeops/service-helpers-browser.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-browser.js +290 -0
- package/dist/lifeops/service-helpers-browser.js.map +1 -0
- package/dist/lifeops/service-helpers-misc.d.ts +68 -0
- package/dist/lifeops/service-helpers-misc.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-misc.js +531 -0
- package/dist/lifeops/service-helpers-misc.js.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts +23 -0
- package/dist/lifeops/service-helpers-occurrence.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-occurrence.js +257 -0
- package/dist/lifeops/service-helpers-occurrence.js.map +1 -0
- package/dist/lifeops/service-helpers-reminder.d.ts +260 -0
- package/dist/lifeops/service-helpers-reminder.d.ts.map +1 -0
- package/dist/lifeops/service-helpers-reminder.js +1186 -0
- package/dist/lifeops/service-helpers-reminder.js.map +1 -0
- package/dist/lifeops/service-mixin-browser.d.ts +31 -0
- package/dist/lifeops/service-mixin-browser.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-browser.js +975 -0
- package/dist/lifeops/service-mixin-browser.js.map +1 -0
- package/dist/lifeops/service-mixin-calendar.d.ts +53 -0
- package/dist/lifeops/service-mixin-calendar.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-calendar.js +68 -0
- package/dist/lifeops/service-mixin-calendar.js.map +1 -0
- package/dist/lifeops/service-mixin-core.d.ts +51 -0
- package/dist/lifeops/service-mixin-core.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-core.js +500 -0
- package/dist/lifeops/service-mixin-core.js.map +1 -0
- package/dist/lifeops/service-mixin-definitions.d.ts +14 -0
- package/dist/lifeops/service-mixin-definitions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-definitions.js +470 -0
- package/dist/lifeops/service-mixin-definitions.js.map +1 -0
- package/dist/lifeops/service-mixin-discord.d.ts +49 -0
- package/dist/lifeops/service-mixin-discord.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-discord.js +1253 -0
- package/dist/lifeops/service-mixin-discord.js.map +1 -0
- package/dist/lifeops/service-mixin-drive.d.ts +96 -0
- package/dist/lifeops/service-mixin-drive.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-drive.js +213 -0
- package/dist/lifeops/service-mixin-drive.js.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts +23 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js +27 -0
- package/dist/lifeops/service-mixin-email-unsubscribe.js.map +1 -0
- package/dist/lifeops/service-mixin-gmail.d.ts +43 -0
- package/dist/lifeops/service-mixin-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-gmail.js +727 -0
- package/dist/lifeops/service-mixin-gmail.js.map +1 -0
- package/dist/lifeops/service-mixin-goals.d.ts +22 -0
- package/dist/lifeops/service-mixin-goals.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-goals.js +884 -0
- package/dist/lifeops/service-mixin-goals.js.map +1 -0
- package/dist/lifeops/service-mixin-google.d.ts +13 -0
- package/dist/lifeops/service-mixin-google.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-google.js +398 -0
- package/dist/lifeops/service-mixin-google.js.map +1 -0
- package/dist/lifeops/service-mixin-health.d.ts +27 -0
- package/dist/lifeops/service-mixin-health.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-health.js +670 -0
- package/dist/lifeops/service-mixin-health.js.map +1 -0
- package/dist/lifeops/service-mixin-imessage.d.ts +106 -0
- package/dist/lifeops/service-mixin-imessage.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-imessage.js +303 -0
- package/dist/lifeops/service-mixin-imessage.js.map +1 -0
- package/dist/lifeops/service-mixin-inbox.d.ts +55 -0
- package/dist/lifeops/service-mixin-inbox.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-inbox.js +597 -0
- package/dist/lifeops/service-mixin-inbox.js.map +1 -0
- package/dist/lifeops/service-mixin-relationships.d.ts +65 -0
- package/dist/lifeops/service-mixin-relationships.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-relationships.js +150 -0
- package/dist/lifeops/service-mixin-relationships.js.map +1 -0
- package/dist/lifeops/service-mixin-reminders.d.ts +62 -0
- package/dist/lifeops/service-mixin-reminders.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-reminders.js +4003 -0
- package/dist/lifeops/service-mixin-reminders.js.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts +53 -0
- package/dist/lifeops/service-mixin-scheduling.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-scheduling.js +405 -0
- package/dist/lifeops/service-mixin-scheduling.js.map +1 -0
- package/dist/lifeops/service-mixin-screentime.d.ts +71 -0
- package/dist/lifeops/service-mixin-screentime.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-screentime.js +530 -0
- package/dist/lifeops/service-mixin-screentime.js.map +1 -0
- package/dist/lifeops/service-mixin-signal.d.ts +74 -0
- package/dist/lifeops/service-mixin-signal.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-signal.js +214 -0
- package/dist/lifeops/service-mixin-signal.js.map +1 -0
- package/dist/lifeops/service-mixin-sleep.d.ts +68 -0
- package/dist/lifeops/service-mixin-sleep.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-sleep.js +43 -0
- package/dist/lifeops/service-mixin-sleep.js.map +1 -0
- package/dist/lifeops/service-mixin-status.d.ts +31 -0
- package/dist/lifeops/service-mixin-status.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-status.js +373 -0
- package/dist/lifeops/service-mixin-status.js.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts +101 -0
- package/dist/lifeops/service-mixin-subscriptions.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-subscriptions.js +50 -0
- package/dist/lifeops/service-mixin-subscriptions.js.map +1 -0
- package/dist/lifeops/service-mixin-telegram.d.ts +104 -0
- package/dist/lifeops/service-mixin-telegram.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-telegram.js +280 -0
- package/dist/lifeops/service-mixin-telegram.js.map +1 -0
- package/dist/lifeops/service-mixin-travel.d.ts +66 -0
- package/dist/lifeops/service-mixin-travel.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-travel.js +275 -0
- package/dist/lifeops/service-mixin-travel.js.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts +96 -0
- package/dist/lifeops/service-mixin-whatsapp.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-whatsapp.js +186 -0
- package/dist/lifeops/service-mixin-whatsapp.js.map +1 -0
- package/dist/lifeops/service-mixin-workflows.d.ts +15 -0
- package/dist/lifeops/service-mixin-workflows.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-workflows.js +710 -0
- package/dist/lifeops/service-mixin-workflows.js.map +1 -0
- package/dist/lifeops/service-mixin-x-read.d.ts +31 -0
- package/dist/lifeops/service-mixin-x-read.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x-read.js +267 -0
- package/dist/lifeops/service-mixin-x-read.js.map +1 -0
- package/dist/lifeops/service-mixin-x.d.ts +66 -0
- package/dist/lifeops/service-mixin-x.d.ts.map +1 -0
- package/dist/lifeops/service-mixin-x.js +501 -0
- package/dist/lifeops/service-mixin-x.js.map +1 -0
- package/dist/lifeops/service-normalize-connector.d.ts +19 -0
- package/dist/lifeops/service-normalize-connector.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-connector.js +816 -0
- package/dist/lifeops/service-normalize-connector.js.map +1 -0
- package/dist/lifeops/service-normalize-gmail.d.ts +11 -0
- package/dist/lifeops/service-normalize-gmail.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-gmail.js +85 -0
- package/dist/lifeops/service-normalize-gmail.js.map +1 -0
- package/dist/lifeops/service-normalize-task.d.ts +9 -0
- package/dist/lifeops/service-normalize-task.d.ts.map +1 -0
- package/dist/lifeops/service-normalize-task.js +567 -0
- package/dist/lifeops/service-normalize-task.js.map +1 -0
- package/dist/lifeops/service-normalize.d.ts +9 -0
- package/dist/lifeops/service-normalize.d.ts.map +1 -0
- package/dist/lifeops/service-normalize.js +53 -0
- package/dist/lifeops/service-normalize.js.map +1 -0
- package/dist/lifeops/service-types.d.ts +75 -0
- package/dist/lifeops/service-types.d.ts.map +1 -0
- package/dist/lifeops/service-types.js +5 -0
- package/dist/lifeops/service-types.js.map +1 -0
- package/dist/lifeops/service.d.ts +482 -0
- package/dist/lifeops/service.d.ts.map +1 -0
- package/dist/lifeops/service.js +62 -0
- package/dist/lifeops/service.js.map +1 -0
- package/dist/lifeops/signal-runtime-config.d.ts +13 -0
- package/dist/lifeops/signal-runtime-config.d.ts.map +1 -0
- package/dist/lifeops/signal-runtime-config.js +44 -0
- package/dist/lifeops/signal-runtime-config.js.map +1 -0
- package/dist/lifeops/signals/bus.d.ts +78 -0
- package/dist/lifeops/signals/bus.d.ts.map +1 -0
- package/dist/lifeops/signals/bus.js +117 -0
- package/dist/lifeops/signals/bus.js.map +1 -0
- package/dist/lifeops/sql.d.ts +65 -0
- package/dist/lifeops/sql.d.ts.map +1 -0
- package/dist/lifeops/sql.js +182 -0
- package/dist/lifeops/sql.js.map +1 -0
- package/dist/lifeops/stretch-decider.d.ts +73 -0
- package/dist/lifeops/stretch-decider.d.ts.map +1 -0
- package/dist/lifeops/stretch-decider.js +49 -0
- package/dist/lifeops/stretch-decider.js.map +1 -0
- package/dist/lifeops/telemetry-mapping.d.ts +14 -0
- package/dist/lifeops/telemetry-mapping.d.ts.map +1 -0
- package/dist/lifeops/telemetry-mapping.js +115 -0
- package/dist/lifeops/telemetry-mapping.js.map +1 -0
- package/dist/lifeops/telemetry-retention.d.ts +21 -0
- package/dist/lifeops/telemetry-retention.d.ts.map +1 -0
- package/dist/lifeops/telemetry-retention.js +13 -0
- package/dist/lifeops/telemetry-retention.js.map +1 -0
- package/dist/lifeops/time/timezone.d.ts +4 -0
- package/dist/lifeops/time/timezone.d.ts.map +1 -0
- package/dist/lifeops/time/timezone.js +154 -0
- package/dist/lifeops/time/timezone.js.map +1 -0
- package/dist/lifeops/time-util.d.ts +10 -0
- package/dist/lifeops/time-util.d.ts.map +1 -0
- package/dist/lifeops/time-util.js +14 -0
- package/dist/lifeops/time-util.js.map +1 -0
- package/dist/lifeops/time.d.ts +17 -0
- package/dist/lifeops/time.d.ts.map +1 -0
- package/dist/lifeops/time.js +152 -0
- package/dist/lifeops/time.js.map +1 -0
- package/dist/lifeops/travel-booking.types.d.ts +46 -0
- package/dist/lifeops/travel-booking.types.d.ts.map +1 -0
- package/dist/lifeops/travel-booking.types.js +1 -0
- package/dist/lifeops/travel-booking.types.js.map +1 -0
- package/dist/lifeops/triggers/schedule-once.d.ts +19 -0
- package/dist/lifeops/triggers/schedule-once.d.ts.map +1 -0
- package/dist/lifeops/triggers/schedule-once.js +99 -0
- package/dist/lifeops/triggers/schedule-once.js.map +1 -0
- package/dist/lifeops/validate/coding-task-request.d.ts +18 -0
- package/dist/lifeops/validate/coding-task-request.d.ts.map +1 -0
- package/dist/lifeops/validate/coding-task-request.js +16 -0
- package/dist/lifeops/validate/coding-task-request.js.map +1 -0
- package/dist/lifeops/voice/grounded-reply.d.ts +41 -0
- package/dist/lifeops/voice/grounded-reply.d.ts.map +1 -0
- package/dist/lifeops/voice/grounded-reply.js +24 -0
- package/dist/lifeops/voice/grounded-reply.js.map +1 -0
- package/dist/lifeops/voice-affect.d.ts +79 -0
- package/dist/lifeops/voice-affect.d.ts.map +1 -0
- package/dist/lifeops/voice-affect.js +253 -0
- package/dist/lifeops/voice-affect.js.map +1 -0
- package/dist/lifeops/wave1-types.d.ts +125 -0
- package/dist/lifeops/wave1-types.d.ts.map +1 -0
- package/dist/lifeops/wave1-types.js +1 -0
- package/dist/lifeops/wave1-types.js.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts +33 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.d.ts.map +1 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js +226 -0
- package/dist/lifeops/work-threads/field-evaluator-thread-ops.js.map +1 -0
- package/dist/lifeops/work-threads/index.d.ts +3 -0
- package/dist/lifeops/work-threads/index.d.ts.map +1 -0
- package/dist/lifeops/work-threads/index.js +7 -0
- package/dist/lifeops/work-threads/index.js.map +1 -0
- package/dist/lifeops/work-threads/store.d.ts +91 -0
- package/dist/lifeops/work-threads/store.d.ts.map +1 -0
- package/dist/lifeops/work-threads/store.js +245 -0
- package/dist/lifeops/work-threads/store.js.map +1 -0
- package/dist/lifeops/work-threads/types.d.ts +58 -0
- package/dist/lifeops/work-threads/types.d.ts.map +1 -0
- package/dist/lifeops/work-threads/types.js +1 -0
- package/dist/lifeops/work-threads/types.js.map +1 -0
- package/dist/platform/host.d.ts +16 -0
- package/dist/platform/host.d.ts.map +1 -0
- package/dist/platform/host.js +22 -0
- package/dist/platform/host.js.map +1 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.d.ts.map +1 -0
- package/dist/platform/index.js +3 -0
- package/dist/platform/index.js.map +1 -0
- package/dist/platform/lifeops-github.d.ts +15 -0
- package/dist/platform/lifeops-github.d.ts.map +1 -0
- package/dist/platform/lifeops-github.js +146 -0
- package/dist/platform/lifeops-github.js.map +1 -0
- package/dist/plugin.d.ts +106 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +989 -0
- package/dist/plugin.js.map +1 -0
- package/dist/provider.d.ts +4 -0
- package/dist/provider.d.ts.map +1 -0
- package/dist/provider.js +108 -0
- package/dist/provider.js.map +1 -0
- package/dist/providers/activity-profile.d.ts +3 -0
- package/dist/providers/activity-profile.d.ts.map +1 -0
- package/dist/providers/activity-profile.js +140 -0
- package/dist/providers/activity-profile.js.map +1 -0
- package/dist/providers/cross-channel-context.d.ts +29 -0
- package/dist/providers/cross-channel-context.d.ts.map +1 -0
- package/dist/providers/cross-channel-context.js +206 -0
- package/dist/providers/cross-channel-context.js.map +1 -0
- package/dist/providers/first-run.d.ts +22 -0
- package/dist/providers/first-run.d.ts.map +1 -0
- package/dist/providers/first-run.js +93 -0
- package/dist/providers/first-run.js.map +1 -0
- package/dist/providers/health.d.ts +2 -0
- package/dist/providers/health.d.ts.map +1 -0
- package/dist/providers/health.js +14 -0
- package/dist/providers/health.js.map +1 -0
- package/dist/providers/inbox-triage.d.ts +3 -0
- package/dist/providers/inbox-triage.d.ts.map +1 -0
- package/dist/providers/inbox-triage.js +134 -0
- package/dist/providers/inbox-triage.js.map +1 -0
- package/dist/providers/lifeops.d.ts +3 -0
- package/dist/providers/lifeops.d.ts.map +1 -0
- package/dist/providers/lifeops.js +548 -0
- package/dist/providers/lifeops.js.map +1 -0
- package/dist/providers/pending-prompts.d.ts +38 -0
- package/dist/providers/pending-prompts.d.ts.map +1 -0
- package/dist/providers/pending-prompts.js +81 -0
- package/dist/providers/pending-prompts.js.map +1 -0
- package/dist/providers/recent-task-states.d.ts +52 -0
- package/dist/providers/recent-task-states.d.ts.map +1 -0
- package/dist/providers/recent-task-states.js +166 -0
- package/dist/providers/recent-task-states.js.map +1 -0
- package/dist/providers/room-policy.d.ts +16 -0
- package/dist/providers/room-policy.d.ts.map +1 -0
- package/dist/providers/room-policy.js +71 -0
- package/dist/providers/room-policy.js.map +1 -0
- package/dist/providers/work-threads.d.ts +3 -0
- package/dist/providers/work-threads.d.ts.map +1 -0
- package/dist/providers/work-threads.js +97 -0
- package/dist/providers/work-threads.js.map +1 -0
- package/dist/public.d.ts +3 -0
- package/dist/public.d.ts.map +1 -0
- package/dist/public.js +17 -0
- package/dist/public.js.map +1 -0
- package/dist/routes/cloud-features-routes.d.ts +9 -0
- package/dist/routes/cloud-features-routes.d.ts.map +1 -0
- package/dist/routes/cloud-features-routes.js +164 -0
- package/dist/routes/cloud-features-routes.js.map +1 -0
- package/dist/routes/entities.d.ts +14 -0
- package/dist/routes/entities.d.ts.map +1 -0
- package/dist/routes/entities.js +203 -0
- package/dist/routes/entities.js.map +1 -0
- package/dist/routes/lifeops-routes.d.ts +20 -0
- package/dist/routes/lifeops-routes.d.ts.map +1 -0
- package/dist/routes/lifeops-routes.js +2337 -0
- package/dist/routes/lifeops-routes.js.map +1 -0
- package/dist/routes/plugin.d.ts +9 -0
- package/dist/routes/plugin.d.ts.map +1 -0
- package/dist/routes/plugin.js +568 -0
- package/dist/routes/plugin.js.map +1 -0
- package/dist/routes/relationships.d.ts +13 -0
- package/dist/routes/relationships.d.ts.map +1 -0
- package/dist/routes/relationships.js +195 -0
- package/dist/routes/relationships.js.map +1 -0
- package/dist/routes/scheduled-tasks.d.ts +102 -0
- package/dist/routes/scheduled-tasks.d.ts.map +1 -0
- package/dist/routes/scheduled-tasks.js +322 -0
- package/dist/routes/scheduled-tasks.js.map +1 -0
- package/dist/routes/sleep-routes.d.ts +3 -0
- package/dist/routes/sleep-routes.d.ts.map +1 -0
- package/dist/routes/sleep-routes.js +33 -0
- package/dist/routes/sleep-routes.js.map +1 -0
- package/dist/routes/travel-provider-relay-routes.d.ts +2 -0
- package/dist/routes/travel-provider-relay-routes.d.ts.map +1 -0
- package/dist/routes/travel-provider-relay-routes.js +7 -0
- package/dist/routes/travel-provider-relay-routes.js.map +1 -0
- package/dist/routes/website-blocker-routes.d.ts +6 -0
- package/dist/routes/website-blocker-routes.d.ts.map +1 -0
- package/dist/routes/website-blocker-routes.js +218 -0
- package/dist/routes/website-blocker-routes.js.map +1 -0
- package/dist/security/action-confirmation.d.ts +12 -0
- package/dist/security/action-confirmation.d.ts.map +1 -0
- package/dist/security/action-confirmation.js +36 -0
- package/dist/security/action-confirmation.js.map +1 -0
- package/dist/service.d.ts +34 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +111 -0
- package/dist/service.js.map +1 -0
- package/dist/travel-time/calendar-create.d.ts +17 -0
- package/dist/travel-time/calendar-create.d.ts.map +1 -0
- package/dist/travel-time/calendar-create.js +28 -0
- package/dist/travel-time/calendar-create.js.map +1 -0
- package/dist/travel-time/service.d.ts +114 -0
- package/dist/travel-time/service.d.ts.map +1 -0
- package/dist/travel-time/service.js +209 -0
- package/dist/travel-time/service.js.map +1 -0
- package/dist/types/app-blocker-settings-card.d.ts +2 -0
- package/dist/types/app-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/app-blocker-settings-card.js +1 -0
- package/dist/types/app-blocker-settings-card.js.map +1 -0
- package/dist/types/briefing.d.ts +59 -0
- package/dist/types/briefing.d.ts.map +1 -0
- package/dist/types/briefing.js +1 -0
- package/dist/types/briefing.js.map +1 -0
- package/dist/types/document-request.d.ts +41 -0
- package/dist/types/document-request.d.ts.map +1 -0
- package/dist/types/document-request.js +1 -0
- package/dist/types/document-request.js.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/website-blocker-settings-card.d.ts +2 -0
- package/dist/types/website-blocker-settings-card.d.ts.map +1 -0
- package/dist/types/website-blocker-settings-card.js +1 -0
- package/dist/types/website-blocker-settings-card.js.map +1 -0
- package/dist/ui.d.ts +13 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +25 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +13 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/lifeops-url.d.ts +3 -0
- package/dist/utils/lifeops-url.d.ts.map +1 -0
- package/dist/utils/lifeops-url.js +28 -0
- package/dist/utils/lifeops-url.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts +32 -0
- package/dist/website-blocker/chat-integration/block-activator.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-activator.js +30 -0
- package/dist/website-blocker/chat-integration/block-activator.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts +7 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js +115 -0
- package/dist/website-blocker/chat-integration/block-rule-reconciler.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts +39 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js +133 -0
- package/dist/website-blocker/chat-integration/block-rule-schema.js.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts +21 -0
- package/dist/website-blocker/chat-integration/block-rule-service.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js +230 -0
- package/dist/website-blocker/chat-integration/block-rule-service.js.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts +13 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js +22 -0
- package/dist/website-blocker/chat-integration/harsh-mode-check.js.map +1 -0
- package/dist/website-blocker/chat-integration/index.d.ts +5 -0
- package/dist/website-blocker/chat-integration/index.d.ts.map +1 -0
- package/dist/website-blocker/chat-integration/index.js +26 -0
- package/dist/website-blocker/chat-integration/index.js.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts +75 -0
- package/dist/website-blocker/proactive-block-bridge.d.ts.map +1 -0
- package/dist/website-blocker/proactive-block-bridge.js +154 -0
- package/dist/website-blocker/proactive-block-bridge.js.map +1 -0
- package/dist/website-blocker/public.d.ts +12 -0
- package/dist/website-blocker/public.d.ts.map +1 -0
- package/dist/website-blocker/public.js +51 -0
- package/dist/website-blocker/public.js.map +1 -0
- package/package.json +28 -28
|
@@ -0,0 +1,485 @@
|
|
|
1
|
+
import { getLocalDateKey, getZonedDateParts } from "../lifeops/time.js";
|
|
2
|
+
import {
|
|
3
|
+
emptyBucketCounts
|
|
4
|
+
} from "./types.js";
|
|
5
|
+
const BUCKET_RANGES = [
|
|
6
|
+
{ bucket: "EARLY_MORNING", start: 5, end: 7 },
|
|
7
|
+
{ bucket: "MORNING", start: 7, end: 10 },
|
|
8
|
+
{ bucket: "MIDDAY", start: 10, end: 14 },
|
|
9
|
+
{ bucket: "AFTERNOON", start: 14, end: 17 },
|
|
10
|
+
{ bucket: "EVENING", start: 17, end: 21 },
|
|
11
|
+
{ bucket: "NIGHT", start: 21, end: 24 }
|
|
12
|
+
// LATE_NIGHT wraps: 0-5
|
|
13
|
+
];
|
|
14
|
+
const CLOCK_ORDERED_TIME_BUCKETS = [
|
|
15
|
+
"LATE_NIGHT",
|
|
16
|
+
"EARLY_MORNING",
|
|
17
|
+
"MORNING",
|
|
18
|
+
"MIDDAY",
|
|
19
|
+
"AFTERNOON",
|
|
20
|
+
"EVENING",
|
|
21
|
+
"NIGHT"
|
|
22
|
+
];
|
|
23
|
+
function classifyTimeBucket(hour) {
|
|
24
|
+
if (hour >= 0 && hour < 5) return "LATE_NIGHT";
|
|
25
|
+
for (const { bucket, start, end } of BUCKET_RANGES) {
|
|
26
|
+
if (hour >= start && hour < end) return bucket;
|
|
27
|
+
}
|
|
28
|
+
return "LATE_NIGHT";
|
|
29
|
+
}
|
|
30
|
+
function resolveCurrentBucket(timezone, now) {
|
|
31
|
+
const date = now ?? /* @__PURE__ */ new Date();
|
|
32
|
+
const parts = getZonedDateParts(date, timezone);
|
|
33
|
+
return classifyTimeBucket(parts.hour);
|
|
34
|
+
}
|
|
35
|
+
const SUSTAINED_INACTIVITY_GAP_MS = 3 * 60 * 60 * 1e3;
|
|
36
|
+
const ACTIVE_THRESHOLD_MS = 15 * 60 * 1e3;
|
|
37
|
+
const SIGNIFICANT_BUCKET_SHARE = 0.1;
|
|
38
|
+
const SCREEN_ACTIVE_FOCUS = /* @__PURE__ */ new Set(["work", "leisure", "transition"]);
|
|
39
|
+
const SCREEN_ACTIVITY_CONFIDENCE_FLOOR = 0.35;
|
|
40
|
+
function isRecord(value) {
|
|
41
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
42
|
+
}
|
|
43
|
+
function localDateKeyForTimestamp(timestamp, timezone) {
|
|
44
|
+
return getLocalDateKey(getZonedDateParts(new Date(timestamp), timezone));
|
|
45
|
+
}
|
|
46
|
+
function parseTimestamp(value) {
|
|
47
|
+
if (!value) {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
const parsed = Date.parse(value);
|
|
51
|
+
return Number.isFinite(parsed) ? parsed : null;
|
|
52
|
+
}
|
|
53
|
+
function parseHealthSnapshot(signal) {
|
|
54
|
+
if (signal.source !== "mobile_health") {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
const health = signal.health ?? (isRecord(signal.metadata.health) ? signal.metadata.health : null);
|
|
58
|
+
if (!health) {
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
const sleep = isRecord(health.sleep) ? health.sleep : null;
|
|
62
|
+
const biometrics = isRecord(health.biometrics) ? health.biometrics : null;
|
|
63
|
+
const isSleeping = Boolean(sleep?.isSleeping);
|
|
64
|
+
const sleepStartedAt = parseTimestamp(
|
|
65
|
+
typeof sleep?.asleepAt === "string" ? sleep.asleepAt : null
|
|
66
|
+
);
|
|
67
|
+
const sleepEndedAt = parseTimestamp(
|
|
68
|
+
typeof sleep?.awakeAt === "string" ? sleep.awakeAt : null
|
|
69
|
+
);
|
|
70
|
+
const biometricsSampleAt = parseTimestamp(
|
|
71
|
+
typeof biometrics?.sampleAt === "string" ? biometrics.sampleAt : null
|
|
72
|
+
);
|
|
73
|
+
return {
|
|
74
|
+
observedAt: signal.observedAt,
|
|
75
|
+
platform: signal.platform,
|
|
76
|
+
source: typeof health.source === "string" ? health.source : "healthkit",
|
|
77
|
+
isSleeping,
|
|
78
|
+
sleepStartedAt,
|
|
79
|
+
sleepEndedAt,
|
|
80
|
+
durationMinutes: typeof sleep?.durationMinutes === "number" && Number.isFinite(sleep.durationMinutes) ? sleep.durationMinutes : null,
|
|
81
|
+
biometricsSampleAt
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
function buildActivitySession(startAt, endAt, timezone) {
|
|
85
|
+
const startParts = getZonedDateParts(new Date(startAt), timezone);
|
|
86
|
+
const endParts = getZonedDateParts(new Date(endAt), timezone);
|
|
87
|
+
const startDayKey = getLocalDateKey(startParts);
|
|
88
|
+
const startDayOrdinal = Math.floor(
|
|
89
|
+
Date.UTC(startParts.year, startParts.month - 1, startParts.day) / 864e5
|
|
90
|
+
);
|
|
91
|
+
const endDayOrdinal = Math.floor(
|
|
92
|
+
Date.UTC(endParts.year, endParts.month - 1, endParts.day) / 864e5
|
|
93
|
+
);
|
|
94
|
+
return {
|
|
95
|
+
startAt,
|
|
96
|
+
endAt,
|
|
97
|
+
startHour: startParts.hour,
|
|
98
|
+
normalizedEndHour: endParts.hour + (endDayOrdinal - startDayOrdinal) * 24,
|
|
99
|
+
startDayKey
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
function buildActivitySessionsFromTimestamps(timestamps, timezone) {
|
|
103
|
+
if (timestamps.length === 0) {
|
|
104
|
+
return [];
|
|
105
|
+
}
|
|
106
|
+
const sorted = [...timestamps].sort((left, right) => left - right);
|
|
107
|
+
const sessions = [];
|
|
108
|
+
let sessionStartAt = sorted[0] ?? 0;
|
|
109
|
+
let sessionEndAt = sorted[0] ?? 0;
|
|
110
|
+
for (let index = 1; index < sorted.length; index += 1) {
|
|
111
|
+
const current = sorted[index] ?? 0;
|
|
112
|
+
if (current - sessionEndAt > SUSTAINED_INACTIVITY_GAP_MS) {
|
|
113
|
+
sessions.push(
|
|
114
|
+
buildActivitySession(sessionStartAt, sessionEndAt, timezone)
|
|
115
|
+
);
|
|
116
|
+
sessionStartAt = current;
|
|
117
|
+
}
|
|
118
|
+
sessionEndAt = current;
|
|
119
|
+
}
|
|
120
|
+
sessions.push(buildActivitySession(sessionStartAt, sessionEndAt, timezone));
|
|
121
|
+
return sessions;
|
|
122
|
+
}
|
|
123
|
+
function isActiveSignal(signal, nowMs) {
|
|
124
|
+
return signal.state === "active" && signal.observedAt <= nowMs;
|
|
125
|
+
}
|
|
126
|
+
function resolveLatestInteractionSnapshot(messages, ownerEntityId, roomSourceMap, currentTime, activitySignals) {
|
|
127
|
+
let latestOwnerSeenAt = 0;
|
|
128
|
+
let latestOwnerPlatform = null;
|
|
129
|
+
let latestClientChatSeenAt = 0;
|
|
130
|
+
let latestSignalSeenAt = 0;
|
|
131
|
+
let latestSignalPlatform = null;
|
|
132
|
+
for (const msg of messages) {
|
|
133
|
+
if (msg.createdAt > currentTime.getTime()) {
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
const source = roomSourceMap.get(msg.roomId) ?? "unknown";
|
|
137
|
+
if (source === "client_chat" && msg.createdAt > latestClientChatSeenAt) {
|
|
138
|
+
latestClientChatSeenAt = msg.createdAt;
|
|
139
|
+
}
|
|
140
|
+
if (msg.entityId === ownerEntityId && msg.createdAt > latestOwnerSeenAt) {
|
|
141
|
+
latestOwnerSeenAt = msg.createdAt;
|
|
142
|
+
latestOwnerPlatform = source;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
if (latestClientChatSeenAt > latestOwnerSeenAt) {
|
|
146
|
+
latestOwnerSeenAt = latestClientChatSeenAt;
|
|
147
|
+
latestOwnerPlatform = "client_chat";
|
|
148
|
+
}
|
|
149
|
+
for (const signal of activitySignals) {
|
|
150
|
+
if (!isActiveSignal(signal, currentTime.getTime())) {
|
|
151
|
+
continue;
|
|
152
|
+
}
|
|
153
|
+
if (signal.observedAt > latestSignalSeenAt) {
|
|
154
|
+
latestSignalSeenAt = signal.observedAt;
|
|
155
|
+
latestSignalPlatform = signal.platform;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
if (latestSignalSeenAt > latestOwnerSeenAt) {
|
|
159
|
+
return {
|
|
160
|
+
lastSeenAt: latestSignalSeenAt,
|
|
161
|
+
lastSeenPlatform: latestSignalPlatform
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
return {
|
|
165
|
+
lastSeenAt: latestOwnerSeenAt,
|
|
166
|
+
lastSeenPlatform: latestOwnerPlatform
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
function resolveScreenHeartbeatAt(profile) {
|
|
170
|
+
if (!profile.screenContextAvailable || profile.screenContextStale) {
|
|
171
|
+
return 0;
|
|
172
|
+
}
|
|
173
|
+
const sampledAt = profile.screenContextSampledAt;
|
|
174
|
+
if (sampledAt === null || sampledAt <= 0) {
|
|
175
|
+
return 0;
|
|
176
|
+
}
|
|
177
|
+
if (!SCREEN_ACTIVE_FOCUS.has(profile.screenContextFocus ?? "unknown")) {
|
|
178
|
+
return 0;
|
|
179
|
+
}
|
|
180
|
+
if (profile.screenContextConfidence !== null && profile.screenContextConfidence < SCREEN_ACTIVITY_CONFIDENCE_FLOOR) {
|
|
181
|
+
return 0;
|
|
182
|
+
}
|
|
183
|
+
return sampledAt;
|
|
184
|
+
}
|
|
185
|
+
function resolveCurrentActivityState(profile, now) {
|
|
186
|
+
const currentTime = now.getTime();
|
|
187
|
+
const thresholdMs = profile.sustainedInactivityThresholdMinutes * 60 * 1e3;
|
|
188
|
+
const screenHeartbeatAt = resolveScreenHeartbeatAt(profile);
|
|
189
|
+
const sleeping = profile.isCurrentlySleeping === true;
|
|
190
|
+
const sleepBoundaryAt = profile.lastSleepSignalAt ?? profile.lastWakeSignalAt ?? profile.lastSeenAt;
|
|
191
|
+
const mostRecentActivityAt = sleeping ? sleepBoundaryAt : Math.max(profile.lastSeenAt, screenHeartbeatAt);
|
|
192
|
+
const hasOpenActivityCycle = !sleeping && mostRecentActivityAt > 0 && currentTime - mostRecentActivityAt <= thresholdMs;
|
|
193
|
+
const cycleStart = !sleeping && profile.currentActivityCycleStartedAt && (profile.hasOpenActivityCycle || mostRecentActivityAt - profile.currentActivityCycleStartedAt <= thresholdMs) ? profile.currentActivityCycleStartedAt : hasOpenActivityCycle ? mostRecentActivityAt : profile.currentActivityCycleStartedAt;
|
|
194
|
+
const currentActivityCycleLocalDate = cycleStart ? localDateKeyForTimestamp(cycleStart, profile.timezone) : sleeping ? sleepBoundaryAt > 0 ? localDateKeyForTimestamp(sleepBoundaryAt, profile.timezone) : profile.currentActivityCycleLocalDate : profile.currentActivityCycleLocalDate;
|
|
195
|
+
const effectiveDayKey = hasOpenActivityCycle ? currentActivityCycleLocalDate ?? localDateKeyForTimestamp(currentTime, profile.timezone) : sleeping ? currentActivityCycleLocalDate ?? localDateKeyForTimestamp(currentTime, profile.timezone) : localDateKeyForTimestamp(currentTime, profile.timezone);
|
|
196
|
+
return {
|
|
197
|
+
lastSeenAt: mostRecentActivityAt,
|
|
198
|
+
lastSeenPlatform: profile.lastSeenPlatform,
|
|
199
|
+
isCurrentlyActive: !sleeping && mostRecentActivityAt > 0 && currentTime - mostRecentActivityAt < ACTIVE_THRESHOLD_MS,
|
|
200
|
+
hasOpenActivityCycle,
|
|
201
|
+
currentActivityCycleStartedAt: sleeping ? null : cycleStart ?? null,
|
|
202
|
+
currentActivityCycleLocalDate,
|
|
203
|
+
effectiveDayKey
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
function resolveEffectiveDayKey(profile, timezone, now) {
|
|
207
|
+
return resolveCurrentActivityState(
|
|
208
|
+
{
|
|
209
|
+
...profile,
|
|
210
|
+
timezone
|
|
211
|
+
},
|
|
212
|
+
now
|
|
213
|
+
).effectiveDayKey;
|
|
214
|
+
}
|
|
215
|
+
function resolveLatestActivityDayKey(profile, timezone, now) {
|
|
216
|
+
const heartbeatAt = Math.max(
|
|
217
|
+
profile.lastSeenAt,
|
|
218
|
+
resolveScreenHeartbeatAt(profile)
|
|
219
|
+
);
|
|
220
|
+
if (heartbeatAt <= 0) {
|
|
221
|
+
return null;
|
|
222
|
+
}
|
|
223
|
+
const thresholdMs = profile.sustainedInactivityThresholdMinutes * 60 * 1e3;
|
|
224
|
+
if (now.getTime() - heartbeatAt <= thresholdMs) {
|
|
225
|
+
if (profile.hasOpenActivityCycle && profile.currentActivityCycleStartedAt) {
|
|
226
|
+
return profile.currentActivityCycleLocalDate ?? localDateKeyForTimestamp(
|
|
227
|
+
profile.currentActivityCycleStartedAt,
|
|
228
|
+
timezone
|
|
229
|
+
);
|
|
230
|
+
}
|
|
231
|
+
return localDateKeyForTimestamp(heartbeatAt, timezone);
|
|
232
|
+
}
|
|
233
|
+
return localDateKeyForTimestamp(heartbeatAt, timezone);
|
|
234
|
+
}
|
|
235
|
+
function analyzeMessages(messages, roomSourceMap, ownerEntityId, timezone, windowDays, firstOptionalArg, secondOptionalArg) {
|
|
236
|
+
const currentTime = firstOptionalArg instanceof Date ? firstOptionalArg : secondOptionalArg instanceof Date ? secondOptionalArg : /* @__PURE__ */ new Date();
|
|
237
|
+
const activitySignals = Array.isArray(firstOptionalArg) ? firstOptionalArg : Array.isArray(secondOptionalArg) ? secondOptionalArg : [];
|
|
238
|
+
const windowStart = currentTime.getTime() - windowDays * 24 * 60 * 60 * 1e3;
|
|
239
|
+
const ownerMessages = messages.filter(
|
|
240
|
+
(m) => m.entityId === ownerEntityId && m.createdAt >= windowStart && m.createdAt <= currentTime.getTime()
|
|
241
|
+
);
|
|
242
|
+
const activeSignals = activitySignals.filter(
|
|
243
|
+
(signal) => signal.observedAt >= windowStart && isActiveSignal(signal, currentTime.getTime())
|
|
244
|
+
);
|
|
245
|
+
const healthSnapshots = activitySignals.map((signal) => parseHealthSnapshot(signal)).filter((snapshot) => snapshot !== null);
|
|
246
|
+
const platformMap = /* @__PURE__ */ new Map();
|
|
247
|
+
const aggregateBuckets = emptyBucketCounts();
|
|
248
|
+
for (const msg of ownerMessages) {
|
|
249
|
+
const source = roomSourceMap.get(msg.roomId) ?? "unknown";
|
|
250
|
+
let entry = platformMap.get(source);
|
|
251
|
+
if (!entry) {
|
|
252
|
+
entry = { count: 0, buckets: emptyBucketCounts(), lastAt: 0 };
|
|
253
|
+
platformMap.set(source, entry);
|
|
254
|
+
}
|
|
255
|
+
entry.count++;
|
|
256
|
+
if (msg.createdAt > entry.lastAt) entry.lastAt = msg.createdAt;
|
|
257
|
+
const parts = getZonedDateParts(new Date(msg.createdAt), timezone);
|
|
258
|
+
const bucket = classifyTimeBucket(parts.hour);
|
|
259
|
+
entry.buckets[bucket]++;
|
|
260
|
+
aggregateBuckets[bucket]++;
|
|
261
|
+
}
|
|
262
|
+
for (const signal of activeSignals) {
|
|
263
|
+
const source = signal.platform.trim().length > 0 ? signal.platform : "client_chat";
|
|
264
|
+
let entry = platformMap.get(source);
|
|
265
|
+
if (!entry) {
|
|
266
|
+
entry = { count: 0, buckets: emptyBucketCounts(), lastAt: 0 };
|
|
267
|
+
platformMap.set(source, entry);
|
|
268
|
+
}
|
|
269
|
+
entry.count++;
|
|
270
|
+
if (signal.observedAt > entry.lastAt) entry.lastAt = signal.observedAt;
|
|
271
|
+
const parts = getZonedDateParts(new Date(signal.observedAt), timezone);
|
|
272
|
+
const bucket = classifyTimeBucket(parts.hour);
|
|
273
|
+
entry.buckets[bucket]++;
|
|
274
|
+
aggregateBuckets[bucket]++;
|
|
275
|
+
}
|
|
276
|
+
const platforms = Array.from(platformMap.entries()).map(([source, data]) => ({
|
|
277
|
+
source,
|
|
278
|
+
messageCount: data.count,
|
|
279
|
+
bucketCounts: data.buckets,
|
|
280
|
+
lastMessageAt: data.lastAt,
|
|
281
|
+
averageMessagesPerDay: windowDays > 0 ? data.count / windowDays : 0
|
|
282
|
+
})).sort((a, b) => b.messageCount - a.messageCount);
|
|
283
|
+
const totalMessages = ownerMessages.length;
|
|
284
|
+
const activityPointCount = totalMessages + activeSignals.length;
|
|
285
|
+
const threshold = activityPointCount > 0 ? Math.max(activityPointCount * SIGNIFICANT_BUCKET_SHARE, 1) : Infinity;
|
|
286
|
+
let typicalFirstActiveHour = null;
|
|
287
|
+
let typicalLastActiveHour = null;
|
|
288
|
+
for (const bucket of CLOCK_ORDERED_TIME_BUCKETS) {
|
|
289
|
+
if (aggregateBuckets[bucket] >= threshold) {
|
|
290
|
+
const midHour = bucketMidpointHour(bucket);
|
|
291
|
+
if (typicalFirstActiveHour === null) typicalFirstActiveHour = midHour;
|
|
292
|
+
typicalLastActiveHour = midHour;
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
const sessions = buildActivitySessionsFromTimestamps(
|
|
296
|
+
[
|
|
297
|
+
...ownerMessages.map((message) => message.createdAt),
|
|
298
|
+
...activeSignals.map((signal) => signal.observedAt)
|
|
299
|
+
],
|
|
300
|
+
timezone
|
|
301
|
+
);
|
|
302
|
+
const sleepHoursFromHealth = healthSnapshots.filter((snapshot) => snapshot.sleepStartedAt !== null).map(
|
|
303
|
+
(snapshot) => getZonedDateParts(new Date(snapshot.sleepStartedAt ?? 0), timezone).hour
|
|
304
|
+
);
|
|
305
|
+
const wakeHoursFromHealth = healthSnapshots.filter((snapshot) => snapshot.sleepEndedAt !== null).map(
|
|
306
|
+
(snapshot) => getZonedDateParts(new Date(snapshot.sleepEndedAt ?? 0), timezone).hour
|
|
307
|
+
);
|
|
308
|
+
const wakeHours = sessions.map((session) => session.startHour).concat(wakeHoursFromHealth).sort((left, right) => left - right);
|
|
309
|
+
const sleepHours = sessions.map((session) => session.normalizedEndHour).concat(sleepHoursFromHealth).sort((left, right) => left - right);
|
|
310
|
+
const typicalWakeHour = wakeHours.length > 0 ? median(wakeHours) : null;
|
|
311
|
+
const typicalSleepHour = sleepHours.length > 0 ? median(sleepHours) : null;
|
|
312
|
+
const sleepDurations = healthSnapshots.map((snapshot) => snapshot.durationMinutes).filter((value) => typeof value === "number");
|
|
313
|
+
const typicalSleepDurationMinutes = sleepDurations.length > 0 ? Math.round(
|
|
314
|
+
sleepDurations.reduce((sum, value) => sum + value, 0) / sleepDurations.length
|
|
315
|
+
) : null;
|
|
316
|
+
const latestHealthSnapshot = healthSnapshots.length > 0 ? [...healthSnapshots].sort(
|
|
317
|
+
(left, right) => right.observedAt - left.observedAt
|
|
318
|
+
)[0] ?? null : null;
|
|
319
|
+
const latestSleepingHealthSnapshot = [...healthSnapshots].filter((snapshot) => snapshot.isSleeping).sort((left, right) => right.observedAt - left.observedAt)[0] ?? null;
|
|
320
|
+
const latestWakeHealthSnapshot = [...healthSnapshots].filter((snapshot) => !snapshot.isSleeping).sort((left, right) => right.observedAt - left.observedAt)[0] ?? null;
|
|
321
|
+
const latestInteraction = resolveLatestInteractionSnapshot(
|
|
322
|
+
messages,
|
|
323
|
+
ownerEntityId,
|
|
324
|
+
roomSourceMap,
|
|
325
|
+
currentTime,
|
|
326
|
+
activeSignals
|
|
327
|
+
);
|
|
328
|
+
let lastSeenAt = latestInteraction.lastSeenAt;
|
|
329
|
+
let lastSeenPlatform = latestInteraction.lastSeenPlatform;
|
|
330
|
+
if (latestHealthSnapshot) {
|
|
331
|
+
const healthBoundaryAt = latestHealthSnapshot.isSleeping ? latestHealthSnapshot.sleepStartedAt ?? latestHealthSnapshot.observedAt : latestHealthSnapshot.sleepEndedAt ?? latestHealthSnapshot.observedAt;
|
|
332
|
+
if (healthBoundaryAt > lastSeenAt) {
|
|
333
|
+
lastSeenAt = healthBoundaryAt;
|
|
334
|
+
lastSeenPlatform = latestHealthSnapshot.platform;
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
const isCurrentlySleeping = latestHealthSnapshot?.isSleeping === true;
|
|
338
|
+
const hasSleepData = healthSnapshots.length > 0;
|
|
339
|
+
const lastSleepSignalAt = latestSleepingHealthSnapshot?.sleepStartedAt ?? latestSleepingHealthSnapshot?.observedAt;
|
|
340
|
+
const lastWakeSignalAt = latestWakeHealthSnapshot?.sleepEndedAt ?? latestWakeHealthSnapshot?.observedAt;
|
|
341
|
+
const hasOpenActivityCycle = !isCurrentlySleeping && lastSeenAt > 0 && currentTime.getTime() - lastSeenAt <= SUSTAINED_INACTIVITY_GAP_MS;
|
|
342
|
+
const currentActivityCycle = sessions.length > 0 ? sessions[sessions.length - 1] : null;
|
|
343
|
+
const latestInteractionStartsNewCycle = !isCurrentlySleeping && lastSeenAt > 0 && (!currentActivityCycle || lastSeenAt > currentActivityCycle.endAt);
|
|
344
|
+
const currentActivityCycleStartedAt = latestInteractionStartsNewCycle ? lastSeenAt : isCurrentlySleeping ? null : currentActivityCycle?.startAt ?? lastSeenAt;
|
|
345
|
+
const currentActivityCycleLocalDate = latestInteractionStartsNewCycle ? localDateKeyForTimestamp(lastSeenAt, timezone) : isCurrentlySleeping ? lastSleepSignalAt !== null ? localDateKeyForTimestamp(lastSleepSignalAt, timezone) : localDateKeyForTimestamp(currentTime.getTime(), timezone) : currentActivityCycle?.startDayKey ?? localDateKeyForTimestamp(lastSeenAt, timezone);
|
|
346
|
+
return {
|
|
347
|
+
ownerEntityId,
|
|
348
|
+
analyzedAt: currentTime.getTime(),
|
|
349
|
+
analysisWindowDays: windowDays,
|
|
350
|
+
timezone,
|
|
351
|
+
totalMessages,
|
|
352
|
+
sustainedInactivityThresholdMinutes: SUSTAINED_INACTIVITY_GAP_MS / 6e4,
|
|
353
|
+
platforms,
|
|
354
|
+
primaryPlatform: platforms[0]?.source ?? null,
|
|
355
|
+
secondaryPlatform: platforms[1]?.source ?? null,
|
|
356
|
+
bucketCounts: aggregateBuckets,
|
|
357
|
+
typicalFirstActiveHour,
|
|
358
|
+
typicalLastActiveHour,
|
|
359
|
+
typicalWakeHour,
|
|
360
|
+
typicalSleepHour,
|
|
361
|
+
hasSleepData,
|
|
362
|
+
isCurrentlySleeping,
|
|
363
|
+
lastSleepSignalAt,
|
|
364
|
+
lastWakeSignalAt,
|
|
365
|
+
sleepSourcePlatform: latestHealthSnapshot?.platform ?? null,
|
|
366
|
+
sleepSource: latestHealthSnapshot?.source ?? null,
|
|
367
|
+
typicalSleepDurationMinutes,
|
|
368
|
+
lastSeenAt,
|
|
369
|
+
lastSeenPlatform,
|
|
370
|
+
isCurrentlyActive: !isCurrentlySleeping && currentTime.getTime() - lastSeenAt < ACTIVE_THRESHOLD_MS,
|
|
371
|
+
hasOpenActivityCycle,
|
|
372
|
+
currentActivityCycleStartedAt,
|
|
373
|
+
currentActivityCycleLocalDate,
|
|
374
|
+
effectiveDayKey: hasOpenActivityCycle ? currentActivityCycleLocalDate : isCurrentlySleeping ? currentActivityCycleLocalDate : localDateKeyForTimestamp(currentTime.getTime(), timezone),
|
|
375
|
+
screenContextFocus: null,
|
|
376
|
+
screenContextSource: null,
|
|
377
|
+
screenContextSampledAt: null,
|
|
378
|
+
screenContextConfidence: null,
|
|
379
|
+
screenContextBusy: false,
|
|
380
|
+
screenContextAvailable: false,
|
|
381
|
+
screenContextStale: false
|
|
382
|
+
};
|
|
383
|
+
}
|
|
384
|
+
function enrichWithCalendar(profile, calendarEvents, timezone) {
|
|
385
|
+
if (calendarEvents.length === 0) {
|
|
386
|
+
return {
|
|
387
|
+
...profile,
|
|
388
|
+
hasCalendarData: false,
|
|
389
|
+
typicalFirstEventHour: null,
|
|
390
|
+
typicalLastEventHour: null,
|
|
391
|
+
avgWeekdayMeetings: null
|
|
392
|
+
};
|
|
393
|
+
}
|
|
394
|
+
const eventHours = [];
|
|
395
|
+
for (const event of calendarEvents) {
|
|
396
|
+
if (event.isAllDay) continue;
|
|
397
|
+
const start = new Date(event.startAt);
|
|
398
|
+
const end = new Date(event.endAt);
|
|
399
|
+
const startParts = getZonedDateParts(start, timezone);
|
|
400
|
+
const endParts = getZonedDateParts(end, timezone);
|
|
401
|
+
const date = new Date(start);
|
|
402
|
+
eventHours.push({
|
|
403
|
+
startHour: startParts.hour,
|
|
404
|
+
endHour: endParts.hour,
|
|
405
|
+
dayOfWeek: date.getDay()
|
|
406
|
+
// 0=Sun, 1=Mon, ...
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
if (eventHours.length === 0) {
|
|
410
|
+
return {
|
|
411
|
+
...profile,
|
|
412
|
+
hasCalendarData: true,
|
|
413
|
+
typicalFirstEventHour: null,
|
|
414
|
+
typicalLastEventHour: null,
|
|
415
|
+
avgWeekdayMeetings: null
|
|
416
|
+
};
|
|
417
|
+
}
|
|
418
|
+
const weekdayEvents = eventHours.filter(
|
|
419
|
+
(e) => e.dayOfWeek >= 1 && e.dayOfWeek <= 5
|
|
420
|
+
);
|
|
421
|
+
const firstHours = weekdayEvents.map((e) => e.startHour).sort((a, b) => a - b);
|
|
422
|
+
const lastHours = weekdayEvents.map((e) => e.endHour).sort((a, b) => a - b);
|
|
423
|
+
const typicalFirstEventHour = firstHours.length > 0 ? median(firstHours) : null;
|
|
424
|
+
const typicalLastEventHour = lastHours.length > 0 ? median(lastHours) : null;
|
|
425
|
+
const weekdaySet = new Set(weekdayEvents.map((e) => e.dayOfWeek));
|
|
426
|
+
const avgWeekdayMeetings = weekdaySet.size > 0 ? Math.round(weekdayEvents.length / weekdaySet.size * 10) / 10 : null;
|
|
427
|
+
return {
|
|
428
|
+
...profile,
|
|
429
|
+
hasCalendarData: true,
|
|
430
|
+
typicalFirstEventHour,
|
|
431
|
+
typicalLastEventHour,
|
|
432
|
+
avgWeekdayMeetings
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
function bucketMidpointHour(bucket) {
|
|
436
|
+
switch (bucket) {
|
|
437
|
+
case "EARLY_MORNING":
|
|
438
|
+
return 6;
|
|
439
|
+
case "MORNING":
|
|
440
|
+
return 8;
|
|
441
|
+
case "MIDDAY":
|
|
442
|
+
return 12;
|
|
443
|
+
case "AFTERNOON":
|
|
444
|
+
return 15;
|
|
445
|
+
case "EVENING":
|
|
446
|
+
return 19;
|
|
447
|
+
case "NIGHT":
|
|
448
|
+
return 22;
|
|
449
|
+
case "LATE_NIGHT":
|
|
450
|
+
return 3;
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
function median(sorted) {
|
|
454
|
+
if (sorted.length === 0) {
|
|
455
|
+
throw new Error("[activity-profile] median requires at least one value");
|
|
456
|
+
}
|
|
457
|
+
const mid = Math.floor(sorted.length / 2);
|
|
458
|
+
if (sorted.length % 2 !== 0) {
|
|
459
|
+
const medianValue = sorted[mid];
|
|
460
|
+
if (medianValue === void 0) {
|
|
461
|
+
throw new Error("[activity-profile] median index out of bounds");
|
|
462
|
+
}
|
|
463
|
+
return medianValue;
|
|
464
|
+
}
|
|
465
|
+
const left = sorted[mid - 1];
|
|
466
|
+
const right = sorted[mid];
|
|
467
|
+
if (left === void 0 || right === void 0) {
|
|
468
|
+
throw new Error("[activity-profile] median pair is missing");
|
|
469
|
+
}
|
|
470
|
+
return Math.round((left + right) / 2);
|
|
471
|
+
}
|
|
472
|
+
function wasActiveToday(profile, timezone, now) {
|
|
473
|
+
return resolveLatestActivityDayKey(profile, timezone, now) === resolveEffectiveDayKey(profile, timezone, now);
|
|
474
|
+
}
|
|
475
|
+
export {
|
|
476
|
+
SUSTAINED_INACTIVITY_GAP_MS,
|
|
477
|
+
analyzeMessages,
|
|
478
|
+
classifyTimeBucket,
|
|
479
|
+
enrichWithCalendar,
|
|
480
|
+
resolveCurrentActivityState,
|
|
481
|
+
resolveCurrentBucket,
|
|
482
|
+
resolveEffectiveDayKey,
|
|
483
|
+
wasActiveToday
|
|
484
|
+
};
|
|
485
|
+
//# sourceMappingURL=analyzer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/activity-profile/analyzer.ts"],"sourcesContent":["import { getLocalDateKey, getZonedDateParts } from \"../lifeops/time.js\";\nimport {\n type ActivityProfile,\n type ActivitySignalRecord,\n emptyBucketCounts,\n type PlatformActivity,\n type TimeBucket,\n} from \"./types.js\";\n\n// ── Time bucket classification ─────────────────────────\n\nconst BUCKET_RANGES: Array<{ bucket: TimeBucket; start: number; end: number }> =\n [\n { bucket: \"EARLY_MORNING\", start: 5, end: 7 },\n { bucket: \"MORNING\", start: 7, end: 10 },\n { bucket: \"MIDDAY\", start: 10, end: 14 },\n { bucket: \"AFTERNOON\", start: 14, end: 17 },\n { bucket: \"EVENING\", start: 17, end: 21 },\n { bucket: \"NIGHT\", start: 21, end: 24 },\n // LATE_NIGHT wraps: 0-5\n ];\n\n// Buckets ordered by clock hour (00:00 → 23:59). ALL_TIME_BUCKETS lists\n// LATE_NIGHT last for legacy reasons; this constant is for callers that\n// genuinely need clock-order traversal (first/last active hour derivation).\nconst CLOCK_ORDERED_TIME_BUCKETS: TimeBucket[] = [\n \"LATE_NIGHT\",\n \"EARLY_MORNING\",\n \"MORNING\",\n \"MIDDAY\",\n \"AFTERNOON\",\n \"EVENING\",\n \"NIGHT\",\n];\n\nexport function classifyTimeBucket(hour: number): TimeBucket {\n if (hour >= 0 && hour < 5) return \"LATE_NIGHT\";\n for (const { bucket, start, end } of BUCKET_RANGES) {\n if (hour >= start && hour < end) return bucket;\n }\n // hour === 24 shouldn't happen but treat as LATE_NIGHT\n return \"LATE_NIGHT\";\n}\n\nexport function resolveCurrentBucket(timezone: string, now?: Date): TimeBucket {\n const date = now ?? new Date();\n const parts = getZonedDateParts(date, timezone);\n return classifyTimeBucket(parts.hour);\n}\n\n// ── Message analysis ───────────────────────────────────\n\nexport interface MessageRecord {\n entityId: string;\n roomId: string;\n createdAt: number; // epoch ms\n}\n\nexport interface CalendarEventRecord {\n startAt: string; // ISO datetime\n endAt: string;\n isAllDay: boolean;\n}\n\nexport const SUSTAINED_INACTIVITY_GAP_MS = 3 * 60 * 60 * 1000; // 3 hours\nconst ACTIVE_THRESHOLD_MS = 15 * 60 * 1000; // 15 minutes\nconst SIGNIFICANT_BUCKET_SHARE = 0.1; // 10% of total messages\nconst SCREEN_ACTIVE_FOCUS = new Set([\"work\", \"leisure\", \"transition\"]);\nconst SCREEN_ACTIVITY_CONFIDENCE_FLOOR = 0.35;\n\ntype ActivitySession = {\n startAt: number;\n endAt: number;\n startHour: number;\n normalizedEndHour: number;\n startDayKey: string;\n};\n\ntype InteractionSnapshot = {\n lastSeenAt: number;\n lastSeenPlatform: string | null;\n};\n\ntype HealthSnapshot = {\n observedAt: number;\n platform: string;\n source: string;\n isSleeping: boolean;\n sleepStartedAt: number | null;\n sleepEndedAt: number | null;\n durationMinutes: number | null;\n biometricsSampleAt: number | null;\n};\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return Boolean(value) && typeof value === \"object\" && !Array.isArray(value);\n}\n\nfunction localDateKeyForTimestamp(timestamp: number, timezone: string): string {\n return getLocalDateKey(getZonedDateParts(new Date(timestamp), timezone));\n}\n\nfunction parseTimestamp(value: string | null | undefined): number | null {\n if (!value) {\n return null;\n }\n const parsed = Date.parse(value);\n return Number.isFinite(parsed) ? parsed : null;\n}\n\nfunction parseHealthSnapshot(\n signal: ActivitySignalRecord,\n): HealthSnapshot | null {\n if (signal.source !== \"mobile_health\") {\n return null;\n }\n const health =\n signal.health ??\n (isRecord(signal.metadata.health) ? signal.metadata.health : null);\n if (!health) {\n return null;\n }\n const sleep = isRecord(health.sleep) ? health.sleep : null;\n const biometrics = isRecord(health.biometrics) ? health.biometrics : null;\n const isSleeping = Boolean(sleep?.isSleeping);\n const sleepStartedAt = parseTimestamp(\n typeof sleep?.asleepAt === \"string\" ? sleep.asleepAt : null,\n );\n const sleepEndedAt = parseTimestamp(\n typeof sleep?.awakeAt === \"string\" ? sleep.awakeAt : null,\n );\n const biometricsSampleAt = parseTimestamp(\n typeof biometrics?.sampleAt === \"string\" ? biometrics.sampleAt : null,\n );\n return {\n observedAt: signal.observedAt,\n platform: signal.platform,\n source: typeof health.source === \"string\" ? health.source : \"healthkit\",\n isSleeping,\n sleepStartedAt,\n sleepEndedAt,\n durationMinutes:\n typeof sleep?.durationMinutes === \"number\" &&\n Number.isFinite(sleep.durationMinutes)\n ? sleep.durationMinutes\n : null,\n biometricsSampleAt,\n };\n}\n\nfunction buildActivitySession(\n startAt: number,\n endAt: number,\n timezone: string,\n): ActivitySession {\n const startParts = getZonedDateParts(new Date(startAt), timezone);\n const endParts = getZonedDateParts(new Date(endAt), timezone);\n const startDayKey = getLocalDateKey(startParts);\n const startDayOrdinal = Math.floor(\n Date.UTC(startParts.year, startParts.month - 1, startParts.day) /\n 86_400_000,\n );\n const endDayOrdinal = Math.floor(\n Date.UTC(endParts.year, endParts.month - 1, endParts.day) / 86_400_000,\n );\n\n return {\n startAt,\n endAt,\n startHour: startParts.hour,\n normalizedEndHour: endParts.hour + (endDayOrdinal - startDayOrdinal) * 24,\n startDayKey,\n };\n}\n\nfunction buildActivitySessionsFromTimestamps(\n timestamps: number[],\n timezone: string,\n): ActivitySession[] {\n if (timestamps.length === 0) {\n return [];\n }\n\n const sorted = [...timestamps].sort((left, right) => left - right);\n const sessions: ActivitySession[] = [];\n let sessionStartAt = sorted[0] ?? 0;\n let sessionEndAt = sorted[0] ?? 0;\n\n for (let index = 1; index < sorted.length; index += 1) {\n const current = sorted[index] ?? 0;\n if (current - sessionEndAt > SUSTAINED_INACTIVITY_GAP_MS) {\n sessions.push(\n buildActivitySession(sessionStartAt, sessionEndAt, timezone),\n );\n sessionStartAt = current;\n }\n sessionEndAt = current;\n }\n\n sessions.push(buildActivitySession(sessionStartAt, sessionEndAt, timezone));\n return sessions;\n}\n\nfunction isActiveSignal(signal: ActivitySignalRecord, nowMs: number): boolean {\n return signal.state === \"active\" && signal.observedAt <= nowMs;\n}\n\nfunction resolveLatestInteractionSnapshot(\n messages: MessageRecord[],\n ownerEntityId: string,\n roomSourceMap: Map<string, string>,\n currentTime: Date,\n activitySignals: ActivitySignalRecord[],\n): InteractionSnapshot {\n let latestOwnerSeenAt = 0;\n let latestOwnerPlatform: string | null = null;\n let latestClientChatSeenAt = 0;\n let latestSignalSeenAt = 0;\n let latestSignalPlatform: string | null = null;\n\n for (const msg of messages) {\n if (msg.createdAt > currentTime.getTime()) {\n continue;\n }\n\n const source = roomSourceMap.get(msg.roomId) ?? \"unknown\";\n if (source === \"client_chat\" && msg.createdAt > latestClientChatSeenAt) {\n latestClientChatSeenAt = msg.createdAt;\n }\n if (msg.entityId === ownerEntityId && msg.createdAt > latestOwnerSeenAt) {\n latestOwnerSeenAt = msg.createdAt;\n latestOwnerPlatform = source;\n }\n }\n\n if (latestClientChatSeenAt > latestOwnerSeenAt) {\n latestOwnerSeenAt = latestClientChatSeenAt;\n latestOwnerPlatform = \"client_chat\";\n }\n\n for (const signal of activitySignals) {\n if (!isActiveSignal(signal, currentTime.getTime())) {\n continue;\n }\n if (signal.observedAt > latestSignalSeenAt) {\n latestSignalSeenAt = signal.observedAt;\n latestSignalPlatform = signal.platform;\n }\n }\n\n if (latestSignalSeenAt > latestOwnerSeenAt) {\n return {\n lastSeenAt: latestSignalSeenAt,\n lastSeenPlatform: latestSignalPlatform,\n };\n }\n\n return {\n lastSeenAt: latestOwnerSeenAt,\n lastSeenPlatform: latestOwnerPlatform,\n };\n}\n\nfunction resolveScreenHeartbeatAt(\n profile: Pick<\n ActivityProfile,\n | \"screenContextAvailable\"\n | \"screenContextStale\"\n | \"screenContextFocus\"\n | \"screenContextSampledAt\"\n | \"screenContextConfidence\"\n >,\n): number {\n if (!profile.screenContextAvailable || profile.screenContextStale) {\n return 0;\n }\n const sampledAt = profile.screenContextSampledAt;\n if (sampledAt === null || sampledAt <= 0) {\n return 0;\n }\n if (!SCREEN_ACTIVE_FOCUS.has(profile.screenContextFocus ?? \"unknown\")) {\n return 0;\n }\n if (\n profile.screenContextConfidence !== null &&\n profile.screenContextConfidence < SCREEN_ACTIVITY_CONFIDENCE_FLOOR\n ) {\n return 0;\n }\n return sampledAt;\n}\n\nexport type CurrentActivityState = Pick<\n ActivityProfile,\n | \"lastSeenAt\"\n | \"lastSeenPlatform\"\n | \"isCurrentlyActive\"\n | \"hasOpenActivityCycle\"\n | \"currentActivityCycleStartedAt\"\n | \"currentActivityCycleLocalDate\"\n | \"effectiveDayKey\"\n>;\n\nexport function resolveCurrentActivityState(\n profile: Pick<\n ActivityProfile,\n | \"timezone\"\n | \"lastSeenAt\"\n | \"lastSeenPlatform\"\n | \"isCurrentlySleeping\"\n | \"lastSleepSignalAt\"\n | \"lastWakeSignalAt\"\n | \"hasOpenActivityCycle\"\n | \"sustainedInactivityThresholdMinutes\"\n | \"currentActivityCycleStartedAt\"\n | \"currentActivityCycleLocalDate\"\n | \"screenContextAvailable\"\n | \"screenContextStale\"\n | \"screenContextFocus\"\n | \"screenContextSampledAt\"\n | \"screenContextConfidence\"\n >,\n now: Date,\n): CurrentActivityState {\n const currentTime = now.getTime();\n const thresholdMs = profile.sustainedInactivityThresholdMinutes * 60 * 1000;\n const screenHeartbeatAt = resolveScreenHeartbeatAt(profile);\n const sleeping = profile.isCurrentlySleeping === true;\n const sleepBoundaryAt =\n profile.lastSleepSignalAt ?? profile.lastWakeSignalAt ?? profile.lastSeenAt;\n const mostRecentActivityAt = sleeping\n ? sleepBoundaryAt\n : Math.max(profile.lastSeenAt, screenHeartbeatAt);\n const hasOpenActivityCycle =\n !sleeping &&\n mostRecentActivityAt > 0 &&\n currentTime - mostRecentActivityAt <= thresholdMs;\n const cycleStart =\n !sleeping &&\n profile.currentActivityCycleStartedAt &&\n (profile.hasOpenActivityCycle ||\n mostRecentActivityAt - profile.currentActivityCycleStartedAt <=\n thresholdMs)\n ? profile.currentActivityCycleStartedAt\n : hasOpenActivityCycle\n ? mostRecentActivityAt\n : profile.currentActivityCycleStartedAt;\n const currentActivityCycleLocalDate = cycleStart\n ? localDateKeyForTimestamp(cycleStart, profile.timezone)\n : sleeping\n ? sleepBoundaryAt > 0\n ? localDateKeyForTimestamp(sleepBoundaryAt, profile.timezone)\n : profile.currentActivityCycleLocalDate\n : profile.currentActivityCycleLocalDate;\n const effectiveDayKey = hasOpenActivityCycle\n ? (currentActivityCycleLocalDate ??\n localDateKeyForTimestamp(currentTime, profile.timezone))\n : sleeping\n ? (currentActivityCycleLocalDate ??\n localDateKeyForTimestamp(currentTime, profile.timezone))\n : localDateKeyForTimestamp(currentTime, profile.timezone);\n\n return {\n lastSeenAt: mostRecentActivityAt,\n lastSeenPlatform: profile.lastSeenPlatform,\n isCurrentlyActive:\n !sleeping &&\n mostRecentActivityAt > 0 &&\n currentTime - mostRecentActivityAt < ACTIVE_THRESHOLD_MS,\n hasOpenActivityCycle,\n currentActivityCycleStartedAt: sleeping ? null : (cycleStart ?? null),\n currentActivityCycleLocalDate,\n effectiveDayKey,\n };\n}\n\nexport function resolveEffectiveDayKey(\n profile: Pick<\n ActivityProfile,\n | \"hasOpenActivityCycle\"\n | \"currentActivityCycleStartedAt\"\n | \"currentActivityCycleLocalDate\"\n | \"lastSeenAt\"\n | \"lastSeenPlatform\"\n | \"isCurrentlySleeping\"\n | \"lastSleepSignalAt\"\n | \"lastWakeSignalAt\"\n | \"sustainedInactivityThresholdMinutes\"\n | \"screenContextAvailable\"\n | \"screenContextStale\"\n | \"screenContextFocus\"\n | \"screenContextSampledAt\"\n | \"screenContextConfidence\"\n >,\n timezone: string,\n now: Date,\n): string {\n return resolveCurrentActivityState(\n {\n ...profile,\n timezone,\n },\n now,\n ).effectiveDayKey;\n}\n\nfunction resolveLatestActivityDayKey(\n profile: Pick<\n ActivityProfile,\n | \"hasOpenActivityCycle\"\n | \"currentActivityCycleStartedAt\"\n | \"currentActivityCycleLocalDate\"\n | \"lastSeenAt\"\n | \"lastSeenPlatform\"\n | \"isCurrentlySleeping\"\n | \"lastSleepSignalAt\"\n | \"lastWakeSignalAt\"\n | \"sustainedInactivityThresholdMinutes\"\n | \"screenContextAvailable\"\n | \"screenContextStale\"\n | \"screenContextFocus\"\n | \"screenContextSampledAt\"\n | \"screenContextConfidence\"\n >,\n timezone: string,\n now: Date,\n): string | null {\n const heartbeatAt = Math.max(\n profile.lastSeenAt,\n resolveScreenHeartbeatAt(profile),\n );\n if (heartbeatAt <= 0) {\n return null;\n }\n const thresholdMs = profile.sustainedInactivityThresholdMinutes * 60 * 1000;\n if (now.getTime() - heartbeatAt <= thresholdMs) {\n if (profile.hasOpenActivityCycle && profile.currentActivityCycleStartedAt) {\n return (\n profile.currentActivityCycleLocalDate ??\n localDateKeyForTimestamp(\n profile.currentActivityCycleStartedAt,\n timezone,\n )\n );\n }\n return localDateKeyForTimestamp(heartbeatAt, timezone);\n }\n return localDateKeyForTimestamp(heartbeatAt, timezone);\n}\n\nexport function analyzeMessages(\n messages: MessageRecord[],\n roomSourceMap: Map<string, string>,\n ownerEntityId: string,\n timezone: string,\n windowDays: number,\n now?: Date,\n): Omit<\n ActivityProfile,\n | \"hasCalendarData\"\n | \"typicalFirstEventHour\"\n | \"typicalLastEventHour\"\n | \"avgWeekdayMeetings\"\n>;\nexport function analyzeMessages(\n messages: MessageRecord[],\n roomSourceMap: Map<string, string>,\n ownerEntityId: string,\n timezone: string,\n windowDays: number,\n now: Date,\n activitySignals: ActivitySignalRecord[],\n): Omit<\n ActivityProfile,\n | \"hasCalendarData\"\n | \"typicalFirstEventHour\"\n | \"typicalLastEventHour\"\n | \"avgWeekdayMeetings\"\n>;\nexport function analyzeMessages(\n messages: MessageRecord[],\n roomSourceMap: Map<string, string>,\n ownerEntityId: string,\n timezone: string,\n windowDays: number,\n activitySignals?: ActivitySignalRecord[],\n now?: Date,\n): Omit<\n ActivityProfile,\n | \"hasCalendarData\"\n | \"typicalFirstEventHour\"\n | \"typicalLastEventHour\"\n | \"avgWeekdayMeetings\"\n>;\nexport function analyzeMessages(\n messages: MessageRecord[],\n roomSourceMap: Map<string, string>,\n ownerEntityId: string,\n timezone: string,\n windowDays: number,\n firstOptionalArg?: Date | ActivitySignalRecord[],\n secondOptionalArg?: Date | ActivitySignalRecord[],\n): Omit<\n ActivityProfile,\n | \"hasCalendarData\"\n | \"typicalFirstEventHour\"\n | \"typicalLastEventHour\"\n | \"avgWeekdayMeetings\"\n> {\n const currentTime =\n firstOptionalArg instanceof Date\n ? firstOptionalArg\n : secondOptionalArg instanceof Date\n ? secondOptionalArg\n : new Date();\n const activitySignals = Array.isArray(firstOptionalArg)\n ? firstOptionalArg\n : Array.isArray(secondOptionalArg)\n ? secondOptionalArg\n : [];\n const windowStart = currentTime.getTime() - windowDays * 24 * 60 * 60 * 1000;\n\n const ownerMessages = messages.filter(\n (m) =>\n m.entityId === ownerEntityId &&\n m.createdAt >= windowStart &&\n m.createdAt <= currentTime.getTime(),\n );\n const activeSignals = activitySignals.filter(\n (signal) =>\n signal.observedAt >= windowStart &&\n isActiveSignal(signal, currentTime.getTime()),\n );\n const healthSnapshots = activitySignals\n .map((signal) => parseHealthSnapshot(signal))\n .filter((snapshot): snapshot is HealthSnapshot => snapshot !== null);\n\n const platformMap = new Map<\n string,\n {\n count: number;\n buckets: Record<TimeBucket, number>;\n lastAt: number;\n }\n >();\n\n const aggregateBuckets = emptyBucketCounts();\n\n for (const msg of ownerMessages) {\n const source = roomSourceMap.get(msg.roomId) ?? \"unknown\";\n let entry = platformMap.get(source);\n if (!entry) {\n entry = { count: 0, buckets: emptyBucketCounts(), lastAt: 0 };\n platformMap.set(source, entry);\n }\n\n entry.count++;\n if (msg.createdAt > entry.lastAt) entry.lastAt = msg.createdAt;\n\n const parts = getZonedDateParts(new Date(msg.createdAt), timezone);\n const bucket = classifyTimeBucket(parts.hour);\n entry.buckets[bucket]++;\n aggregateBuckets[bucket]++;\n }\n\n for (const signal of activeSignals) {\n const source =\n signal.platform.trim().length > 0 ? signal.platform : \"client_chat\";\n let entry = platformMap.get(source);\n if (!entry) {\n entry = { count: 0, buckets: emptyBucketCounts(), lastAt: 0 };\n platformMap.set(source, entry);\n }\n\n entry.count++;\n if (signal.observedAt > entry.lastAt) entry.lastAt = signal.observedAt;\n\n const parts = getZonedDateParts(new Date(signal.observedAt), timezone);\n const bucket = classifyTimeBucket(parts.hour);\n entry.buckets[bucket]++;\n aggregateBuckets[bucket]++;\n }\n\n const platforms: PlatformActivity[] = Array.from(platformMap.entries())\n .map(([source, data]) => ({\n source,\n messageCount: data.count,\n bucketCounts: data.buckets,\n lastMessageAt: data.lastAt,\n averageMessagesPerDay: windowDays > 0 ? data.count / windowDays : 0,\n }))\n .sort((a, b) => b.messageCount - a.messageCount);\n\n const totalMessages = ownerMessages.length;\n const activityPointCount = totalMessages + activeSignals.length;\n const threshold =\n activityPointCount > 0\n ? Math.max(activityPointCount * SIGNIFICANT_BUCKET_SHARE, 1)\n : Infinity;\n\n let typicalFirstActiveHour: number | null = null;\n let typicalLastActiveHour: number | null = null;\n\n // Walk buckets in chronological clock order so LATE_NIGHT (00:00–05:00) is\n // treated as the earliest part of the day, not the latest. ALL_TIME_BUCKETS\n // lists LATE_NIGHT last; iterating in that order would make a single 3 AM\n // message overwrite typicalLastActiveHour to 3, landing GN scheduling in\n // the past and causing it to spam every tick.\n for (const bucket of CLOCK_ORDERED_TIME_BUCKETS) {\n if (aggregateBuckets[bucket] >= threshold) {\n const midHour = bucketMidpointHour(bucket);\n if (typicalFirstActiveHour === null) typicalFirstActiveHour = midHour;\n typicalLastActiveHour = midHour;\n }\n }\n\n const sessions = buildActivitySessionsFromTimestamps(\n [\n ...ownerMessages.map((message) => message.createdAt),\n ...activeSignals.map((signal) => signal.observedAt),\n ],\n timezone,\n );\n const sleepHoursFromHealth = healthSnapshots\n .filter((snapshot) => snapshot.sleepStartedAt !== null)\n .map(\n (snapshot) =>\n getZonedDateParts(new Date(snapshot.sleepStartedAt ?? 0), timezone)\n .hour,\n );\n const wakeHoursFromHealth = healthSnapshots\n .filter((snapshot) => snapshot.sleepEndedAt !== null)\n .map(\n (snapshot) =>\n getZonedDateParts(new Date(snapshot.sleepEndedAt ?? 0), timezone).hour,\n );\n const wakeHours = sessions\n .map((session) => session.startHour)\n .concat(wakeHoursFromHealth)\n .sort((left, right) => left - right);\n const sleepHours = sessions\n .map((session) => session.normalizedEndHour)\n .concat(sleepHoursFromHealth)\n .sort((left, right) => left - right);\n const typicalWakeHour = wakeHours.length > 0 ? median(wakeHours) : null;\n const typicalSleepHour = sleepHours.length > 0 ? median(sleepHours) : null;\n const sleepDurations = healthSnapshots\n .map((snapshot) => snapshot.durationMinutes)\n .filter((value): value is number => typeof value === \"number\");\n const typicalSleepDurationMinutes =\n sleepDurations.length > 0\n ? Math.round(\n sleepDurations.reduce((sum, value) => sum + value, 0) /\n sleepDurations.length,\n )\n : null;\n const latestHealthSnapshot =\n healthSnapshots.length > 0\n ? ([...healthSnapshots].sort(\n (left, right) => right.observedAt - left.observedAt,\n )[0] ?? null)\n : null;\n const latestSleepingHealthSnapshot =\n [...healthSnapshots]\n .filter((snapshot) => snapshot.isSleeping)\n .sort((left, right) => right.observedAt - left.observedAt)[0] ?? null;\n const latestWakeHealthSnapshot =\n [...healthSnapshots]\n .filter((snapshot) => !snapshot.isSleeping)\n .sort((left, right) => right.observedAt - left.observedAt)[0] ?? null;\n\n const latestInteraction = resolveLatestInteractionSnapshot(\n messages,\n ownerEntityId,\n roomSourceMap,\n currentTime,\n activeSignals,\n );\n let lastSeenAt = latestInteraction.lastSeenAt;\n let lastSeenPlatform = latestInteraction.lastSeenPlatform;\n if (latestHealthSnapshot) {\n const healthBoundaryAt = latestHealthSnapshot.isSleeping\n ? (latestHealthSnapshot.sleepStartedAt ?? latestHealthSnapshot.observedAt)\n : (latestHealthSnapshot.sleepEndedAt ?? latestHealthSnapshot.observedAt);\n if (healthBoundaryAt > lastSeenAt) {\n lastSeenAt = healthBoundaryAt;\n lastSeenPlatform = latestHealthSnapshot.platform;\n }\n }\n const isCurrentlySleeping = latestHealthSnapshot?.isSleeping === true;\n const hasSleepData = healthSnapshots.length > 0;\n const lastSleepSignalAt =\n latestSleepingHealthSnapshot?.sleepStartedAt ??\n latestSleepingHealthSnapshot?.observedAt;\n const lastWakeSignalAt =\n latestWakeHealthSnapshot?.sleepEndedAt ??\n latestWakeHealthSnapshot?.observedAt;\n const hasOpenActivityCycle =\n !isCurrentlySleeping &&\n lastSeenAt > 0 &&\n currentTime.getTime() - lastSeenAt <= SUSTAINED_INACTIVITY_GAP_MS;\n const currentActivityCycle =\n sessions.length > 0 ? sessions[sessions.length - 1] : null;\n const latestInteractionStartsNewCycle =\n !isCurrentlySleeping &&\n lastSeenAt > 0 &&\n (!currentActivityCycle || lastSeenAt > currentActivityCycle.endAt);\n const currentActivityCycleStartedAt = latestInteractionStartsNewCycle\n ? lastSeenAt\n : isCurrentlySleeping\n ? null\n : (currentActivityCycle?.startAt ?? lastSeenAt);\n const currentActivityCycleLocalDate = latestInteractionStartsNewCycle\n ? localDateKeyForTimestamp(lastSeenAt, timezone)\n : isCurrentlySleeping\n ? lastSleepSignalAt !== null\n ? localDateKeyForTimestamp(lastSleepSignalAt, timezone)\n : localDateKeyForTimestamp(currentTime.getTime(), timezone)\n : (currentActivityCycle?.startDayKey ??\n localDateKeyForTimestamp(lastSeenAt, timezone));\n\n return {\n ownerEntityId,\n analyzedAt: currentTime.getTime(),\n analysisWindowDays: windowDays,\n timezone,\n totalMessages,\n sustainedInactivityThresholdMinutes: SUSTAINED_INACTIVITY_GAP_MS / 60_000,\n platforms,\n primaryPlatform: platforms[0]?.source ?? null,\n secondaryPlatform: platforms[1]?.source ?? null,\n bucketCounts: aggregateBuckets,\n typicalFirstActiveHour,\n typicalLastActiveHour,\n typicalWakeHour,\n typicalSleepHour,\n hasSleepData,\n isCurrentlySleeping,\n lastSleepSignalAt,\n lastWakeSignalAt,\n sleepSourcePlatform: latestHealthSnapshot?.platform ?? null,\n sleepSource: latestHealthSnapshot?.source ?? null,\n typicalSleepDurationMinutes,\n lastSeenAt,\n lastSeenPlatform,\n isCurrentlyActive:\n !isCurrentlySleeping &&\n currentTime.getTime() - lastSeenAt < ACTIVE_THRESHOLD_MS,\n hasOpenActivityCycle,\n currentActivityCycleStartedAt,\n currentActivityCycleLocalDate,\n effectiveDayKey: hasOpenActivityCycle\n ? currentActivityCycleLocalDate\n : isCurrentlySleeping\n ? currentActivityCycleLocalDate\n : localDateKeyForTimestamp(currentTime.getTime(), timezone),\n screenContextFocus: null,\n screenContextSource: null,\n screenContextSampledAt: null,\n screenContextConfidence: null,\n screenContextBusy: false,\n screenContextAvailable: false,\n screenContextStale: false,\n };\n}\n\n// ── Calendar enrichment ────────────────────────────────\n\nexport function enrichWithCalendar(\n profile: Omit<\n ActivityProfile,\n | \"hasCalendarData\"\n | \"typicalFirstEventHour\"\n | \"typicalLastEventHour\"\n | \"avgWeekdayMeetings\"\n >,\n calendarEvents: CalendarEventRecord[],\n timezone: string,\n): ActivityProfile {\n if (calendarEvents.length === 0) {\n return {\n ...profile,\n hasCalendarData: false,\n typicalFirstEventHour: null,\n typicalLastEventHour: null,\n avgWeekdayMeetings: null,\n };\n }\n\n // Filter to non-all-day events and extract local hours\n const eventHours: {\n startHour: number;\n endHour: number;\n dayOfWeek: number;\n }[] = [];\n\n for (const event of calendarEvents) {\n if (event.isAllDay) continue;\n const start = new Date(event.startAt);\n const end = new Date(event.endAt);\n const startParts = getZonedDateParts(start, timezone);\n const endParts = getZonedDateParts(end, timezone);\n const date = new Date(start);\n eventHours.push({\n startHour: startParts.hour,\n endHour: endParts.hour,\n dayOfWeek: date.getDay(), // 0=Sun, 1=Mon, ...\n });\n }\n\n if (eventHours.length === 0) {\n return {\n ...profile,\n hasCalendarData: true,\n typicalFirstEventHour: null,\n typicalLastEventHour: null,\n avgWeekdayMeetings: null,\n };\n }\n\n // Weekday events only (Mon-Fri)\n const weekdayEvents = eventHours.filter(\n (e) => e.dayOfWeek >= 1 && e.dayOfWeek <= 5,\n );\n\n // Compute median first event hour on weekdays\n const firstHours = weekdayEvents\n .map((e) => e.startHour)\n .sort((a, b) => a - b);\n const lastHours = weekdayEvents.map((e) => e.endHour).sort((a, b) => a - b);\n\n const typicalFirstEventHour =\n firstHours.length > 0 ? median(firstHours) : null;\n const typicalLastEventHour = lastHours.length > 0 ? median(lastHours) : null;\n\n // Average weekday meetings: count unique weekdays, divide total by that\n const weekdaySet = new Set(weekdayEvents.map((e) => e.dayOfWeek));\n const avgWeekdayMeetings =\n weekdaySet.size > 0\n ? Math.round((weekdayEvents.length / weekdaySet.size) * 10) / 10\n : null;\n\n return {\n ...profile,\n hasCalendarData: true,\n typicalFirstEventHour,\n typicalLastEventHour,\n avgWeekdayMeetings,\n };\n}\n\n// ── Helpers ────────────────────────────────────────────\n\nfunction bucketMidpointHour(bucket: TimeBucket): number {\n switch (bucket) {\n case \"EARLY_MORNING\":\n return 6;\n case \"MORNING\":\n return 8;\n case \"MIDDAY\":\n return 12;\n case \"AFTERNOON\":\n return 15;\n case \"EVENING\":\n return 19;\n case \"NIGHT\":\n return 22;\n case \"LATE_NIGHT\":\n return 3;\n }\n}\n\nfunction median(sorted: number[]): number {\n if (sorted.length === 0) {\n throw new Error(\"[activity-profile] median requires at least one value\");\n }\n const mid = Math.floor(sorted.length / 2);\n if (sorted.length % 2 !== 0) {\n const medianValue = sorted[mid];\n if (medianValue === undefined) {\n throw new Error(\"[activity-profile] median index out of bounds\");\n }\n return medianValue;\n }\n\n const left = sorted[mid - 1];\n const right = sorted[mid];\n if (left === undefined || right === undefined) {\n throw new Error(\"[activity-profile] median pair is missing\");\n }\n return Math.round((left + right) / 2);\n}\n\nexport function wasActiveToday(\n profile: Pick<\n ActivityProfile,\n | \"hasOpenActivityCycle\"\n | \"currentActivityCycleStartedAt\"\n | \"currentActivityCycleLocalDate\"\n | \"lastSeenAt\"\n | \"lastSeenPlatform\"\n | \"sustainedInactivityThresholdMinutes\"\n | \"isCurrentlySleeping\"\n | \"lastSleepSignalAt\"\n | \"lastWakeSignalAt\"\n | \"screenContextAvailable\"\n | \"screenContextStale\"\n | \"screenContextFocus\"\n | \"screenContextSampledAt\"\n | \"screenContextConfidence\"\n >,\n timezone: string,\n now: Date,\n): boolean {\n return (\n resolveLatestActivityDayKey(profile, timezone, now) ===\n resolveEffectiveDayKey(profile, timezone, now)\n );\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type IAgentRuntime, Service } from "@elizaos/core";
|
|
2
|
+
export declare class PresenceSignalBridgeService extends Service {
|
|
3
|
+
static readonly serviceType = "presence_signal_bridge";
|
|
4
|
+
capabilityDescription: string;
|
|
5
|
+
private readonly recentFingerprints;
|
|
6
|
+
private readonly messageReceivedHandler;
|
|
7
|
+
private readonly messageSentHandler;
|
|
8
|
+
private readonly actionStartedHandler;
|
|
9
|
+
static start(runtime: IAgentRuntime): Promise<PresenceSignalBridgeService>;
|
|
10
|
+
stop(): Promise<void>;
|
|
11
|
+
private captureActivityFromAction;
|
|
12
|
+
private captureActivityFromMessage;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=presence-signal-bridge-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presence-signal-bridge-service.d.ts","sourceRoot":"","sources":["../../src/activity-profile/presence-signal-bridge-service.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,aAAa,EAElB,OAAO,EACR,MAAM,eAAe,CAAC;AA+CvB,qBAAa,2BAA4B,SAAQ,OAAO;IACtD,gBAAyB,WAAW,4BAA4B;IAEvD,qBAAqB,SACyD;IAEvF,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAA6B;IAEhE,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAIrC;IAEF,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAIjC;IAEF,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAInC;WAEoB,KAAK,CACzB,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,2BAA2B,CAAC;IAcxB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;YAetB,yBAAyB;YA6CzB,0BAA0B;CA0CzC"}
|