new \Where(\Where::_and([ \Where::_operator(self::$PROJECT,'=',$id) ])), \Query::SORT =>[self::$POS=>'ASC'], ],$isAssoc); } static function getForProjectFormatted($id){ $res = []; $a = self::getForProject($id); foreach ($a as $v){ $res[] = self::format($v); } return $res; } static function format($v){ return [ 'id' => intval($v[self::$ID]), 'title' => trim((string)$v[self::$NAME]), 'total' => floatval($v[self::$TOTAL]), 'pos' => intval($v[self::$POS]), ]; } static function remath($id){ $id = intval($id); $C = self::getByID($id); $project_id = $C[self::$PROJECT]; $properties = Property::getForProject($project_id); $values = Value::getForItem($id); $total = 0; foreach ($values as $v){ $prop = $properties[$v[Value::$PROPERTY]]; $prop_value = floatval($prop[Property::$VALUE]); $value = $v[Value::$VALUE]; switch ($prop[Property::$TYPE]){ case Property\structure\eComparePropertyType::TEXT: case Property\structure\eComparePropertyType::BOOl: $total += $prop_value*$value; break; } } Item::updateById($id,$dd = [ self::$TOTAL => $total, ]); return [ 'dd'=>$dd ]; } public static function getFormInputs(\ModuleBZ\Form &$form, array $data, $C, bool $isEdit) { $form ->addInput((new Text()) ->setLabel('Название') ->setValue($C[self::$NAME]) ->setName(self::$NAME) ) ; if(!$C){ $project_id = intval($data['project']); if($project = Project::isProfileMy($project_id)) { $form->addInput((new Hidden()) ->setValue(intval($data['project'])) ->setName(self::$PROJECT) ); } } } 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::$NAME, C::TYPE => eColumnType::VARCHAR, C::LENGTH => 1023, C::TH => V::get(Vars::$NAME), ]), new C([ C::VAR_NAME => &self::$TOTAL, C::TYPE => eColumnType::DOUBLE, C::LENGTH => '10,2', C::DEFAULT => 0, ]), new C([ C::VAR_NAME => &self::$PROJECT, C::TYPE => eColumnType::INT, ]), new C([ C::VAR_NAME => &self::$POS, C::TYPE => eColumnType::INT, C::DEFAULT => time(), ]), new C([ C::VAR_NAME => &self::$PROFILE, C::TYPE => eColumnType::INT, C::DEFAULT => intval(PID) ]), new C([ C::VAR_NAME => &self::$PORTAL, C::TYPE => eColumnType::INT, C::DEFAULT => intval(\Site::$portal_id) ]), new C([ C::VAR_NAME => &self::$ACCOUNT, C::TYPE => eColumnType::INT, C::LENGTH => 11, C::TH => V::get(Vars::$ACCOUNT), C::DEFAULT => intval(\Site::$owner_id), 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 Item();