mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
example of workflow + finalize normalization
This commit is contained in:
parent
dc184762d6
commit
5ac485e06e
@ -5,6 +5,19 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="list-group-item" v-for="w in workflows">
|
<div class="list-group-item" v-for="w in workflows">
|
||||||
{{ w.id }}
|
{{ w.id }}
|
||||||
|
|
||||||
|
Etape actuelle: {{ w.currentStep.currentStep.text }}
|
||||||
|
|
||||||
|
<ul>
|
||||||
|
<li v-for="w in w.steps">
|
||||||
|
Etape: {{ w.currentStep.text }},
|
||||||
|
<span v-if="w.transitionPrevious != null">
|
||||||
|
transition pour arriver à cette étape : {{ w.transitionPrevious.text }},
|
||||||
|
par: {{ w.transitionPreviousBy.text }}, le {{ w.transitionPreviousAt.datetime }}
|
||||||
|
</span>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
<ul class="record_actions">
|
<ul class="record_actions">
|
||||||
<li>
|
<li>
|
||||||
<a class="btn btn-sm btn-outline-primary"
|
<a class="btn btn-sm btn-outline-primary"
|
||||||
@ -33,4 +46,4 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
@ -47,7 +47,7 @@ class EntityWorkflowNormalizer implements NormalizerInterface, NormalizerAwareIn
|
|||||||
'relatedEntityClass' => $object->getRelatedEntityClass(),
|
'relatedEntityClass' => $object->getRelatedEntityClass(),
|
||||||
'relatedEntityId' => $object->getRelatedEntityId(),
|
'relatedEntityId' => $object->getRelatedEntityId(),
|
||||||
'workflow' => $this->metadataExtractor->buildArrayPresentationForWorkflow($workflow),
|
'workflow' => $this->metadataExtractor->buildArrayPresentationForWorkflow($workflow),
|
||||||
'current_step' => $this->metadataExtractor->buildArrayPresentationForPlace($object),
|
'currentStep' => $this->normalizer->normalize($object->getCurrentStep(), $format, $context),
|
||||||
'steps' => $this->normalizer->normalize($object->getStepsChained(), $format, $context),
|
'steps' => $this->normalizer->normalize($object->getStepsChained(), $format, $context),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ use Symfony\Component\Serializer\Normalizer\NormalizerAwareInterface;
|
|||||||
use Symfony\Component\Serializer\Normalizer\NormalizerAwareTrait;
|
use Symfony\Component\Serializer\Normalizer\NormalizerAwareTrait;
|
||||||
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
||||||
|
|
||||||
class EntitWorkflowStepNormalizer implements NormalizerAwareInterface, NormalizerInterface
|
class EntityWorkflowStepNormalizer implements NormalizerAwareInterface, NormalizerInterface
|
||||||
{
|
{
|
||||||
use NormalizerAwareTrait;
|
use NormalizerAwareTrait;
|
||||||
|
|
||||||
@ -38,27 +38,45 @@ class EntitWorkflowStepNormalizer implements NormalizerAwareInterface, Normalize
|
|||||||
'id' => $object->getId(),
|
'id' => $object->getId(),
|
||||||
'comment' => $object->getComment(),
|
'comment' => $object->getComment(),
|
||||||
'currentStep' => $this->metadataExtractor->buildArrayPresentationForPlace($object->getEntityWorkflow(), $object),
|
'currentStep' => $this->metadataExtractor->buildArrayPresentationForPlace($object->getEntityWorkflow(), $object),
|
||||||
'finalizeAfter' => $object->isFinalizeAfter(),
|
'isFinal' => $object->isFinal(),
|
||||||
'isFreezed' => false,
|
'isFreezed' => false,
|
||||||
'isFinalized' => false,
|
'isFinalized' => false,
|
||||||
|
'transitionPrevious' => null,
|
||||||
|
'transitionAfter' => null,
|
||||||
'previousId' => null,
|
'previousId' => null,
|
||||||
'nextId' => null,
|
'nextId' => null,
|
||||||
'by' => null,
|
'transitionPreviousBy' => null,
|
||||||
'at' => null,
|
'transitionPreviousAt' => null,
|
||||||
];
|
];
|
||||||
|
|
||||||
if (null !== $previous = $object->getPrevious()) {
|
if (null !== $previous = $object->getPrevious()) {
|
||||||
|
$data['transitionPrevious'] = $this->metadataExtractor
|
||||||
|
->buildArrayPresentationForTransition($object->getEntityWorkflow(), $object->getPrevious()->getTransitionAfter());
|
||||||
$data['previousId'] = $previous->getId();
|
$data['previousId'] = $previous->getId();
|
||||||
$data['isFreezed'] = $previous->isFreezeAfter();
|
$data['isFreezed'] = $previous->isFreezeAfter();
|
||||||
$data['isFinalized'] = $previous->isFreezeAfter();
|
$data['transitionPreviousBy'] = $this->normalizer->normalize(
|
||||||
$data['by'] = $previous->getTransitionBy();
|
$previous->getTransitionBy(),
|
||||||
$data['at'] = $previous->getTransitionAt();
|
$format,
|
||||||
|
$context
|
||||||
|
);
|
||||||
|
$data['transitionPreviousAt'] = $this->normalizer->normalize(
|
||||||
|
$previous->getTransitionAt(),
|
||||||
|
$format,
|
||||||
|
$context
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (null !== $next = $object->getNext()) {
|
if (null !== $next = $object->getNext()) {
|
||||||
$data['nextId'] = $next->getId();
|
$data['nextId'] = $next->getId();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (null !== $object->getTransitionAfter()) {
|
||||||
|
$data['transitionAfter'] = $this->metadataExtractor->buildArrayPresentationForTransition(
|
||||||
|
$object->getEntityWorkflow(),
|
||||||
|
$object->getTransitionAfter()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
@ -65,6 +65,26 @@ class MetadataExtractor
|
|||||||
return ['name' => $step->getCurrentStep(), 'text' => $text];
|
return ['name' => $step->getCurrentStep(), 'text' => $text];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function buildArrayPresentationForTransition(EntityWorkflow $entityWorkflow, string $transitionName): array
|
||||||
|
{
|
||||||
|
$workflow = $this->registry->get($entityWorkflow, $entityWorkflow->getWorkflowName());
|
||||||
|
$transitions = $workflow->getDefinition()->getTransitions();
|
||||||
|
|
||||||
|
foreach ($transitions as $transition) {
|
||||||
|
if ($transition->getName() === $transitionName) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$metadata = $workflow->getMetadataStore()->getTransitionMetadata($transition);
|
||||||
|
|
||||||
|
return [
|
||||||
|
'name' => $transition->getName(),
|
||||||
|
'text' => array_key_exists('label', $metadata) ?
|
||||||
|
$this->translatableStringHelper->localize($metadata['label']) : $transition->getName(),
|
||||||
|
'isForward' => $metadata['isForward'] ?? null,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
public function buildArrayPresentationForWorkflow(WorkflowInterface $workflow): array
|
public function buildArrayPresentationForWorkflow(WorkflowInterface $workflow): array
|
||||||
{
|
{
|
||||||
$metadata = $workflow->getMetadataStore()->getWorkflowMetadata();
|
$metadata = $workflow->getMetadataStore()->getWorkflowMetadata();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user