arter / amos-workflow
Sistema AMOS per il workflow
Requires
- php: >=5.4.0
- arter/amos-core: ^1.9.50
- cornernote/yii2-workflow-manager: ^1.0.1
- raoul2000/yii2-workflow: ^1.1.0
This package is auto-updated.
Last update: 2025-03-07 11:50:39 UTC
README
The module Workflow is used in order to manage workflow status transitions on records useing a workflow. Amos Workflow is based on:
- raoul2000/yii2-workflow
- cornernote/yii2-workflow-manager
Installation
- The preferred way to install this extension is through composer.
Either run
composer require arter/amos-workflow
or add this row
"arter/amos-workflow": "dev-master"
to the require section of your composer.json
file.
Add module to your modules config in backend:
'modules' => [ 'workflow' => [ 'class' => 'arter\amos\workflow\AmosWorkflow', ], ],
Apply migrations
a. amos-workflow migrations
php yii migrate/up --migrationPath=@vendor/arter/amos-workflow/src/migrations
or add this row to your migrations config in console:
return [ . . . '@vendor/arter/amos-workflow/src/migrations', . . . ];
Configuration
//TODO translate-fix this section
Ogni cambio di stato del workflow viene intercettato come evento e viene scritta un record di log nella tabella workflow_transition_log (vedere WorkflowLogFunctionsBehavior).
Define model workflow
Il workflow classico in amos4 comprende gli stati:
- bozza /draft
- da validare/richiesta pubblicazione
- validato/pubblicato
Per automatizzare/standardizzare alcune operazioni è stata creata in amos-core l'interfaccia WorkflowModelInterface che è bene implementare, insieme ad estendere NotifyRecord per beneficiare ad esempio delle mail automatiche alla richiesta di validazione del modello.
Il workflow del model viene definito tramite il popolamento delle tabelle:
sw_workflow: definizione id del workflow, per convenzione in amos 4 è il nome del model seguito da 'Workflow' es. 'NewsWorkflow'. Definizione dello stato iniziale di default, eventualmente modificabile da interfaccia o tramite migration. Es initial_status_id = 'DRAFT'
sw_status: Definizione degli stati del workflow. Lo stato verrà salvato (come convenzione) nel campo status del model concatendo Workflow_id / status_id ad esempio 'NewsWorkflow/BOZZA'
sw_transition: definizione delle transizioni, ossia di tutti i possibili passaggi di stato. IMPORTANTE: l'errore non esiste la transizione tra stato A e stato B che potreste riscontrare, se avete definito la transizione è in realtà dovuto alla mancanza del permesso dell'utente salvare il modello in quello stato.
sw_metadata: per ogni stato del workflow definisce label sui bottoni di cambio stato, testi dei popup, classi css, ecc. E' possibile anche commentare il passaggio di stato e salvare tale nota/commento nei log di passaggio di stato.
To enable workflow event behavior, insert in your model behavior array eg.
public function behaviors()
{
return ArrayHelper::merge(parent::behaviors(), [
.
.
.
'workflow' => [
'class' => SimpleWorkflowBehavior::className(),
'defaultWorkflowId' => self::NEWS_WORKFLOW,
'propagateErrorsToModel' => true
]
];
}
Widgets
Amos Workflow provides three Widgets:
- WorkflowTransitionButtonsWidget
- WorkflowTransitionStateDescriptorWidget
//TODO explain/example of use for new widgets above
- WorkflowTransitionWidget arter\amos\workflow\widgets\WorkflowTransitionWidget
Draws a section containing model current status and the buttons with possible status to change starting from the current one (reading from sw_metadata).
Comment / notes on status change
If needed, it is possible to show a popup to insert comment/notes on status change; to enable the functionality add in sw_metadata for the transition final status the metadata: key ='comment', value = 1
It is possible to use a global parameter to hide all transition widgets, if the model workflows are bypassed. Insert between your application backend params array:
return [
.
.
.
'hideWorkflowTransitionWidget' => true
.
.
.
];
```
example of use in a form:
<?= WorkflowTransitionWidget::widget([
'form' => $form,
'model' => $model,
'workflowId' => ShowcaseProject::SHOWCASEPROJECT_WORKFLOW,
'classDivIcon' => 'pull-left',
'classDivMessage' => 'pull-left message',
'viewWidgetOnNewRecord' => true,
'translationCategory' => 'amosshowcaseprojects'
]); ?>