|
- <?php
-
- /**
- Copyright La boîte à pain (2018)
-
- contact@laboiteapain.net
-
- Ce logiciel est un programme informatique servant à aider les producteurs
- à distribuer leur production en circuits courts.
-
- Ce logiciel est régi par la licence CeCILL soumise au droit français et
- respectant les principes de diffusion des logiciels libres. Vous pouvez
- utiliser, modifier et/ou redistribuer ce programme sous les conditions
- de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
- sur le site "http://www.cecill.info".
-
- En contrepartie de l'accessibilité au code source et des droits de copie,
- de modification et de redistribution accordés par cette licence, il n'est
- offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
- seule une responsabilité restreinte pèse sur l'auteur du programme, le
- titulaire des droits patrimoniaux et les concédants successifs.
-
- A cet égard l'attention de l'utilisateur est attirée sur les risques
- associés au chargement, à l'utilisation, à la modification et/ou au
- développement et à la reproduction du logiciel par l'utilisateur étant
- donné sa spécificité de logiciel libre, qui peut le rendre complexe à
- manipuler et qui le réserve donc à des développeurs et des professionnels
- avertis possédant des connaissances informatiques approfondies. Les
- utilisateurs sont donc invités à charger et tester l'adéquation du
- logiciel à leurs besoins dans des conditions permettant d'assurer la
- sécurité de leurs systèmes et ou de leurs données et, plus généralement,
- à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
-
- Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
- pris connaissance de la licence CeCILL, et que vous en avez accepté les
- termes.
- */
-
- namespace common\models;
-
- use Yii;
- use yii\db\ActiveRecord;
- use common\models\User;
- use common\models\Commande;
- use yii\helpers\Html;
-
- /**
- * This is the model class for table "credit_historique".
- *
- * @property integer $id
- * @property integer $id_user
- * @property integer $id_commande
- * @property string $date
- * @property double $montant
- * @property string $type
- * @property integer $id_etablissement
- * @property string $moyen_paiement
- */
- class CreditHistory extends ActiveRecord
- {
-
- const TYPE_INITIAL_CREDIT = 'initial-credit';
- const TYPE_CREDIT = 'credit';
- const TYPE_PAYMENT = 'payment';
- const TYPE_REFUND= 'refund';
- const TYPE_DEBIT = 'debit';
-
- const PAYMENT_CREDIT_CARD = 'credit-card';
- const PAYMENT_MONEY = 'money';
- const PAYMENT_CHEQUE = 'cheque';
- const PAYMENT_OTHER = 'other';
-
- /**
- * @inheritdoc
- */
- public static function tableName()
- {
- return 'credit_history';
- }
-
- /**
- * @inheritdoc
- */
- public function rules()
- {
- return [
- [['montant'], 'required'],
- [['id_user', 'id_user_action', 'id_commande', 'id_etablissement'], 'integer'],
- [['date'], 'safe'],
- [['montant'], 'double'],
- [['type', 'moyen_paiement', 'commentaire'], 'string', 'max' => 255],
- ];
- }
-
- /**
- * @inheritdoc
- */
- public function attributeLabels()
- {
- return [
- 'id' => 'ID',
- 'id_user' => 'Utilisateur',
- 'id_user_action' => 'Utilisateur',
- 'id_commande' => 'Commande',
- 'date' => 'Date',
- 'montant' => 'Montant',
- 'type' => 'Type',
- 'id_etablissement' => 'Établissement',
- 'moyen_paiement' => 'Moyen de paiement',
- 'commentaire' => 'Commentaire',
- ];
- }
-
- /*
- * Relations
- */
-
- public function getUser()
- {
- return $this->hasOne(User::className(), ['id' => 'id_user']);
- }
-
- public function getUserAction()
- {
- return $this->hasOne(User::className(), ['id' => 'id_user_action']);
- }
-
- public function getCommande()
- {
- return $this->hasOne(Commande::className(), ['id' => 'id_commande']);
- }
-
- /**
- * Retourne le type de CreditHistorique (paiement, remboursement ou débit).
- *
- * @return string
- */
- public function getLibelleType()
- {
- switch ($this->type) {
- case 'paiement':
- return 'Paiement';
- break;
- case 'remboursement':
- return 'Remboursement';
- break;
- case 'debit':
- return 'Débit';
- break;
- }
- }
-
- /**
- * Enregistre le modèle.
- *
- * @param boolean $runValidation
- * @param array $attributeNames
- */
- public function save($runValidation = true, $attributeNames = NULL)
- {
- // initialisation du commentaire avant sauvegarde
- $this->commentaire .= $this->getStrCommentaire() ;
-
- parent::save($runValidation, $attributeNames);
-
- // mise à jour du crédit au niveau de UserEtablissement
- $user_etablissement = UserEtablissement::findOne([
- 'id_user' => $this->id_user,
- 'id_etablissement' => $this->id_etablissement
- ]);
- if ($user_etablissement) {
- if ($this->isTypeCredit()) {
- $user_etablissement->credit += $this->montant;
- } elseif ($this->isTypeDebit()) {
- $user_etablissement->credit -= $this->montant;
- }
- $user_etablissement->save();
- }
- }
-
- /**
- * Retourne si le CreditHistorique est un débit ou non.
- *
- * @return boolean
- */
- public function isTypeDebit()
- {
- return in_array($this->type, [
- self::TYPE_DEBIT,
- self::TYPE_PAIEMENT,
- ]) ;
- }
-
- /**
- * Retourne si le CreditHistorique est un crédit ou non.
- *
- * @return boolean
- */
- public function isTypeCredit()
- {
- return in_array($this->type, [
- self::TYPE_CREDIT,
- self::TYPE_CREDIT_INITIAL,
- self::TYPE_REMBOURSEMENT
- ]) ;
- }
-
- /**
- * Retourne le montant.
- *
- * @param boolean $format
- * @return float
- */
- public function getMontant($format = false)
- {
- if($format)
- return number_format($this->montant,2) .' €' ;
- else
- return $this->montant ;
- }
-
- /**
- * Retourne le libellé du CreditHistorique informant de son type et
- * éventuellement de la date de sa commande associée.
- *
- * @return string
- */
- public function getStrLibelle()
- {
- $str = '' ;
-
- if($this->type == self::TYPE_CREDIT_INITIAL) {
- $str = 'Crédit initial' ;
- }
- elseif($this->type == self::TYPE_CREDIT) {
- $str = 'Crédit' ;
- }
- elseif($this->type == self::TYPE_PAIEMENT) {
- $str = 'Paiement' ;
- }
- elseif($this->type == self::TYPE_REMBOURSEMENT) {
- $str = 'Remboursement' ;
- }
- elseif($this->type == self::TYPE_DEBIT) {
- $str = 'Débit' ;
- }
-
- if($this->type == self::TYPE_PAIEMENT || $this->type == self::TYPE_REMBOURSEMENT) {
- if(isset($this->commande)) {
- $str .= '<br />Commande : '.date('d/m/Y',strtotime($this->commande->production->date)) ;
- }
- else {
- $str .= '<br />Commande supprimée' ;
- }
- }
-
- return $str ;
- }
-
-
- /**
- * Retourne les informations à ajouter au commentaire du CreditHistorique
- * (libellé, montant, client, action) au format HTML.
- *
- * @return string
- */
- public function getStrCommentaire()
- {
- $str = '' ;
- if(strlen($this->commentaire)) {
- $str .= '<br />' ;
- }
- $str .= $this->getStrLibelle() ;
- if(isset($this->commande)) {
- $str .= '<br />Montant de la commande : '.$this->commande->getMontant(true) ;
- }
- if(isset($this->user)) {
- $str .= '<br />Client : '.Html::encode($this->user->nom. ' '.$this->user->prenom) ;
- }
- if(isset($this->userAction)) {
- $str .= '<br />Action : '.Html::encode($this->userAction->nom. ' '.$this->userAction->prenom) ;
- }
-
- return $str ;
- }
-
- /**
- * Retourne la date.
- *
- * @param boolean $format
- * @return string
- */
- public function getDate($format = false)
- {
- if($format)
- return date('d/m/Y à H:i:s',strtotime($this->date)) ;
- else
- return $this->date ;
- }
-
- /**
- * Retourne le moyen de paiement.
- *
- * @return string
- */
- public function getStrMoyenPaiement()
- {
- switch($this->moyen_paiement) {
- case CreditHistorique::MOYEN_ESPECES : return 'Espèces' ;
- case CreditHistorique::MOYEN_CHEQUE : return 'Chèque' ;
- case CreditHistorique::MOYEN_CB : return 'Carte bancaire' ;
- case CreditHistorique::MOYEN_AUTRE : return 'Autre' ;
- default: return 'Crédit pain' ;
- }
- }
-
- /**
- * Retourne le libellé de l'utilisateur ayant initié l'action.
- *
- * @return string
- */
- public function strUserAction()
- {
- if($this->userAction) {
- return $this->userAction->nom . ' ' . $this->userAction->prenom ;
- }
- else {
- return 'Système' ;
- }
- }
-
- }
|