meraproject/module/shop/cashbox/model.php

224 lines
7.7 KiB
PHP
Raw Normal View History

<?
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();
///