@stamhoofd/backend 2.118.1 → 2.120.0
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/package.json +32 -22
- package/src/audit-logs/ModelLogger.ts +4 -2
- package/src/audit-logs/OrderLogger.ts +1 -1
- package/src/boot.ts +32 -14
- package/src/crons/balance-emails.ts +4 -2
- package/src/crons/clearExcelCache.test.ts +8 -8
- package/src/crons/update-cached-balances.ts +40 -14
- package/src/debug.ts +3 -2
- package/src/decoders/StringArrayDecoder.ts +1 -1
- package/src/decoders/StringNullableDecoder.ts +1 -1
- package/src/email-recipient-loaders/documents.ts +2 -1
- package/src/email-recipient-loaders/members.ts +2 -1
- package/src/email-recipient-loaders/orders.ts +2 -1
- package/src/email-recipient-loaders/payments.ts +6 -3
- package/src/email-recipient-loaders/receivable-balances.ts +2 -1
- package/src/email-recipient-loaders/registrations.ts +2 -1
- package/src/email-replacements/getEmailReplacementsForPayment.ts +8 -7
- package/src/endpoints/admin/members/ChargeMembersEndpoint.ts +7 -6
- package/src/endpoints/admin/memberships/ChargeMembershipsEndpoint.ts +3 -2
- package/src/endpoints/admin/memberships/GetChargeMembershipsSummaryEndpoint.ts +2 -1
- package/src/endpoints/admin/organizations/ChargeOrganizationsEndpoint.ts +4 -3
- package/src/endpoints/admin/organizations/GetOrganizationsCountEndpoint.ts +3 -2
- package/src/endpoints/admin/organizations/GetOrganizationsEndpoint.ts +7 -5
- package/src/endpoints/admin/organizations/PatchOrganizationsEndpoint.ts +12 -10
- package/src/endpoints/admin/registrations/ChargeRegistrationsEndpoint.ts +4 -3
- package/src/endpoints/auth/CreateAdminEndpoint.ts +8 -6
- package/src/endpoints/auth/CreateTokenEndpoint.ts +14 -12
- package/src/endpoints/auth/DeleteTokenEndpoint.ts +2 -1
- package/src/endpoints/auth/DeleteUserEndpoint.ts +2 -1
- package/src/endpoints/auth/ForgotPasswordEndpoint.ts +5 -4
- package/src/endpoints/auth/GetOtherUserEndpoint.ts +3 -2
- package/src/endpoints/auth/GetUserEndpoint.ts +3 -2
- package/src/endpoints/auth/OpenIDConnectAuthTokenEndpoint.ts +2 -1
- package/src/endpoints/auth/OpenIDConnectCallbackEndpoint.ts +4 -2
- package/src/endpoints/auth/OpenIDConnectStartEndpoint.ts +3 -2
- package/src/endpoints/auth/PatchUserEndpoint.ts +15 -12
- package/src/endpoints/auth/PollEmailVerificationEndpoint.ts +3 -2
- package/src/endpoints/auth/RetryEmailVerificationEndpoint.ts +3 -2
- package/src/endpoints/auth/SignupEndpoint.ts +5 -4
- package/src/endpoints/auth/VerifyEmailEndpoint.ts +6 -5
- package/src/endpoints/frontend/FrontendEnvironmentEndpoint.ts +3 -2
- package/src/endpoints/global/addresses/SearchRegionsEndpoint.ts +8 -5
- package/src/endpoints/global/addresses/ValidateAddressEndpoint.ts +5 -3
- package/src/endpoints/global/audit-logs/GetAuditLogsEndpoint.ts +8 -5
- package/src/endpoints/global/billing/ActivatePackagesEndpoint.ts +9 -7
- package/src/endpoints/global/billing/DeactivatePackageEndpoint.ts +4 -3
- package/src/endpoints/global/caddy/CheckDomainCertEndpoint.ts +4 -2
- package/src/endpoints/global/email/CreateEmailEndpoint.ts +9 -7
- package/src/endpoints/global/email/GetAdminEmailsEndpoint.test.ts +2 -1
- package/src/endpoints/global/email/GetAdminEmailsEndpoint.ts +22 -19
- package/src/endpoints/global/email/GetEmailAddressEndpoint.ts +6 -4
- package/src/endpoints/global/email/GetEmailEndpoint.ts +4 -3
- package/src/endpoints/global/email/GetUserEmailsEndpoint.test.ts +3 -2
- package/src/endpoints/global/email/GetUserEmailsEndpoint.ts +7 -4
- package/src/endpoints/global/email/ManageEmailAddressEndpoint.ts +7 -5
- package/src/endpoints/global/email/PatchEmailEndpoint.test.ts +11 -11
- package/src/endpoints/global/email/PatchEmailEndpoint.ts +14 -11
- package/src/endpoints/global/email-recipients/GetEmailRecipientsCountEndpoint.ts +3 -2
- package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.test.ts +2 -1
- package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.ts +8 -5
- package/src/endpoints/global/email-recipients/RetryEmailRecipientEndpoint.ts +7 -5
- package/src/endpoints/global/email-recipients/helpers/validateEmailRecipientFilter.ts +4 -3
- package/src/endpoints/global/events/GetEventNotificationsCountEndpoint.ts +3 -2
- package/src/endpoints/global/events/GetEventNotificationsEndpoint.ts +9 -6
- package/src/endpoints/global/events/GetEventsEndpoint.ts +7 -4
- package/src/endpoints/global/events/PatchEventNotificationsEndpoint.test.ts +4 -2
- package/src/endpoints/global/events/PatchEventNotificationsEndpoint.ts +17 -15
- package/src/endpoints/global/events/PatchEventsEndpoint.test.ts +4 -2
- package/src/endpoints/global/events/PatchEventsEndpoint.ts +28 -26
- package/src/endpoints/global/files/ExportToExcelEndpoint.ts +8 -5
- package/src/endpoints/global/files/GetFileCache.ts +5 -3
- package/src/endpoints/global/files/UploadFile.ts +10 -4
- package/src/endpoints/global/files/UploadImage.ts +4 -2
- package/src/endpoints/global/groups/GetGroupsEndpoint.test.ts +4 -2
- package/src/endpoints/global/groups/GetGroupsEndpoint.ts +8 -5
- package/src/endpoints/global/members/GetMemberFamilyEndpoint.ts +7 -5
- package/src/endpoints/global/members/GetMembersCountEndpoint.ts +3 -2
- package/src/endpoints/global/members/GetMembersEndpoint.test.ts +4 -2
- package/src/endpoints/global/members/GetMembersEndpoint.ts +10 -8
- package/src/endpoints/global/members/PatchOrganizationMembersEndpoint.test.ts +257 -6
- package/src/endpoints/global/members/PatchOrganizationMembersEndpoint.ts +162 -107
- package/src/endpoints/global/members/helpers/validateGroupFilter.ts +4 -3
- package/src/endpoints/global/members/shouldCheckIfMemberIsDuplicate.ts +3 -2
- package/src/endpoints/global/organizations/CheckRegisterCodeEndpoint.ts +3 -2
- package/src/endpoints/global/organizations/CreateOrganizationEndpoint.test.ts +3 -2
- package/src/endpoints/global/organizations/CreateOrganizationEndpoint.ts +8 -7
- package/src/endpoints/global/organizations/GetOrganizationFromDomainEndpoint.ts +5 -3
- package/src/endpoints/global/organizations/GetOrganizationFromUriEndpoint.ts +5 -3
- package/src/endpoints/global/organizations/SearchOrganizationEndpoint.ts +8 -5
- package/src/endpoints/global/payments/StripeWebhookEndpoint.ts +4 -2
- package/src/endpoints/global/platform/GetPlatformAdminsEndpoint.ts +2 -1
- package/src/endpoints/global/platform/GetPlatformEndpoint.ts +3 -2
- package/src/endpoints/global/platform/PatchPlatformEnpoint.test.ts +3 -2
- package/src/endpoints/global/platform/PatchPlatformEnpoint.ts +7 -4
- package/src/endpoints/global/platform-memberships/GetPlatformMembershipsCountEndpoint.ts +47 -0
- package/src/endpoints/global/platform-memberships/GetPlatformMembershipsEndpoint.ts +206 -0
- package/src/endpoints/global/registration/GetRegistrationsCountEndpoint.ts +3 -2
- package/src/endpoints/global/registration/GetRegistrationsEndpoint.test.ts +2 -1
- package/src/endpoints/global/registration/GetRegistrationsEndpoint.ts +10 -7
- package/src/endpoints/global/registration/GetUserDetailedPayableBalanceEndpoint.ts +4 -2
- package/src/endpoints/global/registration/GetUserDocumentsEndpoint.ts +4 -2
- package/src/endpoints/global/registration/GetUserMembersEndpoint.ts +3 -2
- package/src/endpoints/global/registration/GetUserPayableBalanceEndpoint.ts +2 -1
- package/src/endpoints/global/registration/PatchUserMembersEndpoint.test.ts +5 -3
- package/src/endpoints/global/registration/PatchUserMembersEndpoint.ts +13 -9
- package/src/endpoints/global/registration/RegisterMembersEndpoint.test.ts +50 -49
- package/src/endpoints/global/registration/RegisterMembersEndpoint.ts +25 -22
- package/src/endpoints/global/registration-periods/GetRegistrationPeriodsEndpoint.ts +8 -5
- package/src/endpoints/global/registration-periods/PatchRegistrationPeriodsEndpoint.ts +9 -7
- package/src/endpoints/global/sso/GetSSOEndpoint.ts +4 -2
- package/src/endpoints/global/sso/SetSSOEndpoint.ts +3 -2
- package/src/endpoints/global/webshops/GetWebshopFromDomainEndpoint.ts +4 -2
- package/src/endpoints/global/webshops/GetWebshopsCountEndpoint.ts +43 -0
- package/src/endpoints/global/webshops/GetWebshopsEndpoint.test.ts +808 -0
- package/src/endpoints/global/webshops/GetWebshopsEndpoint.ts +221 -0
- package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemEndpoint.ts +4 -3
- package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsEndpoint.ts +6 -4
- package/src/endpoints/organization/dashboard/balance-items/PatchBalanceItemsEndpoint.ts +15 -13
- package/src/endpoints/organization/dashboard/billing/GetOrganizationDetailedPayableBalanceEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/billing/GetOrganizationPayableBalanceEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/billing/GetPackagesEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/documents/GetDocumentTemplateXML.ts +3 -2
- package/src/endpoints/organization/dashboard/documents/GetDocumentTemplatesCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/documents/GetDocumentTemplatesEndpoint.ts +7 -4
- package/src/endpoints/organization/dashboard/documents/GetDocumentsCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/documents/GetDocumentsEndpoint.ts +7 -4
- package/src/endpoints/organization/dashboard/documents/PatchDocumentEndpoint.ts +9 -7
- package/src/endpoints/organization/dashboard/documents/PatchDocumentTemplatesEndpoint.test.ts +4 -2
- package/src/endpoints/organization/dashboard/documents/PatchDocumentTemplatesEndpoint.ts +7 -5
- package/src/endpoints/organization/dashboard/email/CheckEmailBouncesEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.test.ts +36 -1
- package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.ts +13 -4
- package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.test.ts +4 -2
- package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.ts +7 -5
- package/src/endpoints/organization/dashboard/invoices/GetInvoicesCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/invoices/GetInvoicesEndpoint.ts +6 -4
- package/src/endpoints/organization/dashboard/invoices/PatchInvoicesEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/mollie/CheckMollieEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/mollie/ConnectMollieEndpoint.ts +6 -3
- package/src/endpoints/organization/dashboard/mollie/DisconnectMollieEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/mollie/GetMollieDashboardEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/nolt/CreateNoltTokenEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/organization/GetOrganizationArchivedGroups.ts +4 -2
- package/src/endpoints/organization/dashboard/organization/GetOrganizationDeletedGroups.ts +3 -2
- package/src/endpoints/organization/dashboard/organization/GetUitpasClientIdEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.test.ts +5 -3
- package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.ts +22 -19
- package/src/endpoints/organization/dashboard/organization/SearchUitpasOrganizersEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/organization/SetOrganizationDomainEndpoint.ts +11 -9
- package/src/endpoints/organization/dashboard/organization/SetUitpasClientCredentialsEndpoint.ts +8 -7
- package/src/endpoints/organization/dashboard/payments/GetMemberBalanceEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/payments/GetPaymentsCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/payments/GetPaymentsEndpoint.ts +7 -5
- package/src/endpoints/organization/dashboard/payments/PatchPaymentsEndpoint.ts +18 -16
- package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalanceEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.test.ts +2 -1
- package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.ts +8 -5
- package/src/endpoints/organization/dashboard/registration-periods/MoveRegistrationPeriods.test.ts +4 -2
- package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.test.ts +4 -2
- package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.ts +32 -29
- package/src/endpoints/organization/dashboard/registration-periods/SetupStepReviewEndpoint.ts +6 -3
- package/src/endpoints/organization/dashboard/stripe/ConnectStripeEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/stripe/DeleteStripeAccountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/stripe/GetStripeAccountLinkEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/stripe/GetStripeAccountsEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/stripe/GetStripeLoginLinkEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/stripe/UpdateStripeAccountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/users/CreateApiUserEndpoint.ts +4 -3
- package/src/endpoints/organization/dashboard/users/DeleteUserEndpoint.ts +4 -3
- package/src/endpoints/organization/dashboard/users/GetApiUsersEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/users/GetOrganizationAdminsEndpoint.ts +2 -1
- package/src/endpoints/organization/dashboard/users/PatchApiUserEndpoint.ts +6 -4
- package/src/endpoints/organization/dashboard/webshops/CreateWebshopEndpoint.ts +7 -6
- package/src/endpoints/organization/dashboard/webshops/DeleteWebshopEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/webshops/GetDiscountCodesEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersCountEndpoint.ts +3 -2
- package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersEndpoint.ts +7 -4
- package/src/endpoints/organization/dashboard/webshops/{GetWebshopTicketsCountEndpoint → GetWebshopTicketsCountEndpoint.ts} +7 -7
- package/src/endpoints/organization/dashboard/webshops/GetWebshopTicketsEndpoint.ts +9 -6
- package/src/endpoints/organization/dashboard/webshops/GetWebshopUriAvailabilityEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/webshops/PatchDiscountCodesEndpoint.ts +6 -4
- package/src/endpoints/organization/dashboard/webshops/PatchWebshopEndpoint.ts +13 -12
- package/src/endpoints/organization/dashboard/webshops/PatchWebshopOrdersEndpoint.ts +4 -2
- package/src/endpoints/organization/dashboard/webshops/PatchWebshopTicketsEndpoint.ts +5 -3
- package/src/endpoints/organization/dashboard/webshops/SearchUitpasEventsEndpoint.ts +6 -4
- package/src/endpoints/organization/dashboard/webshops/VerifyWebshopDomainEndpoint.ts +2 -1
- package/src/endpoints/organization/shared/ExchangePaymentEndpoint.ts +6 -4
- package/src/endpoints/organization/shared/GetDocumentHtml.ts +4 -3
- package/src/endpoints/organization/shared/GetPaymentEndpoint.ts +4 -3
- package/src/endpoints/organization/shared/GetUitpasNumberDetailsEndpoint.ts +3 -2
- package/src/endpoints/organization/shared/auth/GetOrganizationEndpoint.ts +3 -2
- package/src/endpoints/organization/webshops/CheckWebshopDiscountCodesEndpoint.ts +4 -3
- package/src/endpoints/organization/webshops/GetOrderByPaymentEndpoint.ts +5 -4
- package/src/endpoints/organization/webshops/GetOrderEndpoint.ts +4 -3
- package/src/endpoints/organization/webshops/GetTicketsEndpoint.ts +7 -5
- package/src/endpoints/organization/webshops/GetWebshopEndpoint.ts +4 -3
- package/src/endpoints/organization/webshops/PlaceOrderEndpoint.test.ts +7 -3
- package/src/endpoints/organization/webshops/PlaceOrderEndpoint.ts +11 -10
- package/src/endpoints/organization/webshops/RetrieveUitpasSocialTariffPriceEndpoint.ts +5 -4
- package/src/endpoints/system/HealthEndpoint.test.ts +44 -0
- package/src/endpoints/system/HealthEndpoint.ts +14 -6
- package/src/excel-loaders/balance-items.ts +19 -17
- package/src/excel-loaders/event-notifications.ts +15 -13
- package/src/excel-loaders/index.ts +1 -0
- package/src/excel-loaders/members.ts +45 -43
- package/src/excel-loaders/organizations.ts +26 -25
- package/src/excel-loaders/payments.ts +44 -42
- package/src/excel-loaders/platform-memberships.ts +202 -0
- package/src/excel-loaders/receivable-balances.ts +25 -23
- package/src/excel-loaders/registrations.ts +30 -28
- package/src/helpers/AddressValidator.test.ts +2 -1
- package/src/helpers/AddressValidator.ts +13 -10
- package/src/helpers/AdminPermissionChecker.ts +193 -95
- package/src/helpers/AuthenticatedStructures.ts +13 -11
- package/src/helpers/BuckarooHelper.ts +3 -2
- package/src/helpers/Context.ts +8 -6
- package/src/helpers/CookieHelper.ts +2 -2
- package/src/helpers/FileCache.ts +9 -9
- package/src/helpers/ForwardHandler.ts +3 -2
- package/src/helpers/GlobalHelper.ts +2 -0
- package/src/helpers/GroupBuilder.ts +2 -1
- package/src/helpers/GroupedThrottledQueue.test.ts +19 -19
- package/src/helpers/LimitedFilteredRequestHelper.ts +1 -1
- package/src/helpers/MemberCharger.ts +2 -1
- package/src/helpers/MemberUserSyncer.ts +6 -3
- package/src/helpers/MembershipCharger.ts +2 -2
- package/src/helpers/OrganizationCharger.ts +2 -1
- package/src/helpers/PeriodHelper.ts +2 -1
- package/src/helpers/SQLTranslatedString.ts +3 -2
- package/src/helpers/ServiceFeeHelper.ts +1 -1
- package/src/helpers/SetupStepUpdater.ts +6 -5
- package/src/helpers/StripeHelper.ts +9 -8
- package/src/helpers/TagHelper.test.ts +5 -5
- package/src/helpers/TagHelper.ts +2 -1
- package/src/helpers/TemporaryMemberAccess.ts +2 -1
- package/src/helpers/ThrottledQueue.test.ts +20 -20
- package/src/helpers/UitpasTokenRepository.ts +7 -7
- package/src/helpers/ViesHelper.ts +5 -4
- package/src/helpers/XlsxTransformerColumnHelper.ts +21 -19
- package/src/helpers/email-html-helpers.ts +13 -12
- package/src/helpers/fetchToAsyncIterator.ts +1 -1
- package/src/helpers/outstandingBalanceJoin.ts +2 -1
- package/src/helpers/updateMemberDetailsUitpasNumber.ts +5 -4
- package/src/middleware/ContextMiddleware.ts +1 -1
- package/src/migrate.ts +21 -4
- package/src/seeds/0000000003-default-email-templates.ts +1 -1
- package/src/seeds/0000000004-single-organization.ts +2 -1
- package/src/seeds/1752848561-groups-registration-periods.ts +3 -2
- package/src/seeds/1754560914-groups-prices.test.ts +2 -1
- package/src/seeds/1754560914-groups-prices.ts +2 -1
- package/src/seeds/1755790070-fill-email-recipient-errors.ts +6 -6
- package/src/seeds/1755876819-remove-duplicate-members.ts +2 -1
- package/src/seeds/1765896674-document-update-year.test.ts +2 -1
- package/src/seeds/1773754928-force-save-members.ts +15 -0
- package/src/services/AuditLogService.ts +3 -2
- package/src/services/BalanceItemPaymentService.ts +2 -2
- package/src/services/BalanceItemService.ts +2 -1
- package/src/services/BootChecksService.test.ts +33 -0
- package/src/services/BootChecksService.ts +21 -0
- package/src/services/DatabaseCollationService.test.ts +18 -0
- package/src/services/DatabaseCollationService.ts +81 -0
- package/src/services/DocumentService.ts +1 -1
- package/src/services/EventNotificationService.ts +5 -4
- package/src/services/FileSignService.ts +2 -2
- package/src/services/InvoiceService.ts +3 -3
- package/src/services/MemberNumberService.ts +6 -4
- package/src/services/MemberRecordStore.ts +28 -19
- package/src/services/PaymentReallocationService.test.ts +2 -1
- package/src/services/PaymentReallocationService.ts +2 -1
- package/src/services/PaymentService.ts +28 -26
- package/src/services/RegistrationService.ts +65 -3
- package/src/services/SSOService.ts +13 -9
- package/src/services/STPackageService.ts +7 -5
- package/src/services/StartupHealthService.ts +15 -0
- package/src/services/uitpas/PassholderEndpoints.ts +2 -2
- package/src/services/uitpas/UitpasService.ts +11 -8
- package/src/services/uitpas/cancelTicketSales.ts +1 -1
- package/src/services/uitpas/checkPermissionsFor.ts +9 -9
- package/src/services/uitpas/getSocialTariffForEvent.ts +4 -4
- package/src/services/uitpas/getSocialTariffForUitpasNumbers.ts +5 -5
- package/src/services/uitpas/handleUitpasResponse.ts +1 -1
- package/src/services/uitpas/registerTicketSales.ts +4 -4
- package/src/services/uitpas/searchUitpasEvents.ts +3 -3
- package/src/services/uitpas/searchUitpasOrganizers.ts +3 -3
- package/src/sql-filters/audit-logs.ts +2 -1
- package/src/sql-filters/balance-item-payments.ts +2 -1
- package/src/sql-filters/balance-items.ts +2 -1
- package/src/sql-filters/base-registration-filter-compilers.ts +6 -4
- package/src/sql-filters/document-templates.ts +2 -1
- package/src/sql-filters/documents.ts +2 -1
- package/src/sql-filters/email-recipients.ts +2 -1
- package/src/sql-filters/emails.ts +2 -1
- package/src/sql-filters/event-notifications.ts +2 -1
- package/src/sql-filters/events.ts +2 -1
- package/src/sql-filters/groups.ts +2 -1
- package/src/sql-filters/invoiced-balance-items.ts +2 -1
- package/src/sql-filters/invoices.ts +2 -1
- package/src/sql-filters/member-responsibility-records.ts +2 -1
- package/src/sql-filters/members.ts +8 -7
- package/src/sql-filters/orders.ts +3 -2
- package/src/sql-filters/organization-registration-periods.ts +2 -1
- package/src/sql-filters/organizations.ts +2 -1
- package/src/sql-filters/payments.ts +2 -1
- package/src/sql-filters/platform-memberships.ts +67 -0
- package/src/sql-filters/receivable-balances.ts +2 -1
- package/src/sql-filters/registration-periods.ts +2 -1
- package/src/sql-filters/registrations.ts +2 -1
- package/src/sql-filters/tickets.ts +2 -1
- package/src/sql-filters/users.ts +2 -1
- package/src/sql-filters/webshops.ts +38 -0
- package/src/sql-sorters/audit-logs.ts +3 -2
- package/src/sql-sorters/balance-items.ts +3 -2
- package/src/sql-sorters/document-templates.ts +3 -2
- package/src/sql-sorters/documents.ts +3 -2
- package/src/sql-sorters/email-recipients.ts +3 -2
- package/src/sql-sorters/emails.ts +3 -2
- package/src/sql-sorters/event-notifications.ts +3 -2
- package/src/sql-sorters/events.ts +3 -2
- package/src/sql-sorters/groups.ts +3 -2
- package/src/sql-sorters/invoices.ts +3 -2
- package/src/sql-sorters/members.ts +3 -2
- package/src/sql-sorters/orders.ts +3 -2
- package/src/sql-sorters/organization-registration-periods.ts +3 -2
- package/src/sql-sorters/organizations.ts +3 -2
- package/src/sql-sorters/payments.ts +3 -2
- package/src/sql-sorters/platform-memberships.ts +40 -0
- package/src/sql-sorters/receivable-balances.ts +3 -2
- package/src/sql-sorters/registration-periods.ts +3 -2
- package/src/sql-sorters/registrations.ts +3 -2
- package/src/sql-sorters/tickets.ts +3 -2
- package/src/sql-sorters/webshops.ts +40 -0
- package/tests/actions/patchOrganizationMember.ts +5 -4
- package/tests/actions/patchPaymentStatus.ts +2 -2
- package/tests/actions/patchUserMember.ts +6 -4
- package/tests/e2e/api-rate-limits.test.ts +4 -5
- package/tests/e2e/bundle-discounts.test.ts +3 -2
- package/tests/e2e/charge-members.test.ts +7 -5
- package/tests/e2e/documents.test.ts +3 -2
- package/tests/e2e/private-files.test.ts +11 -13
- package/tests/e2e/register.test.ts +6 -5
- package/tests/e2e/stock.test.ts +6 -8
- package/tests/e2e/tickets.test.ts +4 -2
- package/tests/helpers/StripeMocker.ts +3 -3
- package/tests/init/initAdmin.ts +4 -2
- package/tests/init/initBundleDiscount.ts +3 -2
- package/tests/init/initPayconiq.ts +1 -1
- package/tests/init/initPermissionRole.ts +4 -2
- package/tests/init/initPlatformRecordCategory.ts +1 -1
- package/tests/init/initStripe.ts +1 -1
- package/tests/vitest.global.setup.ts +26 -0
- package/tests/{jest.setup.ts → vitest.setup.ts} +4 -3
- package/tsconfig.build.json +17 -0
- package/tsconfig.json +10 -41
- package/tsconfig.test.json +17 -0
- package/vitest.config.js +13 -0
- package/eslint.config.mjs +0 -5
- package/jest.config.cjs +0 -27
- package/tests/jest.global.setup.ts +0 -33
- package/tests/toMatchMap.ts +0 -68
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import type { XlsxTransformerColumn, XlsxTransformerSheet } from '@stamhoofd/excel-writer';
|
|
2
|
+
import { XlsxBuiltInNumberFormat } from '@stamhoofd/excel-writer';
|
|
2
3
|
import { Platform } from '@stamhoofd/models';
|
|
3
|
-
import {
|
|
4
|
+
import type { LimitedFilteredRequest, PlatformMember} from '@stamhoofd/structures';
|
|
5
|
+
import { ExcelExportType, Gender, GroupType, MembershipStatus, PlatformFamily, Platform as PlatformStruct, UnencodeablePaginatedResponse } from '@stamhoofd/structures';
|
|
4
6
|
import { Formatter } from '@stamhoofd/utility';
|
|
5
7
|
import { ExportToExcelEndpoint } from '../endpoints/global/files/ExportToExcelEndpoint.js';
|
|
6
8
|
import { GetMembersEndpoint } from '../endpoints/global/members/GetMembersEndpoint.js';
|
|
@@ -11,7 +13,7 @@ import { XlsxTransformerColumnHelper } from '../helpers/XlsxTransformerColumnHel
|
|
|
11
13
|
export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
12
14
|
{
|
|
13
15
|
id: 'id',
|
|
14
|
-
name: $t(`
|
|
16
|
+
name: $t(`%d`),
|
|
15
17
|
width: 40,
|
|
16
18
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
17
19
|
value: object.id,
|
|
@@ -19,7 +21,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
19
21
|
},
|
|
20
22
|
{
|
|
21
23
|
id: 'memberNumber',
|
|
22
|
-
name: $t(`
|
|
24
|
+
name: $t(`%cH`),
|
|
23
25
|
width: 20,
|
|
24
26
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
25
27
|
value: object.details.memberNumber,
|
|
@@ -27,7 +29,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
27
29
|
},
|
|
28
30
|
{
|
|
29
31
|
id: 'firstName',
|
|
30
|
-
name: $t(`
|
|
32
|
+
name: $t(`%1MT`),
|
|
31
33
|
width: 20,
|
|
32
34
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
33
35
|
value: object.details.firstName,
|
|
@@ -35,7 +37,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
35
37
|
},
|
|
36
38
|
{
|
|
37
39
|
id: 'lastName',
|
|
38
|
-
name: $t(`
|
|
40
|
+
name: $t(`%1MU`),
|
|
39
41
|
width: 20,
|
|
40
42
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
41
43
|
value: object.details.lastName,
|
|
@@ -43,7 +45,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
43
45
|
},
|
|
44
46
|
{
|
|
45
47
|
id: 'birthDay',
|
|
46
|
-
name: $t(`
|
|
48
|
+
name: $t(`%17w`),
|
|
47
49
|
width: 20,
|
|
48
50
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
49
51
|
value: object.details.birthDay,
|
|
@@ -56,7 +58,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
56
58
|
},
|
|
57
59
|
{
|
|
58
60
|
id: 'age',
|
|
59
|
-
name: $t(`
|
|
61
|
+
name: $t(`%9S`),
|
|
60
62
|
width: 20,
|
|
61
63
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
62
64
|
value: object.details.age,
|
|
@@ -64,7 +66,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
64
66
|
},
|
|
65
67
|
{
|
|
66
68
|
id: 'gender',
|
|
67
|
-
name: $t(`
|
|
69
|
+
name: $t(`%19i`),
|
|
68
70
|
width: 20,
|
|
69
71
|
getValue: ({ patchedMember: object }: PlatformMember) => {
|
|
70
72
|
const gender = object.details.gender;
|
|
@@ -76,7 +78,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
76
78
|
},
|
|
77
79
|
{
|
|
78
80
|
id: 'phone',
|
|
79
|
-
name: $t(`
|
|
81
|
+
name: $t(`%wD`),
|
|
80
82
|
width: 20,
|
|
81
83
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
82
84
|
value: object.details.phone,
|
|
@@ -84,7 +86,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
84
86
|
},
|
|
85
87
|
{
|
|
86
88
|
id: 'email',
|
|
87
|
-
name: $t(`
|
|
89
|
+
name: $t(`%1FK`),
|
|
88
90
|
width: 40,
|
|
89
91
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
90
92
|
value: object.details.email,
|
|
@@ -111,7 +113,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
111
113
|
}),
|
|
112
114
|
{
|
|
113
115
|
id: 'securityCode',
|
|
114
|
-
name: $t(`
|
|
116
|
+
name: $t(`%wE`),
|
|
115
117
|
width: 20,
|
|
116
118
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
117
119
|
value: object.details.securityCode,
|
|
@@ -119,7 +121,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
119
121
|
},
|
|
120
122
|
{
|
|
121
123
|
id: 'uitpasNumber',
|
|
122
|
-
name: $t(`
|
|
124
|
+
name: $t(`%wF`),
|
|
123
125
|
width: 20,
|
|
124
126
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
125
127
|
value: object.details.uitpasNumberDetails?.uitpasNumber ?? null,
|
|
@@ -128,7 +130,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
128
130
|
{
|
|
129
131
|
id: 'requiresFinancialSupport',
|
|
130
132
|
// todo: use correct term
|
|
131
|
-
name: $t(`
|
|
133
|
+
name: $t(`%wG`),
|
|
132
134
|
width: 20,
|
|
133
135
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
134
136
|
value: XlsxTransformerColumnHelper.formatBoolean(object.details.hasFinancialSupportOrActiveUitpas),
|
|
@@ -136,7 +138,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
136
138
|
},
|
|
137
139
|
{
|
|
138
140
|
id: 'notes',
|
|
139
|
-
name: $t(`
|
|
141
|
+
name: $t(`%Ve`),
|
|
140
142
|
width: 20,
|
|
141
143
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
142
144
|
value: object.details.notes,
|
|
@@ -144,7 +146,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
144
146
|
},
|
|
145
147
|
{
|
|
146
148
|
id: 'nationalRegisterNumber',
|
|
147
|
-
name: $t(`
|
|
149
|
+
name: $t(`%wK`),
|
|
148
150
|
width: 30,
|
|
149
151
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
150
152
|
value: object.details.nationalRegisterNumber?.toString() ?? '',
|
|
@@ -152,7 +154,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
152
154
|
},
|
|
153
155
|
{
|
|
154
156
|
id: 'membership',
|
|
155
|
-
name: $t(`
|
|
157
|
+
name: $t(`%Wq`),
|
|
156
158
|
width: 20,
|
|
157
159
|
getValue: (member: PlatformMember) => {
|
|
158
160
|
return {
|
|
@@ -162,11 +164,11 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
162
164
|
},
|
|
163
165
|
{
|
|
164
166
|
id: 'organization',
|
|
165
|
-
name: $t(`
|
|
167
|
+
name: $t(`%wA`),
|
|
166
168
|
width: 40,
|
|
167
169
|
getValue: (member: PlatformMember) => {
|
|
168
170
|
const organizations = member.filterOrganizations({ currentPeriod: true, types: [GroupType.Membership] });
|
|
169
|
-
const str = Formatter.joinLast(organizations.map(o => o.name).sort(), ', ', ' ' + $t(`
|
|
171
|
+
const str = Formatter.joinLast(organizations.map(o => o.name).sort(), ', ', ' ' + $t(`%M1`) + ' ') || Context.i18n.$t('%5D');
|
|
170
172
|
|
|
171
173
|
return {
|
|
172
174
|
value: str,
|
|
@@ -175,11 +177,11 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
175
177
|
},
|
|
176
178
|
{
|
|
177
179
|
id: 'uri',
|
|
178
|
-
name: $t(`
|
|
180
|
+
name: $t(`%7C`),
|
|
179
181
|
width: 30,
|
|
180
182
|
getValue: (member: PlatformMember) => {
|
|
181
183
|
const organizations = member.filterOrganizations({ currentPeriod: true, types: [GroupType.Membership] });
|
|
182
|
-
const str = Formatter.joinLast(organizations.map(o => o.uri).sort(), ', ', ' ' + $t(`
|
|
184
|
+
const str = Formatter.joinLast(organizations.map(o => o.uri).sort(), ', ', ' ' + $t(`%M1`) + ' ') || Context.i18n.$t('%5D');
|
|
183
185
|
|
|
184
186
|
return {
|
|
185
187
|
value: str,
|
|
@@ -192,7 +194,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
192
194
|
// unverified data
|
|
193
195
|
{
|
|
194
196
|
id: 'unverifiedPhones',
|
|
195
|
-
name: $t(`
|
|
197
|
+
name: $t(`%wL`),
|
|
196
198
|
width: 20,
|
|
197
199
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
198
200
|
value: object.details.unverifiedPhones.join(', '),
|
|
@@ -200,7 +202,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
200
202
|
},
|
|
201
203
|
{
|
|
202
204
|
id: 'unverifiedEmails',
|
|
203
|
-
name: $t(`
|
|
205
|
+
name: $t(`%wM`),
|
|
204
206
|
width: 20,
|
|
205
207
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
206
208
|
value: object.details.unverifiedEmails.join(', '),
|
|
@@ -213,7 +215,7 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
213
215
|
}),
|
|
214
216
|
{
|
|
215
217
|
id: 'unverifiedAddresses',
|
|
216
|
-
name: $t(`
|
|
218
|
+
name: $t(`%wN`),
|
|
217
219
|
width: 20,
|
|
218
220
|
getValue: ({ patchedMember: object }: PlatformMember) => ({
|
|
219
221
|
value: object.details.unverifiedAddresses.map(a => a.toString()).join('; '),
|
|
@@ -239,16 +241,16 @@ export const baseMemberColumns: XlsxTransformerColumn<PlatformMember>[] = [
|
|
|
239
241
|
// Assign to a typed variable to assure we have correct type checking in place
|
|
240
242
|
const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
241
243
|
id: 'members',
|
|
242
|
-
name: $t(`
|
|
244
|
+
name: $t(`%1EH`),
|
|
243
245
|
columns: [
|
|
244
246
|
...baseMemberColumns,
|
|
245
247
|
{
|
|
246
248
|
id: 'group',
|
|
247
|
-
name: $t(`
|
|
249
|
+
name: $t(`%wH`),
|
|
248
250
|
width: 40,
|
|
249
251
|
getValue: (member: PlatformMember) => {
|
|
250
252
|
const groups = member.filterRegistrations({ currentPeriod: true, types: [GroupType.Membership], organizationId: Context.organization?.id });
|
|
251
|
-
const str = Formatter.joinLast(Formatter.uniqueArray(groups.map(o => o.group.settings.name.toString())).sort(), ', ', ' ' + $t(`
|
|
253
|
+
const str = Formatter.joinLast(Formatter.uniqueArray(groups.map(o => o.group.settings.name.toString())).sort(), ', ', ' ' + $t(`%M1`) + ' ') || Context.i18n.$t('%5D');
|
|
252
254
|
|
|
253
255
|
return {
|
|
254
256
|
value: str,
|
|
@@ -257,13 +259,13 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
257
259
|
},
|
|
258
260
|
{
|
|
259
261
|
id: 'defaultAgeGroup',
|
|
260
|
-
name: $t(`
|
|
262
|
+
name: $t(`%wI`),
|
|
261
263
|
width: 40,
|
|
262
264
|
getValue: (member: PlatformMember) => {
|
|
263
265
|
const groups = member.filterRegistrations({ currentPeriod: true, types: [GroupType.Membership], organizationId: Context.organization?.id });
|
|
264
266
|
const defaultAgeGroupIds = Formatter.uniqueArray(groups.filter(o => o.group.defaultAgeGroupId));
|
|
265
|
-
const defaultAgeGroups = defaultAgeGroupIds.map(o => PlatformStruct.shared.config.defaultAgeGroups.find(g => g.id === o.group.defaultAgeGroupId)?.name ?? $t(`
|
|
266
|
-
const str = Formatter.joinLast(Formatter.uniqueArray(defaultAgeGroups).sort(), ', ', ' ' + $t(`
|
|
267
|
+
const defaultAgeGroups = defaultAgeGroupIds.map(o => PlatformStruct.shared.config.defaultAgeGroups.find(g => g.id === o.group.defaultAgeGroupId)?.name ?? $t(`%wJ`));
|
|
268
|
+
const str = Formatter.joinLast(Formatter.uniqueArray(defaultAgeGroups).sort(), ', ', ' ' + $t(`%M1`) + ' ') || Context.i18n.$t('%5D');
|
|
267
269
|
|
|
268
270
|
return {
|
|
269
271
|
value: str,
|
|
@@ -272,7 +274,7 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
272
274
|
},
|
|
273
275
|
{
|
|
274
276
|
id: 'outstandingBalance',
|
|
275
|
-
name: $t(`
|
|
277
|
+
name: $t(`%76`),
|
|
276
278
|
width: 30,
|
|
277
279
|
getValue: (v) => {
|
|
278
280
|
return {
|
|
@@ -288,7 +290,7 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
288
290
|
},
|
|
289
291
|
{
|
|
290
292
|
id: 'createdAt',
|
|
291
|
-
name: $t('
|
|
293
|
+
name: $t('%1Jc'),
|
|
292
294
|
width: 20,
|
|
293
295
|
getValue: v => ({
|
|
294
296
|
value: v.member.createdAt,
|
|
@@ -321,7 +323,7 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
321
323
|
return [
|
|
322
324
|
{
|
|
323
325
|
id: `groups.${groupId}.${recordName}`,
|
|
324
|
-
name: $t(`
|
|
326
|
+
name: $t(`%62`),
|
|
325
327
|
width: 30,
|
|
326
328
|
getValue: (member: PlatformMember) => {
|
|
327
329
|
const registration = getRegistration(member);
|
|
@@ -354,7 +356,7 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
354
356
|
return [
|
|
355
357
|
{
|
|
356
358
|
id: `groups.${groupId}.${recordName}.${menuId}.${optionId}${returnAmount ? '.amount' : ''}`,
|
|
357
|
-
name: $t(`
|
|
359
|
+
name: $t(`%wO`),
|
|
358
360
|
width: 30,
|
|
359
361
|
getValue: (member: PlatformMember) => {
|
|
360
362
|
const registration = getRegistration(member);
|
|
@@ -390,7 +392,7 @@ const sheet: XlsxTransformerSheet<PlatformMember, PlatformMember> = {
|
|
|
390
392
|
return [
|
|
391
393
|
{
|
|
392
394
|
id: `groups.${groupId}.${recordName}.${menuId}`,
|
|
393
|
-
name: $t(`
|
|
395
|
+
name: $t(`%Tb`),
|
|
394
396
|
width: 30,
|
|
395
397
|
getValue: (member: PlatformMember) => {
|
|
396
398
|
const registration = getRegistration(member);
|
|
@@ -468,23 +470,23 @@ ExportToExcelEndpoint.loaders.set(ExcelExportType.Members, {
|
|
|
468
470
|
|
|
469
471
|
function formatGender(gender: Gender): string {
|
|
470
472
|
switch (gender) {
|
|
471
|
-
case Gender.Male: return $t(`
|
|
472
|
-
case Gender.Female: return $t(`
|
|
473
|
-
default: return $t(`
|
|
473
|
+
case Gender.Male: return $t(`%XK`);
|
|
474
|
+
case Gender.Female: return $t(`%XM`);
|
|
475
|
+
default: return $t(`%1JG`);
|
|
474
476
|
}
|
|
475
477
|
}
|
|
476
478
|
|
|
477
479
|
function formatMembershipStatus(status: MembershipStatus): string {
|
|
478
480
|
switch (status) {
|
|
479
481
|
case MembershipStatus.Trial:
|
|
480
|
-
return $t(`
|
|
482
|
+
return $t(`%1IH`);
|
|
481
483
|
case MembershipStatus.Active:
|
|
482
|
-
return $t(`
|
|
484
|
+
return $t(`%1H0`);
|
|
483
485
|
case MembershipStatus.Expiring:
|
|
484
|
-
return $t(`
|
|
486
|
+
return $t(`%7F`);
|
|
485
487
|
case MembershipStatus.Temporary:
|
|
486
|
-
return $t(`
|
|
488
|
+
return $t(`%zU`);
|
|
487
489
|
case MembershipStatus.Inactive:
|
|
488
|
-
return $t(`
|
|
490
|
+
return $t(`%zV`);
|
|
489
491
|
}
|
|
490
492
|
}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { ArrayDecoder, field } from '@simonbackx/simple-encoding';
|
|
2
|
-
import { XlsxTransformerSheet } from '@stamhoofd/excel-writer';
|
|
2
|
+
import type { XlsxTransformerSheet } from '@stamhoofd/excel-writer';
|
|
3
3
|
import { Group, Member, MemberResponsibilityRecord } from '@stamhoofd/models';
|
|
4
|
-
import {
|
|
4
|
+
import type { LimitedFilteredRequest, Premise } from '@stamhoofd/structures';
|
|
5
|
+
import { ExcelExportType, MemberResponsibilityRecord as MemberResponsibilityRecordStruct, MemberWithRegistrationsBlob, Organization as OrganizationStruct, PaginatedResponse, Platform as PlatformStruct } from '@stamhoofd/structures';
|
|
5
6
|
import { Formatter, Sorter } from '@stamhoofd/utility';
|
|
6
7
|
import { GetOrganizationsEndpoint } from '../endpoints/admin/organizations/GetOrganizationsEndpoint.js';
|
|
7
8
|
import { ExportToExcelEndpoint } from '../endpoints/global/files/ExportToExcelEndpoint.js';
|
|
@@ -28,11 +29,11 @@ type Object = OrganizationWithResponsibilities;
|
|
|
28
29
|
// Assign to a typed variable to assure we have correct type checking in place
|
|
29
30
|
const sheet: XlsxTransformerSheet<Object, Object> = {
|
|
30
31
|
id: 'organizations',
|
|
31
|
-
name: $t(`
|
|
32
|
+
name: $t(`%wP`),
|
|
32
33
|
columns: [
|
|
33
34
|
{
|
|
34
35
|
id: 'id',
|
|
35
|
-
name: $t(`
|
|
36
|
+
name: $t(`%d`),
|
|
36
37
|
width: 40,
|
|
37
38
|
getValue: (object: Object) => ({
|
|
38
39
|
value: object.id,
|
|
@@ -40,7 +41,7 @@ const sheet: XlsxTransformerSheet<Object, Object> = {
|
|
|
40
41
|
},
|
|
41
42
|
{
|
|
42
43
|
id: 'uri',
|
|
43
|
-
name: $t(`
|
|
44
|
+
name: $t(`%7C`),
|
|
44
45
|
width: 20,
|
|
45
46
|
getValue: (object: Object) => ({
|
|
46
47
|
value: object.uri,
|
|
@@ -48,7 +49,7 @@ const sheet: XlsxTransformerSheet<Object, Object> = {
|
|
|
48
49
|
},
|
|
49
50
|
{
|
|
50
51
|
id: 'name',
|
|
51
|
-
name: $t(`
|
|
52
|
+
name: $t(`%Gq`),
|
|
52
53
|
width: 50,
|
|
53
54
|
getValue: (object: Object) => ({
|
|
54
55
|
value: object.name,
|
|
@@ -56,13 +57,13 @@ const sheet: XlsxTransformerSheet<Object, Object> = {
|
|
|
56
57
|
},
|
|
57
58
|
{
|
|
58
59
|
id: 'tags',
|
|
59
|
-
name: $t(`
|
|
60
|
+
name: $t(`%13`),
|
|
60
61
|
width: 50,
|
|
61
62
|
getValue: (object: Object) => {
|
|
62
63
|
const platform = PlatformStruct.shared;
|
|
63
64
|
|
|
64
65
|
return {
|
|
65
|
-
value: object.meta.tags.map(tag => platform.config.tags.find(t => t.id === tag)?.name ?? $t(`
|
|
66
|
+
value: object.meta.tags.map(tag => platform.config.tags.find(t => t.id === tag)?.name ?? $t(`%Gr`)).join(', '),
|
|
66
67
|
};
|
|
67
68
|
},
|
|
68
69
|
},
|
|
@@ -87,7 +88,7 @@ const sheet: XlsxTransformerSheet<Object, Object> = {
|
|
|
87
88
|
|
|
88
89
|
const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordWithMemberAndOrganization> = {
|
|
89
90
|
id: 'responsibilities',
|
|
90
|
-
name: $t(`
|
|
91
|
+
name: $t(`%7D`),
|
|
91
92
|
transform(organization) {
|
|
92
93
|
return organization.responsibilities.map(r => MemberResponsibilityRecordWithMemberAndOrganization.create({
|
|
93
94
|
...r,
|
|
@@ -97,7 +98,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
97
98
|
columns: [
|
|
98
99
|
{
|
|
99
100
|
id: 'organization.id',
|
|
100
|
-
name: $t(`
|
|
101
|
+
name: $t(`%d`),
|
|
101
102
|
width: 35,
|
|
102
103
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
103
104
|
value: object.organization.id,
|
|
@@ -105,7 +106,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
105
106
|
},
|
|
106
107
|
{
|
|
107
108
|
id: 'organization.uri',
|
|
108
|
-
name: $t(`
|
|
109
|
+
name: $t(`%7C`),
|
|
109
110
|
width: 20,
|
|
110
111
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
111
112
|
value: object.organization.uri,
|
|
@@ -113,7 +114,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
113
114
|
},
|
|
114
115
|
{
|
|
115
116
|
id: 'organization.name',
|
|
116
|
-
name: $t(`
|
|
117
|
+
name: $t(`%CX`),
|
|
117
118
|
width: 50,
|
|
118
119
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
119
120
|
value: object.organization.name,
|
|
@@ -121,7 +122,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
121
122
|
},
|
|
122
123
|
{
|
|
123
124
|
id: 'responsibility.name',
|
|
124
|
-
name: $t(`
|
|
125
|
+
name: $t(`%H2`),
|
|
125
126
|
width: 50,
|
|
126
127
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => {
|
|
127
128
|
const platform = PlatformStruct.shared;
|
|
@@ -129,18 +130,18 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
129
130
|
|
|
130
131
|
if (!responsibility) {
|
|
131
132
|
return {
|
|
132
|
-
value: $t(`
|
|
133
|
+
value: $t(`%wQ`),
|
|
133
134
|
};
|
|
134
135
|
}
|
|
135
136
|
|
|
136
137
|
return {
|
|
137
|
-
value: responsibility.name + (responsibility.isGroupBased ? ' ' + $t(`
|
|
138
|
+
value: responsibility.name + (responsibility.isGroupBased ? ' ' + $t(`%wR`) + ' ' + (object.group?.settings.name ?? $t(`%wS`)) : ''),
|
|
138
139
|
};
|
|
139
140
|
},
|
|
140
141
|
},
|
|
141
142
|
{
|
|
142
143
|
id: 'responsibility.member.firstName',
|
|
143
|
-
name: $t(`
|
|
144
|
+
name: $t(`%1MT`),
|
|
144
145
|
width: 30,
|
|
145
146
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
146
147
|
value: object.member.firstName,
|
|
@@ -148,7 +149,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
148
149
|
},
|
|
149
150
|
{
|
|
150
151
|
id: 'responsibility.member.lastName',
|
|
151
|
-
name: $t(`
|
|
152
|
+
name: $t(`%1MU`),
|
|
152
153
|
width: 30,
|
|
153
154
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
154
155
|
value: object.member.details.lastName,
|
|
@@ -156,7 +157,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
156
157
|
},
|
|
157
158
|
{
|
|
158
159
|
id: 'responsibility.member.email',
|
|
159
|
-
name: $t(`
|
|
160
|
+
name: $t(`%wT`),
|
|
160
161
|
width: 50,
|
|
161
162
|
getValue: (object: MemberResponsibilityRecordWithMemberAndOrganization) => ({
|
|
162
163
|
value: object.member.details.email,
|
|
@@ -172,7 +173,7 @@ const responsibilities: XlsxTransformerSheet<Object, MemberResponsibilityRecordW
|
|
|
172
173
|
type PremiseWithOrganization = { organization: Object; premise: Premise };
|
|
173
174
|
const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
174
175
|
id: 'premises',
|
|
175
|
-
name: $t(`
|
|
176
|
+
name: $t(`%6c`),
|
|
176
177
|
transform(organization) {
|
|
177
178
|
return organization.privateMeta?.premises.map(r => ({
|
|
178
179
|
organization,
|
|
@@ -182,7 +183,7 @@ const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
|
182
183
|
columns: [
|
|
183
184
|
{
|
|
184
185
|
id: 'organization.id',
|
|
185
|
-
name: $t(`
|
|
186
|
+
name: $t(`%d`),
|
|
186
187
|
width: 35,
|
|
187
188
|
getValue: (object: PremiseWithOrganization) => ({
|
|
188
189
|
value: object.organization.id,
|
|
@@ -190,7 +191,7 @@ const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
|
190
191
|
},
|
|
191
192
|
{
|
|
192
193
|
id: 'organization.uri',
|
|
193
|
-
name: $t(`
|
|
194
|
+
name: $t(`%7C`),
|
|
194
195
|
width: 20,
|
|
195
196
|
getValue: (object: PremiseWithOrganization) => ({
|
|
196
197
|
value: object.organization.uri,
|
|
@@ -198,7 +199,7 @@ const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
|
198
199
|
},
|
|
199
200
|
{
|
|
200
201
|
id: 'organization.name',
|
|
201
|
-
name: $t(`
|
|
202
|
+
name: $t(`%CX`),
|
|
202
203
|
width: 50,
|
|
203
204
|
getValue: (object: PremiseWithOrganization) => ({
|
|
204
205
|
value: object.organization.name,
|
|
@@ -206,7 +207,7 @@ const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
|
206
207
|
},
|
|
207
208
|
{
|
|
208
209
|
id: 'premise.name',
|
|
209
|
-
name: $t(`
|
|
210
|
+
name: $t(`%Gq`),
|
|
210
211
|
width: 20,
|
|
211
212
|
getValue: (object: PremiseWithOrganization) => ({
|
|
212
213
|
value: object.premise.name,
|
|
@@ -214,13 +215,13 @@ const premises: XlsxTransformerSheet<Object, PremiseWithOrganization> = {
|
|
|
214
215
|
},
|
|
215
216
|
{
|
|
216
217
|
id: 'premise.type',
|
|
217
|
-
name: $t(`
|
|
218
|
+
name: $t(`%1B`),
|
|
218
219
|
width: 20,
|
|
219
220
|
getValue: (object: PremiseWithOrganization) => {
|
|
220
221
|
const ids = object.premise.premiseTypeIds;
|
|
221
222
|
const platform = PlatformStruct.shared;
|
|
222
223
|
return {
|
|
223
|
-
value: ids.map(id => platform.config.premiseTypes.find(t => t.id === id)?.name ?? $t(`
|
|
224
|
+
value: ids.map(id => platform.config.premiseTypes.find(t => t.id === id)?.name ?? $t(`%Gr`)).join(', '),
|
|
224
225
|
};
|
|
225
226
|
},
|
|
226
227
|
},
|