259 lines
9.1 KiB
PHP
259 lines
9.1 KiB
PHP
<?
|
|
namespace themes\merakomis\fot;
|
|
|
|
use core\db\structure\Column as C;
|
|
use core\db\structure\eColumnType;
|
|
use core\lang\structure\LangVariable as V;
|
|
use ms\ms\structure\msModuleTable;
|
|
use common\Image;
|
|
use ModuleBZ\Form\Input\ImagePicker;
|
|
use ModuleBZ\Form\Input\Switcher;
|
|
use ModuleBZ\Form\Input\Text;
|
|
use ModuleBZ\Form\Input\Textarea;
|
|
use ModuleBZ\Layout\Row;
|
|
use themes\merakomis\Fot;
|
|
use themes\merakomis\fot\budget\structure\lang as Vars;
|
|
|
|
|
|
class Budget extends msModuleTable {
|
|
static $self;
|
|
static $cache = [];
|
|
static $table_name = 'tMerakomisFotBudget';
|
|
static $controller = 'themes.merakomis.fot.budget';
|
|
|
|
static $ID = 'id';
|
|
static $YEAR = 'year';
|
|
static $MONTH = 'month';
|
|
static $MONEY = 'money'; // сколько выделили
|
|
static $FOT = 'fot'; // ЗП суммарно по всем сотрудникам
|
|
static $CHANGED = 'changed';
|
|
static $KEY = 'key';
|
|
static $PORTAL = 'portal';
|
|
static $PROFILE = 'profile';
|
|
static $ACCOUNT = 'account';
|
|
|
|
|
|
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::$KEY] = self::getKey($values);
|
|
return parent::_insert($values, $options); // TODO: Change the autogenerated stub
|
|
}
|
|
public function _updateById(int $id, array $values)
|
|
{
|
|
//$values[self::$KEY] = self::getKey($values);
|
|
//$values[self::$CHANGED] = 1;
|
|
return parent::_updateById($id, $values); // TODO: Change the autogenerated stub
|
|
}
|
|
|
|
static public function getKey($x)
|
|
{
|
|
return $x[self::$YEAR].'-'.$x[self::$MONTH];
|
|
}
|
|
|
|
public static function installUniques()
|
|
{
|
|
\DB::addUnique(self::$table_name,self::$table_name.'_unique',[self::$KEY]);
|
|
}
|
|
|
|
public static function mathByYearMonth($year,$month,$options=[]){
|
|
$x = self::get($year,$month);
|
|
self::math($x[self::$ID],$options);
|
|
}
|
|
public static function math($id,$options=[])
|
|
{
|
|
$budget = self::getById($id);
|
|
$year = $budget[self::$YEAR];
|
|
$month = $budget[self::$MONTH];
|
|
$budgetMoney = $budget[self::$MONEY]*1000000;
|
|
if(!$options['not_generate']) Fot::generate($year,$month);
|
|
$r = Fot::select($q = [
|
|
\Query::WHERE => new \Where(\Where::_and([
|
|
\Where::_operator(Fot::$YEAR,'=',$year),
|
|
\Where::_operator(Fot::$MONTH,'=',$month),
|
|
]))
|
|
]);
|
|
//echo new \Query($q);
|
|
$total = 0;
|
|
$total2 = 0;
|
|
$emps = [];
|
|
while($l = \DB::fetch($r)){
|
|
Fot::decrypt($l);
|
|
$money = cfloatval($l[Fot::$FZP]);
|
|
$emps[$l[Fot::$ID]]['money'] = $money;
|
|
$total += $money;
|
|
}
|
|
|
|
self::updateById($id,[self::$FOT=>$total]);
|
|
foreach($emps as $id=>$emp){
|
|
$k = $total ? $emp['money'] / $total : 0;
|
|
$empFot = $k * $budgetMoney;
|
|
$total2 += $empFot;
|
|
$r = Fot::updateById($id,$x = [
|
|
Fot::$K=>$k,
|
|
Fot::$FOT=>$empFot,
|
|
]);
|
|
Fot::math($id);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
static function get($year,$month){
|
|
$key = self::getKey([self::$YEAR=>$year,self::$MONTH=>$month]);
|
|
$x = self::getOneEqualByColumn(self::$KEY,$key);
|
|
if(!$x) {
|
|
$date = date($year . '-' . $month . '-01', '-1 month');
|
|
$time = strtotime($date);
|
|
$key2 = self::getKey([self::$YEAR => date('Y',$time),self::$MONTH => date('m',$time)]);
|
|
$y = self::getOneEqualByColumn(self::$KEY,$key2);
|
|
$data = [
|
|
self::$YEAR => $year,
|
|
self::$MONTH => $month,
|
|
self::$KEY => $key,
|
|
self::$MONEY => 0,
|
|
];
|
|
if($y) {
|
|
$data[self::$MONEY] = $y[self::$MONEY];
|
|
}
|
|
self::insert($data);
|
|
$x = self::getOneEqualByColumn(self::$KEY,$key);
|
|
if($y) {
|
|
self::math($x[self::$ID]);
|
|
$x = self::getOneEqualByColumn(self::$KEY,$key);
|
|
}
|
|
}
|
|
return $x;
|
|
}
|
|
|
|
|
|
|
|
static function getFormInputs(\ModuleBZ\Form &$form, array $data, $C, bool $isEdit) {
|
|
|
|
$img = null;
|
|
if($c = $C[self::$IMAGE]) $img = Image::imageResize( Image::getByID($c)[Image::$URL], 128);
|
|
|
|
$form
|
|
->addRow((new Row())
|
|
->addColumn((new ImagePicker())
|
|
->setClassAll('c-1-4')
|
|
->setName(self::$IMAGE)
|
|
->setLabel(V::get(Vars::$IMAGE))
|
|
->setUploadUrl(\Site::sectionUrl(substr(Image::UPLOAD_URL_ACCOUNT,1),true))
|
|
//->setAjaxData(['token'=>Theme::getUploadToken()])
|
|
->setSrc($img?:'')
|
|
->setValue($C[self::$IMAGE])
|
|
)
|
|
)->addRow((new Row())
|
|
->addColumn(((new Text())
|
|
->setName(self::$NAME)
|
|
->setValue($C[self::$NAME])
|
|
->setClassAll('c-50')
|
|
->setLabel($c = V::get(Vars::$NAME))
|
|
->setPlaceholder($c)
|
|
))
|
|
->addColumn(((new Text())
|
|
->setName(self::$TEXT_ID)
|
|
->setValue($C[self::$TEXT_ID])
|
|
->setClassAll('c-50')
|
|
->setLabel($c = V::get(Vars::$TEXT_ID))
|
|
->setPlaceholder($c)
|
|
))
|
|
)->addRow((new Row())
|
|
->addColumn(((new Switcher())
|
|
->setName(self::$VIS)
|
|
->setValue($C[self::$VIS])
|
|
->setClassAll('c-1-3')
|
|
->setPlaceholder($c = V::get(Vars::$VIS))
|
|
->setChecked(boolval($C[self::$VIS]))
|
|
))
|
|
)->addRow((new Row())
|
|
->addColumn(((new Textarea())
|
|
->setName(self::$TEXT)
|
|
->setValue($C[self::$TEXT])
|
|
->setClassAll('c-100')
|
|
->setLabel($c = V::get(Vars::$TEXT))
|
|
->setPlaceholder($c )
|
|
->setAutoHeight(false)
|
|
//->setIsHtmlEditor(true)
|
|
//->setTinyMCEApiKey(Theme::$TINY_MCE_KEY)
|
|
//->setTinyMCEImageUploadUrl(Theme::$TINY_MCE_IMAGE_UPLOAD_URL)
|
|
))
|
|
)
|
|
;
|
|
}
|
|
|
|
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::$YEAR,
|
|
C::TYPE => eColumnType::INT,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$MONTH,
|
|
C::TYPE => eColumnType::INT,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$KEY,
|
|
C::TYPE => eColumnType::VARCHAR,
|
|
C::LENGTH => 7,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$MONEY,
|
|
C::TYPE => eColumnType::DOUBLE,
|
|
C::LENGTH => '10,2',
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$FOT,
|
|
C::TYPE => eColumnType::DOUBLE,
|
|
C::LENGTH => '10,2',
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$CHANGED,
|
|
C::TYPE => eColumnType::TINYINT,
|
|
C::LENGTH => 1,
|
|
C::DEFAULT => 0,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$POS,
|
|
C::TYPE => eColumnType::INT,
|
|
C::DEFAULT => time(),
|
|
c::HIDDEN => true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$PORTAL,
|
|
C::TYPE => eColumnType::INT,
|
|
C::DEFAULT => intval(\Site::$portal_id),
|
|
c::HIDDEN => true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$PROFILE,
|
|
C::TYPE => eColumnType::INT,
|
|
C::DEFAULT => intval(PID),
|
|
//C::TH => V::get(Vars::$PROFILE),
|
|
c::HIDDEN => true,
|
|
]),
|
|
new C([
|
|
C::VAR_NAME => &self::$ACCOUNT,
|
|
C::TYPE => eColumnType::INT,
|
|
C::DEFAULT => intval(\Site::$owner_id),
|
|
//C::TH => V::get(Vars::$ACCOUNT),
|
|
c::HIDDEN => true,
|
|
]),
|
|
];
|
|
}
|
|
|
|
}
|
|
new Budget();
|
|
|