Completed
Push — master ( 753652...d0e0e5 )
by Dmitry
04:54
created

src/models/Calculation.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
/**
3
 * Finance module for HiPanel
4
 *
5
 * @link      https://github.com/hiqdev/hipanel-module-finance
6
 * @package   hipanel-module-finance
7
 * @license   BSD-3-Clause
8
 * @copyright Copyright (c) 2015-2019, HiQDev (http://hiqdev.com/)
9
 */
10
11
namespace hipanel\modules\finance\models;
12
13
use Yii;
14
use yii\base\InvalidParamException;
15
16
/**
17
 * Class Calculation.
18
 *
19
 *
20
 * @property-read Value[] value
21
 * @property-read Value[] valueConverted
22
 */
23
class Calculation extends \hipanel\base\Model
24
{
25
    use \hipanel\base\ModelTrait;
26
27
    /** {@inheritdoc} */
28
    public static function tableName()
29
    {
30
        return 'action';
31
    }
32
33
    /** {@inheritdoc} */
34
    public function init()
35
    {
36
        if (!isset($this->seller)) {
37
            if (Yii::$app->user->getIsGuest()) {
38
                $this->seller = Yii::$app->params['user.seller'];
39
            } else {
40
                $this->seller = Yii::$app->user->identity->seller;
41
            }
42
        }
43
44
        if (!isset($this->client) && !Yii::$app->user->getIsGuest()) {
45
            $this->client = Yii::$app->user->identity->username;
46
        }
47
48
        $this->synchronize();
49
    }
50
51
    public function getValue()
52
    {
53
        // ['tariff_id' => 'currency'] is a dumb relation condition and does not make any sense
54
        return $this->hasMany(Value::class, ['tariff_id' => 'currency'])->indexBy('currency');
55
    }
56
57
    public function getValueConverted()
58
    {
59
        // ['tariff_id' => 'currency'] is a dumb relation condition and does not make any sense
60
        return $this->hasMany(Value::class, ['tariff_id' => 'currency'])->indexBy('currency');
61
    }
62
63
    /**
64
     * @param string $currency
65
     *
66
     * @throws InvalidParamException when the $currency is not calculated
67
     * @return Value
68
     */
69
    public function forCurrency($currency)
70
    {
71
        if (isset($this->value[$currency])) {
72
            return $this->value[$currency];
73
        }
74
        if (!empty($this->value)) {
75
            return reset($this->value);
0 ignored issues
show
Comprehensibility Best Practice introduced by
The expression reset($this->value); of type hipanel\modules\finance\models\Value|false adds false to the return on line 75 which is incompatible with the return type documented by hipanel\modules\finance\...alculation::forCurrency of type hipanel\modules\finance\models\Value. It seems like you forgot to handle an error condition.
Loading history...
76
        }
77
        Yii::warning('Value for currency $currency was not found. Using fake free value. Most probably, tariff is free', __METHOD__);
78
79
        return new Value(['value' => 0, 'price' => 0]);
80
81
    }
82
83
    /** {@inheritdoc} */
84
    public function rules()
85
    {
86
        return [
87
            [['object', 'seller', 'client', 'type', 'currency', 'item'], 'safe'],
88
            [['amount'], 'number'],
89
            [['tariff_id', 'calculation_id'], 'integer'],
90
        ];
91
    }
92
93
    /**
94
     * Synchronises the model to represent actual state of [[position]]
95
     * The method must update values, that affects the calculation and
96
     * can be changed in cart without position re-adding.
97
     * For example: quantity.
98
     */
99
    public function synchronize()
100
    {
101
        return true;
102
    }
103
}
104