feat : cycle de vie brouillon/validé du ticket de pesée (ERP-193)
Une pesée (bascule ou manuelle) s'enregistre désormais dès la validation de sa
modale, sans exiger la contrepartie ni l'immatriculation : le ticket naît
« brouillon » (status DRAFT, sans numéro). Le bouton « Valider » finalise quand
les 3 champs du haut (contrepartie + champ associé + immatriculation) ET les 2
pesées sont renseignés : attribution du numéro {siteCode}-TP-{NNNN} et passage
en VALIDATED, puis ouverture du bon de pesée PDF.
Back : counterparty_type/immatriculation/number nullables + colonne status
(migration racine), contraintes strictes déplacées en groupe de validation
finalize, opération PATCH /weighing_tickets/{id}/validate, numéro attribué à la
validation. Front : 4 champs en haut hors blocs, persistance immédiate des
pesées, écrans Ajouter/Modifier refondus, colonne Statut dans la liste, form à
plat pleine largeur. Tests back (lifecycle brouillon/validate) + front à jour.
This commit is contained in:
@@ -220,7 +220,8 @@ abstract class AbstractWeighingTicketApiTestCase extends AbstractApiTestCase
|
||||
|
||||
/**
|
||||
* POST un ticket et renvoie la reponse (assertions de statut a la charge de
|
||||
* l'appelant).
|
||||
* l'appelant). Cree un BROUILLON (status DRAFT, sans numero, ERP-193) — la
|
||||
* validation est portee par validateTicket().
|
||||
*/
|
||||
protected function postTicket(Client $http, array $payload): ResponseInterface
|
||||
{
|
||||
@@ -230,6 +231,32 @@ abstract class AbstractWeighingTicketApiTestCase extends AbstractApiTestCase
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* « Valider » un ticket : PATCH /weighing_tickets/{id}/validate (ERP-193).
|
||||
* Declenche la validation stricte (groupe finalize) + attribution du numero +
|
||||
* passage en VALIDATED. Body vide par defaut = on valide l'etat deja persiste.
|
||||
*/
|
||||
protected function validateTicket(Client $http, int $id, array $payload = []): ResponseInterface
|
||||
{
|
||||
return $http->request('PATCH', '/api/weighing_tickets/'.$id.'/validate', [
|
||||
'headers' => ['Content-Type' => self::MERGE],
|
||||
'json' => [] === $payload ? new \stdClass() : $payload,
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* POST un brouillon complet puis le valide ; renvoie le ticket VALIDE (numero
|
||||
* attribue). Le payload doit porter contrepartie + immatriculation + 2 pesees.
|
||||
*
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
protected function createValidatedTicket(Client $http, array $payload): array
|
||||
{
|
||||
$id = (int) $this->postTicket($http, $payload)->toArray()['id'];
|
||||
|
||||
return $this->validateTicket($http, $id)->toArray();
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrouve un membre d'une collection Hydra par son id.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user