|
- <?php
-
- namespace common\models;
-
- use yii\base\Object;
- use Yii;
-
-
- class ProductionProduit extends \yii\db\ActiveRecord {
-
-
-
- public static function tableName() {
- return 'production_produit';
- }
-
-
-
- public function rules() {
- return [
- [['id_production', 'id_produit', 'actif', 'quantite_max'], 'integer']
- ];
- }
-
- public function getProduit() {
- return $this->hasOne(Produit::className(), ['id' => 'id_produit']);
- }
-
-
-
- public function attributeLabels() {
- return [
- 'id' => 'ID',
- 'id_production' => 'Id Production',
- 'id_produit' => 'Id Produit',
- 'actif' => 'Actif',
- 'quantite_max' => 'Quantité max',
- ];
- }
-
- public static function findProduits($id_production) {
-
- $production_produits = ProductionProduit::find()
- ->with('produit')
- ->where(['id_production' => $id_production])
- ->all();
-
- $arr_production_produits = [];
-
- $commandes = Commande::find()
- ->with('commandeProduits', 'user')
- ->joinWith('production')
- ->where(['production.id' => $id_production])
- ->orderBy('date ASC')
- ->all();
-
- foreach ($production_produits as $pp) {
- if (isset($pp->produit)) {
- $arr_production_produits[$pp->id_produit] = [
- 'actif' => (int) $pp->actif,
- 'epuise' => (int) $pp->produit->epuise,
- 'vrac' => (int) $pp->produit->vrac,
- 'quantite_max' => $pp->quantite_max,
- 'quantite_commandee' => Commande::getQuantiteProduit($pp->id_produit, $commandes),
- 'quantite_restante' => $pp->quantite_max - Commande::getQuantiteProduit($pp->id_produit, $commandes)
- ];
- }
- }
-
- return $arr_production_produits;
- }
-
- }
|