@open-mercato/core 0.5.1-develop.2691.d8a0934b37 → 0.5.1-develop.2699.f8b50c8046
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/modules/api_keys/data/entities.js +1 -1
- package/dist/modules/api_keys/data/entities.js.map +1 -1
- package/dist/modules/api_keys/services/apiKeyService.js +5 -5
- package/dist/modules/api_keys/services/apiKeyService.js.map +2 -2
- package/dist/modules/attachments/api/library/[id]/route.js +1 -1
- package/dist/modules/attachments/api/library/[id]/route.js.map +2 -2
- package/dist/modules/attachments/api/library/route.js +7 -9
- package/dist/modules/attachments/api/library/route.js.map +2 -2
- package/dist/modules/attachments/api/partitions/route.js +3 -3
- package/dist/modules/attachments/api/partitions/route.js.map +2 -2
- package/dist/modules/attachments/api/route.js +6 -5
- package/dist/modules/attachments/api/route.js.map +2 -2
- package/dist/modules/attachments/api/transfer/route.js +1 -1
- package/dist/modules/attachments/api/transfer/route.js.map +2 -2
- package/dist/modules/attachments/data/entities.js +2 -1
- package/dist/modules/attachments/data/entities.js.map +2 -2
- package/dist/modules/attachments/lib/ocrQueue.js +1 -1
- package/dist/modules/attachments/lib/ocrQueue.js.map +2 -2
- package/dist/modules/audit_logs/api/audit-logs/actions/export/route.js.map +2 -2
- package/dist/modules/audit_logs/api/audit-logs/actions/route.js.map +2 -2
- package/dist/modules/audit_logs/data/entities.js +1 -1
- package/dist/modules/audit_logs/data/entities.js.map +1 -1
- package/dist/modules/audit_logs/services/actionLogService.js +77 -70
- package/dist/modules/audit_logs/services/actionLogService.js.map +2 -2
- package/dist/modules/auth/api/roles/acl/route.js +1 -1
- package/dist/modules/auth/api/roles/acl/route.js.map +2 -2
- package/dist/modules/auth/api/users/acl/route.js +2 -2
- package/dist/modules/auth/api/users/acl/route.js.map +2 -2
- package/dist/modules/auth/api/users/resend-invite/route.js +1 -1
- package/dist/modules/auth/api/users/resend-invite/route.js.map +2 -2
- package/dist/modules/auth/cli.js +12 -6
- package/dist/modules/auth/cli.js.map +2 -2
- package/dist/modules/auth/commands/users.js +1 -1
- package/dist/modules/auth/commands/users.js.map +2 -2
- package/dist/modules/auth/data/entities.js +1 -1
- package/dist/modules/auth/data/entities.js.map +2 -2
- package/dist/modules/auth/lib/setup-app.js +3 -3
- package/dist/modules/auth/lib/setup-app.js.map +2 -2
- package/dist/modules/auth/services/authService.js +2 -2
- package/dist/modules/auth/services/authService.js.map +2 -2
- package/dist/modules/business_rules/api/rules/route.js +3 -3
- package/dist/modules/business_rules/api/rules/route.js.map +2 -2
- package/dist/modules/business_rules/api/sets/[id]/members/route.js +7 -4
- package/dist/modules/business_rules/api/sets/[id]/members/route.js.map +2 -2
- package/dist/modules/business_rules/api/sets/route.js +3 -3
- package/dist/modules/business_rules/api/sets/route.js.map +2 -2
- package/dist/modules/business_rules/cli.js +1 -1
- package/dist/modules/business_rules/cli.js.map +2 -2
- package/dist/modules/business_rules/data/entities.js +2 -9
- package/dist/modules/business_rules/data/entities.js.map +2 -2
- package/dist/modules/business_rules/lib/rule-engine.js +1 -1
- package/dist/modules/business_rules/lib/rule-engine.js.map +2 -2
- package/dist/modules/catalog/api/option-schemas/route.js +0 -1
- package/dist/modules/catalog/api/option-schemas/route.js.map +2 -2
- package/dist/modules/catalog/data/entities.js +2 -11
- package/dist/modules/catalog/data/entities.js.map +2 -2
- package/dist/modules/configs/data/entities.js +2 -1
- package/dist/modules/configs/data/entities.js.map +2 -2
- package/dist/modules/currencies/commands/fetch-configs.js +3 -3
- package/dist/modules/currencies/commands/fetch-configs.js.map +2 -2
- package/dist/modules/currencies/data/entities.js +1 -1
- package/dist/modules/currencies/data/entities.js.map +2 -2
- package/dist/modules/customer_accounts/api/signup.js +1 -1
- package/dist/modules/customer_accounts/api/signup.js.map +2 -2
- package/dist/modules/customer_accounts/data/entities.js +1 -1
- package/dist/modules/customer_accounts/data/entities.js.map +2 -2
- package/dist/modules/customer_accounts/services/customerInvitationService.js +1 -1
- package/dist/modules/customer_accounts/services/customerInvitationService.js.map +2 -2
- package/dist/modules/customer_accounts/services/customerSessionService.js +1 -1
- package/dist/modules/customer_accounts/services/customerSessionService.js.map +2 -2
- package/dist/modules/customer_accounts/services/customerTokenService.js +12 -7
- package/dist/modules/customer_accounts/services/customerTokenService.js.map +2 -2
- package/dist/modules/customers/api/interactions/conflicts/route.js +19 -17
- package/dist/modules/customers/api/interactions/conflicts/route.js.map +2 -2
- package/dist/modules/customers/api/interactions/counts/route.js +7 -6
- package/dist/modules/customers/api/interactions/counts/route.js.map +2 -2
- package/dist/modules/customers/api/interactions/route.js +28 -42
- package/dist/modules/customers/api/interactions/route.js.map +2 -2
- package/dist/modules/customers/api/utils.js +29 -24
- package/dist/modules/customers/api/utils.js.map +2 -2
- package/dist/modules/customers/cli.js +45 -40
- package/dist/modules/customers/cli.js.map +2 -2
- package/dist/modules/customers/commands/dictionaries.js +1 -1
- package/dist/modules/customers/commands/dictionaries.js.map +2 -2
- package/dist/modules/customers/commands/tags.js +1 -1
- package/dist/modules/customers/commands/tags.js.map +2 -2
- package/dist/modules/customers/data/entities.js +2 -12
- package/dist/modules/customers/data/entities.js.map +2 -2
- package/dist/modules/customers/lib/interactionProjection.js +18 -15
- package/dist/modules/customers/lib/interactionProjection.js.map +2 -2
- package/dist/modules/customers/lib/personCompanyLinkTable.js +6 -8
- package/dist/modules/customers/lib/personCompanyLinkTable.js.map +2 -2
- package/dist/modules/dashboards/api/roles/widgets/route.js +1 -1
- package/dist/modules/dashboards/api/roles/widgets/route.js.map +2 -2
- package/dist/modules/dashboards/api/users/widgets/route.js +1 -1
- package/dist/modules/dashboards/api/users/widgets/route.js.map +2 -2
- package/dist/modules/dashboards/data/entities.js +1 -1
- package/dist/modules/dashboards/data/entities.js.map +1 -1
- package/dist/modules/data_sync/api/mappings/route.js +1 -1
- package/dist/modules/data_sync/api/mappings/route.js.map +2 -2
- package/dist/modules/data_sync/data/entities.js +2 -1
- package/dist/modules/data_sync/data/entities.js.map +2 -2
- package/dist/modules/data_sync/lib/id-mapping.js +1 -1
- package/dist/modules/data_sync/lib/id-mapping.js.map +2 -2
- package/dist/modules/data_sync/lib/sync-run-service.js +1 -1
- package/dist/modules/data_sync/lib/sync-run-service.js.map +2 -2
- package/dist/modules/dictionaries/commands/factory.js +1 -1
- package/dist/modules/dictionaries/commands/factory.js.map +2 -2
- package/dist/modules/dictionaries/data/entities.js +2 -9
- package/dist/modules/dictionaries/data/entities.js.map +2 -2
- package/dist/modules/directory/commands/organizations.js +4 -4
- package/dist/modules/directory/commands/organizations.js.map +2 -2
- package/dist/modules/directory/data/entities.js +2 -1
- package/dist/modules/directory/data/entities.js.map +2 -2
- package/dist/modules/entities/api/definitions.js +2 -2
- package/dist/modules/entities/api/definitions.js.map +2 -2
- package/dist/modules/entities/api/encryption.js +2 -2
- package/dist/modules/entities/api/encryption.js.map +2 -2
- package/dist/modules/entities/api/relations/options.js +2 -2
- package/dist/modules/entities/api/relations/options.js.map +2 -2
- package/dist/modules/entities/cli.js +4 -4
- package/dist/modules/entities/cli.js.map +2 -2
- package/dist/modules/entities/data/entities.js +1 -1
- package/dist/modules/entities/data/entities.js.map +2 -2
- package/dist/modules/entities/lib/field-definitions.js +2 -2
- package/dist/modules/entities/lib/field-definitions.js.map +2 -2
- package/dist/modules/entities/lib/register.js +1 -1
- package/dist/modules/entities/lib/register.js.map +2 -2
- package/dist/modules/feature_toggles/data/entities.js +2 -9
- package/dist/modules/feature_toggles/data/entities.js.map +2 -2
- package/dist/modules/inbox_ops/api/proposals/counts/route.js +3 -6
- package/dist/modules/inbox_ops/api/proposals/counts/route.js.map +2 -2
- package/dist/modules/inbox_ops/data/entities.js +2 -8
- package/dist/modules/inbox_ops/data/entities.js.map +2 -2
- package/dist/modules/inbox_ops/lib/messagesIntegration.js +6 -6
- package/dist/modules/inbox_ops/lib/messagesIntegration.js.map +2 -2
- package/dist/modules/integrations/data/entities.js +2 -1
- package/dist/modules/integrations/data/entities.js.map +2 -2
- package/dist/modules/integrations/lib/credentials-service.js +1 -1
- package/dist/modules/integrations/lib/credentials-service.js.map +2 -2
- package/dist/modules/integrations/lib/log-service.js +1 -1
- package/dist/modules/integrations/lib/log-service.js.map +2 -2
- package/dist/modules/integrations/lib/state-service.js +1 -1
- package/dist/modules/integrations/lib/state-service.js.map +2 -2
- package/dist/modules/messages/api/route.js +90 -93
- package/dist/modules/messages/api/route.js.map +2 -2
- package/dist/modules/messages/api/unread-count/route.js +8 -7
- package/dist/modules/messages/api/unread-count/route.js.map +2 -2
- package/dist/modules/messages/commands/confirmations.js +1 -1
- package/dist/modules/messages/commands/confirmations.js.map +2 -2
- package/dist/modules/messages/commands/messages.js +3 -3
- package/dist/modules/messages/commands/messages.js.map +2 -2
- package/dist/modules/messages/data/entities.js +2 -1
- package/dist/modules/messages/data/entities.js.map +2 -2
- package/dist/modules/messages/lib/email-sender.js +1 -1
- package/dist/modules/messages/lib/email-sender.js.map +2 -2
- package/dist/modules/messages/lib/searchLookup.js +8 -8
- package/dist/modules/messages/lib/searchLookup.js.map +2 -2
- package/dist/modules/messages/lib/tokenConsumption.js +9 -4
- package/dist/modules/messages/lib/tokenConsumption.js.map +2 -2
- package/dist/modules/notifications/data/entities.js +2 -1
- package/dist/modules/notifications/data/entities.js.map +2 -2
- package/dist/modules/notifications/lib/notificationRecipients.js +15 -5
- package/dist/modules/notifications/lib/notificationRecipients.js.map +2 -2
- package/dist/modules/notifications/lib/notificationService.js +39 -34
- package/dist/modules/notifications/lib/notificationService.js.map +2 -2
- package/dist/modules/notifications/workers/create-notification.worker.js +14 -13
- package/dist/modules/notifications/workers/create-notification.worker.js.map +2 -2
- package/dist/modules/payment_gateways/api/transactions/route.js +2 -2
- package/dist/modules/payment_gateways/api/transactions/route.js.map +2 -2
- package/dist/modules/payment_gateways/data/entities.js +2 -1
- package/dist/modules/payment_gateways/data/entities.js.map +2 -2
- package/dist/modules/payment_gateways/lib/gateway-service.js +1 -1
- package/dist/modules/payment_gateways/lib/gateway-service.js.map +2 -2
- package/dist/modules/payment_gateways/lib/webhook-utils.js +2 -2
- package/dist/modules/payment_gateways/lib/webhook-utils.js.map +2 -2
- package/dist/modules/perspectives/data/entities.js +1 -1
- package/dist/modules/perspectives/data/entities.js.map +2 -2
- package/dist/modules/planner/data/entities.js +1 -1
- package/dist/modules/planner/data/entities.js.map +2 -2
- package/dist/modules/progress/data/entities.js +2 -1
- package/dist/modules/progress/data/entities.js.map +2 -2
- package/dist/modules/progress/lib/progressServiceImpl.js +1 -1
- package/dist/modules/progress/lib/progressServiceImpl.js.map +2 -2
- package/dist/modules/query_index/api/status.js +66 -57
- package/dist/modules/query_index/api/status.js.map +2 -2
- package/dist/modules/query_index/cli.js +39 -24
- package/dist/modules/query_index/cli.js.map +2 -2
- package/dist/modules/query_index/data/entities.js +1 -1
- package/dist/modules/query_index/data/entities.js.map +2 -2
- package/dist/modules/query_index/di.js +25 -13
- package/dist/modules/query_index/di.js.map +2 -2
- package/dist/modules/query_index/lib/batch.js +31 -33
- package/dist/modules/query_index/lib/batch.js.map +2 -2
- package/dist/modules/query_index/lib/coverage.js +63 -50
- package/dist/modules/query_index/lib/coverage.js.map +2 -2
- package/dist/modules/query_index/lib/engine.js +592 -588
- package/dist/modules/query_index/lib/engine.js.map +2 -2
- package/dist/modules/query_index/lib/indexer.js +74 -47
- package/dist/modules/query_index/lib/indexer.js.map +2 -2
- package/dist/modules/query_index/lib/jobs.js +37 -24
- package/dist/modules/query_index/lib/jobs.js.map +2 -2
- package/dist/modules/query_index/lib/purge.js +19 -11
- package/dist/modules/query_index/lib/purge.js.map +2 -2
- package/dist/modules/query_index/lib/reindexer.js +47 -44
- package/dist/modules/query_index/lib/reindexer.js.map +2 -2
- package/dist/modules/query_index/lib/search-tokens.js +47 -25
- package/dist/modules/query_index/lib/search-tokens.js.map +2 -2
- package/dist/modules/query_index/lib/stale.js +14 -12
- package/dist/modules/query_index/lib/stale.js.map +2 -2
- package/dist/modules/query_index/lib/subscriber-scope.js +2 -2
- package/dist/modules/query_index/lib/subscriber-scope.js.map +2 -2
- package/dist/modules/query_index/subscribers/delete_one.js +3 -2
- package/dist/modules/query_index/subscribers/delete_one.js.map +2 -2
- package/dist/modules/resources/commands/tag-assignments.js +1 -1
- package/dist/modules/resources/commands/tag-assignments.js.map +2 -2
- package/dist/modules/resources/commands/tags.js +1 -1
- package/dist/modules/resources/commands/tags.js.map +2 -2
- package/dist/modules/resources/data/entities.js +2 -1
- package/dist/modules/resources/data/entities.js.map +2 -2
- package/dist/modules/sales/commands/documentAddresses.js +2 -2
- package/dist/modules/sales/commands/documentAddresses.js.map +2 -2
- package/dist/modules/sales/commands/notes.js.map +2 -2
- package/dist/modules/sales/commands/tags.js +1 -1
- package/dist/modules/sales/commands/tags.js.map +2 -2
- package/dist/modules/sales/data/enrichers.js +9 -8
- package/dist/modules/sales/data/enrichers.js.map +2 -2
- package/dist/modules/sales/data/entities.js +2 -11
- package/dist/modules/sales/data/entities.js.map +2 -2
- package/dist/modules/shipping_carriers/data/entities.js +2 -1
- package/dist/modules/shipping_carriers/data/entities.js.map +2 -2
- package/dist/modules/shipping_carriers/lib/shipping-service.js +1 -1
- package/dist/modules/shipping_carriers/lib/shipping-service.js.map +2 -2
- package/dist/modules/shipping_carriers/lib/webhook-utils.js +2 -2
- package/dist/modules/shipping_carriers/lib/webhook-utils.js.map +2 -2
- package/dist/modules/staff/data/entities.js +1 -1
- package/dist/modules/staff/data/entities.js.map +2 -2
- package/dist/modules/translations/api/[entityType]/[entityId]/route.js +3 -5
- package/dist/modules/translations/api/[entityType]/[entityId]/route.js.map +2 -2
- package/dist/modules/translations/api/context.js +2 -2
- package/dist/modules/translations/api/context.js.map +2 -2
- package/dist/modules/translations/commands/translations.js +46 -39
- package/dist/modules/translations/commands/translations.js.map +2 -2
- package/dist/modules/translations/components/TranslationManager.js +19 -10
- package/dist/modules/translations/components/TranslationManager.js.map +2 -2
- package/dist/modules/translations/data/entities.js +1 -1
- package/dist/modules/translations/data/entities.js.map +2 -2
- package/dist/modules/translations/lib/apply.js +4 -4
- package/dist/modules/translations/lib/apply.js.map +2 -2
- package/dist/modules/translations/lib/batch.js +3 -2
- package/dist/modules/translations/lib/batch.js.map +2 -2
- package/dist/modules/translations/subscribers/cleanup.js +3 -5
- package/dist/modules/translations/subscribers/cleanup.js.map +2 -2
- package/dist/modules/workflows/api/definitions/route.js +1 -1
- package/dist/modules/workflows/api/definitions/route.js.map +2 -2
- package/dist/modules/workflows/cli.js +5 -5
- package/dist/modules/workflows/cli.js.map +2 -2
- package/dist/modules/workflows/data/entities.js +2 -1
- package/dist/modules/workflows/data/entities.js.map +2 -2
- package/dist/modules/workflows/lib/event-logger.js +2 -2
- package/dist/modules/workflows/lib/event-logger.js.map +2 -2
- package/dist/modules/workflows/lib/seeds.js +16 -1
- package/dist/modules/workflows/lib/seeds.js.map +2 -2
- package/dist/modules/workflows/lib/step-handler.js +3 -3
- package/dist/modules/workflows/lib/step-handler.js.map +2 -2
- package/dist/modules/workflows/lib/task-handler.js +1 -1
- package/dist/modules/workflows/lib/task-handler.js.map +2 -2
- package/dist/modules/workflows/lib/transition-handler.js +1 -1
- package/dist/modules/workflows/lib/transition-handler.js.map +2 -2
- package/dist/modules/workflows/lib/workflow-executor.js +2 -2
- package/dist/modules/workflows/lib/workflow-executor.js.map +2 -2
- package/jest.config.cjs +4 -2
- package/package.json +3 -3
- package/src/modules/api_keys/data/entities.ts +1 -1
- package/src/modules/api_keys/services/apiKeyService.ts +5 -5
- package/src/modules/attachments/api/library/[id]/route.ts +1 -1
- package/src/modules/attachments/api/library/route.ts +10 -12
- package/src/modules/attachments/api/partitions/route.ts +3 -3
- package/src/modules/attachments/api/route.ts +10 -8
- package/src/modules/attachments/api/transfer/route.ts +1 -1
- package/src/modules/attachments/data/entities.ts +2 -1
- package/src/modules/attachments/lib/ocrQueue.ts +1 -1
- package/src/modules/audit_logs/api/audit-logs/actions/export/route.ts +4 -4
- package/src/modules/audit_logs/api/audit-logs/actions/route.ts +4 -4
- package/src/modules/audit_logs/data/entities.ts +1 -1
- package/src/modules/audit_logs/services/actionLogService.ts +96 -87
- package/src/modules/auth/api/roles/acl/route.ts +1 -1
- package/src/modules/auth/api/users/acl/route.ts +2 -2
- package/src/modules/auth/api/users/resend-invite/route.ts +1 -1
- package/src/modules/auth/cli.ts +46 -40
- package/src/modules/auth/commands/users.ts +1 -1
- package/src/modules/auth/data/entities.ts +1 -1
- package/src/modules/auth/lib/setup-app.ts +3 -3
- package/src/modules/auth/services/authService.ts +2 -2
- package/src/modules/business_rules/api/rules/route.ts +3 -3
- package/src/modules/business_rules/api/sets/[id]/members/route.ts +7 -4
- package/src/modules/business_rules/api/sets/route.ts +3 -3
- package/src/modules/business_rules/cli.ts +1 -1
- package/src/modules/business_rules/data/entities.ts +2 -9
- package/src/modules/business_rules/lib/rule-engine.ts +1 -1
- package/src/modules/catalog/api/option-schemas/route.ts +0 -1
- package/src/modules/catalog/data/entities.ts +2 -11
- package/src/modules/configs/data/entities.ts +2 -1
- package/src/modules/currencies/commands/fetch-configs.ts +3 -3
- package/src/modules/currencies/data/entities.ts +1 -1
- package/src/modules/customer_accounts/api/signup.ts +1 -1
- package/src/modules/customer_accounts/data/entities.ts +1 -1
- package/src/modules/customer_accounts/services/customerInvitationService.ts +1 -1
- package/src/modules/customer_accounts/services/customerSessionService.ts +1 -1
- package/src/modules/customer_accounts/services/customerTokenService.ts +26 -15
- package/src/modules/customers/api/interactions/conflicts/route.ts +26 -23
- package/src/modules/customers/api/interactions/counts/route.ts +13 -11
- package/src/modules/customers/api/interactions/route.ts +32 -44
- package/src/modules/customers/api/utils.ts +45 -37
- package/src/modules/customers/cli.ts +88 -67
- package/src/modules/customers/commands/dictionaries.ts +1 -1
- package/src/modules/customers/commands/tags.ts +1 -1
- package/src/modules/customers/data/entities.ts +2 -12
- package/src/modules/customers/lib/interactionProjection.ts +36 -25
- package/src/modules/customers/lib/personCompanyLinkTable.ts +13 -18
- package/src/modules/dashboards/api/roles/widgets/route.ts +1 -1
- package/src/modules/dashboards/api/users/widgets/route.ts +1 -1
- package/src/modules/dashboards/data/entities.ts +1 -1
- package/src/modules/data_sync/api/mappings/route.ts +1 -1
- package/src/modules/data_sync/data/entities.ts +2 -1
- package/src/modules/data_sync/lib/id-mapping.ts +1 -1
- package/src/modules/data_sync/lib/sync-run-service.ts +1 -1
- package/src/modules/dictionaries/commands/factory.ts +1 -1
- package/src/modules/dictionaries/data/entities.ts +2 -9
- package/src/modules/directory/commands/organizations.ts +4 -4
- package/src/modules/directory/data/entities.ts +2 -1
- package/src/modules/entities/api/definitions.ts +2 -2
- package/src/modules/entities/api/encryption.ts +2 -2
- package/src/modules/entities/api/relations/options.ts +8 -3
- package/src/modules/entities/cli.ts +4 -4
- package/src/modules/entities/data/entities.ts +1 -1
- package/src/modules/entities/lib/field-definitions.ts +2 -2
- package/src/modules/entities/lib/register.ts +1 -1
- package/src/modules/feature_toggles/data/entities.ts +2 -9
- package/src/modules/inbox_ops/api/proposals/counts/route.ts +10 -10
- package/src/modules/inbox_ops/data/entities.ts +2 -8
- package/src/modules/inbox_ops/lib/messagesIntegration.ts +12 -11
- package/src/modules/integrations/data/entities.ts +2 -1
- package/src/modules/integrations/lib/credentials-service.ts +1 -1
- package/src/modules/integrations/lib/log-service.ts +1 -1
- package/src/modules/integrations/lib/state-service.ts +1 -1
- package/src/modules/messages/api/route.ts +134 -123
- package/src/modules/messages/api/unread-count/route.ts +19 -16
- package/src/modules/messages/commands/confirmations.ts +1 -1
- package/src/modules/messages/commands/messages.ts +3 -3
- package/src/modules/messages/data/entities.ts +2 -1
- package/src/modules/messages/lib/email-sender.ts +1 -1
- package/src/modules/messages/lib/searchLookup.ts +16 -13
- package/src/modules/messages/lib/tokenConsumption.ts +16 -8
- package/src/modules/notifications/data/entities.ts +2 -1
- package/src/modules/notifications/lib/notificationRecipients.ts +42 -26
- package/src/modules/notifications/lib/notificationService.ts +53 -42
- package/src/modules/notifications/workers/create-notification.worker.ts +20 -17
- package/src/modules/payment_gateways/api/transactions/route.ts +2 -2
- package/src/modules/payment_gateways/data/entities.ts +2 -1
- package/src/modules/payment_gateways/lib/gateway-service.ts +1 -1
- package/src/modules/payment_gateways/lib/webhook-utils.ts +2 -2
- package/src/modules/perspectives/data/entities.ts +1 -1
- package/src/modules/planner/data/entities.ts +1 -1
- package/src/modules/progress/data/entities.ts +2 -1
- package/src/modules/progress/lib/progressServiceImpl.ts +1 -1
- package/src/modules/query_index/api/status.ts +85 -71
- package/src/modules/query_index/cli.ts +51 -31
- package/src/modules/query_index/data/entities.ts +1 -1
- package/src/modules/query_index/di.ts +41 -16
- package/src/modules/query_index/lib/batch.ts +68 -55
- package/src/modules/query_index/lib/coverage.ts +115 -88
- package/src/modules/query_index/lib/engine.ts +1036 -1096
- package/src/modules/query_index/lib/indexer.ts +115 -79
- package/src/modules/query_index/lib/jobs.ts +51 -31
- package/src/modules/query_index/lib/purge.ts +25 -19
- package/src/modules/query_index/lib/reindexer.ts +97 -84
- package/src/modules/query_index/lib/search-tokens.ts +67 -36
- package/src/modules/query_index/lib/stale.ts +14 -17
- package/src/modules/query_index/lib/subscriber-scope.ts +6 -5
- package/src/modules/query_index/subscribers/delete_one.ts +9 -6
- package/src/modules/resources/commands/tag-assignments.ts +1 -1
- package/src/modules/resources/commands/tags.ts +1 -1
- package/src/modules/resources/data/entities.ts +2 -1
- package/src/modules/sales/commands/documentAddresses.ts +2 -2
- package/src/modules/sales/commands/notes.ts +1 -1
- package/src/modules/sales/commands/tags.ts +1 -1
- package/src/modules/sales/data/enrichers.ts +17 -13
- package/src/modules/sales/data/entities.ts +2 -11
- package/src/modules/shipping_carriers/data/entities.ts +2 -1
- package/src/modules/shipping_carriers/lib/shipping-service.ts +1 -1
- package/src/modules/shipping_carriers/lib/webhook-utils.ts +2 -2
- package/src/modules/staff/data/entities.ts +1 -1
- package/src/modules/translations/api/[entityType]/[entityId]/route.ts +14 -11
- package/src/modules/translations/api/context.ts +4 -4
- package/src/modules/translations/commands/translations.ts +116 -81
- package/src/modules/translations/components/TranslationManager.tsx +23 -14
- package/src/modules/translations/data/entities.ts +1 -1
- package/src/modules/translations/i18n/de.json +1 -0
- package/src/modules/translations/i18n/en.json +1 -0
- package/src/modules/translations/i18n/es.json +1 -0
- package/src/modules/translations/i18n/pl.json +1 -0
- package/src/modules/translations/lib/apply.ts +6 -6
- package/src/modules/translations/lib/batch.ts +9 -7
- package/src/modules/translations/subscribers/cleanup.ts +10 -11
- package/src/modules/workflows/api/definitions/route.ts +1 -1
- package/src/modules/workflows/cli.ts +5 -5
- package/src/modules/workflows/data/entities.ts +2 -1
- package/src/modules/workflows/lib/event-logger.ts +2 -2
- package/src/modules/workflows/lib/seeds.ts +16 -1
- package/src/modules/workflows/lib/step-handler.ts +3 -3
- package/src/modules/workflows/lib/task-handler.ts +1 -1
- package/src/modules/workflows/lib/transition-handler.ts +1 -1
- package/src/modules/workflows/lib/workflow-executor.ts +2 -2
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/modules/customers/data/entities.ts"],
|
|
4
|
-
"sourcesContent": ["import {\n Entity,\n PrimaryKey,\n Property,\n Index,\n Unique,\n OneToOne,\n OneToMany,\n ManyToOne,\n Collection,\n OptionalProps,\n} from '@mikro-orm/core'\n\nexport type CustomerEntityKind = 'person' | 'company'\nexport type CustomerAddressFormat = 'line_first' | 'street_first'\n\n@Entity({ tableName: 'customer_entities' })\n@Index({ name: 'customer_entities_org_tenant_kind_idx', properties: ['organizationId', 'tenantId', 'kind'] })\n@Index({\n name: 'idx_ce_tenant_org_person_id',\n expression:\n `create index \"idx_ce_tenant_org_person_id\" on \"customer_entities\" (\"tenant_id\", \"organization_id\", \"id\") where deleted_at is null and kind = 'person'`,\n})\n@Index({\n name: 'idx_ce_tenant_org_company_id',\n expression:\n `create index \"idx_ce_tenant_org_company_id\" on \"customer_entities\" (\"tenant_id\", \"organization_id\", \"id\") where deleted_at is null and kind = 'company'`,\n})\n@Index({\n name: 'idx_ce_tenant_company_id',\n expression:\n `create index \"idx_ce_tenant_company_id\" on \"customer_entities\" (\"tenant_id\", \"id\") where deleted_at is null and kind = 'company'`,\n})\n@Index({\n name: 'idx_ce_tenant_person_id',\n expression:\n `create index \"idx_ce_tenant_person_id\" on \"customer_entities\" (\"tenant_id\", \"id\") where deleted_at is null and kind = 'person'`,\n})\nexport class CustomerEntity {\n [OptionalProps]?: 'isActive' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: CustomerEntityKind\n\n @Property({ name: 'display_name', type: 'text' })\n displayName!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'primary_email', type: 'text', nullable: true })\n primaryEmail?: string | null\n\n @Property({ name: 'primary_phone', type: 'text', nullable: true })\n primaryPhone?: string | null\n\n @Property({ name: 'status', type: 'text', nullable: true })\n status?: string | null\n\n @Property({ name: 'lifecycle_stage', type: 'text', nullable: true })\n lifecycleStage?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'temperature', type: 'text', nullable: true })\n temperature?: string | null\n\n @Property({ name: 'renewal_quarter', type: 'text', nullable: true })\n renewalQuarter?: string | null\n\n @Property({ name: 'next_interaction_at', type: Date, nullable: true })\n nextInteractionAt?: Date | null\n\n @Property({ name: 'next_interaction_name', type: 'text', nullable: true })\n nextInteractionName?: string | null\n\n @Property({ name: 'next_interaction_ref_id', type: 'text', nullable: true })\n nextInteractionRefId?: string | null\n\n @Property({ name: 'next_interaction_icon', type: 'text', nullable: true })\n nextInteractionIcon?: string | null\n\n @Property({ name: 'next_interaction_color', type: 'text', nullable: true })\n nextInteractionColor?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @OneToOne(() => CustomerPersonProfile, (profile) => profile.entity, { nullable: true, mappedBy: 'entity' })\n personProfile?: CustomerPersonProfile | null\n\n @OneToOne(() => CustomerCompanyProfile, (profile) => profile.entity, { nullable: true, mappedBy: 'entity' })\n companyProfile?: CustomerCompanyProfile | null\n\n @OneToMany(() => CustomerAddress, (address) => address.entity)\n addresses = new Collection<CustomerAddress>(this)\n\n @OneToMany(() => CustomerActivity, (activity) => activity.entity)\n activities = new Collection<CustomerActivity>(this)\n\n @OneToMany(() => CustomerComment, (comment) => comment.entity)\n comments = new Collection<CustomerComment>(this)\n\n @OneToMany(() => CustomerTagAssignment, (assignment) => assignment.entity)\n tagAssignments = new Collection<CustomerTagAssignment>(this)\n\n @OneToMany(() => CustomerTodoLink, (link) => link.entity)\n todoLinks = new Collection<CustomerTodoLink>(this)\n\n @OneToMany(() => CustomerInteraction, (interaction) => interaction.entity)\n interactions = new Collection<CustomerInteraction>(this)\n\n @OneToMany(() => CustomerDealPersonLink, (link) => link.person)\n dealPersonLinks = new Collection<CustomerDealPersonLink>(this)\n\n @OneToMany(() => CustomerDealCompanyLink, (link) => link.company)\n dealCompanyLinks = new Collection<CustomerDealCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonCompanyLink, (link) => link.person)\n personCompanyLinks = new Collection<CustomerPersonCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonCompanyLink, (link) => link.company)\n linkedPeople = new Collection<CustomerPersonCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonProfile, (person) => person.company)\n companyMembers = new Collection<CustomerPersonProfile>(this)\n}\n\n@Entity({ tableName: 'customer_people' })\n@Index({ name: 'customer_people_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'idx_customer_people_entity_id',\n expression:\n `create index \"idx_customer_people_entity_id\" on \"customer_people\" (\"entity_id\")`,\n})\nexport class CustomerPersonProfile {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'first_name', type: 'text', nullable: true })\n firstName?: string | null\n\n @Property({ name: 'last_name', type: 'text', nullable: true })\n lastName?: string | null\n\n @Property({ name: 'preferred_name', type: 'text', nullable: true })\n preferredName?: string | null\n\n @Property({ name: 'job_title', type: 'text', nullable: true })\n jobTitle?: string | null\n\n @Property({ name: 'department', type: 'text', nullable: true })\n department?: string | null\n\n @Property({ name: 'seniority', type: 'text', nullable: true })\n seniority?: string | null\n\n @Property({ name: 'timezone', type: 'text', nullable: true })\n timezone?: string | null\n\n @Property({ name: 'linked_in_url', type: 'text', nullable: true })\n linkedInUrl?: string | null\n\n @Property({ name: 'twitter_url', type: 'text', nullable: true })\n twitterUrl?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToOne(() => CustomerEntity, (entity) => entity.personProfile, {\n fieldName: 'entity_id',\n owner: true,\n })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, {\n fieldName: 'company_entity_id',\n nullable: true,\n })\n company?: CustomerEntity | null\n}\n\n@Entity({ tableName: 'customer_person_company_links' })\n@Index({ name: 'customer_person_company_links_person_idx', properties: ['person'] })\n@Index({ name: 'customer_person_company_links_company_idx', properties: ['company'] })\n@Index({ name: 'customer_person_company_links_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_person_company_links_active_unique',\n expression:\n `create unique index \"customer_person_company_links_active_unique\" on \"customer_person_company_links\" (\"person_entity_id\", \"company_entity_id\") where \"deleted_at\" is null`,\n})\nexport class CustomerPersonCompanyLink {\n [OptionalProps]?: 'isPrimary' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n person!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n company!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_companies' })\n@Index({ name: 'customer_companies_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'idx_customer_companies_entity_id',\n expression:\n `create index \"idx_customer_companies_entity_id\" on \"customer_companies\" (\"entity_id\")`,\n})\nexport class CustomerCompanyProfile {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'legal_name', type: 'text', nullable: true })\n legalName?: string | null\n\n @Property({ name: 'brand_name', type: 'text', nullable: true })\n brandName?: string | null\n\n @Property({ name: 'domain', type: 'text', nullable: true })\n domain?: string | null\n\n @Property({ name: 'website_url', type: 'text', nullable: true })\n websiteUrl?: string | null\n\n @Property({ name: 'industry', type: 'text', nullable: true })\n industry?: string | null\n\n @Property({ name: 'size_bucket', type: 'text', nullable: true })\n sizeBucket?: string | null\n\n @Property({ name: 'annual_revenue', type: 'numeric', precision: 16, scale: 2, nullable: true })\n annualRevenue?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToOne(() => CustomerEntity, (entity) => entity.companyProfile, {\n fieldName: 'entity_id',\n owner: true,\n })\n entity!: CustomerEntity\n\n}\n\n@Entity({ tableName: 'customer_deals' })\n@Index({ name: 'customer_deals_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_deals_closure_stats_idx',\n properties: ['organizationId', 'tenantId', 'closureOutcome', 'updatedAt'],\n})\nexport class CustomerDeal {\n [OptionalProps]?: 'status' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n title!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'status', type: 'text', default: 'open' })\n status: string = 'open'\n\n @Property({ name: 'pipeline_stage', type: 'text', nullable: true })\n pipelineStage?: string | null\n\n @Property({ name: 'pipeline_id', type: 'uuid', nullable: true })\n pipelineId?: string | null\n\n @Property({ name: 'pipeline_stage_id', type: 'uuid', nullable: true })\n pipelineStageId?: string | null\n\n @Property({ name: 'value_amount', type: 'numeric', precision: 14, scale: 2, nullable: true })\n valueAmount?: string | null\n\n @Property({ name: 'value_currency', type: 'text', nullable: true })\n valueCurrency?: string | null\n\n @Property({ name: 'probability', type: 'int', nullable: true })\n probability?: number | null\n\n @Property({ name: 'expected_close_at', type: Date, nullable: true })\n expectedCloseAt?: Date | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'closure_outcome', type: 'text', nullable: true })\n closureOutcome?: string | null\n\n @Property({ name: 'loss_reason_id', type: 'uuid', nullable: true })\n lossReasonId?: string | null\n\n @Property({ name: 'loss_notes', type: 'text', nullable: true })\n lossNotes?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @OneToMany(() => CustomerDealPersonLink, (link) => link.deal)\n people = new Collection<CustomerDealPersonLink>(this)\n\n @OneToMany(() => CustomerDealCompanyLink, (link) => link.deal)\n companies = new Collection<CustomerDealCompanyLink>(this)\n\n @OneToMany(() => CustomerActivity, (activity) => activity.deal)\n activities = new Collection<CustomerActivity>(this)\n\n @OneToMany(() => CustomerComment, (comment) => comment.deal)\n comments = new Collection<CustomerComment>(this)\n\n @OneToMany(() => CustomerDealStageTransition, (transition) => transition.deal)\n stageTransitions = new Collection<CustomerDealStageTransition>(this)\n}\n\n@Entity({ tableName: 'customer_deal_stage_transitions' })\n@Index({ name: 'customer_deal_stage_transitions_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_stage_transitions_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_deal_stage_transitions_deal_stage_uq', properties: ['deal', 'stageId'] })\nexport class CustomerDealStageTransition {\n [OptionalProps]?: 'isActive' | 'createdAt' | 'updatedAt' | 'deletedAt' | 'transitionedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'pipeline_id', type: 'uuid' })\n pipelineId!: string\n\n @Property({ name: 'stage_id', type: 'uuid' })\n stageId!: string\n\n @Property({ name: 'stage_label', type: 'text' })\n stageLabel!: string\n\n @Property({ name: 'stage_order', type: 'int' })\n stageOrder!: number\n\n @Property({ name: 'transitioned_at', type: Date, onCreate: () => new Date() })\n transitionedAt: Date = new Date()\n\n @Property({ name: 'transitioned_by_user_id', type: 'uuid', nullable: true })\n transitionedByUserId?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n}\n\n@Entity({ tableName: 'customer_deal_people' })\n@Index({ name: 'customer_deal_people_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_people_person_idx', properties: ['person'] })\n@Unique({ name: 'customer_deal_people_unique', properties: ['deal', 'person'] })\nexport class CustomerDealPersonLink {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'role', type: 'text', nullable: true })\n participantRole?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n person!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_deal_companies' })\n@Index({ name: 'customer_deal_companies_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_companies_company_idx', properties: ['company'] })\n@Unique({ name: 'customer_deal_companies_unique', properties: ['deal', 'company'] })\nexport class CustomerDealCompanyLink {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n company!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_activities' })\n@Index({ name: 'customer_activities_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({ name: 'customer_activities_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_activities_entity_occurred_created_idx', properties: ['entity', 'occurredAt', 'createdAt'] })\nexport class CustomerActivity {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'activity_type', type: 'text' })\n activityType!: string\n\n @Property({ name: 'subject', type: 'text', nullable: true })\n subject?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id', nullable: true })\n deal?: CustomerDeal | null\n}\n\n@Entity({ tableName: 'customer_interactions' })\n@Index({\n name: 'customer_interactions_entity_status_scheduled_idx',\n properties: ['entity', 'status', 'scheduledAt', 'createdAt'],\n})\n@Index({\n name: 'customer_interactions_org_tenant_status_idx',\n properties: ['organizationId', 'tenantId', 'status', 'scheduledAt'],\n})\n@Index({\n name: 'customer_interactions_type_idx',\n properties: ['tenantId', 'organizationId', 'interactionType'],\n})\nexport class CustomerInteraction {\n [OptionalProps]?: 'status' | 'pinned' | 'createdAt' | 'updatedAt' | 'deletedAt' | 'durationMinutes' | 'location' | 'allDay' | 'recurrenceRule' | 'recurrenceEnd' | 'participants' | 'reminderMinutes' | 'visibility' | 'linkedEntities' | 'guestPermissions'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'interaction_type', type: 'text' })\n interactionType!: string\n\n @Property({ name: 'title', type: 'text', nullable: true })\n title?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'status', type: 'text', default: 'planned' })\n status: string = 'planned'\n\n @Property({ name: 'scheduled_at', type: Date, nullable: true })\n scheduledAt?: Date | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'priority', type: 'int', nullable: true })\n priority?: number | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'deal_id', type: 'uuid', nullable: true })\n dealId?: string | null\n\n @Property({ name: 'duration_minutes', type: 'int', nullable: true })\n durationMinutes?: number | null\n\n @Property({ name: 'location', type: 'text', nullable: true })\n location?: string | null\n\n @Property({ name: 'all_day', type: 'boolean', nullable: true })\n allDay?: boolean | null\n\n @Property({ name: 'recurrence_rule', type: 'text', nullable: true })\n recurrenceRule?: string | null\n\n @Property({ name: 'recurrence_end', type: Date, nullable: true })\n recurrenceEnd?: Date | null\n\n @Property({ name: 'participants', type: 'jsonb', nullable: true })\n participants?: Array<{ userId: string; name?: string; email?: string; status?: string }> | null\n\n @Property({ name: 'reminder_minutes', type: 'int', nullable: true })\n reminderMinutes?: number | null\n\n @Property({ name: 'visibility', type: 'text', nullable: true })\n visibility?: string | null\n\n @Property({ name: 'linked_entities', type: 'jsonb', nullable: true })\n linkedEntities?: Array<{ id: string; type: string; label: string }> | null\n\n @Property({ name: 'guest_permissions', type: 'jsonb', nullable: true })\n guestPermissions?: { canInviteOthers?: boolean; canModify?: boolean; canSeeList?: boolean } | null\n\n @Property({ name: 'pinned', type: 'boolean', default: false })\n pinned: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_comments' })\n@Index({ name: 'customer_comments_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_comments_entity_created_idx', properties: ['entity', 'createdAt'] })\nexport class CustomerComment {\n [OptionalProps]?: 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'body', type: 'text' })\n body!: string\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id', nullable: true })\n deal?: CustomerDeal | null\n}\n\n@Entity({ tableName: 'customer_addresses' })\n@Index({ name: 'customer_addresses_entity_idx', properties: ['entity'] })\nexport class CustomerAddress {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'name', type: 'text', nullable: true })\n name?: string | null\n\n @Property({ name: 'purpose', type: 'text', nullable: true })\n purpose?: string | null\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ name: 'address_line1', type: 'text' })\n addressLine1!: string\n\n @Property({ name: 'address_line2', type: 'text', nullable: true })\n addressLine2?: string | null\n\n @Property({ name: 'city', type: 'text', nullable: true })\n city?: string | null\n\n @Property({ name: 'region', type: 'text', nullable: true })\n region?: string | null\n\n @Property({ name: 'postal_code', type: 'text', nullable: true })\n postalCode?: string | null\n\n @Property({ name: 'country', type: 'text', nullable: true })\n country?: string | null\n\n @Property({ name: 'building_number', type: 'text', nullable: true })\n buildingNumber?: string | null\n\n @Property({ name: 'flat_number', type: 'text', nullable: true })\n flatNumber?: string | null\n\n @Property({ name: 'latitude', type: 'float', nullable: true })\n latitude?: number | null\n\n @Property({ name: 'longitude', type: 'float', nullable: true })\n longitude?: number | null\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_settings' })\n@Unique({ name: 'customer_settings_scope_unique', properties: ['organizationId', 'tenantId'] })\nexport class CustomerSettings {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'address_format', type: 'text', default: 'line_first' })\n addressFormat: CustomerAddressFormat = 'line_first'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_tags' })\n@Index({ name: 'customer_tags_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_tags_org_slug_unique', properties: ['organizationId', 'tenantId', 'slug'] })\nexport class CustomerTag {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n slug!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ name: 'color', type: 'text', nullable: true })\n color?: string | null\n\n @Property({ name: 'description', type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToMany(() => CustomerTagAssignment, (assignment) => assignment.tag)\n assignments = new Collection<CustomerTagAssignment>(this)\n}\n\n@Entity({ tableName: 'customer_tag_assignments' })\n@Index({ name: 'customer_tag_assignments_entity_idx', properties: ['entity'] })\n@Unique({ name: 'customer_tag_assignments_unique', properties: ['tag', 'entity'] })\nexport class CustomerTagAssignment {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerTag, { fieldName: 'tag_id' })\n tag!: CustomerTag\n\n@ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_dictionary_entries' })\n@Index({ name: 'customer_dictionary_entries_scope_idx', properties: ['organizationId', 'tenantId', 'kind'] })\n@Unique({ name: 'customer_dictionary_entries_unique', properties: ['organizationId', 'tenantId', 'kind', 'normalizedValue'] })\nexport class CustomerDictionaryEntry {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: string\n\n @Property({ type: 'text' })\n value!: string\n\n @Property({ name: 'normalized_value', type: 'text' })\n normalizedValue!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ type: 'text', nullable: true })\n color?: string | null\n\n @Property({ type: 'text', nullable: true })\n icon?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_pipelines' })\n@Index({ name: 'customer_pipelines_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\nexport class CustomerPipeline {\n [OptionalProps]?: 'isDefault' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'is_default', type: 'boolean', default: false })\n isDefault: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_pipeline_stages' })\n@Index({ name: 'customer_pipeline_stages_pipeline_position_idx', properties: ['pipelineId', 'order'] })\n@Index({ name: 'customer_pipeline_stages_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\nexport class CustomerPipelineStage {\n [OptionalProps]?: 'order' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'pipeline_id', type: 'uuid' })\n pipelineId!: string\n\n @Property({ name: 'name', type: 'text' })\n label!: string\n\n @Property({ name: 'position', type: 'int', default: 0 })\n order: number = 0\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_todo_links' })\n@Index({ name: 'customer_todo_links_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_todo_links_entity_created_idx', properties: ['entity', 'createdAt'] })\n@Unique({ name: 'customer_todo_links_unique', properties: ['entity', 'todoId', 'todoSource'] })\nexport class CustomerTodoLink {\n [OptionalProps]?: 'createdAt' | 'createdByUserId'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'todo_id', type: 'uuid' })\n todoId!: string\n\n @Property({ name: 'todo_source', type: 'text', default: 'customers:interaction' })\n todoSource: string = 'customers:interaction'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'created_by_user_id', type: 'uuid', nullable: true })\n createdByUserId?: string | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_entity_roles' })\n@Index({ name: 'customer_entity_roles_entity_idx', properties: ['entityType', 'entityId'] })\n@Index({ name: 'customer_entity_roles_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_entity_roles_active_unique',\n expression:\n 'create unique index \"customer_entity_roles_active_unique\" on \"customer_entity_roles\" (\"entity_type\", \"entity_id\", \"role_type\") where \"deleted_at\" is null',\n})\nexport class CustomerEntityRole {\n [OptionalProps]?: 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'entity_type', type: 'text' })\n entityType!: string\n\n @Property({ name: 'entity_id', type: 'uuid' })\n entityId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @Property({ name: 'role_type', type: 'text' })\n roleType!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'customer_dictionary_kind_settings' })\n@Index({ name: 'customer_dict_kind_settings_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_dict_kind_settings_unique', properties: ['organizationId', 'tenantId', 'kind'] })\nexport class CustomerDictionaryKindSetting {\n [OptionalProps]?: 'selectionMode' | 'visibleInTags' | 'sortOrder' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: string\n\n @Property({ name: 'selection_mode', type: 'text', default: 'single' })\n selectionMode: string = 'single'\n\n @Property({ name: 'visible_in_tags', type: 'boolean', default: true })\n visibleInTags: boolean = true\n\n @Property({ name: 'sort_order', type: 'int', default: 0 })\n sortOrder: number = 0\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_labels' })\n@Index({ name: 'customer_labels_scope_idx', properties: ['organizationId', 'tenantId', 'userId'] })\n@Unique({ name: 'customer_labels_unique', properties: ['userId', 'tenantId', 'organizationId', 'slug'] })\nexport class CustomerLabel {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @Property({ type: 'text' })\n slug!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_label_assignments' })\n@Index({ name: 'customer_label_assignments_entity_idx', properties: ['entity'] })\n@Unique({ name: 'customer_label_assignments_unique', properties: ['label', 'entity'] })\nexport class CustomerLabelAssignment {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @ManyToOne(() => CustomerLabel, { fieldName: 'label_id' })\n label!: CustomerLabel\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_company_billing' })\n@Index({ name: 'customer_company_billing_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_company_billing_entity_unique', properties: ['entity'] })\nexport class CustomerCompanyBilling {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @Property({ name: 'bank_name', type: 'text', nullable: true })\n bankName?: string | null\n\n @Property({ name: 'bank_account_masked', type: 'text', nullable: true })\n bankAccountMasked?: string | null\n\n @Property({ name: 'payment_terms', type: 'text', nullable: true })\n paymentTerms?: string | null\n\n @Property({ name: 'preferred_currency', type: 'text', nullable: true })\n preferredCurrency?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_person_company_roles' })\n@Index({ name: 'customer_pcr_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({ name: 'customer_pcr_person_company_idx', properties: ['personEntity', 'companyEntity'] })\n@Unique({ name: 'customer_pcr_unique', properties: ['personEntity', 'companyEntity', 'roleValue'] })\nexport class CustomerPersonCompanyRole {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n personEntity!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n companyEntity!: CustomerEntity\n\n @Property({ name: 'role_value', type: 'text' })\n roleValue!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["import { Collection, OptionalProps } from '@mikro-orm/core'\nimport { Entity, Index, ManyToOne, OneToMany, OneToOne, PrimaryKey, Property, Unique } from '@mikro-orm/decorators/legacy'\n\nexport type CustomerEntityKind = 'person' | 'company'\nexport type CustomerAddressFormat = 'line_first' | 'street_first'\n\n@Entity({ tableName: 'customer_entities' })\n@Index({ name: 'customer_entities_org_tenant_kind_idx', properties: ['organizationId', 'tenantId', 'kind'] })\n@Index({\n name: 'idx_ce_tenant_org_person_id',\n expression:\n `create index \"idx_ce_tenant_org_person_id\" on \"customer_entities\" (\"tenant_id\", \"organization_id\", \"id\") where deleted_at is null and kind = 'person'`,\n})\n@Index({\n name: 'idx_ce_tenant_org_company_id',\n expression:\n `create index \"idx_ce_tenant_org_company_id\" on \"customer_entities\" (\"tenant_id\", \"organization_id\", \"id\") where deleted_at is null and kind = 'company'`,\n})\n@Index({\n name: 'idx_ce_tenant_company_id',\n expression:\n `create index \"idx_ce_tenant_company_id\" on \"customer_entities\" (\"tenant_id\", \"id\") where deleted_at is null and kind = 'company'`,\n})\n@Index({\n name: 'idx_ce_tenant_person_id',\n expression:\n `create index \"idx_ce_tenant_person_id\" on \"customer_entities\" (\"tenant_id\", \"id\") where deleted_at is null and kind = 'person'`,\n})\nexport class CustomerEntity {\n [OptionalProps]?: 'isActive' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: CustomerEntityKind\n\n @Property({ name: 'display_name', type: 'text' })\n displayName!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'primary_email', type: 'text', nullable: true })\n primaryEmail?: string | null\n\n @Property({ name: 'primary_phone', type: 'text', nullable: true })\n primaryPhone?: string | null\n\n @Property({ name: 'status', type: 'text', nullable: true })\n status?: string | null\n\n @Property({ name: 'lifecycle_stage', type: 'text', nullable: true })\n lifecycleStage?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'temperature', type: 'text', nullable: true })\n temperature?: string | null\n\n @Property({ name: 'renewal_quarter', type: 'text', nullable: true })\n renewalQuarter?: string | null\n\n @Property({ name: 'next_interaction_at', type: Date, nullable: true })\n nextInteractionAt?: Date | null\n\n @Property({ name: 'next_interaction_name', type: 'text', nullable: true })\n nextInteractionName?: string | null\n\n @Property({ name: 'next_interaction_ref_id', type: 'text', nullable: true })\n nextInteractionRefId?: string | null\n\n @Property({ name: 'next_interaction_icon', type: 'text', nullable: true })\n nextInteractionIcon?: string | null\n\n @Property({ name: 'next_interaction_color', type: 'text', nullable: true })\n nextInteractionColor?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @OneToOne(() => CustomerPersonProfile, (profile) => profile.entity, { nullable: true, mappedBy: 'entity' })\n personProfile?: CustomerPersonProfile | null\n\n @OneToOne(() => CustomerCompanyProfile, (profile) => profile.entity, { nullable: true, mappedBy: 'entity' })\n companyProfile?: CustomerCompanyProfile | null\n\n @OneToMany(() => CustomerAddress, (address) => address.entity)\n addresses = new Collection<CustomerAddress>(this)\n\n @OneToMany(() => CustomerActivity, (activity) => activity.entity)\n activities = new Collection<CustomerActivity>(this)\n\n @OneToMany(() => CustomerComment, (comment) => comment.entity)\n comments = new Collection<CustomerComment>(this)\n\n @OneToMany(() => CustomerTagAssignment, (assignment) => assignment.entity)\n tagAssignments = new Collection<CustomerTagAssignment>(this)\n\n @OneToMany(() => CustomerTodoLink, (link) => link.entity)\n todoLinks = new Collection<CustomerTodoLink>(this)\n\n @OneToMany(() => CustomerInteraction, (interaction) => interaction.entity)\n interactions = new Collection<CustomerInteraction>(this)\n\n @OneToMany(() => CustomerDealPersonLink, (link) => link.person)\n dealPersonLinks = new Collection<CustomerDealPersonLink>(this)\n\n @OneToMany(() => CustomerDealCompanyLink, (link) => link.company)\n dealCompanyLinks = new Collection<CustomerDealCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonCompanyLink, (link) => link.person)\n personCompanyLinks = new Collection<CustomerPersonCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonCompanyLink, (link) => link.company)\n linkedPeople = new Collection<CustomerPersonCompanyLink>(this)\n\n @OneToMany(() => CustomerPersonProfile, (person) => person.company)\n companyMembers = new Collection<CustomerPersonProfile>(this)\n}\n\n@Entity({ tableName: 'customer_people' })\n@Index({ name: 'customer_people_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'idx_customer_people_entity_id',\n expression:\n `create index \"idx_customer_people_entity_id\" on \"customer_people\" (\"entity_id\")`,\n})\nexport class CustomerPersonProfile {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'first_name', type: 'text', nullable: true })\n firstName?: string | null\n\n @Property({ name: 'last_name', type: 'text', nullable: true })\n lastName?: string | null\n\n @Property({ name: 'preferred_name', type: 'text', nullable: true })\n preferredName?: string | null\n\n @Property({ name: 'job_title', type: 'text', nullable: true })\n jobTitle?: string | null\n\n @Property({ name: 'department', type: 'text', nullable: true })\n department?: string | null\n\n @Property({ name: 'seniority', type: 'text', nullable: true })\n seniority?: string | null\n\n @Property({ name: 'timezone', type: 'text', nullable: true })\n timezone?: string | null\n\n @Property({ name: 'linked_in_url', type: 'text', nullable: true })\n linkedInUrl?: string | null\n\n @Property({ name: 'twitter_url', type: 'text', nullable: true })\n twitterUrl?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToOne(() => CustomerEntity, (entity) => entity.personProfile, {\n fieldName: 'entity_id',\n owner: true,\n })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, {\n fieldName: 'company_entity_id',\n nullable: true,\n })\n company?: CustomerEntity | null\n}\n\n@Entity({ tableName: 'customer_person_company_links' })\n@Index({ name: 'customer_person_company_links_person_idx', properties: ['person'] })\n@Index({ name: 'customer_person_company_links_company_idx', properties: ['company'] })\n@Index({ name: 'customer_person_company_links_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_person_company_links_active_unique',\n expression:\n `create unique index \"customer_person_company_links_active_unique\" on \"customer_person_company_links\" (\"person_entity_id\", \"company_entity_id\") where \"deleted_at\" is null`,\n})\nexport class CustomerPersonCompanyLink {\n [OptionalProps]?: 'isPrimary' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n person!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n company!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_companies' })\n@Index({ name: 'customer_companies_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'idx_customer_companies_entity_id',\n expression:\n `create index \"idx_customer_companies_entity_id\" on \"customer_companies\" (\"entity_id\")`,\n})\nexport class CustomerCompanyProfile {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'legal_name', type: 'text', nullable: true })\n legalName?: string | null\n\n @Property({ name: 'brand_name', type: 'text', nullable: true })\n brandName?: string | null\n\n @Property({ name: 'domain', type: 'text', nullable: true })\n domain?: string | null\n\n @Property({ name: 'website_url', type: 'text', nullable: true })\n websiteUrl?: string | null\n\n @Property({ name: 'industry', type: 'text', nullable: true })\n industry?: string | null\n\n @Property({ name: 'size_bucket', type: 'text', nullable: true })\n sizeBucket?: string | null\n\n @Property({ name: 'annual_revenue', type: 'numeric', precision: 16, scale: 2, nullable: true })\n annualRevenue?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToOne(() => CustomerEntity, (entity) => entity.companyProfile, {\n fieldName: 'entity_id',\n owner: true,\n })\n entity!: CustomerEntity\n\n}\n\n@Entity({ tableName: 'customer_deals' })\n@Index({ name: 'customer_deals_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_deals_closure_stats_idx',\n properties: ['organizationId', 'tenantId', 'closureOutcome', 'updatedAt'],\n})\nexport class CustomerDeal {\n [OptionalProps]?: 'status' | 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n title!: string\n\n @Property({ type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'status', type: 'text', default: 'open' })\n status: string = 'open'\n\n @Property({ name: 'pipeline_stage', type: 'text', nullable: true })\n pipelineStage?: string | null\n\n @Property({ name: 'pipeline_id', type: 'uuid', nullable: true })\n pipelineId?: string | null\n\n @Property({ name: 'pipeline_stage_id', type: 'uuid', nullable: true })\n pipelineStageId?: string | null\n\n @Property({ name: 'value_amount', type: 'numeric', precision: 14, scale: 2, nullable: true })\n valueAmount?: string | null\n\n @Property({ name: 'value_currency', type: 'text', nullable: true })\n valueCurrency?: string | null\n\n @Property({ name: 'probability', type: 'int', nullable: true })\n probability?: number | null\n\n @Property({ name: 'expected_close_at', type: Date, nullable: true })\n expectedCloseAt?: Date | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'closure_outcome', type: 'text', nullable: true })\n closureOutcome?: string | null\n\n @Property({ name: 'loss_reason_id', type: 'uuid', nullable: true })\n lossReasonId?: string | null\n\n @Property({ name: 'loss_notes', type: 'text', nullable: true })\n lossNotes?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @OneToMany(() => CustomerDealPersonLink, (link) => link.deal)\n people = new Collection<CustomerDealPersonLink>(this)\n\n @OneToMany(() => CustomerDealCompanyLink, (link) => link.deal)\n companies = new Collection<CustomerDealCompanyLink>(this)\n\n @OneToMany(() => CustomerActivity, (activity) => activity.deal)\n activities = new Collection<CustomerActivity>(this)\n\n @OneToMany(() => CustomerComment, (comment) => comment.deal)\n comments = new Collection<CustomerComment>(this)\n\n @OneToMany(() => CustomerDealStageTransition, (transition) => transition.deal)\n stageTransitions = new Collection<CustomerDealStageTransition>(this)\n}\n\n@Entity({ tableName: 'customer_deal_stage_transitions' })\n@Index({ name: 'customer_deal_stage_transitions_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_stage_transitions_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_deal_stage_transitions_deal_stage_uq', properties: ['deal', 'stageId'] })\nexport class CustomerDealStageTransition {\n [OptionalProps]?: 'isActive' | 'createdAt' | 'updatedAt' | 'deletedAt' | 'transitionedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'pipeline_id', type: 'uuid' })\n pipelineId!: string\n\n @Property({ name: 'stage_id', type: 'uuid' })\n stageId!: string\n\n @Property({ name: 'stage_label', type: 'text' })\n stageLabel!: string\n\n @Property({ name: 'stage_order', type: 'int' })\n stageOrder!: number\n\n @Property({ name: 'transitioned_at', type: Date, onCreate: () => new Date() })\n transitionedAt: Date = new Date()\n\n @Property({ name: 'transitioned_by_user_id', type: 'uuid', nullable: true })\n transitionedByUserId?: string | null\n\n @Property({ name: 'is_active', type: 'boolean', default: true })\n isActive: boolean = true\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n}\n\n@Entity({ tableName: 'customer_deal_people' })\n@Index({ name: 'customer_deal_people_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_people_person_idx', properties: ['person'] })\n@Unique({ name: 'customer_deal_people_unique', properties: ['deal', 'person'] })\nexport class CustomerDealPersonLink {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'role', type: 'text', nullable: true })\n participantRole?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n person!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_deal_companies' })\n@Index({ name: 'customer_deal_companies_deal_idx', properties: ['deal'] })\n@Index({ name: 'customer_deal_companies_company_idx', properties: ['company'] })\n@Unique({ name: 'customer_deal_companies_unique', properties: ['deal', 'company'] })\nexport class CustomerDealCompanyLink {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id' })\n deal!: CustomerDeal\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n company!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_activities' })\n@Index({ name: 'customer_activities_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Index({ name: 'customer_activities_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_activities_entity_occurred_created_idx', properties: ['entity', 'occurredAt', 'createdAt'] })\nexport class CustomerActivity {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'activity_type', type: 'text' })\n activityType!: string\n\n @Property({ name: 'subject', type: 'text', nullable: true })\n subject?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id', nullable: true })\n deal?: CustomerDeal | null\n}\n\n@Entity({ tableName: 'customer_interactions' })\n@Index({\n name: 'customer_interactions_entity_status_scheduled_idx',\n properties: ['entity', 'status', 'scheduledAt', 'createdAt'],\n})\n@Index({\n name: 'customer_interactions_org_tenant_status_idx',\n properties: ['organizationId', 'tenantId', 'status', 'scheduledAt'],\n})\n@Index({\n name: 'customer_interactions_type_idx',\n properties: ['tenantId', 'organizationId', 'interactionType'],\n})\nexport class CustomerInteraction {\n [OptionalProps]?: 'status' | 'pinned' | 'createdAt' | 'updatedAt' | 'deletedAt' | 'durationMinutes' | 'location' | 'allDay' | 'recurrenceRule' | 'recurrenceEnd' | 'participants' | 'reminderMinutes' | 'visibility' | 'linkedEntities' | 'guestPermissions'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'interaction_type', type: 'text' })\n interactionType!: string\n\n @Property({ name: 'title', type: 'text', nullable: true })\n title?: string | null\n\n @Property({ name: 'body', type: 'text', nullable: true })\n body?: string | null\n\n @Property({ name: 'status', type: 'text', default: 'planned' })\n status: string = 'planned'\n\n @Property({ name: 'scheduled_at', type: Date, nullable: true })\n scheduledAt?: Date | null\n\n @Property({ name: 'occurred_at', type: Date, nullable: true })\n occurredAt?: Date | null\n\n @Property({ name: 'priority', type: 'int', nullable: true })\n priority?: number | null\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'owner_user_id', type: 'uuid', nullable: true })\n ownerUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'source', type: 'text', nullable: true })\n source?: string | null\n\n @Property({ name: 'deal_id', type: 'uuid', nullable: true })\n dealId?: string | null\n\n @Property({ name: 'duration_minutes', type: 'int', nullable: true })\n durationMinutes?: number | null\n\n @Property({ name: 'location', type: 'text', nullable: true })\n location?: string | null\n\n @Property({ name: 'all_day', type: 'boolean', nullable: true })\n allDay?: boolean | null\n\n @Property({ name: 'recurrence_rule', type: 'text', nullable: true })\n recurrenceRule?: string | null\n\n @Property({ name: 'recurrence_end', type: Date, nullable: true })\n recurrenceEnd?: Date | null\n\n @Property({ name: 'participants', type: 'jsonb', nullable: true })\n participants?: Array<{ userId: string; name?: string; email?: string; status?: string }> | null\n\n @Property({ name: 'reminder_minutes', type: 'int', nullable: true })\n reminderMinutes?: number | null\n\n @Property({ name: 'visibility', type: 'text', nullable: true })\n visibility?: string | null\n\n @Property({ name: 'linked_entities', type: 'jsonb', nullable: true })\n linkedEntities?: Array<{ id: string; type: string; label: string }> | null\n\n @Property({ name: 'guest_permissions', type: 'jsonb', nullable: true })\n guestPermissions?: { canInviteOthers?: boolean; canModify?: boolean; canSeeList?: boolean } | null\n\n @Property({ name: 'pinned', type: 'boolean', default: false })\n pinned: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_comments' })\n@Index({ name: 'customer_comments_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_comments_entity_created_idx', properties: ['entity', 'createdAt'] })\nexport class CustomerComment {\n [OptionalProps]?: 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'body', type: 'text' })\n body!: string\n\n @Property({ name: 'author_user_id', type: 'uuid', nullable: true })\n authorUserId?: string | null\n\n @Property({ name: 'appearance_icon', type: 'text', nullable: true })\n appearanceIcon?: string | null\n\n @Property({ name: 'appearance_color', type: 'text', nullable: true })\n appearanceColor?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @ManyToOne(() => CustomerDeal, { fieldName: 'deal_id', nullable: true })\n deal?: CustomerDeal | null\n}\n\n@Entity({ tableName: 'customer_addresses' })\n@Index({ name: 'customer_addresses_entity_idx', properties: ['entity'] })\nexport class CustomerAddress {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'name', type: 'text', nullable: true })\n name?: string | null\n\n @Property({ name: 'purpose', type: 'text', nullable: true })\n purpose?: string | null\n\n @Property({ name: 'company_name', type: 'text', nullable: true })\n companyName?: string | null\n\n @Property({ name: 'address_line1', type: 'text' })\n addressLine1!: string\n\n @Property({ name: 'address_line2', type: 'text', nullable: true })\n addressLine2?: string | null\n\n @Property({ name: 'city', type: 'text', nullable: true })\n city?: string | null\n\n @Property({ name: 'region', type: 'text', nullable: true })\n region?: string | null\n\n @Property({ name: 'postal_code', type: 'text', nullable: true })\n postalCode?: string | null\n\n @Property({ name: 'country', type: 'text', nullable: true })\n country?: string | null\n\n @Property({ name: 'building_number', type: 'text', nullable: true })\n buildingNumber?: string | null\n\n @Property({ name: 'flat_number', type: 'text', nullable: true })\n flatNumber?: string | null\n\n @Property({ name: 'latitude', type: 'float', nullable: true })\n latitude?: number | null\n\n @Property({ name: 'longitude', type: 'float', nullable: true })\n longitude?: number | null\n\n @Property({ name: 'is_primary', type: 'boolean', default: false })\n isPrimary: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_settings' })\n@Unique({ name: 'customer_settings_scope_unique', properties: ['organizationId', 'tenantId'] })\nexport class CustomerSettings {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'address_format', type: 'text', default: 'line_first' })\n addressFormat: CustomerAddressFormat = 'line_first'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_tags' })\n@Index({ name: 'customer_tags_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_tags_org_slug_unique', properties: ['organizationId', 'tenantId', 'slug'] })\nexport class CustomerTag {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n slug!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ name: 'color', type: 'text', nullable: true })\n color?: string | null\n\n @Property({ name: 'description', type: 'text', nullable: true })\n description?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @OneToMany(() => CustomerTagAssignment, (assignment) => assignment.tag)\n assignments = new Collection<CustomerTagAssignment>(this)\n}\n\n@Entity({ tableName: 'customer_tag_assignments' })\n@Index({ name: 'customer_tag_assignments_entity_idx', properties: ['entity'] })\n@Unique({ name: 'customer_tag_assignments_unique', properties: ['tag', 'entity'] })\nexport class CustomerTagAssignment {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @ManyToOne(() => CustomerTag, { fieldName: 'tag_id' })\n tag!: CustomerTag\n\n@ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_dictionary_entries' })\n@Index({ name: 'customer_dictionary_entries_scope_idx', properties: ['organizationId', 'tenantId', 'kind'] })\n@Unique({ name: 'customer_dictionary_entries_unique', properties: ['organizationId', 'tenantId', 'kind', 'normalizedValue'] })\nexport class CustomerDictionaryEntry {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: string\n\n @Property({ type: 'text' })\n value!: string\n\n @Property({ name: 'normalized_value', type: 'text' })\n normalizedValue!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ type: 'text', nullable: true })\n color?: string | null\n\n @Property({ type: 'text', nullable: true })\n icon?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_pipelines' })\n@Index({ name: 'customer_pipelines_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\nexport class CustomerPipeline {\n [OptionalProps]?: 'isDefault' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n name!: string\n\n @Property({ name: 'is_default', type: 'boolean', default: false })\n isDefault: boolean = false\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_pipeline_stages' })\n@Index({ name: 'customer_pipeline_stages_pipeline_position_idx', properties: ['pipelineId', 'order'] })\n@Index({ name: 'customer_pipeline_stages_org_tenant_idx', properties: ['organizationId', 'tenantId'] })\nexport class CustomerPipelineStage {\n [OptionalProps]?: 'order' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'pipeline_id', type: 'uuid' })\n pipelineId!: string\n\n @Property({ name: 'name', type: 'text' })\n label!: string\n\n @Property({ name: 'position', type: 'int', default: 0 })\n order: number = 0\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_todo_links' })\n@Index({ name: 'customer_todo_links_entity_idx', properties: ['entity'] })\n@Index({ name: 'customer_todo_links_entity_created_idx', properties: ['entity', 'createdAt'] })\n@Unique({ name: 'customer_todo_links_unique', properties: ['entity', 'todoId', 'todoSource'] })\nexport class CustomerTodoLink {\n [OptionalProps]?: 'createdAt' | 'createdByUserId'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'todo_id', type: 'uuid' })\n todoId!: string\n\n @Property({ name: 'todo_source', type: 'text', default: 'customers:interaction' })\n todoSource: string = 'customers:interaction'\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'created_by_user_id', type: 'uuid', nullable: true })\n createdByUserId?: string | null\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n}\n\n@Entity({ tableName: 'customer_entity_roles' })\n@Index({ name: 'customer_entity_roles_entity_idx', properties: ['entityType', 'entityId'] })\n@Index({ name: 'customer_entity_roles_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({\n name: 'customer_entity_roles_active_unique',\n expression:\n 'create unique index \"customer_entity_roles_active_unique\" on \"customer_entity_roles\" (\"entity_type\", \"entity_id\", \"role_type\") where \"deleted_at\" is null',\n})\nexport class CustomerEntityRole {\n [OptionalProps]?: 'createdAt' | 'updatedAt' | 'deletedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'entity_type', type: 'text' })\n entityType!: string\n\n @Property({ name: 'entity_id', type: 'uuid' })\n entityId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @Property({ name: 'role_type', type: 'text' })\n roleType!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n\n @Property({ name: 'deleted_at', type: Date, nullable: true })\n deletedAt?: Date | null\n}\n\n@Entity({ tableName: 'customer_dictionary_kind_settings' })\n@Index({ name: 'customer_dict_kind_settings_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_dict_kind_settings_unique', properties: ['organizationId', 'tenantId', 'kind'] })\nexport class CustomerDictionaryKindSetting {\n [OptionalProps]?: 'selectionMode' | 'visibleInTags' | 'sortOrder' | 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ type: 'text' })\n kind!: string\n\n @Property({ name: 'selection_mode', type: 'text', default: 'single' })\n selectionMode: string = 'single'\n\n @Property({ name: 'visible_in_tags', type: 'boolean', default: true })\n visibleInTags: boolean = true\n\n @Property({ name: 'sort_order', type: 'int', default: 0 })\n sortOrder: number = 0\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_labels' })\n@Index({ name: 'customer_labels_scope_idx', properties: ['organizationId', 'tenantId', 'userId'] })\n@Unique({ name: 'customer_labels_unique', properties: ['userId', 'tenantId', 'organizationId', 'slug'] })\nexport class CustomerLabel {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @Property({ type: 'text' })\n slug!: string\n\n @Property({ type: 'text' })\n label!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_label_assignments' })\n@Index({ name: 'customer_label_assignments_entity_idx', properties: ['entity'] })\n@Unique({ name: 'customer_label_assignments_unique', properties: ['label', 'entity'] })\nexport class CustomerLabelAssignment {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @Property({ name: 'user_id', type: 'uuid' })\n userId!: string\n\n @ManyToOne(() => CustomerLabel, { fieldName: 'label_id' })\n label!: CustomerLabel\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_company_billing' })\n@Index({ name: 'customer_company_billing_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Unique({ name: 'customer_company_billing_entity_unique', properties: ['entity'] })\nexport class CustomerCompanyBilling {\n [OptionalProps]?: 'createdAt' | 'updatedAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'entity_id' })\n entity!: CustomerEntity\n\n @Property({ name: 'bank_name', type: 'text', nullable: true })\n bankName?: string | null\n\n @Property({ name: 'bank_account_masked', type: 'text', nullable: true })\n bankAccountMasked?: string | null\n\n @Property({ name: 'payment_terms', type: 'text', nullable: true })\n paymentTerms?: string | null\n\n @Property({ name: 'preferred_currency', type: 'text', nullable: true })\n preferredCurrency?: string | null\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n\n @Property({ name: 'updated_at', type: Date, onCreate: () => new Date(), onUpdate: () => new Date() })\n updatedAt: Date = new Date()\n}\n\n@Entity({ tableName: 'customer_person_company_roles' })\n@Index({ name: 'customer_pcr_scope_idx', properties: ['organizationId', 'tenantId'] })\n@Index({ name: 'customer_pcr_person_company_idx', properties: ['personEntity', 'companyEntity'] })\n@Unique({ name: 'customer_pcr_unique', properties: ['personEntity', 'companyEntity', 'roleValue'] })\nexport class CustomerPersonCompanyRole {\n [OptionalProps]?: 'createdAt'\n\n @PrimaryKey({ type: 'uuid', defaultRaw: 'gen_random_uuid()' })\n id!: string\n\n @Property({ name: 'organization_id', type: 'uuid' })\n organizationId!: string\n\n @Property({ name: 'tenant_id', type: 'uuid' })\n tenantId!: string\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'person_entity_id' })\n personEntity!: CustomerEntity\n\n @ManyToOne(() => CustomerEntity, { fieldName: 'company_entity_id' })\n companyEntity!: CustomerEntity\n\n @Property({ name: 'role_value', type: 'text' })\n roleValue!: string\n\n @Property({ name: 'created_at', type: Date, onCreate: () => new Date() })\n createdAt: Date = new Date()\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,35 +1,38 @@
|
|
|
1
|
+
import { sql } from "kysely";
|
|
1
2
|
async function recomputeNextInteraction(em, entityId, organizationId) {
|
|
2
|
-
const
|
|
3
|
-
|
|
3
|
+
const db = em.getKysely();
|
|
4
|
+
let query = db.selectFrom("customer_interactions").select([
|
|
5
|
+
"id",
|
|
6
|
+
"scheduled_at",
|
|
7
|
+
"title",
|
|
8
|
+
"interaction_type",
|
|
9
|
+
"appearance_icon",
|
|
10
|
+
"appearance_color"
|
|
11
|
+
]).where("entity_id", "=", entityId).where("status", "=", "planned").where("scheduled_at", "is not", null).where("deleted_at", "is", null);
|
|
4
12
|
if (organizationId) {
|
|
5
|
-
query.
|
|
13
|
+
query = query.where("organization_id", "=", organizationId);
|
|
6
14
|
}
|
|
7
|
-
const candidate = await query.orderBy(
|
|
8
|
-
{ column: "scheduled_at", order: "asc" },
|
|
9
|
-
{ column: "priority", order: "desc", nulls: "last" },
|
|
10
|
-
{ column: "created_at", order: "asc" },
|
|
11
|
-
{ column: "id", order: "asc" }
|
|
12
|
-
]).first();
|
|
15
|
+
const candidate = await query.orderBy("scheduled_at", "asc").orderBy(sql`priority desc nulls last`).orderBy("created_at", "asc").orderBy("id", "asc").executeTakeFirst();
|
|
13
16
|
if (candidate) {
|
|
14
17
|
const interactionName = candidate.title && candidate.title.trim() !== "" ? candidate.title : candidate.interaction_type;
|
|
15
|
-
await
|
|
18
|
+
await db.updateTable("customer_entities").set({
|
|
16
19
|
next_interaction_at: candidate.scheduled_at,
|
|
17
20
|
next_interaction_name: interactionName,
|
|
18
21
|
next_interaction_ref_id: candidate.id,
|
|
19
22
|
next_interaction_icon: candidate.appearance_icon,
|
|
20
23
|
next_interaction_color: candidate.appearance_color,
|
|
21
|
-
updated_at:
|
|
22
|
-
});
|
|
24
|
+
updated_at: sql`now()`
|
|
25
|
+
}).where("id", "=", entityId).execute();
|
|
23
26
|
return { nextInteractionId: String(candidate.id) };
|
|
24
27
|
} else {
|
|
25
|
-
await
|
|
28
|
+
await db.updateTable("customer_entities").set({
|
|
26
29
|
next_interaction_at: null,
|
|
27
30
|
next_interaction_name: null,
|
|
28
31
|
next_interaction_ref_id: null,
|
|
29
32
|
next_interaction_icon: null,
|
|
30
33
|
next_interaction_color: null,
|
|
31
|
-
updated_at:
|
|
32
|
-
});
|
|
34
|
+
updated_at: sql`now()`
|
|
35
|
+
}).where("id", "=", entityId).execute();
|
|
33
36
|
return { nextInteractionId: null };
|
|
34
37
|
}
|
|
35
38
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/modules/customers/lib/interactionProjection.ts"],
|
|
4
|
-
"sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\n\nexport type NextInteractionProjectionResult = {\n nextInteractionId: string | null\n}\n\n/**\n * Recomputes the next-interaction projection fields on a CustomerEntity.\n *\n * Algorithm:\n * 1. Find all interactions for entityId where status = 'planned', scheduled_at IS NOT NULL, deleted_at IS NULL\n * 2. Sort by scheduled_at ASC, priority DESC NULLS LAST, created_at ASC, id ASC\n * 3. Take the first row and project its fields onto the CustomerEntity\n * 4. If no candidates, set all projection fields to NULL\n */\nexport async function recomputeNextInteraction(\n em: EntityManager,\n entityId: string,\n organizationId?: string | null,\n): Promise<NextInteractionProjectionResult> {\n const
|
|
5
|
-
"mappings": "
|
|
4
|
+
"sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\nimport { sql } from 'kysely'\n\nexport type NextInteractionProjectionResult = {\n nextInteractionId: string | null\n}\n\n/**\n * Recomputes the next-interaction projection fields on a CustomerEntity.\n *\n * Algorithm:\n * 1. Find all interactions for entityId where status = 'planned', scheduled_at IS NOT NULL, deleted_at IS NULL\n * 2. Sort by scheduled_at ASC, priority DESC NULLS LAST, created_at ASC, id ASC\n * 3. Take the first row and project its fields onto the CustomerEntity\n * 4. If no candidates, set all projection fields to NULL\n */\nexport async function recomputeNextInteraction(\n em: EntityManager,\n entityId: string,\n organizationId?: string | null,\n): Promise<NextInteractionProjectionResult> {\n const db = em.getKysely<any>() as any\n\n let query = db\n .selectFrom('customer_interactions')\n .select([\n 'id',\n 'scheduled_at',\n 'title',\n 'interaction_type',\n 'appearance_icon',\n 'appearance_color',\n ])\n .where('entity_id', '=', entityId)\n .where('status', '=', 'planned')\n .where('scheduled_at', 'is not', null)\n .where('deleted_at', 'is', null)\n if (organizationId) {\n query = query.where('organization_id', '=', organizationId)\n }\n\n const candidate = await query\n .orderBy('scheduled_at', 'asc')\n .orderBy(sql`priority desc nulls last`)\n .orderBy('created_at', 'asc')\n .orderBy('id', 'asc')\n .executeTakeFirst() as Record<string, any> | undefined\n\n if (candidate) {\n const interactionName = candidate.title && candidate.title.trim() !== ''\n ? candidate.title\n : candidate.interaction_type\n\n await db\n .updateTable('customer_entities')\n .set({\n next_interaction_at: candidate.scheduled_at,\n next_interaction_name: interactionName,\n next_interaction_ref_id: candidate.id,\n next_interaction_icon: candidate.appearance_icon,\n next_interaction_color: candidate.appearance_color,\n updated_at: sql`now()`,\n } as any)\n .where('id', '=', entityId)\n .execute()\n return { nextInteractionId: String(candidate.id) }\n } else {\n await db\n .updateTable('customer_entities')\n .set({\n next_interaction_at: null,\n next_interaction_name: null,\n next_interaction_ref_id: null,\n next_interaction_icon: null,\n next_interaction_color: null,\n updated_at: sql`now()`,\n } as any)\n .where('id', '=', entityId)\n .execute()\n return { nextInteractionId: null }\n }\n}\n"],
|
|
5
|
+
"mappings": "AACA,SAAS,WAAW;AAepB,eAAsB,yBACpB,IACA,UACA,gBAC0C;AAC1C,QAAM,KAAK,GAAG,UAAe;AAE7B,MAAI,QAAQ,GACT,WAAW,uBAAuB,EAClC,OAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC,EACA,MAAM,aAAa,KAAK,QAAQ,EAChC,MAAM,UAAU,KAAK,SAAS,EAC9B,MAAM,gBAAgB,UAAU,IAAI,EACpC,MAAM,cAAc,MAAM,IAAI;AACjC,MAAI,gBAAgB;AAClB,YAAQ,MAAM,MAAM,mBAAmB,KAAK,cAAc;AAAA,EAC5D;AAEA,QAAM,YAAY,MAAM,MACrB,QAAQ,gBAAgB,KAAK,EAC7B,QAAQ,6BAA6B,EACrC,QAAQ,cAAc,KAAK,EAC3B,QAAQ,MAAM,KAAK,EACnB,iBAAiB;AAEpB,MAAI,WAAW;AACb,UAAM,kBAAkB,UAAU,SAAS,UAAU,MAAM,KAAK,MAAM,KAClE,UAAU,QACV,UAAU;AAEd,UAAM,GACH,YAAY,mBAAmB,EAC/B,IAAI;AAAA,MACH,qBAAqB,UAAU;AAAA,MAC/B,uBAAuB;AAAA,MACvB,yBAAyB,UAAU;AAAA,MACnC,uBAAuB,UAAU;AAAA,MACjC,wBAAwB,UAAU;AAAA,MAClC,YAAY;AAAA,IACd,CAAQ,EACP,MAAM,MAAM,KAAK,QAAQ,EACzB,QAAQ;AACX,WAAO,EAAE,mBAAmB,OAAO,UAAU,EAAE,EAAE;AAAA,EACnD,OAAO;AACL,UAAM,GACH,YAAY,mBAAmB,EAC/B,IAAI;AAAA,MACH,qBAAqB;AAAA,MACrB,uBAAuB;AAAA,MACvB,yBAAyB;AAAA,MACzB,uBAAuB;AAAA,MACvB,wBAAwB;AAAA,MACxB,YAAY;AAAA,IACd,CAAQ,EACP,MAAM,MAAM,KAAK,QAAQ,EACzB,QAAQ;AACX,WAAO,EAAE,mBAAmB,KAAK;AAAA,EACnC;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,19 +1,17 @@
|
|
|
1
|
+
import { sql } from "@mikro-orm/postgresql";
|
|
1
2
|
const PERSON_COMPANY_LINKS_TABLE = "customer_person_company_links";
|
|
2
3
|
const PERSON_COMPANY_LINKS_DELETED_AT_COLUMN = "deleted_at";
|
|
3
4
|
let supportsDeletedAtColumnPromise = null;
|
|
4
5
|
let warnedAboutMissingDeletedAtColumn = false;
|
|
5
|
-
function getKnex(em) {
|
|
6
|
-
return em.getConnection().getKnex();
|
|
7
|
-
}
|
|
8
6
|
async function customerPersonCompanyLinksSupportDeletedAt(em) {
|
|
9
|
-
if (typeof em.
|
|
7
|
+
if (typeof em.getKysely !== "function") {
|
|
10
8
|
return true;
|
|
11
9
|
}
|
|
12
10
|
if (!supportsDeletedAtColumnPromise) {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
11
|
+
const db = em.getKysely();
|
|
12
|
+
const probe = db.selectFrom("information_schema.columns").select(["column_name"]).where(sql`table_schema = current_schema()`).where("table_name", "=", PERSON_COMPANY_LINKS_TABLE).where("column_name", "=", PERSON_COMPANY_LINKS_DELETED_AT_COLUMN).executeTakeFirst().then((row) => !!row).catch(() => false);
|
|
13
|
+
supportsDeletedAtColumnPromise = probe;
|
|
14
|
+
return probe;
|
|
17
15
|
}
|
|
18
16
|
return supportsDeletedAtColumnPromise;
|
|
19
17
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/modules/customers/lib/personCompanyLinkTable.ts"],
|
|
4
|
-
"sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\n\nconst PERSON_COMPANY_LINKS_TABLE = 'customer_person_company_links'\nconst PERSON_COMPANY_LINKS_DELETED_AT_COLUMN = 'deleted_at'\n\nlet supportsDeletedAtColumnPromise: Promise<boolean> | null = null\nlet warnedAboutMissingDeletedAtColumn = false\n\
|
|
5
|
-
"mappings": "
|
|
4
|
+
"sourcesContent": ["import type { EntityManager } from '@mikro-orm/postgresql'\nimport { sql } from '@mikro-orm/postgresql'\n\nconst PERSON_COMPANY_LINKS_TABLE = 'customer_person_company_links'\nconst PERSON_COMPANY_LINKS_DELETED_AT_COLUMN = 'deleted_at'\n\nlet supportsDeletedAtColumnPromise: Promise<boolean> | null = null\nlet warnedAboutMissingDeletedAtColumn = false\n\nexport async function customerPersonCompanyLinksSupportDeletedAt(em: EntityManager): Promise<boolean> {\n if (typeof (em as { getKysely?: unknown }).getKysely !== 'function') {\n return true\n }\n if (!supportsDeletedAtColumnPromise) {\n const db = em.getKysely<any>() as any\n const probe: Promise<boolean> = db\n .selectFrom('information_schema.columns')\n .select(['column_name'])\n .where(sql<boolean>`table_schema = current_schema()`)\n .where('table_name', '=', PERSON_COMPANY_LINKS_TABLE)\n .where('column_name', '=', PERSON_COMPANY_LINKS_DELETED_AT_COLUMN)\n .executeTakeFirst()\n .then((row: unknown) => !!row)\n .catch(() => false)\n supportsDeletedAtColumnPromise = probe\n return probe\n }\n return supportsDeletedAtColumnPromise\n}\n\nexport function warnMissingCustomerPersonCompanyLinksDeletedAt(source: string): void {\n if (warnedAboutMissingDeletedAtColumn) {\n return\n }\n warnedAboutMissingDeletedAtColumn = true\n console.warn(\n `[${source}] missing ${PERSON_COMPANY_LINKS_TABLE}.${PERSON_COMPANY_LINKS_DELETED_AT_COLUMN}; ` +\n 'continuing without link soft-delete filtering. Run yarn db:migrate.',\n )\n}\n\nexport async function withActiveCustomerPersonCompanyLinkFilter<T extends Record<string, unknown>>(\n em: EntityManager,\n where: T,\n source: string,\n): Promise<T & { deletedAt?: null }> {\n const supportsDeletedAt = await customerPersonCompanyLinksSupportDeletedAt(em)\n if (!supportsDeletedAt) {\n warnMissingCustomerPersonCompanyLinksDeletedAt(source)\n return { ...where }\n }\n return { ...where, deletedAt: null }\n}\n"],
|
|
5
|
+
"mappings": "AACA,SAAS,WAAW;AAEpB,MAAM,6BAA6B;AACnC,MAAM,yCAAyC;AAE/C,IAAI,iCAA0D;AAC9D,IAAI,oCAAoC;AAExC,eAAsB,2CAA2C,IAAqC;AACpG,MAAI,OAAQ,GAA+B,cAAc,YAAY;AACnE,WAAO;AAAA,EACT;AACA,MAAI,CAAC,gCAAgC;AACnC,UAAM,KAAK,GAAG,UAAe;AAC7B,UAAM,QAA0B,GAC7B,WAAW,4BAA4B,EACvC,OAAO,CAAC,aAAa,CAAC,EACtB,MAAM,oCAA6C,EACnD,MAAM,cAAc,KAAK,0BAA0B,EACnD,MAAM,eAAe,KAAK,sCAAsC,EAChE,iBAAiB,EACjB,KAAK,CAAC,QAAiB,CAAC,CAAC,GAAG,EAC5B,MAAM,MAAM,KAAK;AACpB,qCAAiC;AACjC,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,SAAS,+CAA+C,QAAsB;AACnF,MAAI,mCAAmC;AACrC;AAAA,EACF;AACA,sCAAoC;AACpC,UAAQ;AAAA,IACN,IAAI,MAAM,aAAa,0BAA0B,IAAI,sCAAsC;AAAA,EAE7F;AACF;AAEA,eAAsB,0CACpB,IACA,OACA,QACmC;AACnC,QAAM,oBAAoB,MAAM,2CAA2C,EAAE;AAC7E,MAAI,CAAC,mBAAmB;AACtB,mDAA+C,MAAM;AACrD,WAAO,EAAE,GAAG,MAAM;AAAA,EACpB;AACA,SAAO,EAAE,GAAG,OAAO,WAAW,KAAK;AACrC;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|