new \Where(\Where::_and([ \Where::_operator(Property::$GROUP, '=', $id) ])) ]); while ($l = \DB::fetch($r)) { Property::removeById($l[Property::$ID]); } } else { $r = Property::update(new \Where(\Where::_and([ \Where::_operator(Property::$GROUP, '=', $id) ])),[ Property::$GROUP=>'0', ] ); } } static function getForProject($id,$isAssoc = true){ $id = intval($id); return self::select([ \Query::WHERE => new \Where(\Where::_and([ \Where::_operator(self::$PROJECT,'=',$id), ])), ],$isAssoc); } static function getZeroGroupFormatted(){ return self::format([ self::$ID => 0, self::$POS => -1, self::$NAME => 'Без группы', self::$IS_OPEN => true, ]); } static function getForProjectFormatted($id){ $res = []; $res[] = self::getZeroGroupFormatted(); $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]), 'pos' => intval($v[self::$POS]), 'is_open' => boolval($v[self::$IS_OPEN]), ]; } static function getNameListForProject($id){ $id = intval($id); $zero = self::getZeroGroupFormatted(); $res[0] = $zero['title']; $a = self::getNameList([ \Query::WHERE => new \Where(\Where::_and([ \Where::_operator(self::$PROJECT,'=',$id) ])) ]); foreach ($a as $k=>$v){ $res[$k] = $v; } return $res; } 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::$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::$IS_OPEN, C::TYPE => eColumnType::TINYINT, C::DEFAULT => 1, ]), 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 Group(); ///