mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-08-21 07:03:49 +00:00
example of workflow + finalize normalization
This commit is contained in:
@@ -47,7 +47,7 @@ class EntityWorkflowNormalizer implements NormalizerInterface, NormalizerAwareIn
|
||||
'relatedEntityClass' => $object->getRelatedEntityClass(),
|
||||
'relatedEntityId' => $object->getRelatedEntityId(),
|
||||
'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),
|
||||
];
|
||||
}
|
||||
|
@@ -17,7 +17,7 @@ use Symfony\Component\Serializer\Normalizer\NormalizerAwareInterface;
|
||||
use Symfony\Component\Serializer\Normalizer\NormalizerAwareTrait;
|
||||
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
||||
|
||||
class EntitWorkflowStepNormalizer implements NormalizerAwareInterface, NormalizerInterface
|
||||
class EntityWorkflowStepNormalizer implements NormalizerAwareInterface, NormalizerInterface
|
||||
{
|
||||
use NormalizerAwareTrait;
|
||||
|
||||
@@ -38,27 +38,45 @@ class EntitWorkflowStepNormalizer implements NormalizerAwareInterface, Normalize
|
||||
'id' => $object->getId(),
|
||||
'comment' => $object->getComment(),
|
||||
'currentStep' => $this->metadataExtractor->buildArrayPresentationForPlace($object->getEntityWorkflow(), $object),
|
||||
'finalizeAfter' => $object->isFinalizeAfter(),
|
||||
'isFinal' => $object->isFinal(),
|
||||
'isFreezed' => false,
|
||||
'isFinalized' => false,
|
||||
'transitionPrevious' => null,
|
||||
'transitionAfter' => null,
|
||||
'previousId' => null,
|
||||
'nextId' => null,
|
||||
'by' => null,
|
||||
'at' => null,
|
||||
'transitionPreviousBy' => null,
|
||||
'transitionPreviousAt' => null,
|
||||
];
|
||||
|
||||
if (null !== $previous = $object->getPrevious()) {
|
||||
$data['transitionPrevious'] = $this->metadataExtractor
|
||||
->buildArrayPresentationForTransition($object->getEntityWorkflow(), $object->getPrevious()->getTransitionAfter());
|
||||
$data['previousId'] = $previous->getId();
|
||||
$data['isFreezed'] = $previous->isFreezeAfter();
|
||||
$data['isFinalized'] = $previous->isFreezeAfter();
|
||||
$data['by'] = $previous->getTransitionBy();
|
||||
$data['at'] = $previous->getTransitionAt();
|
||||
$data['transitionPreviousBy'] = $this->normalizer->normalize(
|
||||
$previous->getTransitionBy(),
|
||||
$format,
|
||||
$context
|
||||
);
|
||||
$data['transitionPreviousAt'] = $this->normalizer->normalize(
|
||||
$previous->getTransitionAt(),
|
||||
$format,
|
||||
$context
|
||||
);
|
||||
}
|
||||
|
||||
if (null !== $next = $object->getNext()) {
|
||||
$data['nextId'] = $next->getId();
|
||||
}
|
||||
|
||||
if (null !== $object->getTransitionAfter()) {
|
||||
$data['transitionAfter'] = $this->metadataExtractor->buildArrayPresentationForTransition(
|
||||
$object->getEntityWorkflow(),
|
||||
$object->getTransitionAfter()
|
||||
);
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
Reference in New Issue
Block a user