|
- <?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;
-
- /**
- * This is the model class for table "produit".
- *
- * @property integer $id
- * @property string $nom
- * @property string $description
- * @property integer $actif
- * @property string $illustration
- * @property string $photo
- * @property string $saison
- * @property double $prix
- * @property double $poids
- * @property string $recette
- */
- class Produit extends \yii\db\ActiveRecord {
-
- var $total = 0;
-
- /**
- * @inheritdoc
- */
- public static function tableName() {
- return 'produit';
- }
-
- /**
- * @inheritdoc
- */
- public function rules() {
- return [
- [['nom', 'id_etablissement'], 'required'],
- [['actif', 'order', 'quantite_max', 'id_etablissement'], 'integer'],
- [['lundi', 'mardi', 'mercredi', 'jeudi', 'vendredi', 'samedi', 'dimanche', 'epuise'], 'boolean'],
- [['prix', 'poids'], 'number'],
- [['illustration', 'photo'], 'file'],
- [['nom', 'description', 'illustration', 'photo', 'saison', 'diminutif'], 'string', 'max' => 255],
- [['recette'], 'string', 'max' => 1000],
- ];
- }
-
- /**
- * @inheritdoc
- */
- public function attributeLabels() {
- return [
- 'id' => 'ID',
- 'nom' => 'Nom',
- 'description' => 'Description',
- 'actif' => 'Actif',
- 'illustration' => 'Illustration',
- 'photo' => 'Photo',
- 'saison' => 'Saison',
- 'prix' => 'Prix',
- 'poids' => 'Poids (g)',
- 'recette' => 'Recette',
- 'lundi' => 'Lundi',
- 'mardi' => 'Mardi',
- 'mercredi' => 'Mercredi',
- 'jeudi' => 'Jeudi',
- 'vendredi' => 'Vendredi',
- 'samedi' => 'Samedi',
- 'dimanche' => 'Dimanche',
- 'order' => 'Ordre',
- 'quantite_max' => 'Quantité max par défaut',
- 'epuise' => 'Épuisé',
- ];
- }
-
- public function getDescription() {
- $description = $this->description;
- if (isset($this->poids) && is_numeric($this->poids) && $this->poids > 0) {
- if ($this->poids >= 1000) {
- $description .= ' (' . ($this->poids / 1000) . 'kg)';
- } else {
- $description .= ' (' . $this->poids . 'g)';
- }
- }
- return $description;
- }
-
- public function getLibelleAdmin() {
- return $this->nom;
- }
-
- public function save($runValidation = true, $attributeNames = NULL) {
- $this->id_etablissement = Yii::$app->user->identity->id_etablissement;
- return parent::save($runValidation, $attributeNames);
- }
-
- public function getAll() {
- return Produit::find()
- ->where([
- 'id_etablissement' => Yii::$app->user->identity->id_etablissement,
- ])
- ->orderBy('order ASC')
- ->all();
- }
-
- public function getByProduction($id_production) {
- return Produit::find()
- ->leftJoin('production_produit', 'produit.id = production_produit.id_produit')
- ->where([
- 'id_etablissement' => Yii::$app->user->identity->id_etablissement,
- 'production_produit.id_production' => $id_production
- ])
- ->orderBy('production_produit.actif DESC, produit.order ASC')
- ->all();
- }
-
- public static function count() {
- return Produit::find()
- ->where([
- 'id_etablissement' => Yii::$app->user->identity->id_etablissement
- ])
- ->count();
- }
-
- }
|