224 lines
7.7 KiB
PHP
224 lines
7.7 KiB
PHP
<?
|
||
namespace shop;
|
||
|
||
use common\Image;
|
||
use common\Payment;
|
||
use core\db\structure\Column as C;
|
||
use core\db\structure\eColumnType;
|
||
use shop\cash\structure\eCashType;
|
||
use shop\core\structure\shopModuleTable;
|
||
use shop\shop\structure\eCurrency;
|
||
use ui\form\structure\eInputType;
|
||
use ui\Form;
|
||
use ui\input\Input;
|
||
use core\lang\structure\LangVariable as V;
|
||
use shop\cashbox\structure\shopCashboxLang as Vars;
|
||
|
||
|
||
class Cashbox extends shopModuleTable {
|
||
static $self;
|
||
static $table_name = 'shopCashbox';
|
||
static $controller = 'shop.cashbox';
|
||
static $default_sort;
|
||
static $easy_left_joins;
|
||
|
||
|
||
static $ID = 'id';
|
||
static $NAME = 'name';
|
||
static $CURRENCY = 'currency';
|
||
static $IMAGE = 'image';
|
||
static $TOTAL = 'total';
|
||
static $START = 'start';
|
||
static $POS = 'pos';
|
||
static $ACCOUNT = 'account';
|
||
static $CREATED = 'created';
|
||
static $UPDATED = 'updated';
|
||
|
||
static function getTitle(){return V::get(Vars::$MODULE_NAME);}
|
||
static function getSystemLangValues():array{ return Vars::getArray(); }
|
||
|
||
public function _insert(array $values, array $options = array()) {
|
||
$values[self::$TOTAL] = floatval($values[self::$START]);
|
||
return parent::_insert($values, $options); // TODO: Change the autogenerated stub
|
||
}
|
||
|
||
public function __construct($install_id = null) {
|
||
parent::__construct($install_id);
|
||
static::$default_sort = self::$POS;
|
||
static::$easy_left_joins = [
|
||
[Image::$table_name,Image::$ID,self::$IMAGE]
|
||
];
|
||
}
|
||
|
||
|
||
public function _update(\Where $w, array $values) {
|
||
$values[self::$UPDATED] = time();
|
||
if(isset($values[self::$START])) {
|
||
$values[self::$TOTAL] = self::mathTotal($values);
|
||
}
|
||
return parent::_update($w, $values);
|
||
}
|
||
|
||
static function appFormat($v){
|
||
return [
|
||
'name' =>self::getName($v),
|
||
'total'=>$v[self::$TOTAL],
|
||
'currency'=>eCurrency::getName($v[self::$CURRENCY]),
|
||
'image'=>Image::imageResize($v[Image::$URL],200,200,85,['crop'=>'center']),
|
||
];
|
||
}
|
||
|
||
|
||
static function remath($C){
|
||
if(is_numeric($C)) $C = self::getByID($C);
|
||
$total = self::mathTotal($C);
|
||
self::updateById($C[self::$ID],[self::$TOTAL=>$total]);
|
||
}
|
||
|
||
static function mathTotal($C){
|
||
if(is_numeric($C)) $C = self::getByID($C);
|
||
$id = $C[self::$ID];
|
||
// Считаем все движения по счёту
|
||
$pays = Cash::select([
|
||
\Query::SELECT => 'SUM('.Cash::$VALUE.') as cc',
|
||
\Query::WHERE => new \Where(\Where::_and([
|
||
\Where::_operator(Cash::$CASHBOX,'=',$id),
|
||
\Where::_in(Cash::$TYPE,[eCashType::MINUS,eCashType::PLUS]),
|
||
])),
|
||
]);
|
||
$plus1 = floatval( \DB::fetch($pays)['cc'] );
|
||
|
||
// Считаем все переводы со счёта
|
||
$minus = Cash::select([
|
||
\Query::SELECT => 'SUM('.Cash::$VALUE.') as cc',
|
||
\Query::WHERE => new \Where(\Where::_and([
|
||
\Where::_operator(Cash::$CASHBOX2,'=',$id),
|
||
\Where::_operator(Cash::$TYPE,'=',eCashType::TRANSFER),
|
||
])),
|
||
]);
|
||
$minus1 = floatval( \DB::fetch($minus)['cc'] );
|
||
|
||
// Считаем все переводы на счёт
|
||
$plus = Cash::select([
|
||
\Query::SELECT => 'SUM('.Cash::$VALUE.') as cc',
|
||
\Query::WHERE => new \Where(\Where::_and([
|
||
\Where::_operator(Cash::$CASHBOX,'=',$id),
|
||
\Where::_operator(Cash::$TYPE,'=',eCashType::TRANSFER),
|
||
])),
|
||
]);
|
||
$plus2 = floatval( \DB::fetch($plus)['cc'] );
|
||
|
||
return $plus1 - $minus1 + $plus2;
|
||
|
||
}
|
||
|
||
|
||
|
||
static function getForm($values = [], $options = []) :array {
|
||
return [
|
||
self::getCommonFormInputs(),
|
||
[
|
||
Form::VIEW=>Form::ROW,
|
||
Form::COLS => [
|
||
[
|
||
Form::VIEW =>Form::INPUT,
|
||
Form::COL_CLASSES =>'col-12',
|
||
Form::KEY_VALUE =>self::$NAME,
|
||
Form::TYPE =>eInputType::TEXT,
|
||
Form::INPUT_OPT => [
|
||
Input::PLACEHOLDER => $c = V::get(Vars::$NAME),
|
||
Input::LABEL => $c,
|
||
],
|
||
],
|
||
]
|
||
],
|
||
self::getCommonFormSubmits($values),
|
||
];
|
||
}
|
||
|
||
static function columnInfo() : array {
|
||
return [
|
||
new C([
|
||
C::VAR_NAME =>&self::$ID,
|
||
C::TYPE =>eColumnType::INT,
|
||
C::AUTO_INCREMENT =>true,
|
||
C::PRIMARY =>true,
|
||
C::DEFAULT =>0,
|
||
C::HIDDEN =>true,
|
||
C::TH =>V::get(Vars::$ID),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$IMAGE,
|
||
C::TYPE => eColumnType::INT,
|
||
C::DEFAULT => 0,
|
||
C::TH => V::get(Vars::$IMAGE),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$NAME,
|
||
C::TYPE => eColumnType::VARCHAR,
|
||
C::LENGTH => 1023,
|
||
C::TH => V::get(Vars::$NAME),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$CURRENCY,
|
||
C::TYPE => eColumnType::TINYINT,
|
||
C::LENGTH => 3,
|
||
C::TH => V::get(Vars::$CURRENCY),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$TOTAL,
|
||
C::TYPE => eColumnType::DOUBLE,
|
||
C::TH => V::get(Vars::$TOTAL),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$START,
|
||
C::TYPE => eColumnType::DOUBLE,
|
||
C::DEFAULT => 0,
|
||
C::TH => V::get(Vars::$START),
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$POS,
|
||
C::TYPE => eColumnType::INT,
|
||
C::DEFAULT => time(),
|
||
C::HIDDEN => true,
|
||
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$ACCOUNT,
|
||
C::TYPE => eColumnType::INT,
|
||
C::LENGTH => 11,
|
||
C::TH => V::get(Vars::$ACCOUNT),
|
||
C::DEFAULT => intval(UID),
|
||
c::HIDDEN=>true,
|
||
c::FUNC_VALUE => function($v){
|
||
if($id = $v[self::$ACCOUNT]) {
|
||
return \Account::getName( \Account::getByID($id) );
|
||
} else return '-';
|
||
},
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$CREATED,
|
||
C::TYPE => eColumnType::INT,
|
||
C::LENGTH => 11,
|
||
C::TH => V::get(Vars::$CREATED),
|
||
C::DEFAULT => time(),
|
||
c::FUNC_VALUE => function($v){return self::formatDate($v[self::$CREATED]);},
|
||
c::HIDDEN=>true,
|
||
]),
|
||
new C([
|
||
C::VAR_NAME => &self::$UPDATED,
|
||
C::TYPE => eColumnType::INT,
|
||
C::DEFAULT => time(),
|
||
C::TH => V::get(Vars::$UPDATED),
|
||
c::FUNC_VALUE => function($v){return self::formatDate($v[self::$UPDATED]);},
|
||
c::HIDDEN=>true,
|
||
]),
|
||
];
|
||
}
|
||
|
||
}
|
||
new Cashbox();
|
||
|
||
|
||
///
|