@webiny/api-workflows 0.0.0-unstable.61c048f412
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/LICENSE +21 -0
- package/README.md +11 -0
- package/constants.d.ts +3 -0
- package/constants.js +5 -0
- package/constants.js.map +1 -0
- package/domain/notifications/abstractions.d.ts +64 -0
- package/domain/notifications/abstractions.js +10 -0
- package/domain/notifications/abstractions.js.map +1 -0
- package/domain/notifications/errors.d.ts +5 -0
- package/domain/notifications/errors.js +11 -0
- package/domain/notifications/errors.js.map +1 -0
- package/domain/workflow/WorkflowMapper.d.ts +12 -0
- package/domain/workflow/WorkflowMapper.js +29 -0
- package/domain/workflow/WorkflowMapper.js.map +1 -0
- package/domain/workflow/abstractions.d.ts +37 -0
- package/domain/workflow/abstractions.js +6 -0
- package/domain/workflow/abstractions.js.map +1 -0
- package/domain/workflow/errors.d.ts +23 -0
- package/domain/workflow/errors.js +36 -0
- package/domain/workflow/errors.js.map +1 -0
- package/domain/workflow/workflowModel.d.ts +9 -0
- package/domain/workflow/workflowModel.js +32 -0
- package/domain/workflow/workflowModel.js.map +1 -0
- package/domain/workflowState/WorkflowState.d.ts +55 -0
- package/domain/workflowState/WorkflowState.js +327 -0
- package/domain/workflowState/WorkflowState.js.map +1 -0
- package/domain/workflowState/WorkflowStateMapper.d.ts +9 -0
- package/domain/workflowState/WorkflowStateMapper.js +40 -0
- package/domain/workflowState/WorkflowStateMapper.js.map +1 -0
- package/domain/workflowState/abstractions.d.ts +75 -0
- package/domain/workflowState/abstractions.js +13 -0
- package/domain/workflowState/abstractions.js.map +1 -0
- package/domain/workflowState/errors.d.ts +86 -0
- package/domain/workflowState/errors.js +139 -0
- package/domain/workflowState/errors.js.map +1 -0
- package/domain/workflowState/guards/canReview.d.ts +2 -0
- package/domain/workflowState/guards/canReview.js +5 -0
- package/domain/workflowState/guards/canReview.js.map +1 -0
- package/domain/workflowState/guards/canTakeOver.d.ts +2 -0
- package/domain/workflowState/guards/canTakeOver.js +5 -0
- package/domain/workflowState/guards/canTakeOver.js.map +1 -0
- package/domain/workflowState/guards/isInReview.d.ts +2 -0
- package/domain/workflowState/guards/isInReview.js +6 -0
- package/domain/workflowState/guards/isInReview.js.map +1 -0
- package/domain/workflowState/guards/isRejected.d.ts +2 -0
- package/domain/workflowState/guards/isRejected.js +6 -0
- package/domain/workflowState/guards/isRejected.js.map +1 -0
- package/domain/workflowState/guards/isStepOwner.d.ts +2 -0
- package/domain/workflowState/guards/isStepOwner.js +5 -0
- package/domain/workflowState/guards/isStepOwner.js.map +1 -0
- package/domain/workflowState/stateModel.d.ts +9 -0
- package/domain/workflowState/stateModel.js +58 -0
- package/domain/workflowState/stateModel.js.map +1 -0
- package/features/internal/GetUserTeams/GetUserTeamsUseCase.d.ts +12 -0
- package/features/internal/GetUserTeams/GetUserTeamsUseCase.js +36 -0
- package/features/internal/GetUserTeams/GetUserTeamsUseCase.js.map +1 -0
- package/features/internal/GetUserTeams/abstractions.d.ts +10 -0
- package/features/internal/GetUserTeams/abstractions.js +4 -0
- package/features/internal/GetUserTeams/abstractions.js.map +1 -0
- package/features/internal/GetUserTeams/feature.d.ts +1 -0
- package/features/internal/GetUserTeams/feature.js +10 -0
- package/features/internal/GetUserTeams/feature.js.map +1 -0
- package/features/internal/GetUserTeams/index.d.ts +1 -0
- package/features/internal/GetUserTeams/index.js +3 -0
- package/features/internal/GetUserTeams/index.js.map +1 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesRepository.d.ts +11 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesRepository.js +24 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesRepository.js.map +1 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesUseCase.d.ts +13 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesUseCase.js +40 -0
- package/features/notifications/ListNotificationTypes/ListNotificationTypesUseCase.js.map +1 -0
- package/features/notifications/ListNotificationTypes/abstractions.d.ts +31 -0
- package/features/notifications/ListNotificationTypes/abstractions.js +15 -0
- package/features/notifications/ListNotificationTypes/abstractions.js.map +1 -0
- package/features/notifications/ListNotificationTypes/feature.d.ts +1 -0
- package/features/notifications/ListNotificationTypes/feature.js +12 -0
- package/features/notifications/ListNotificationTypes/feature.js.map +1 -0
- package/features/notifications/ListNotificationTypes/index.d.ts +3 -0
- package/features/notifications/ListNotificationTypes/index.js +4 -0
- package/features/notifications/ListNotificationTypes/index.js.map +1 -0
- package/features/notifications/NotificationTransport/MailNotificationTransport.d.ts +13 -0
- package/features/notifications/NotificationTransport/MailNotificationTransport.js +47 -0
- package/features/notifications/NotificationTransport/MailNotificationTransport.js.map +1 -0
- package/features/notifications/NotificationTransport/abstractions.d.ts +21 -0
- package/features/notifications/NotificationTransport/abstractions.js +4 -0
- package/features/notifications/NotificationTransport/abstractions.js.map +1 -0
- package/features/notifications/NotificationTransport/feature.d.ts +1 -0
- package/features/notifications/NotificationTransport/feature.js +10 -0
- package/features/notifications/NotificationTransport/feature.js.map +1 -0
- package/features/notifications/NotificationTransport/index.d.ts +3 -0
- package/features/notifications/NotificationTransport/index.js +4 -0
- package/features/notifications/NotificationTransport/index.js.map +1 -0
- package/features/shared/abstractions.d.ts +21 -0
- package/features/shared/abstractions.js +3 -0
- package/features/shared/abstractions.js.map +1 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowRepository.d.ts +14 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowRepository.js +45 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowRepository.js.map +1 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowUseCase.d.ts +15 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowUseCase.js +57 -0
- package/features/workflow/CreateWorkflow/CreateWorkflowUseCase.js.map +1 -0
- package/features/workflow/CreateWorkflow/abstractions.d.ts +56 -0
- package/features/workflow/CreateWorkflow/abstractions.js +19 -0
- package/features/workflow/CreateWorkflow/abstractions.js.map +1 -0
- package/features/workflow/CreateWorkflow/events.d.ts +21 -0
- package/features/workflow/CreateWorkflow/events.js +20 -0
- package/features/workflow/CreateWorkflow/events.js.map +1 -0
- package/features/workflow/CreateWorkflow/feature.d.ts +1 -0
- package/features/workflow/CreateWorkflow/feature.js +12 -0
- package/features/workflow/CreateWorkflow/feature.js.map +1 -0
- package/features/workflow/CreateWorkflow/index.d.ts +4 -0
- package/features/workflow/CreateWorkflow/index.js +5 -0
- package/features/workflow/CreateWorkflow/index.js.map +1 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowRepository.d.ts +13 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowRepository.js +33 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowRepository.js.map +1 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowUseCase.d.ts +17 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowUseCase.js +59 -0
- package/features/workflow/DeleteWorkflow/DeleteWorkflowUseCase.js.map +1 -0
- package/features/workflow/DeleteWorkflow/abstractions.d.ts +50 -0
- package/features/workflow/DeleteWorkflow/abstractions.js +19 -0
- package/features/workflow/DeleteWorkflow/abstractions.js.map +1 -0
- package/features/workflow/DeleteWorkflow/events.d.ts +21 -0
- package/features/workflow/DeleteWorkflow/events.js +20 -0
- package/features/workflow/DeleteWorkflow/events.js.map +1 -0
- package/features/workflow/DeleteWorkflow/feature.d.ts +1 -0
- package/features/workflow/DeleteWorkflow/feature.js +12 -0
- package/features/workflow/DeleteWorkflow/feature.js.map +1 -0
- package/features/workflow/DeleteWorkflow/index.d.ts +4 -0
- package/features/workflow/DeleteWorkflow/index.js +5 -0
- package/features/workflow/DeleteWorkflow/index.js.map +1 -0
- package/features/workflow/GetWorkflow/GetWorkflowRepository.d.ts +14 -0
- package/features/workflow/GetWorkflow/GetWorkflowRepository.js +46 -0
- package/features/workflow/GetWorkflow/GetWorkflowRepository.js.map +1 -0
- package/features/workflow/GetWorkflow/GetWorkflowUseCase.d.ts +13 -0
- package/features/workflow/GetWorkflow/GetWorkflowUseCase.js +34 -0
- package/features/workflow/GetWorkflow/GetWorkflowUseCase.js.map +1 -0
- package/features/workflow/GetWorkflow/abstractions.d.ts +45 -0
- package/features/workflow/GetWorkflow/abstractions.js +15 -0
- package/features/workflow/GetWorkflow/abstractions.js.map +1 -0
- package/features/workflow/GetWorkflow/feature.d.ts +1 -0
- package/features/workflow/GetWorkflow/feature.js +12 -0
- package/features/workflow/GetWorkflow/feature.js.map +1 -0
- package/features/workflow/GetWorkflow/index.d.ts +1 -0
- package/features/workflow/GetWorkflow/index.js +3 -0
- package/features/workflow/GetWorkflow/index.js.map +1 -0
- package/features/workflow/ListWorkflows/ListWorkflowsRepository.d.ts +18 -0
- package/features/workflow/ListWorkflows/ListWorkflowsRepository.js +67 -0
- package/features/workflow/ListWorkflows/ListWorkflowsRepository.js.map +1 -0
- package/features/workflow/ListWorkflows/ListWorkflowsUseCase.d.ts +10 -0
- package/features/workflow/ListWorkflows/ListWorkflowsUseCase.js +20 -0
- package/features/workflow/ListWorkflows/ListWorkflowsUseCase.js.map +1 -0
- package/features/workflow/ListWorkflows/abstractions.d.ts +60 -0
- package/features/workflow/ListWorkflows/abstractions.js +15 -0
- package/features/workflow/ListWorkflows/abstractions.js.map +1 -0
- package/features/workflow/ListWorkflows/feature.d.ts +1 -0
- package/features/workflow/ListWorkflows/feature.js +12 -0
- package/features/workflow/ListWorkflows/feature.js.map +1 -0
- package/features/workflow/ListWorkflows/index.d.ts +1 -0
- package/features/workflow/ListWorkflows/index.js +3 -0
- package/features/workflow/ListWorkflows/index.js.map +1 -0
- package/features/workflow/StoreWorkflow/StoreWorkflowUseCase.d.ts +15 -0
- package/features/workflow/StoreWorkflow/StoreWorkflowUseCase.js +37 -0
- package/features/workflow/StoreWorkflow/StoreWorkflowUseCase.js.map +1 -0
- package/features/workflow/StoreWorkflow/abstractions.d.ts +32 -0
- package/features/workflow/StoreWorkflow/abstractions.js +11 -0
- package/features/workflow/StoreWorkflow/abstractions.js.map +1 -0
- package/features/workflow/StoreWorkflow/feature.d.ts +1 -0
- package/features/workflow/StoreWorkflow/feature.js +17 -0
- package/features/workflow/StoreWorkflow/feature.js.map +1 -0
- package/features/workflow/StoreWorkflow/index.d.ts +3 -0
- package/features/workflow/StoreWorkflow/index.js +4 -0
- package/features/workflow/StoreWorkflow/index.js.map +1 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowRepository.d.ts +15 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowRepository.js +49 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowRepository.js.map +1 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowUseCase.d.ts +15 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowUseCase.js +59 -0
- package/features/workflow/UpdateWorkflow/UpdateWorkflowUseCase.js.map +1 -0
- package/features/workflow/UpdateWorkflow/abstractions.d.ts +57 -0
- package/features/workflow/UpdateWorkflow/abstractions.js +19 -0
- package/features/workflow/UpdateWorkflow/abstractions.js.map +1 -0
- package/features/workflow/UpdateWorkflow/events.d.ts +21 -0
- package/features/workflow/UpdateWorkflow/events.js +20 -0
- package/features/workflow/UpdateWorkflow/events.js.map +1 -0
- package/features/workflow/UpdateWorkflow/feature.d.ts +1 -0
- package/features/workflow/UpdateWorkflow/feature.js +12 -0
- package/features/workflow/UpdateWorkflow/feature.js.map +1 -0
- package/features/workflow/UpdateWorkflow/index.d.ts +4 -0
- package/features/workflow/UpdateWorkflow/index.js +5 -0
- package/features/workflow/UpdateWorkflow/index.js.map +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/ApproveWorkflowStateStepUseCase.d.ts +15 -0
- package/features/workflowState/ApproveWorkflowStateStep/ApproveWorkflowStateStepUseCase.js +39 -0
- package/features/workflowState/ApproveWorkflowStateStep/ApproveWorkflowStateStepUseCase.js.map +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/abstractions.d.ts +26 -0
- package/features/workflowState/ApproveWorkflowStateStep/abstractions.js +4 -0
- package/features/workflowState/ApproveWorkflowStateStep/abstractions.js.map +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/events.d.ts +12 -0
- package/features/workflowState/ApproveWorkflowStateStep/events.js +11 -0
- package/features/workflowState/ApproveWorkflowStateStep/events.js.map +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/feature.d.ts +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/feature.js +10 -0
- package/features/workflowState/ApproveWorkflowStateStep/feature.js.map +1 -0
- package/features/workflowState/ApproveWorkflowStateStep/index.d.ts +2 -0
- package/features/workflowState/ApproveWorkflowStateStep/index.js +4 -0
- package/features/workflowState/ApproveWorkflowStateStep/index.js.map +1 -0
- package/features/workflowState/CancelWorkflowState/CancelWorkflowStateUseCase.d.ts +13 -0
- package/features/workflowState/CancelWorkflowState/CancelWorkflowStateUseCase.js +29 -0
- package/features/workflowState/CancelWorkflowState/CancelWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/CancelWorkflowState/abstractions.d.ts +26 -0
- package/features/workflowState/CancelWorkflowState/abstractions.js +9 -0
- package/features/workflowState/CancelWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/CancelWorkflowState/events.d.ts +12 -0
- package/features/workflowState/CancelWorkflowState/events.js +11 -0
- package/features/workflowState/CancelWorkflowState/events.js.map +1 -0
- package/features/workflowState/CancelWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/CancelWorkflowState/feature.js +10 -0
- package/features/workflowState/CancelWorkflowState/feature.js.map +1 -0
- package/features/workflowState/CancelWorkflowState/index.d.ts +2 -0
- package/features/workflowState/CancelWorkflowState/index.js +4 -0
- package/features/workflowState/CancelWorkflowState/index.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateRepository.d.ts +14 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateRepository.js +32 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateRepository.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateUseCase.d.ts +20 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateUseCase.js +108 -0
- package/features/workflowState/CreateWorkflowState/CreateWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/abstractions.d.ts +54 -0
- package/features/workflowState/CreateWorkflowState/abstractions.js +15 -0
- package/features/workflowState/CreateWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/events.d.ts +12 -0
- package/features/workflowState/CreateWorkflowState/events.js +11 -0
- package/features/workflowState/CreateWorkflowState/events.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/CreateWorkflowState/feature.js +12 -0
- package/features/workflowState/CreateWorkflowState/feature.js.map +1 -0
- package/features/workflowState/CreateWorkflowState/index.d.ts +2 -0
- package/features/workflowState/CreateWorkflowState/index.js +4 -0
- package/features/workflowState/CreateWorkflowState/index.js.map +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/DeleteTargetWorkflowStateUseCase.d.ts +21 -0
- package/features/workflowState/DeleteTargetWorkflowState/DeleteTargetWorkflowStateUseCase.js +59 -0
- package/features/workflowState/DeleteTargetWorkflowState/DeleteTargetWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/abstractions.d.ts +23 -0
- package/features/workflowState/DeleteTargetWorkflowState/abstractions.js +4 -0
- package/features/workflowState/DeleteTargetWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/events.d.ts +12 -0
- package/features/workflowState/DeleteTargetWorkflowState/events.js +11 -0
- package/features/workflowState/DeleteTargetWorkflowState/events.js.map +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/feature.js +10 -0
- package/features/workflowState/DeleteTargetWorkflowState/feature.js.map +1 -0
- package/features/workflowState/DeleteTargetWorkflowState/index.d.ts +2 -0
- package/features/workflowState/DeleteTargetWorkflowState/index.js +4 -0
- package/features/workflowState/DeleteTargetWorkflowState/index.js.map +1 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateRepository.d.ts +13 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateRepository.js +20 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateRepository.js.map +1 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateUseCase.d.ts +14 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateUseCase.js +32 -0
- package/features/workflowState/DeleteWorkflowState/DeleteWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/DeleteWorkflowState/abstractions.d.ts +25 -0
- package/features/workflowState/DeleteWorkflowState/abstractions.js +5 -0
- package/features/workflowState/DeleteWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/DeleteWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/DeleteWorkflowState/feature.js +12 -0
- package/features/workflowState/DeleteWorkflowState/feature.js.map +1 -0
- package/features/workflowState/DeleteWorkflowState/index.d.ts +1 -0
- package/features/workflowState/DeleteWorkflowState/index.js +3 -0
- package/features/workflowState/DeleteWorkflowState/index.js.map +1 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateRepository.d.ts +14 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateRepository.js +52 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateRepository.js.map +1 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateUseCase.d.ts +14 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateUseCase.js +38 -0
- package/features/workflowState/GetTargetWorkflowState/GetTargetWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/GetTargetWorkflowState/abstractions.d.ts +48 -0
- package/features/workflowState/GetTargetWorkflowState/abstractions.js +15 -0
- package/features/workflowState/GetTargetWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/GetTargetWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/GetTargetWorkflowState/feature.js +12 -0
- package/features/workflowState/GetTargetWorkflowState/feature.js.map +1 -0
- package/features/workflowState/GetTargetWorkflowState/index.d.ts +1 -0
- package/features/workflowState/GetTargetWorkflowState/index.js +3 -0
- package/features/workflowState/GetTargetWorkflowState/index.js.map +1 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateRepository.d.ts +14 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateRepository.js +32 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateRepository.js.map +1 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateUseCase.d.ts +14 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateUseCase.js +30 -0
- package/features/workflowState/GetWorkflowState/GetWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/GetWorkflowState/abstractions.d.ts +39 -0
- package/features/workflowState/GetWorkflowState/abstractions.js +15 -0
- package/features/workflowState/GetWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/GetWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/GetWorkflowState/feature.js +12 -0
- package/features/workflowState/GetWorkflowState/feature.js.map +1 -0
- package/features/workflowState/GetWorkflowState/index.d.ts +1 -0
- package/features/workflowState/GetWorkflowState/index.js +3 -0
- package/features/workflowState/GetWorkflowState/index.js.map +1 -0
- package/features/workflowState/ListOwnWorkflowStates/ListOwnWorkflowStatesUseCase.d.ts +13 -0
- package/features/workflowState/ListOwnWorkflowStates/ListOwnWorkflowStatesUseCase.js +41 -0
- package/features/workflowState/ListOwnWorkflowStates/ListOwnWorkflowStatesUseCase.js.map +1 -0
- package/features/workflowState/ListOwnWorkflowStates/abstractions.d.ts +22 -0
- package/features/workflowState/ListOwnWorkflowStates/abstractions.js +9 -0
- package/features/workflowState/ListOwnWorkflowStates/abstractions.js.map +1 -0
- package/features/workflowState/ListOwnWorkflowStates/feature.d.ts +1 -0
- package/features/workflowState/ListOwnWorkflowStates/feature.js +10 -0
- package/features/workflowState/ListOwnWorkflowStates/feature.js.map +1 -0
- package/features/workflowState/ListOwnWorkflowStates/index.d.ts +1 -0
- package/features/workflowState/ListOwnWorkflowStates/index.js +3 -0
- package/features/workflowState/ListOwnWorkflowStates/index.js.map +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/ListRequestedWorkflowStatesUseCase.d.ts +15 -0
- package/features/workflowState/ListRequestedWorkflowStates/ListRequestedWorkflowStatesUseCase.js +49 -0
- package/features/workflowState/ListRequestedWorkflowStates/ListRequestedWorkflowStatesUseCase.js.map +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/abstractions.d.ts +22 -0
- package/features/workflowState/ListRequestedWorkflowStates/abstractions.js +9 -0
- package/features/workflowState/ListRequestedWorkflowStates/abstractions.js.map +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/feature.d.ts +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/feature.js +10 -0
- package/features/workflowState/ListRequestedWorkflowStates/feature.js.map +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/index.d.ts +1 -0
- package/features/workflowState/ListRequestedWorkflowStates/index.js +3 -0
- package/features/workflowState/ListRequestedWorkflowStates/index.js.map +1 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesRepository.d.ts +16 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesRepository.js +43 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesRepository.js.map +1 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesUseCase.d.ts +14 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesUseCase.js +36 -0
- package/features/workflowState/ListWorkflowStates/ListWorkflowStatesUseCase.js.map +1 -0
- package/features/workflowState/ListWorkflowStates/abstractions.d.ts +56 -0
- package/features/workflowState/ListWorkflowStates/abstractions.js +15 -0
- package/features/workflowState/ListWorkflowStates/abstractions.js.map +1 -0
- package/features/workflowState/ListWorkflowStates/feature.d.ts +1 -0
- package/features/workflowState/ListWorkflowStates/feature.js +12 -0
- package/features/workflowState/ListWorkflowStates/feature.js.map +1 -0
- package/features/workflowState/ListWorkflowStates/index.d.ts +1 -0
- package/features/workflowState/ListWorkflowStates/index.js +3 -0
- package/features/workflowState/ListWorkflowStates/index.js.map +1 -0
- package/features/workflowState/README.md +8 -0
- package/features/workflowState/RejectWorkflowStateStep/RejectWorkflowStateStepUseCase.d.ts +15 -0
- package/features/workflowState/RejectWorkflowStateStep/RejectWorkflowStateStepUseCase.js +39 -0
- package/features/workflowState/RejectWorkflowStateStep/RejectWorkflowStateStepUseCase.js.map +1 -0
- package/features/workflowState/RejectWorkflowStateStep/abstractions.d.ts +26 -0
- package/features/workflowState/RejectWorkflowStateStep/abstractions.js +4 -0
- package/features/workflowState/RejectWorkflowStateStep/abstractions.js.map +1 -0
- package/features/workflowState/RejectWorkflowStateStep/events.d.ts +12 -0
- package/features/workflowState/RejectWorkflowStateStep/events.js +11 -0
- package/features/workflowState/RejectWorkflowStateStep/events.js.map +1 -0
- package/features/workflowState/RejectWorkflowStateStep/feature.d.ts +1 -0
- package/features/workflowState/RejectWorkflowStateStep/feature.js +10 -0
- package/features/workflowState/RejectWorkflowStateStep/feature.js.map +1 -0
- package/features/workflowState/RejectWorkflowStateStep/index.d.ts +2 -0
- package/features/workflowState/RejectWorkflowStateStep/index.js +4 -0
- package/features/workflowState/RejectWorkflowStateStep/index.js.map +1 -0
- package/features/workflowState/StartWorkflowStateStep/StartWorkflowStateStepUseCase.d.ts +15 -0
- package/features/workflowState/StartWorkflowStateStep/StartWorkflowStateStepUseCase.js +39 -0
- package/features/workflowState/StartWorkflowStateStep/StartWorkflowStateStepUseCase.js.map +1 -0
- package/features/workflowState/StartWorkflowStateStep/abstractions.d.ts +25 -0
- package/features/workflowState/StartWorkflowStateStep/abstractions.js +4 -0
- package/features/workflowState/StartWorkflowStateStep/abstractions.js.map +1 -0
- package/features/workflowState/StartWorkflowStateStep/events.d.ts +12 -0
- package/features/workflowState/StartWorkflowStateStep/events.js +11 -0
- package/features/workflowState/StartWorkflowStateStep/events.js.map +1 -0
- package/features/workflowState/StartWorkflowStateStep/feature.d.ts +1 -0
- package/features/workflowState/StartWorkflowStateStep/feature.js +10 -0
- package/features/workflowState/StartWorkflowStateStep/feature.js.map +1 -0
- package/features/workflowState/StartWorkflowStateStep/index.d.ts +2 -0
- package/features/workflowState/StartWorkflowStateStep/index.js +4 -0
- package/features/workflowState/StartWorkflowStateStep/index.js.map +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/TakeOverWorkflowStateStepUseCase.d.ts +15 -0
- package/features/workflowState/TakeOverWorkflowStateStep/TakeOverWorkflowStateStepUseCase.js +39 -0
- package/features/workflowState/TakeOverWorkflowStateStep/TakeOverWorkflowStateStepUseCase.js.map +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/abstractions.d.ts +26 -0
- package/features/workflowState/TakeOverWorkflowStateStep/abstractions.js +4 -0
- package/features/workflowState/TakeOverWorkflowStateStep/abstractions.js.map +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/events.d.ts +12 -0
- package/features/workflowState/TakeOverWorkflowStateStep/events.js +11 -0
- package/features/workflowState/TakeOverWorkflowStateStep/events.js.map +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/feature.d.ts +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/feature.js +10 -0
- package/features/workflowState/TakeOverWorkflowStateStep/feature.js.map +1 -0
- package/features/workflowState/TakeOverWorkflowStateStep/index.d.ts +2 -0
- package/features/workflowState/TakeOverWorkflowStateStep/index.js +4 -0
- package/features/workflowState/TakeOverWorkflowStateStep/index.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateRepository.d.ts +17 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateRepository.js +48 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateRepository.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateUseCase.d.ts +20 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateUseCase.js +57 -0
- package/features/workflowState/UpdateWorkflowState/UpdateWorkflowStateUseCase.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/abstractions.d.ts +48 -0
- package/features/workflowState/UpdateWorkflowState/abstractions.js +15 -0
- package/features/workflowState/UpdateWorkflowState/abstractions.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/events.d.ts +12 -0
- package/features/workflowState/UpdateWorkflowState/events.js +11 -0
- package/features/workflowState/UpdateWorkflowState/events.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/feature.d.ts +1 -0
- package/features/workflowState/UpdateWorkflowState/feature.js +12 -0
- package/features/workflowState/UpdateWorkflowState/feature.js.map +1 -0
- package/features/workflowState/UpdateWorkflowState/index.d.ts +2 -0
- package/features/workflowState/UpdateWorkflowState/index.js +4 -0
- package/features/workflowState/UpdateWorkflowState/index.js.map +1 -0
- package/graphql/notifications.d.ts +2 -0
- package/graphql/notifications.js +51 -0
- package/graphql/notifications.js.map +1 -0
- package/graphql/validation/approveWorkflowState.d.ts +11 -0
- package/graphql/validation/approveWorkflowState.js +7 -0
- package/graphql/validation/approveWorkflowState.js.map +1 -0
- package/graphql/validation/cancelWorkflowState.d.ts +8 -0
- package/graphql/validation/cancelWorkflowState.js +6 -0
- package/graphql/validation/cancelWorkflowState.js.map +1 -0
- package/graphql/validation/createWorkflowState.d.ts +14 -0
- package/graphql/validation/createWorkflowState.js +8 -0
- package/graphql/validation/createWorkflowState.js.map +1 -0
- package/graphql/validation/deleteWorkflow.d.ts +11 -0
- package/graphql/validation/deleteWorkflow.js +7 -0
- package/graphql/validation/deleteWorkflow.js.map +1 -0
- package/graphql/validation/getTargetWorkflowState.d.ts +11 -0
- package/graphql/validation/getTargetWorkflowState.js +7 -0
- package/graphql/validation/getTargetWorkflowState.js.map +1 -0
- package/graphql/validation/getWorkflow.d.ts +11 -0
- package/graphql/validation/getWorkflow.js +7 -0
- package/graphql/validation/getWorkflow.js.map +1 -0
- package/graphql/validation/getWorkflowState.d.ts +8 -0
- package/graphql/validation/getWorkflowState.js +6 -0
- package/graphql/validation/getWorkflowState.js.map +1 -0
- package/graphql/validation/listWorkflowStates.d.ts +108 -0
- package/graphql/validation/listWorkflowStates.js +42 -0
- package/graphql/validation/listWorkflowStates.js.map +1 -0
- package/graphql/validation/listWorkflows.d.ts +42 -0
- package/graphql/validation/listWorkflows.js +22 -0
- package/graphql/validation/listWorkflows.js.map +1 -0
- package/graphql/validation/rejectWorkflowState.d.ts +11 -0
- package/graphql/validation/rejectWorkflowState.js +7 -0
- package/graphql/validation/rejectWorkflowState.js.map +1 -0
- package/graphql/validation/startWorkflowState.d.ts +8 -0
- package/graphql/validation/startWorkflowState.js +6 -0
- package/graphql/validation/startWorkflowState.js.map +1 -0
- package/graphql/validation/step.d.ts +49 -0
- package/graphql/validation/step.js +21 -0
- package/graphql/validation/step.js.map +1 -0
- package/graphql/validation/storeWorkflow.d.ts +107 -0
- package/graphql/validation/storeWorkflow.js +9 -0
- package/graphql/validation/storeWorkflow.js.map +1 -0
- package/graphql/validation/takeOverWorkflowStateStep.d.ts +8 -0
- package/graphql/validation/takeOverWorkflowStateStep.js +6 -0
- package/graphql/validation/takeOverWorkflowStateStep.js.map +1 -0
- package/graphql/validation/workflow.d.ts +80 -0
- package/graphql/validation/workflow.js +10 -0
- package/graphql/validation/workflow.js.map +1 -0
- package/graphql/workflowState.d.ts +2 -0
- package/graphql/workflowState.js +398 -0
- package/graphql/workflowState.js.map +1 -0
- package/graphql/workflows.d.ts +2 -0
- package/graphql/workflows.js +216 -0
- package/graphql/workflows.js.map +1 -0
- package/index.d.ts +2 -0
- package/index.js +102 -0
- package/index.js.map +1 -0
- package/package.json +41 -0
- package/types.d.ts +13 -0
- package/types.js +7 -0
- package/types.js.map +1 -0
|
@@ -0,0 +1,327 @@
|
|
|
1
|
+
import { WorkflowStateRecordState } from "./abstractions.js";
|
|
2
|
+
import { Result } from "@webiny/feature/api";
|
|
3
|
+
import { WorkflowStateNotAuthorizedError, WorkflowStateNoPendingStepError, WorkflowStateStepCannotReviewError, WorkflowStateStepCannotTakeOverError, WorkflowStateStepNotStepOwnerError, WorkflowStateInReviewError, WorkflowStateRejectedError, WorkflowStateNoCurrentStepError, WorkflowStateNotInReview } from "./errors.js";
|
|
4
|
+
import { canReview } from "./guards/canReview.js";
|
|
5
|
+
import { isRejected } from "./guards/isRejected.js";
|
|
6
|
+
import { canTakeOver } from "./guards/canTakeOver.js";
|
|
7
|
+
import { isInReview } from "./guards/isInReview.js";
|
|
8
|
+
import { isStepOwner } from "./guards/isStepOwner.js";
|
|
9
|
+
export class WorkflowState {
|
|
10
|
+
constructor(record, teams, currentIdentity) {
|
|
11
|
+
this.record = record;
|
|
12
|
+
this.teams = teams;
|
|
13
|
+
this.currentIdentity = currentIdentity;
|
|
14
|
+
}
|
|
15
|
+
get id() {
|
|
16
|
+
return this.record.id;
|
|
17
|
+
}
|
|
18
|
+
get app() {
|
|
19
|
+
return this.record.app;
|
|
20
|
+
}
|
|
21
|
+
get title() {
|
|
22
|
+
return this.record.title;
|
|
23
|
+
}
|
|
24
|
+
get workflowId() {
|
|
25
|
+
return this.record.workflowId;
|
|
26
|
+
}
|
|
27
|
+
get targetId() {
|
|
28
|
+
return this.record.targetId;
|
|
29
|
+
}
|
|
30
|
+
get targetRevisionId() {
|
|
31
|
+
return this.record.targetRevisionId;
|
|
32
|
+
}
|
|
33
|
+
get isActive() {
|
|
34
|
+
return this.record.isActive;
|
|
35
|
+
}
|
|
36
|
+
get comment() {
|
|
37
|
+
return this.record.comment;
|
|
38
|
+
}
|
|
39
|
+
get state() {
|
|
40
|
+
return this.record.state;
|
|
41
|
+
}
|
|
42
|
+
get steps() {
|
|
43
|
+
return this.record.steps.map(step => {
|
|
44
|
+
return this.enrichStep({
|
|
45
|
+
createdBy: this.record.createdBy,
|
|
46
|
+
step
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
get createdOn() {
|
|
51
|
+
return this.record.createdOn;
|
|
52
|
+
}
|
|
53
|
+
get savedOn() {
|
|
54
|
+
return this.record.savedOn;
|
|
55
|
+
}
|
|
56
|
+
get createdBy() {
|
|
57
|
+
return this.record.createdBy;
|
|
58
|
+
}
|
|
59
|
+
get savedBy() {
|
|
60
|
+
return this.record.savedBy;
|
|
61
|
+
}
|
|
62
|
+
get done() {
|
|
63
|
+
/**
|
|
64
|
+
* A just-in-case check.
|
|
65
|
+
*/
|
|
66
|
+
if (this.record.steps.length === 0) {
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
return this.record.steps.every(step => {
|
|
70
|
+
return step.state === WorkflowStateRecordState.approved;
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Current step can be:
|
|
76
|
+
* - in review step
|
|
77
|
+
* - rejected step - can only be one
|
|
78
|
+
* - first pending step
|
|
79
|
+
* - last approved step
|
|
80
|
+
*/
|
|
81
|
+
get currentStep() {
|
|
82
|
+
const steps = this.steps;
|
|
83
|
+
const inReview = steps.find(step => step.state === WorkflowStateRecordState.inReview);
|
|
84
|
+
if (inReview) {
|
|
85
|
+
return inReview;
|
|
86
|
+
}
|
|
87
|
+
const rejected = steps.find(step => step.state === WorkflowStateRecordState.rejected);
|
|
88
|
+
if (rejected) {
|
|
89
|
+
return rejected;
|
|
90
|
+
}
|
|
91
|
+
const pending = steps.find(step => step.state === WorkflowStateRecordState.pending);
|
|
92
|
+
if (pending) {
|
|
93
|
+
return pending;
|
|
94
|
+
}
|
|
95
|
+
const approved = steps.toReversed().find(step => step.state === WorkflowStateRecordState.approved);
|
|
96
|
+
if (approved) {
|
|
97
|
+
return approved;
|
|
98
|
+
}
|
|
99
|
+
throw new WorkflowStateNoCurrentStepError(steps);
|
|
100
|
+
}
|
|
101
|
+
get nextStep() {
|
|
102
|
+
const steps = this.steps;
|
|
103
|
+
const currentStep = this.currentStep;
|
|
104
|
+
const currentIndex = steps.findIndex(step => step.id === currentStep.id);
|
|
105
|
+
if (currentIndex === -1) {
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
return steps[currentIndex + 1] || null;
|
|
109
|
+
}
|
|
110
|
+
get previousStep() {
|
|
111
|
+
const steps = this.steps;
|
|
112
|
+
const currentStep = this.currentStep;
|
|
113
|
+
const currentIndex = steps.findIndex(step => step.id === currentStep.id);
|
|
114
|
+
if (currentIndex <= 0) {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
return steps[currentIndex - 1] || null;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
* Active step is the one that is currently "inReview". If there is a rejected step, returns null.
|
|
122
|
+
*/
|
|
123
|
+
getActiveStep() {
|
|
124
|
+
const steps = this.steps;
|
|
125
|
+
const hasRejected = steps.some(step => {
|
|
126
|
+
return step.state === WorkflowStateRecordState.rejected;
|
|
127
|
+
});
|
|
128
|
+
if (hasRejected) {
|
|
129
|
+
return null;
|
|
130
|
+
}
|
|
131
|
+
const step = steps.find(step => {
|
|
132
|
+
return step.state === WorkflowStateRecordState.inReview;
|
|
133
|
+
});
|
|
134
|
+
return step || null;
|
|
135
|
+
}
|
|
136
|
+
start() {
|
|
137
|
+
const stepResult = this.getPendingStep();
|
|
138
|
+
if (stepResult.isFail()) {
|
|
139
|
+
return Result.fail(stepResult.error);
|
|
140
|
+
}
|
|
141
|
+
const step = stepResult.value;
|
|
142
|
+
if (!canReview(step)) {
|
|
143
|
+
return Result.fail(new WorkflowStateStepCannotReviewError(step));
|
|
144
|
+
}
|
|
145
|
+
const identity = {
|
|
146
|
+
id: this.currentIdentity.id,
|
|
147
|
+
displayName: this.currentIdentity.displayName,
|
|
148
|
+
type: this.currentIdentity.type
|
|
149
|
+
};
|
|
150
|
+
this.updateStep(step.id, {
|
|
151
|
+
savedBy: identity,
|
|
152
|
+
state: WorkflowStateRecordState.inReview
|
|
153
|
+
});
|
|
154
|
+
this.updateRecord({
|
|
155
|
+
savedBy: identity,
|
|
156
|
+
state: WorkflowStateRecordState.inReview
|
|
157
|
+
});
|
|
158
|
+
return Result.ok();
|
|
159
|
+
}
|
|
160
|
+
takeOver() {
|
|
161
|
+
if (isRejected(this.record)) {
|
|
162
|
+
return Result.fail(new WorkflowStateRejectedError(this.record));
|
|
163
|
+
}
|
|
164
|
+
const step = this.getActiveStep();
|
|
165
|
+
if (!step) {
|
|
166
|
+
return Result.fail(new WorkflowStateNotAuthorizedError(`Cannot take over a workflow state that is not in review.`));
|
|
167
|
+
}
|
|
168
|
+
if (!canTakeOver(step)) {
|
|
169
|
+
return Result.fail(new WorkflowStateStepCannotTakeOverError(step));
|
|
170
|
+
}
|
|
171
|
+
if (!canReview(step)) {
|
|
172
|
+
return Result.fail(new WorkflowStateStepCannotReviewError(step));
|
|
173
|
+
}
|
|
174
|
+
const identity = {
|
|
175
|
+
id: this.currentIdentity.id,
|
|
176
|
+
displayName: this.currentIdentity.displayName,
|
|
177
|
+
type: this.currentIdentity.type
|
|
178
|
+
};
|
|
179
|
+
this.updateStep(step.id, {
|
|
180
|
+
savedBy: identity
|
|
181
|
+
});
|
|
182
|
+
this.updateRecord({
|
|
183
|
+
savedBy: identity
|
|
184
|
+
});
|
|
185
|
+
return Result.ok();
|
|
186
|
+
}
|
|
187
|
+
approve(comment) {
|
|
188
|
+
if (isRejected(this.record)) {
|
|
189
|
+
return Result.fail(new WorkflowStateRejectedError(this.record));
|
|
190
|
+
}
|
|
191
|
+
const step = this.getActiveStep();
|
|
192
|
+
/**
|
|
193
|
+
* Step cannot be found - all steps are either approved or rejected.
|
|
194
|
+
*/
|
|
195
|
+
if (!step) {
|
|
196
|
+
return Result.fail(new WorkflowStateNotAuthorizedError(`Cannot approve a workflow state that is not in review.`));
|
|
197
|
+
}
|
|
198
|
+
if (!canReview(step)) {
|
|
199
|
+
return Result.fail(new WorkflowStateStepCannotReviewError(step));
|
|
200
|
+
}
|
|
201
|
+
if (!isStepOwner(step)) {
|
|
202
|
+
return Result.fail(new WorkflowStateStepNotStepOwnerError(step));
|
|
203
|
+
}
|
|
204
|
+
this.approveStep(step.id, comment);
|
|
205
|
+
const nextStep = this.getNextStep(step.id);
|
|
206
|
+
this.updateRecord({
|
|
207
|
+
state: nextStep ? WorkflowStateRecordState.pending : WorkflowStateRecordState.approved
|
|
208
|
+
});
|
|
209
|
+
return Result.ok();
|
|
210
|
+
}
|
|
211
|
+
reject(comment) {
|
|
212
|
+
if (isRejected(this.record)) {
|
|
213
|
+
return Result.fail(new WorkflowStateRejectedError(this.record));
|
|
214
|
+
}
|
|
215
|
+
const step = this.getActiveStep();
|
|
216
|
+
if (!step) {
|
|
217
|
+
return Result.fail(new WorkflowStateNotInReview(`Cannot reject a workflow state that is not in review.`, this));
|
|
218
|
+
}
|
|
219
|
+
if (!canReview(step)) {
|
|
220
|
+
return Result.fail(new WorkflowStateStepCannotReviewError(step));
|
|
221
|
+
}
|
|
222
|
+
if (!isStepOwner(step)) {
|
|
223
|
+
return Result.fail(new WorkflowStateStepNotStepOwnerError(step));
|
|
224
|
+
}
|
|
225
|
+
this.rejectStep(step.id, comment);
|
|
226
|
+
this.updateRecord({
|
|
227
|
+
state: WorkflowStateRecordState.rejected
|
|
228
|
+
});
|
|
229
|
+
return Result.ok();
|
|
230
|
+
}
|
|
231
|
+
getPendingStep() {
|
|
232
|
+
if (isRejected(this.record)) {
|
|
233
|
+
return Result.fail(new WorkflowStateRejectedError(this.record));
|
|
234
|
+
}
|
|
235
|
+
if (isInReview(this.record)) {
|
|
236
|
+
return Result.fail(new WorkflowStateInReviewError(this.record));
|
|
237
|
+
}
|
|
238
|
+
for (const step of this.steps) {
|
|
239
|
+
if (step.state === WorkflowStateRecordState.pending) {
|
|
240
|
+
return Result.ok(step);
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
return Result.fail(new WorkflowStateNoPendingStepError());
|
|
244
|
+
}
|
|
245
|
+
updateRecord(record) {
|
|
246
|
+
Object.assign(this.record, record);
|
|
247
|
+
}
|
|
248
|
+
updateStep(id, input) {
|
|
249
|
+
const step = this.record.steps.find(s => s.id === id);
|
|
250
|
+
if (!step) {
|
|
251
|
+
throw new Error(`Step with ID "${id}" not found.`);
|
|
252
|
+
}
|
|
253
|
+
Object.assign(step, {
|
|
254
|
+
savedBy: {
|
|
255
|
+
id: this.currentIdentity.id,
|
|
256
|
+
displayName: this.currentIdentity.displayName,
|
|
257
|
+
type: this.currentIdentity.type
|
|
258
|
+
},
|
|
259
|
+
...input
|
|
260
|
+
});
|
|
261
|
+
}
|
|
262
|
+
approveStep(id, comment) {
|
|
263
|
+
this.updateStep(id, {
|
|
264
|
+
state: WorkflowStateRecordState.approved,
|
|
265
|
+
comment
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
rejectStep(id, comment) {
|
|
269
|
+
this.updateStep(id, {
|
|
270
|
+
state: WorkflowStateRecordState.rejected,
|
|
271
|
+
comment
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
getNextStep(currentStepId) {
|
|
275
|
+
const index = this.record.steps.findIndex(s => s.id === currentStepId);
|
|
276
|
+
if (index === -1) {
|
|
277
|
+
return undefined;
|
|
278
|
+
}
|
|
279
|
+
return this.record.steps[index + 1];
|
|
280
|
+
}
|
|
281
|
+
enrichStep(params) {
|
|
282
|
+
const {
|
|
283
|
+
step,
|
|
284
|
+
createdBy
|
|
285
|
+
} = params;
|
|
286
|
+
const identity = this.currentIdentity;
|
|
287
|
+
/**
|
|
288
|
+
* User who created the workflow state cannot take part in reviewing it.
|
|
289
|
+
*/
|
|
290
|
+
if (createdBy.id === identity.id) {
|
|
291
|
+
return {
|
|
292
|
+
...step,
|
|
293
|
+
isOwner: false,
|
|
294
|
+
canTakeOver: false,
|
|
295
|
+
canReview: false
|
|
296
|
+
};
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* Current user is step owner - they started the review.
|
|
300
|
+
*/
|
|
301
|
+
const isOwner = step.savedBy?.id === identity.id;
|
|
302
|
+
/**
|
|
303
|
+
* Can current user actually review this step?
|
|
304
|
+
*/
|
|
305
|
+
const canReview = step.teams.some(team => {
|
|
306
|
+
return this.teams.some(t => {
|
|
307
|
+
return t.id === team.id;
|
|
308
|
+
});
|
|
309
|
+
});
|
|
310
|
+
/**
|
|
311
|
+
* Can current user take over the review from another reviewer?
|
|
312
|
+
* Taking over is only possible if current user did not start the review of the step - and review was actually started.
|
|
313
|
+
*/
|
|
314
|
+
const canTakeOver = canReview && !!step.savedBy?.id && step.state === WorkflowStateRecordState.inReview;
|
|
315
|
+
return {
|
|
316
|
+
...step,
|
|
317
|
+
canTakeOver: !isOwner ? canTakeOver : false,
|
|
318
|
+
isOwner,
|
|
319
|
+
canReview
|
|
320
|
+
};
|
|
321
|
+
}
|
|
322
|
+
toRecord() {
|
|
323
|
+
return this.record;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
//# sourceMappingURL=WorkflowState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["WorkflowStateRecordState","Result","WorkflowStateNotAuthorizedError","WorkflowStateNoPendingStepError","WorkflowStateStepCannotReviewError","WorkflowStateStepCannotTakeOverError","WorkflowStateStepNotStepOwnerError","WorkflowStateInReviewError","WorkflowStateRejectedError","WorkflowStateNoCurrentStepError","WorkflowStateNotInReview","canReview","isRejected","canTakeOver","isInReview","isStepOwner","WorkflowState","constructor","record","teams","currentIdentity","id","app","title","workflowId","targetId","targetRevisionId","isActive","comment","state","steps","map","step","enrichStep","createdBy","createdOn","savedOn","savedBy","done","length","every","approved","currentStep","inReview","find","rejected","pending","toReversed","nextStep","currentIndex","findIndex","previousStep","getActiveStep","hasRejected","some","start","stepResult","getPendingStep","isFail","fail","error","value","identity","displayName","type","updateStep","updateRecord","ok","takeOver","approve","approveStep","getNextStep","reject","rejectStep","Object","assign","input","s","Error","currentStepId","index","undefined","params","isOwner","team","t","toRecord"],"sources":["WorkflowState.ts"],"sourcesContent":["import type {\n IWorkflowState,\n IWorkflowStateRecord,\n IWorkflowStateIdentity,\n IEnrichedWorkflowStateRecordStep,\n IWorkflowStateRecordStep\n} from \"./abstractions.js\";\nimport { WorkflowStateRecordState } from \"./abstractions.js\";\nimport { Result } from \"@webiny/feature/api\";\nimport type { IWorkflowStepTeam } from \"../workflow/abstractions.js\";\nimport {\n WorkflowStateNotAuthorizedError,\n WorkflowStateNoPendingStepError,\n WorkflowStateStepCannotReviewError,\n WorkflowStateStepCannotTakeOverError,\n WorkflowStateStepNotStepOwnerError,\n WorkflowStateInReviewError,\n WorkflowStateRejectedError,\n WorkflowStateNoCurrentStepError,\n WorkflowStateNotInReview\n} from \"./errors.js\";\nimport { canReview } from \"./guards/canReview.js\";\nimport { isRejected } from \"./guards/isRejected.js\";\nimport { canTakeOver } from \"./guards/canTakeOver.js\";\nimport { isInReview } from \"./guards/isInReview.js\";\nimport { isStepOwner } from \"./guards/isStepOwner.js\";\n\ninterface IEnrichStepWithPermissionParams {\n createdBy: Pick<IWorkflowStateIdentity, \"id\">;\n step: IWorkflowStateRecordStep;\n}\n\nexport class WorkflowState implements IWorkflowState {\n constructor(\n private record: IWorkflowStateRecord,\n private teams: IWorkflowStepTeam[],\n private currentIdentity: IWorkflowStateIdentity\n ) {}\n\n get id() {\n return this.record.id;\n }\n\n get app() {\n return this.record.app;\n }\n\n get title() {\n return this.record.title;\n }\n\n get workflowId() {\n return this.record.workflowId;\n }\n\n get targetId() {\n return this.record.targetId;\n }\n\n get targetRevisionId() {\n return this.record.targetRevisionId;\n }\n\n get isActive() {\n return this.record.isActive;\n }\n\n get comment() {\n return this.record.comment;\n }\n\n get state() {\n return this.record.state;\n }\n\n get steps() {\n return this.record.steps.map(step => {\n return this.enrichStep({ createdBy: this.record.createdBy, step });\n });\n }\n\n get createdOn() {\n return this.record.createdOn;\n }\n\n get savedOn() {\n return this.record.savedOn;\n }\n\n get createdBy() {\n return this.record.createdBy;\n }\n\n get savedBy() {\n return this.record.savedBy;\n }\n\n get done(): boolean {\n /**\n * A just-in-case check.\n */\n if (this.record.steps.length === 0) {\n return false;\n }\n return this.record.steps.every(step => {\n return step.state === WorkflowStateRecordState.approved;\n });\n }\n\n /**\n * Current step can be:\n * - in review step\n * - rejected step - can only be one\n * - first pending step\n * - last approved step\n */\n get currentStep(): IEnrichedWorkflowStateRecordStep {\n const steps = this.steps;\n const inReview = steps.find(step => step.state === WorkflowStateRecordState.inReview);\n if (inReview) {\n return inReview;\n }\n\n const rejected = steps.find(step => step.state === WorkflowStateRecordState.rejected);\n if (rejected) {\n return rejected;\n }\n const pending = steps.find(step => step.state === WorkflowStateRecordState.pending);\n if (pending) {\n return pending;\n }\n const approved = steps\n .toReversed()\n .find(step => step.state === WorkflowStateRecordState.approved);\n if (approved) {\n return approved;\n }\n throw new WorkflowStateNoCurrentStepError(steps);\n }\n\n get nextStep(): IEnrichedWorkflowStateRecordStep | null {\n const steps = this.steps;\n const currentStep = this.currentStep;\n const currentIndex = steps.findIndex(step => step.id === currentStep.id);\n if (currentIndex === -1) {\n return null;\n }\n return steps[currentIndex + 1] || null;\n }\n\n get previousStep(): IEnrichedWorkflowStateRecordStep | null {\n const steps = this.steps;\n const currentStep = this.currentStep;\n const currentIndex = steps.findIndex(step => step.id === currentStep.id);\n if (currentIndex <= 0) {\n return null;\n }\n return steps[currentIndex - 1] || null;\n }\n\n /**\n * Active step is the one that is currently \"inReview\". If there is a rejected step, returns null.\n */\n getActiveStep(): IEnrichedWorkflowStateRecordStep | null {\n const steps = this.steps;\n const hasRejected = steps.some(step => {\n return step.state === WorkflowStateRecordState.rejected;\n });\n if (hasRejected) {\n return null;\n }\n const step = steps.find(step => {\n return step.state === WorkflowStateRecordState.inReview;\n });\n return step || null;\n }\n\n start(): Result<void, WorkflowState.Error> {\n const stepResult = this.getPendingStep();\n if (stepResult.isFail()) {\n return Result.fail(stepResult.error);\n }\n\n const step = stepResult.value;\n\n if (!canReview(step)) {\n return Result.fail(new WorkflowStateStepCannotReviewError(step));\n }\n\n const identity = {\n id: this.currentIdentity.id,\n displayName: this.currentIdentity.displayName,\n type: this.currentIdentity.type\n };\n\n this.updateStep(step.id, {\n savedBy: identity,\n state: WorkflowStateRecordState.inReview\n });\n this.updateRecord({\n savedBy: identity,\n state: WorkflowStateRecordState.inReview\n });\n\n return Result.ok();\n }\n\n takeOver(): Result<void, WorkflowState.Error> {\n if (isRejected(this.record)) {\n return Result.fail(new WorkflowStateRejectedError(this.record));\n }\n const step = this.getActiveStep();\n if (!step) {\n return Result.fail(\n new WorkflowStateNotAuthorizedError(\n `Cannot take over a workflow state that is not in review.`\n )\n );\n }\n if (!canTakeOver(step)) {\n return Result.fail(new WorkflowStateStepCannotTakeOverError(step));\n }\n if (!canReview(step)) {\n return Result.fail(new WorkflowStateStepCannotReviewError(step));\n }\n\n const identity = {\n id: this.currentIdentity.id,\n displayName: this.currentIdentity.displayName,\n type: this.currentIdentity.type\n };\n\n this.updateStep(step.id, {\n savedBy: identity\n });\n this.updateRecord({\n savedBy: identity\n });\n\n return Result.ok();\n }\n\n approve(comment?: string): Result<void, WorkflowState.Error> {\n if (isRejected(this.record)) {\n return Result.fail(new WorkflowStateRejectedError(this.record));\n }\n const step = this.getActiveStep();\n /**\n * Step cannot be found - all steps are either approved or rejected.\n */\n if (!step) {\n return Result.fail(\n new WorkflowStateNotAuthorizedError(\n `Cannot approve a workflow state that is not in review.`\n )\n );\n }\n if (!canReview(step)) {\n return Result.fail(new WorkflowStateStepCannotReviewError(step));\n }\n if (!isStepOwner(step)) {\n return Result.fail(new WorkflowStateStepNotStepOwnerError(step));\n }\n\n this.approveStep(step.id, comment);\n\n const nextStep = this.getNextStep(step.id);\n\n this.updateRecord({\n state: nextStep ? WorkflowStateRecordState.pending : WorkflowStateRecordState.approved\n });\n\n return Result.ok();\n }\n\n reject(comment: string): Result<void, WorkflowState.Error> {\n if (isRejected(this.record)) {\n return Result.fail(new WorkflowStateRejectedError(this.record));\n }\n const step = this.getActiveStep();\n if (!step) {\n return Result.fail(\n new WorkflowStateNotInReview(\n `Cannot reject a workflow state that is not in review.`,\n this\n )\n );\n }\n\n if (!canReview(step)) {\n return Result.fail(new WorkflowStateStepCannotReviewError(step));\n }\n if (!isStepOwner(step)) {\n return Result.fail(new WorkflowStateStepNotStepOwnerError(step));\n }\n\n this.rejectStep(step.id, comment);\n this.updateRecord({\n state: WorkflowStateRecordState.rejected\n });\n\n return Result.ok();\n }\n\n private getPendingStep(): Result<\n IEnrichedWorkflowStateRecordStep,\n WorkflowStateRejectedError | WorkflowStateInReviewError | WorkflowStateNoPendingStepError\n > {\n if (isRejected(this.record)) {\n return Result.fail(new WorkflowStateRejectedError(this.record));\n }\n if (isInReview(this.record)) {\n return Result.fail(new WorkflowStateInReviewError(this.record));\n }\n for (const step of this.steps) {\n if (step.state === WorkflowStateRecordState.pending) {\n return Result.ok(step);\n }\n }\n return Result.fail(new WorkflowStateNoPendingStepError());\n }\n\n private updateRecord(record: Partial<Omit<IWorkflowStateRecord, \"id\">>): void {\n Object.assign(this.record, record);\n }\n\n private updateStep(id: string, input: Partial<Omit<IWorkflowStateRecordStep, \"id\">>): void {\n const step = this.record.steps.find(s => s.id === id);\n if (!step) {\n throw new Error(`Step with ID \"${id}\" not found.`);\n }\n Object.assign(step, {\n savedBy: {\n id: this.currentIdentity.id,\n displayName: this.currentIdentity.displayName,\n type: this.currentIdentity.type\n },\n ...input\n });\n }\n\n private approveStep(id: string, comment?: string): void {\n this.updateStep(id, {\n state: WorkflowStateRecordState.approved,\n comment\n });\n }\n\n private rejectStep(id: string, comment: string): void {\n this.updateStep(id, {\n state: WorkflowStateRecordState.rejected,\n comment\n });\n }\n\n private getNextStep(currentStepId: string): IWorkflowStateRecordStep | undefined {\n const index = this.record.steps.findIndex(s => s.id === currentStepId);\n if (index === -1) {\n return undefined;\n }\n return this.record.steps[index + 1];\n }\n\n private enrichStep(params: IEnrichStepWithPermissionParams): IEnrichedWorkflowStateRecordStep {\n const { step, createdBy } = params;\n const identity = this.currentIdentity;\n /**\n * User who created the workflow state cannot take part in reviewing it.\n */\n if (createdBy.id === identity.id) {\n return {\n ...step,\n isOwner: false,\n canTakeOver: false,\n canReview: false\n };\n }\n /**\n * Current user is step owner - they started the review.\n */\n const isOwner = step.savedBy?.id === identity.id;\n /**\n * Can current user actually review this step?\n */\n const canReview = step.teams.some(team => {\n return this.teams.some(t => {\n return t.id === team.id;\n });\n });\n /**\n * Can current user take over the review from another reviewer?\n * Taking over is only possible if current user did not start the review of the step - and review was actually started.\n */\n const canTakeOver =\n canReview && !!step.savedBy?.id && step.state === WorkflowStateRecordState.inReview;\n\n return {\n ...step,\n canTakeOver: !isOwner ? canTakeOver : false,\n isOwner,\n canReview\n };\n }\n\n toRecord(): IWorkflowStateRecord {\n return this.record;\n }\n}\n\nexport namespace WorkflowState {\n export type Error =\n | WorkflowStateNotAuthorizedError\n | WorkflowStateNoPendingStepError\n | WorkflowStateStepCannotReviewError\n | WorkflowStateStepCannotTakeOverError\n | WorkflowStateStepNotStepOwnerError\n | WorkflowStateInReviewError\n | WorkflowStateNotInReview\n | WorkflowStateRejectedError\n | WorkflowStateNoCurrentStepError;\n}\n"],"mappings":"AAOA,SAASA,wBAAwB;AACjC,SAASC,MAAM,QAAQ,qBAAqB;AAE5C,SACIC,+BAA+B,EAC/BC,+BAA+B,EAC/BC,kCAAkC,EAClCC,oCAAoC,EACpCC,kCAAkC,EAClCC,0BAA0B,EAC1BC,0BAA0B,EAC1BC,+BAA+B,EAC/BC,wBAAwB;AAE5B,SAASC,SAAS;AAClB,SAASC,UAAU;AACnB,SAASC,WAAW;AACpB,SAASC,UAAU;AACnB,SAASC,WAAW;AAOpB,OAAO,MAAMC,aAAa,CAA2B;EACjDC,WAAWA,CACCC,MAA4B,EAC5BC,KAA0B,EAC1BC,eAAuC,EACjD;IAAA,KAHUF,MAA4B,GAA5BA,MAA4B;IAAA,KAC5BC,KAA0B,GAA1BA,KAA0B;IAAA,KAC1BC,eAAuC,GAAvCA,eAAuC;EAChD;EAEH,IAAIC,EAAEA,CAAA,EAAG;IACL,OAAO,IAAI,CAACH,MAAM,CAACG,EAAE;EACzB;EAEA,IAAIC,GAAGA,CAAA,EAAG;IACN,OAAO,IAAI,CAACJ,MAAM,CAACI,GAAG;EAC1B;EAEA,IAAIC,KAAKA,CAAA,EAAG;IACR,OAAO,IAAI,CAACL,MAAM,CAACK,KAAK;EAC5B;EAEA,IAAIC,UAAUA,CAAA,EAAG;IACb,OAAO,IAAI,CAACN,MAAM,CAACM,UAAU;EACjC;EAEA,IAAIC,QAAQA,CAAA,EAAG;IACX,OAAO,IAAI,CAACP,MAAM,CAACO,QAAQ;EAC/B;EAEA,IAAIC,gBAAgBA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACR,MAAM,CAACQ,gBAAgB;EACvC;EAEA,IAAIC,QAAQA,CAAA,EAAG;IACX,OAAO,IAAI,CAACT,MAAM,CAACS,QAAQ;EAC/B;EAEA,IAAIC,OAAOA,CAAA,EAAG;IACV,OAAO,IAAI,CAACV,MAAM,CAACU,OAAO;EAC9B;EAEA,IAAIC,KAAKA,CAAA,EAAG;IACR,OAAO,IAAI,CAACX,MAAM,CAACW,KAAK;EAC5B;EAEA,IAAIC,KAAKA,CAAA,EAAG;IACR,OAAO,IAAI,CAACZ,MAAM,CAACY,KAAK,CAACC,GAAG,CAACC,IAAI,IAAI;MACjC,OAAO,IAAI,CAACC,UAAU,CAAC;QAAEC,SAAS,EAAE,IAAI,CAAChB,MAAM,CAACgB,SAAS;QAAEF;MAAK,CAAC,CAAC;IACtE,CAAC,CAAC;EACN;EAEA,IAAIG,SAASA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACjB,MAAM,CAACiB,SAAS;EAChC;EAEA,IAAIC,OAAOA,CAAA,EAAG;IACV,OAAO,IAAI,CAAClB,MAAM,CAACkB,OAAO;EAC9B;EAEA,IAAIF,SAASA,CAAA,EAAG;IACZ,OAAO,IAAI,CAAChB,MAAM,CAACgB,SAAS;EAChC;EAEA,IAAIG,OAAOA,CAAA,EAAG;IACV,OAAO,IAAI,CAACnB,MAAM,CAACmB,OAAO;EAC9B;EAEA,IAAIC,IAAIA,CAAA,EAAY;IAChB;AACR;AACA;IACQ,IAAI,IAAI,CAACpB,MAAM,CAACY,KAAK,CAACS,MAAM,KAAK,CAAC,EAAE;MAChC,OAAO,KAAK;IAChB;IACA,OAAO,IAAI,CAACrB,MAAM,CAACY,KAAK,CAACU,KAAK,CAACR,IAAI,IAAI;MACnC,OAAOA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAACyC,QAAQ;IAC3D,CAAC,CAAC;EACN;;EAEA;AACJ;AACA;AACA;AACA;AACA;AACA;EACI,IAAIC,WAAWA,CAAA,EAAqC;IAChD,MAAMZ,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,MAAMa,QAAQ,GAAGb,KAAK,CAACc,IAAI,CAACZ,IAAI,IAAIA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC2C,QAAQ,CAAC;IACrF,IAAIA,QAAQ,EAAE;MACV,OAAOA,QAAQ;IACnB;IAEA,MAAME,QAAQ,GAAGf,KAAK,CAACc,IAAI,CAACZ,IAAI,IAAIA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC6C,QAAQ,CAAC;IACrF,IAAIA,QAAQ,EAAE;MACV,OAAOA,QAAQ;IACnB;IACA,MAAMC,OAAO,GAAGhB,KAAK,CAACc,IAAI,CAACZ,IAAI,IAAIA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC8C,OAAO,CAAC;IACnF,IAAIA,OAAO,EAAE;MACT,OAAOA,OAAO;IAClB;IACA,MAAML,QAAQ,GAAGX,KAAK,CACjBiB,UAAU,CAAC,CAAC,CACZH,IAAI,CAACZ,IAAI,IAAIA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAACyC,QAAQ,CAAC;IACnE,IAAIA,QAAQ,EAAE;MACV,OAAOA,QAAQ;IACnB;IACA,MAAM,IAAIhC,+BAA+B,CAACqB,KAAK,CAAC;EACpD;EAEA,IAAIkB,QAAQA,CAAA,EAA4C;IACpD,MAAMlB,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,MAAMY,WAAW,GAAG,IAAI,CAACA,WAAW;IACpC,MAAMO,YAAY,GAAGnB,KAAK,CAACoB,SAAS,CAAClB,IAAI,IAAIA,IAAI,CAACX,EAAE,KAAKqB,WAAW,CAACrB,EAAE,CAAC;IACxE,IAAI4B,YAAY,KAAK,CAAC,CAAC,EAAE;MACrB,OAAO,IAAI;IACf;IACA,OAAOnB,KAAK,CAACmB,YAAY,GAAG,CAAC,CAAC,IAAI,IAAI;EAC1C;EAEA,IAAIE,YAAYA,CAAA,EAA4C;IACxD,MAAMrB,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,MAAMY,WAAW,GAAG,IAAI,CAACA,WAAW;IACpC,MAAMO,YAAY,GAAGnB,KAAK,CAACoB,SAAS,CAAClB,IAAI,IAAIA,IAAI,CAACX,EAAE,KAAKqB,WAAW,CAACrB,EAAE,CAAC;IACxE,IAAI4B,YAAY,IAAI,CAAC,EAAE;MACnB,OAAO,IAAI;IACf;IACA,OAAOnB,KAAK,CAACmB,YAAY,GAAG,CAAC,CAAC,IAAI,IAAI;EAC1C;;EAEA;AACJ;AACA;EACIG,aAAaA,CAAA,EAA4C;IACrD,MAAMtB,KAAK,GAAG,IAAI,CAACA,KAAK;IACxB,MAAMuB,WAAW,GAAGvB,KAAK,CAACwB,IAAI,CAACtB,IAAI,IAAI;MACnC,OAAOA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC6C,QAAQ;IAC3D,CAAC,CAAC;IACF,IAAIQ,WAAW,EAAE;MACb,OAAO,IAAI;IACf;IACA,MAAMrB,IAAI,GAAGF,KAAK,CAACc,IAAI,CAACZ,IAAI,IAAI;MAC5B,OAAOA,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC2C,QAAQ;IAC3D,CAAC,CAAC;IACF,OAAOX,IAAI,IAAI,IAAI;EACvB;EAEAuB,KAAKA,CAAA,EAAsC;IACvC,MAAMC,UAAU,GAAG,IAAI,CAACC,cAAc,CAAC,CAAC;IACxC,IAAID,UAAU,CAACE,MAAM,CAAC,CAAC,EAAE;MACrB,OAAOzD,MAAM,CAAC0D,IAAI,CAACH,UAAU,CAACI,KAAK,CAAC;IACxC;IAEA,MAAM5B,IAAI,GAAGwB,UAAU,CAACK,KAAK;IAE7B,IAAI,CAAClD,SAAS,CAACqB,IAAI,CAAC,EAAE;MAClB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIvD,kCAAkC,CAAC4B,IAAI,CAAC,CAAC;IACpE;IAEA,MAAM8B,QAAQ,GAAG;MACbzC,EAAE,EAAE,IAAI,CAACD,eAAe,CAACC,EAAE;MAC3B0C,WAAW,EAAE,IAAI,CAAC3C,eAAe,CAAC2C,WAAW;MAC7CC,IAAI,EAAE,IAAI,CAAC5C,eAAe,CAAC4C;IAC/B,CAAC;IAED,IAAI,CAACC,UAAU,CAACjC,IAAI,CAACX,EAAE,EAAE;MACrBgB,OAAO,EAAEyB,QAAQ;MACjBjC,KAAK,EAAE7B,wBAAwB,CAAC2C;IACpC,CAAC,CAAC;IACF,IAAI,CAACuB,YAAY,CAAC;MACd7B,OAAO,EAAEyB,QAAQ;MACjBjC,KAAK,EAAE7B,wBAAwB,CAAC2C;IACpC,CAAC,CAAC;IAEF,OAAO1C,MAAM,CAACkE,EAAE,CAAC,CAAC;EACtB;EAEAC,QAAQA,CAAA,EAAsC;IAC1C,IAAIxD,UAAU,CAAC,IAAI,CAACM,MAAM,CAAC,EAAE;MACzB,OAAOjB,MAAM,CAAC0D,IAAI,CAAC,IAAInD,0BAA0B,CAAC,IAAI,CAACU,MAAM,CAAC,CAAC;IACnE;IACA,MAAMc,IAAI,GAAG,IAAI,CAACoB,aAAa,CAAC,CAAC;IACjC,IAAI,CAACpB,IAAI,EAAE;MACP,OAAO/B,MAAM,CAAC0D,IAAI,CACd,IAAIzD,+BAA+B,CAC/B,0DACJ,CACJ,CAAC;IACL;IACA,IAAI,CAACW,WAAW,CAACmB,IAAI,CAAC,EAAE;MACpB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAItD,oCAAoC,CAAC2B,IAAI,CAAC,CAAC;IACtE;IACA,IAAI,CAACrB,SAAS,CAACqB,IAAI,CAAC,EAAE;MAClB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIvD,kCAAkC,CAAC4B,IAAI,CAAC,CAAC;IACpE;IAEA,MAAM8B,QAAQ,GAAG;MACbzC,EAAE,EAAE,IAAI,CAACD,eAAe,CAACC,EAAE;MAC3B0C,WAAW,EAAE,IAAI,CAAC3C,eAAe,CAAC2C,WAAW;MAC7CC,IAAI,EAAE,IAAI,CAAC5C,eAAe,CAAC4C;IAC/B,CAAC;IAED,IAAI,CAACC,UAAU,CAACjC,IAAI,CAACX,EAAE,EAAE;MACrBgB,OAAO,EAAEyB;IACb,CAAC,CAAC;IACF,IAAI,CAACI,YAAY,CAAC;MACd7B,OAAO,EAAEyB;IACb,CAAC,CAAC;IAEF,OAAO7D,MAAM,CAACkE,EAAE,CAAC,CAAC;EACtB;EAEAE,OAAOA,CAACzC,OAAgB,EAAqC;IACzD,IAAIhB,UAAU,CAAC,IAAI,CAACM,MAAM,CAAC,EAAE;MACzB,OAAOjB,MAAM,CAAC0D,IAAI,CAAC,IAAInD,0BAA0B,CAAC,IAAI,CAACU,MAAM,CAAC,CAAC;IACnE;IACA,MAAMc,IAAI,GAAG,IAAI,CAACoB,aAAa,CAAC,CAAC;IACjC;AACR;AACA;IACQ,IAAI,CAACpB,IAAI,EAAE;MACP,OAAO/B,MAAM,CAAC0D,IAAI,CACd,IAAIzD,+BAA+B,CAC/B,wDACJ,CACJ,CAAC;IACL;IACA,IAAI,CAACS,SAAS,CAACqB,IAAI,CAAC,EAAE;MAClB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIvD,kCAAkC,CAAC4B,IAAI,CAAC,CAAC;IACpE;IACA,IAAI,CAACjB,WAAW,CAACiB,IAAI,CAAC,EAAE;MACpB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIrD,kCAAkC,CAAC0B,IAAI,CAAC,CAAC;IACpE;IAEA,IAAI,CAACsC,WAAW,CAACtC,IAAI,CAACX,EAAE,EAAEO,OAAO,CAAC;IAElC,MAAMoB,QAAQ,GAAG,IAAI,CAACuB,WAAW,CAACvC,IAAI,CAACX,EAAE,CAAC;IAE1C,IAAI,CAAC6C,YAAY,CAAC;MACdrC,KAAK,EAAEmB,QAAQ,GAAGhD,wBAAwB,CAAC8C,OAAO,GAAG9C,wBAAwB,CAACyC;IAClF,CAAC,CAAC;IAEF,OAAOxC,MAAM,CAACkE,EAAE,CAAC,CAAC;EACtB;EAEAK,MAAMA,CAAC5C,OAAe,EAAqC;IACvD,IAAIhB,UAAU,CAAC,IAAI,CAACM,MAAM,CAAC,EAAE;MACzB,OAAOjB,MAAM,CAAC0D,IAAI,CAAC,IAAInD,0BAA0B,CAAC,IAAI,CAACU,MAAM,CAAC,CAAC;IACnE;IACA,MAAMc,IAAI,GAAG,IAAI,CAACoB,aAAa,CAAC,CAAC;IACjC,IAAI,CAACpB,IAAI,EAAE;MACP,OAAO/B,MAAM,CAAC0D,IAAI,CACd,IAAIjD,wBAAwB,CACxB,uDAAuD,EACvD,IACJ,CACJ,CAAC;IACL;IAEA,IAAI,CAACC,SAAS,CAACqB,IAAI,CAAC,EAAE;MAClB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIvD,kCAAkC,CAAC4B,IAAI,CAAC,CAAC;IACpE;IACA,IAAI,CAACjB,WAAW,CAACiB,IAAI,CAAC,EAAE;MACpB,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIrD,kCAAkC,CAAC0B,IAAI,CAAC,CAAC;IACpE;IAEA,IAAI,CAACyC,UAAU,CAACzC,IAAI,CAACX,EAAE,EAAEO,OAAO,CAAC;IACjC,IAAI,CAACsC,YAAY,CAAC;MACdrC,KAAK,EAAE7B,wBAAwB,CAAC6C;IACpC,CAAC,CAAC;IAEF,OAAO5C,MAAM,CAACkE,EAAE,CAAC,CAAC;EACtB;EAEQV,cAAcA,CAAA,EAGpB;IACE,IAAI7C,UAAU,CAAC,IAAI,CAACM,MAAM,CAAC,EAAE;MACzB,OAAOjB,MAAM,CAAC0D,IAAI,CAAC,IAAInD,0BAA0B,CAAC,IAAI,CAACU,MAAM,CAAC,CAAC;IACnE;IACA,IAAIJ,UAAU,CAAC,IAAI,CAACI,MAAM,CAAC,EAAE;MACzB,OAAOjB,MAAM,CAAC0D,IAAI,CAAC,IAAIpD,0BAA0B,CAAC,IAAI,CAACW,MAAM,CAAC,CAAC;IACnE;IACA,KAAK,MAAMc,IAAI,IAAI,IAAI,CAACF,KAAK,EAAE;MAC3B,IAAIE,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC8C,OAAO,EAAE;QACjD,OAAO7C,MAAM,CAACkE,EAAE,CAACnC,IAAI,CAAC;MAC1B;IACJ;IACA,OAAO/B,MAAM,CAAC0D,IAAI,CAAC,IAAIxD,+BAA+B,CAAC,CAAC,CAAC;EAC7D;EAEQ+D,YAAYA,CAAChD,MAAiD,EAAQ;IAC1EwD,MAAM,CAACC,MAAM,CAAC,IAAI,CAACzD,MAAM,EAAEA,MAAM,CAAC;EACtC;EAEQ+C,UAAUA,CAAC5C,EAAU,EAAEuD,KAAoD,EAAQ;IACvF,MAAM5C,IAAI,GAAG,IAAI,CAACd,MAAM,CAACY,KAAK,CAACc,IAAI,CAACiC,CAAC,IAAIA,CAAC,CAACxD,EAAE,KAAKA,EAAE,CAAC;IACrD,IAAI,CAACW,IAAI,EAAE;MACP,MAAM,IAAI8C,KAAK,CAAC,iBAAiBzD,EAAE,cAAc,CAAC;IACtD;IACAqD,MAAM,CAACC,MAAM,CAAC3C,IAAI,EAAE;MAChBK,OAAO,EAAE;QACLhB,EAAE,EAAE,IAAI,CAACD,eAAe,CAACC,EAAE;QAC3B0C,WAAW,EAAE,IAAI,CAAC3C,eAAe,CAAC2C,WAAW;QAC7CC,IAAI,EAAE,IAAI,CAAC5C,eAAe,CAAC4C;MAC/B,CAAC;MACD,GAAGY;IACP,CAAC,CAAC;EACN;EAEQN,WAAWA,CAACjD,EAAU,EAAEO,OAAgB,EAAQ;IACpD,IAAI,CAACqC,UAAU,CAAC5C,EAAE,EAAE;MAChBQ,KAAK,EAAE7B,wBAAwB,CAACyC,QAAQ;MACxCb;IACJ,CAAC,CAAC;EACN;EAEQ6C,UAAUA,CAACpD,EAAU,EAAEO,OAAe,EAAQ;IAClD,IAAI,CAACqC,UAAU,CAAC5C,EAAE,EAAE;MAChBQ,KAAK,EAAE7B,wBAAwB,CAAC6C,QAAQ;MACxCjB;IACJ,CAAC,CAAC;EACN;EAEQ2C,WAAWA,CAACQ,aAAqB,EAAwC;IAC7E,MAAMC,KAAK,GAAG,IAAI,CAAC9D,MAAM,CAACY,KAAK,CAACoB,SAAS,CAAC2B,CAAC,IAAIA,CAAC,CAACxD,EAAE,KAAK0D,aAAa,CAAC;IACtE,IAAIC,KAAK,KAAK,CAAC,CAAC,EAAE;MACd,OAAOC,SAAS;IACpB;IACA,OAAO,IAAI,CAAC/D,MAAM,CAACY,KAAK,CAACkD,KAAK,GAAG,CAAC,CAAC;EACvC;EAEQ/C,UAAUA,CAACiD,MAAuC,EAAoC;IAC1F,MAAM;MAAElD,IAAI;MAAEE;IAAU,CAAC,GAAGgD,MAAM;IAClC,MAAMpB,QAAQ,GAAG,IAAI,CAAC1C,eAAe;IACrC;AACR;AACA;IACQ,IAAIc,SAAS,CAACb,EAAE,KAAKyC,QAAQ,CAACzC,EAAE,EAAE;MAC9B,OAAO;QACH,GAAGW,IAAI;QACPmD,OAAO,EAAE,KAAK;QACdtE,WAAW,EAAE,KAAK;QAClBF,SAAS,EAAE;MACf,CAAC;IACL;IACA;AACR;AACA;IACQ,MAAMwE,OAAO,GAAGnD,IAAI,CAACK,OAAO,EAAEhB,EAAE,KAAKyC,QAAQ,CAACzC,EAAE;IAChD;AACR;AACA;IACQ,MAAMV,SAAS,GAAGqB,IAAI,CAACb,KAAK,CAACmC,IAAI,CAAC8B,IAAI,IAAI;MACtC,OAAO,IAAI,CAACjE,KAAK,CAACmC,IAAI,CAAC+B,CAAC,IAAI;QACxB,OAAOA,CAAC,CAAChE,EAAE,KAAK+D,IAAI,CAAC/D,EAAE;MAC3B,CAAC,CAAC;IACN,CAAC,CAAC;IACF;AACR;AACA;AACA;IACQ,MAAMR,WAAW,GACbF,SAAS,IAAI,CAAC,CAACqB,IAAI,CAACK,OAAO,EAAEhB,EAAE,IAAIW,IAAI,CAACH,KAAK,KAAK7B,wBAAwB,CAAC2C,QAAQ;IAEvF,OAAO;MACH,GAAGX,IAAI;MACPnB,WAAW,EAAE,CAACsE,OAAO,GAAGtE,WAAW,GAAG,KAAK;MAC3CsE,OAAO;MACPxE;IACJ,CAAC;EACL;EAEA2E,QAAQA,CAAA,EAAyB;IAC7B,OAAO,IAAI,CAACpE,MAAM;EACtB;AACJ","ignoreList":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { IWorkflowStateMapper, IWorkflowStateTransformerFromCmsEntryInput, IWorkflowStateTransformerFromCmsEntryOutput, IWorkflowStateTransformerToCmsEntryInput, IWorkflowStateTransformerToCmsEntryOutput } from "./abstractions.js";
|
|
2
|
+
declare class WorkflowStateMapperImpl implements IWorkflowStateMapper {
|
|
3
|
+
fromCmsEntry(input: IWorkflowStateTransformerFromCmsEntryInput): IWorkflowStateTransformerFromCmsEntryOutput;
|
|
4
|
+
toCmsEntry(input: IWorkflowStateTransformerToCmsEntryInput): IWorkflowStateTransformerToCmsEntryOutput;
|
|
5
|
+
}
|
|
6
|
+
export declare const WorkflowStateMapper: typeof WorkflowStateMapperImpl & {
|
|
7
|
+
__abstraction: import("@webiny/di").Abstraction<IWorkflowStateMapper>;
|
|
8
|
+
};
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { WorkflowStateMapper as WorkflowStateMapperAbstraction } from "./abstractions.js";
|
|
2
|
+
class WorkflowStateMapperImpl {
|
|
3
|
+
fromCmsEntry(input) {
|
|
4
|
+
return {
|
|
5
|
+
id: input.id,
|
|
6
|
+
workflowId: input.values.workflowId,
|
|
7
|
+
title: input.values.title,
|
|
8
|
+
targetId: input.values.targetId,
|
|
9
|
+
targetRevisionId: input.values.targetRevisionId,
|
|
10
|
+
steps: input.values.steps,
|
|
11
|
+
isActive: input.values.isActive,
|
|
12
|
+
app: input.values.app,
|
|
13
|
+
state: input.values.state,
|
|
14
|
+
comment: input.values.comment,
|
|
15
|
+
savedBy: input.savedBy,
|
|
16
|
+
createdBy: input.createdBy,
|
|
17
|
+
savedOn: new Date(input.savedOn),
|
|
18
|
+
createdOn: new Date(input.createdOn)
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
toCmsEntry(input) {
|
|
22
|
+
return {
|
|
23
|
+
isActive: input.isActive,
|
|
24
|
+
title: input.title,
|
|
25
|
+
workflowId: input.workflowId,
|
|
26
|
+
targetId: input.targetId,
|
|
27
|
+
targetRevisionId: input.targetRevisionId,
|
|
28
|
+
steps: input.steps,
|
|
29
|
+
app: input.app,
|
|
30
|
+
state: input.state,
|
|
31
|
+
comment: input.comment
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
export const WorkflowStateMapper = WorkflowStateMapperAbstraction.createImplementation({
|
|
36
|
+
implementation: WorkflowStateMapperImpl,
|
|
37
|
+
dependencies: []
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
//# sourceMappingURL=WorkflowStateMapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["WorkflowStateMapper","WorkflowStateMapperAbstraction","WorkflowStateMapperImpl","fromCmsEntry","input","id","workflowId","values","title","targetId","targetRevisionId","steps","isActive","app","state","comment","savedBy","createdBy","savedOn","Date","createdOn","toCmsEntry","createImplementation","implementation","dependencies"],"sources":["WorkflowStateMapper.ts"],"sourcesContent":["import type {\n IWorkflowStateMapper,\n IWorkflowStateTransformerFromCmsEntryInput,\n IWorkflowStateTransformerFromCmsEntryOutput,\n IWorkflowStateTransformerToCmsEntryInput,\n IWorkflowStateTransformerToCmsEntryOutput\n} from \"./abstractions.js\";\nimport { WorkflowStateMapper as WorkflowStateMapperAbstraction } from \"./abstractions.js\";\n\nclass WorkflowStateMapperImpl implements IWorkflowStateMapper {\n public fromCmsEntry(\n input: IWorkflowStateTransformerFromCmsEntryInput\n ): IWorkflowStateTransformerFromCmsEntryOutput {\n return {\n id: input.id,\n workflowId: input.values.workflowId,\n title: input.values.title,\n targetId: input.values.targetId,\n targetRevisionId: input.values.targetRevisionId,\n steps: input.values.steps,\n isActive: input.values.isActive,\n app: input.values.app,\n state: input.values.state,\n comment: input.values.comment,\n savedBy: input.savedBy,\n createdBy: input.createdBy,\n savedOn: new Date(input.savedOn),\n createdOn: new Date(input.createdOn)\n };\n }\n\n public toCmsEntry(\n input: IWorkflowStateTransformerToCmsEntryInput\n ): IWorkflowStateTransformerToCmsEntryOutput {\n return {\n isActive: input.isActive,\n title: input.title,\n workflowId: input.workflowId,\n targetId: input.targetId,\n targetRevisionId: input.targetRevisionId,\n steps: input.steps,\n app: input.app,\n state: input.state,\n comment: input.comment\n };\n }\n}\n\nexport const WorkflowStateMapper = WorkflowStateMapperAbstraction.createImplementation({\n implementation: WorkflowStateMapperImpl,\n dependencies: []\n});\n"],"mappings":"AAOA,SAASA,mBAAmB,IAAIC,8BAA8B;AAE9D,MAAMC,uBAAuB,CAAiC;EACnDC,YAAYA,CACfC,KAAiD,EACN;IAC3C,OAAO;MACHC,EAAE,EAAED,KAAK,CAACC,EAAE;MACZC,UAAU,EAAEF,KAAK,CAACG,MAAM,CAACD,UAAU;MACnCE,KAAK,EAAEJ,KAAK,CAACG,MAAM,CAACC,KAAK;MACzBC,QAAQ,EAAEL,KAAK,CAACG,MAAM,CAACE,QAAQ;MAC/BC,gBAAgB,EAAEN,KAAK,CAACG,MAAM,CAACG,gBAAgB;MAC/CC,KAAK,EAAEP,KAAK,CAACG,MAAM,CAACI,KAAK;MACzBC,QAAQ,EAAER,KAAK,CAACG,MAAM,CAACK,QAAQ;MAC/BC,GAAG,EAAET,KAAK,CAACG,MAAM,CAACM,GAAG;MACrBC,KAAK,EAAEV,KAAK,CAACG,MAAM,CAACO,KAAK;MACzBC,OAAO,EAAEX,KAAK,CAACG,MAAM,CAACQ,OAAO;MAC7BC,OAAO,EAAEZ,KAAK,CAACY,OAAO;MACtBC,SAAS,EAAEb,KAAK,CAACa,SAAS;MAC1BC,OAAO,EAAE,IAAIC,IAAI,CAACf,KAAK,CAACc,OAAO,CAAC;MAChCE,SAAS,EAAE,IAAID,IAAI,CAACf,KAAK,CAACgB,SAAS;IACvC,CAAC;EACL;EAEOC,UAAUA,CACbjB,KAA+C,EACN;IACzC,OAAO;MACHQ,QAAQ,EAAER,KAAK,CAACQ,QAAQ;MACxBJ,KAAK,EAAEJ,KAAK,CAACI,KAAK;MAClBF,UAAU,EAAEF,KAAK,CAACE,UAAU;MAC5BG,QAAQ,EAAEL,KAAK,CAACK,QAAQ;MACxBC,gBAAgB,EAAEN,KAAK,CAACM,gBAAgB;MACxCC,KAAK,EAAEP,KAAK,CAACO,KAAK;MAClBE,GAAG,EAAET,KAAK,CAACS,GAAG;MACdC,KAAK,EAAEV,KAAK,CAACU,KAAK;MAClBC,OAAO,EAAEX,KAAK,CAACW;IACnB,CAAC;EACL;AACJ;AAEA,OAAO,MAAMf,mBAAmB,GAAGC,8BAA8B,CAACqB,oBAAoB,CAAC;EACnFC,cAAc,EAAErB,uBAAuB;EACvCsB,YAAY,EAAE;AAClB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import type { CmsEntry, CmsModel } from "@webiny/api-headless-cms/types";
|
|
2
|
+
import type { IWorkflowStep } from "../workflow/abstractions.js";
|
|
3
|
+
export declare enum WorkflowStateRecordState {
|
|
4
|
+
pending = "pending",
|
|
5
|
+
inReview = "inReview",
|
|
6
|
+
approved = "approved",
|
|
7
|
+
rejected = "rejected"
|
|
8
|
+
}
|
|
9
|
+
export interface IWorkflowStateIdentity {
|
|
10
|
+
id: string;
|
|
11
|
+
displayName: string;
|
|
12
|
+
type: string;
|
|
13
|
+
}
|
|
14
|
+
export interface IWorkflowStateRecordStep extends IWorkflowStep {
|
|
15
|
+
state: WorkflowStateRecordState;
|
|
16
|
+
comment: string | null;
|
|
17
|
+
savedBy: IWorkflowStateIdentity | null;
|
|
18
|
+
}
|
|
19
|
+
export interface IWorkflowStateRecord<Steps extends IWorkflowStateRecordStep = IWorkflowStateRecordStep> {
|
|
20
|
+
id: string;
|
|
21
|
+
app: string;
|
|
22
|
+
title: string;
|
|
23
|
+
workflowId: string;
|
|
24
|
+
targetId: string;
|
|
25
|
+
targetRevisionId: string;
|
|
26
|
+
isActive: boolean;
|
|
27
|
+
comment: string | undefined;
|
|
28
|
+
state: WorkflowStateRecordState;
|
|
29
|
+
steps: Steps[];
|
|
30
|
+
createdOn: Date;
|
|
31
|
+
savedOn: Date;
|
|
32
|
+
createdBy: IWorkflowStateIdentity;
|
|
33
|
+
savedBy: IWorkflowStateIdentity;
|
|
34
|
+
}
|
|
35
|
+
export interface IEnrichedWorkflowStateRecordStep extends IWorkflowStateRecordStep {
|
|
36
|
+
isOwner: boolean;
|
|
37
|
+
canTakeOver: boolean;
|
|
38
|
+
canReview: boolean;
|
|
39
|
+
}
|
|
40
|
+
export interface IWorkflowState {
|
|
41
|
+
readonly id: string;
|
|
42
|
+
readonly app: string;
|
|
43
|
+
readonly title: string;
|
|
44
|
+
readonly workflowId: string;
|
|
45
|
+
readonly targetId: string;
|
|
46
|
+
readonly targetRevisionId: string;
|
|
47
|
+
readonly isActive: boolean;
|
|
48
|
+
readonly comment: string | undefined;
|
|
49
|
+
readonly state: WorkflowStateRecordState;
|
|
50
|
+
readonly steps: IEnrichedWorkflowStateRecordStep[];
|
|
51
|
+
readonly createdOn: Date;
|
|
52
|
+
readonly savedOn: Date;
|
|
53
|
+
readonly createdBy: IWorkflowStateIdentity;
|
|
54
|
+
readonly savedBy: IWorkflowStateIdentity;
|
|
55
|
+
readonly done: boolean;
|
|
56
|
+
readonly currentStep: IEnrichedWorkflowStateRecordStep;
|
|
57
|
+
readonly nextStep: IEnrichedWorkflowStateRecordStep | null;
|
|
58
|
+
readonly previousStep: IEnrichedWorkflowStateRecordStep | null;
|
|
59
|
+
}
|
|
60
|
+
export declare const WorkflowStateModel: import("@webiny/di").Abstraction<CmsModel>;
|
|
61
|
+
export declare namespace WorkflowStateModel {
|
|
62
|
+
type Interface = CmsModel;
|
|
63
|
+
}
|
|
64
|
+
export type IWorkflowStateTransformerFromCmsEntryInput = CmsEntry<Omit<IWorkflowStateRecord, "id" | "savedOn" | "createdOn" | "savedBy" | "createdBy">>;
|
|
65
|
+
export type IWorkflowStateTransformerFromCmsEntryOutput = IWorkflowStateRecord;
|
|
66
|
+
export type IWorkflowStateTransformerToCmsEntryInput = Omit<IWorkflowStateRecord, "savedOn" | "createdOn" | "savedBy">;
|
|
67
|
+
export type IWorkflowStateTransformerToCmsEntryOutput = Omit<IWorkflowStateRecord, "id" | "savedOn" | "createdOn" | "savedBy" | "createdBy">;
|
|
68
|
+
export interface IWorkflowStateMapper {
|
|
69
|
+
fromCmsEntry(input: IWorkflowStateTransformerFromCmsEntryInput): IWorkflowStateTransformerFromCmsEntryOutput;
|
|
70
|
+
toCmsEntry(input: IWorkflowStateTransformerToCmsEntryInput): IWorkflowStateTransformerToCmsEntryOutput;
|
|
71
|
+
}
|
|
72
|
+
export declare const WorkflowStateMapper: import("@webiny/di").Abstraction<IWorkflowStateMapper>;
|
|
73
|
+
export declare namespace WorkflowStateMapper {
|
|
74
|
+
type Interface = IWorkflowStateMapper;
|
|
75
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { createAbstraction } from "@webiny/feature/api";
|
|
2
|
+
export let WorkflowStateRecordState = /*#__PURE__*/function (WorkflowStateRecordState) {
|
|
3
|
+
WorkflowStateRecordState["pending"] = "pending";
|
|
4
|
+
WorkflowStateRecordState["inReview"] = "inReview";
|
|
5
|
+
WorkflowStateRecordState["approved"] = "approved";
|
|
6
|
+
WorkflowStateRecordState["rejected"] = "rejected";
|
|
7
|
+
return WorkflowStateRecordState;
|
|
8
|
+
}({});
|
|
9
|
+
// Abstractions
|
|
10
|
+
export const WorkflowStateModel = createAbstraction("WorkflowStateModel");
|
|
11
|
+
export const WorkflowStateMapper = createAbstraction("WorkflowStateMapper");
|
|
12
|
+
|
|
13
|
+
//# sourceMappingURL=abstractions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","WorkflowStateRecordState","WorkflowStateModel","WorkflowStateMapper"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/api\";\nimport type { CmsEntry, CmsModel } from \"@webiny/api-headless-cms/types\";\nimport type { IWorkflowStep } from \"../workflow/abstractions.js\";\n\nexport enum WorkflowStateRecordState {\n pending = \"pending\",\n inReview = \"inReview\",\n approved = \"approved\",\n rejected = \"rejected\"\n}\n\nexport interface IWorkflowStateIdentity {\n id: string;\n displayName: string;\n type: string;\n}\n\nexport interface IWorkflowStateRecordStep extends IWorkflowStep {\n state: WorkflowStateRecordState;\n comment: string | null;\n savedBy: IWorkflowStateIdentity | null;\n}\n\nexport interface IWorkflowStateRecord<\n Steps extends IWorkflowStateRecordStep = IWorkflowStateRecordStep\n> {\n id: string;\n app: string;\n title: string;\n workflowId: string;\n targetId: string;\n targetRevisionId: string;\n isActive: boolean;\n comment: string | undefined;\n state: WorkflowStateRecordState;\n steps: Steps[];\n createdOn: Date;\n savedOn: Date;\n createdBy: IWorkflowStateIdentity;\n savedBy: IWorkflowStateIdentity;\n}\n\nexport interface IEnrichedWorkflowStateRecordStep extends IWorkflowStateRecordStep {\n isOwner: boolean;\n canTakeOver: boolean;\n canReview: boolean;\n}\n\nexport interface IWorkflowState {\n readonly id: string;\n readonly app: string;\n readonly title: string;\n readonly workflowId: string;\n readonly targetId: string;\n readonly targetRevisionId: string;\n readonly isActive: boolean;\n readonly comment: string | undefined;\n readonly state: WorkflowStateRecordState;\n readonly steps: IEnrichedWorkflowStateRecordStep[];\n readonly createdOn: Date;\n readonly savedOn: Date;\n readonly createdBy: IWorkflowStateIdentity;\n readonly savedBy: IWorkflowStateIdentity;\n readonly done: boolean;\n readonly currentStep: IEnrichedWorkflowStateRecordStep;\n readonly nextStep: IEnrichedWorkflowStateRecordStep | null;\n readonly previousStep: IEnrichedWorkflowStateRecordStep | null;\n}\n\n// Abstractions\nexport const WorkflowStateModel = createAbstraction<CmsModel>(\"WorkflowStateModel\");\n\nexport namespace WorkflowStateModel {\n export type Interface = CmsModel;\n}\n\nexport type IWorkflowStateTransformerFromCmsEntryInput = CmsEntry<\n Omit<IWorkflowStateRecord, \"id\" | \"savedOn\" | \"createdOn\" | \"savedBy\" | \"createdBy\">\n>;\n\nexport type IWorkflowStateTransformerFromCmsEntryOutput = IWorkflowStateRecord;\n\nexport type IWorkflowStateTransformerToCmsEntryInput = Omit<\n IWorkflowStateRecord,\n \"savedOn\" | \"createdOn\" | \"savedBy\"\n>;\n\nexport type IWorkflowStateTransformerToCmsEntryOutput = Omit<\n IWorkflowStateRecord,\n \"id\" | \"savedOn\" | \"createdOn\" | \"savedBy\" | \"createdBy\"\n>;\n\nexport interface IWorkflowStateMapper {\n fromCmsEntry(\n input: IWorkflowStateTransformerFromCmsEntryInput\n ): IWorkflowStateTransformerFromCmsEntryOutput;\n toCmsEntry(\n input: IWorkflowStateTransformerToCmsEntryInput\n ): IWorkflowStateTransformerToCmsEntryOutput;\n}\n\nexport const WorkflowStateMapper = createAbstraction<IWorkflowStateMapper>(\"WorkflowStateMapper\");\n\nexport namespace WorkflowStateMapper {\n export type Interface = IWorkflowStateMapper;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,qBAAqB;AAIvD,WAAYC,wBAAwB,0BAAxBA,wBAAwB;EAAxBA,wBAAwB;EAAxBA,wBAAwB;EAAxBA,wBAAwB;EAAxBA,wBAAwB;EAAA,OAAxBA,wBAAwB;AAAA;AAiEpC;AACA,OAAO,MAAMC,kBAAkB,GAAGF,iBAAiB,CAAW,oBAAoB,CAAC;AA+BnF,OAAO,MAAMG,mBAAmB,GAAGH,iBAAiB,CAAuB,qBAAqB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { BaseError } from "@webiny/feature/api";
|
|
2
|
+
import type { IWorkflowStateRecord, IWorkflowStateRecordStep } from "./abstractions.js";
|
|
3
|
+
export declare class WorkflowStateNotFoundError extends BaseError<{
|
|
4
|
+
id?: string;
|
|
5
|
+
app?: string;
|
|
6
|
+
targetRevisionId?: string;
|
|
7
|
+
}> {
|
|
8
|
+
readonly code: "Workflows/State/NotFound";
|
|
9
|
+
constructor(data: {
|
|
10
|
+
id?: string;
|
|
11
|
+
app?: string;
|
|
12
|
+
targetRevisionId?: string;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
export declare class WorkflowStateNotAuthorizedError extends BaseError {
|
|
16
|
+
readonly code: "Workflows/State/NotAuthorized";
|
|
17
|
+
constructor(message: string);
|
|
18
|
+
}
|
|
19
|
+
export declare class WorkflowStatePersistenceError extends BaseError {
|
|
20
|
+
readonly code: "Workflows/State/Persistence";
|
|
21
|
+
constructor(error: Error);
|
|
22
|
+
}
|
|
23
|
+
export declare class WorkflowStateValidationError extends BaseError {
|
|
24
|
+
readonly code: "Workflows/State/Validation";
|
|
25
|
+
constructor(message: string);
|
|
26
|
+
}
|
|
27
|
+
export declare class ActiveStateExistsError extends BaseError<{
|
|
28
|
+
app: string;
|
|
29
|
+
targetRevisionId: string;
|
|
30
|
+
}> {
|
|
31
|
+
readonly code: "Workflows/State/ActiveExists";
|
|
32
|
+
constructor(data: {
|
|
33
|
+
app: string;
|
|
34
|
+
targetRevisionId: string;
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
export declare class MultipleWorkflowsFoundError extends BaseError {
|
|
38
|
+
readonly code: "Workflows/State/MultipleFound";
|
|
39
|
+
constructor(data: any);
|
|
40
|
+
}
|
|
41
|
+
export declare class WorkflowStateNoPendingStepError extends BaseError {
|
|
42
|
+
readonly code: "Workflows/State/NoPendingStep";
|
|
43
|
+
constructor();
|
|
44
|
+
}
|
|
45
|
+
export declare class WorkflowStateStepCannotReviewError extends BaseError<{
|
|
46
|
+
step: IWorkflowStateRecordStep;
|
|
47
|
+
}> {
|
|
48
|
+
readonly code: "Workflows/State/Step/CannotReview";
|
|
49
|
+
constructor(step: IWorkflowStateRecordStep);
|
|
50
|
+
}
|
|
51
|
+
export declare class WorkflowStateStepCannotTakeOverError extends BaseError<{
|
|
52
|
+
step: IWorkflowStateRecordStep;
|
|
53
|
+
}> {
|
|
54
|
+
readonly code: "Workflows/State/Step/CannotTakeOver";
|
|
55
|
+
constructor(step: IWorkflowStateRecordStep);
|
|
56
|
+
}
|
|
57
|
+
export declare class WorkflowStateStepNotStepOwnerError extends BaseError<{
|
|
58
|
+
step: IWorkflowStateRecordStep;
|
|
59
|
+
}> {
|
|
60
|
+
readonly code: "Workflows/State/Step/NotStepOwner";
|
|
61
|
+
constructor(step: IWorkflowStateRecordStep);
|
|
62
|
+
}
|
|
63
|
+
export declare class WorkflowStateInReviewError extends BaseError<{
|
|
64
|
+
state: IWorkflowStateRecord;
|
|
65
|
+
}> {
|
|
66
|
+
readonly code: "Workflows/State/InReview";
|
|
67
|
+
constructor(state: IWorkflowStateRecord);
|
|
68
|
+
}
|
|
69
|
+
export declare class WorkflowStateRejectedError extends BaseError<{
|
|
70
|
+
state: IWorkflowStateRecord;
|
|
71
|
+
}> {
|
|
72
|
+
readonly code: "Workflows/State/Rejected";
|
|
73
|
+
constructor(state: IWorkflowStateRecord);
|
|
74
|
+
}
|
|
75
|
+
export declare class WorkflowStateNotInReview extends BaseError<{
|
|
76
|
+
state: IWorkflowStateRecord;
|
|
77
|
+
}> {
|
|
78
|
+
readonly code: "Workflows/State/NotInReview";
|
|
79
|
+
constructor(message: string, state: IWorkflowStateRecord);
|
|
80
|
+
}
|
|
81
|
+
export declare class WorkflowStateNoCurrentStepError extends BaseError<{
|
|
82
|
+
steps: IWorkflowStateRecordStep[];
|
|
83
|
+
}> {
|
|
84
|
+
readonly code: "Workflows/State/NoCurrentStep";
|
|
85
|
+
constructor(steps: IWorkflowStateRecordStep[]);
|
|
86
|
+
}
|