new \Where(\Where::_and([ \Where::_operator(BlocK::$TO,'=',msTo::PAGE), \Where::_operator(BlocK::$OID,'=',$page_id), \Where::_operator(BlocK::$VIS,'=',1), ])) ],true); } static function getForSectionByTextID($text_id,$section_id){ $a = self::select($q =[ \Query::TABLES=>self::$table_name, \Query::COUNT=>1, \Query::WHERE=>new \Where(\Where::_and([ \Where::_operator(self::$TO,'=',msTo::SECTION), \Where::_operator(self::$OID,'=',$section_id), \Where::_operator(self::$TEXT_ID,'=',$text_id), ])) ],true); return array_pop($a); } public static function getEditTabs($values=[]) { $id = $values[self::$ID]; return [ [ eTab::NAME=>'Блоки', eTab::TYPE=>eTabType::TABLE, eTab::CONTENT=>function($values=[]){ $id = $values[self::$ID]; $link_id = \Site::sectionUrl( 'content/page/'.$id.'/block/' ); $o = [ \ModuleTable::ROW_CLICK => eRowClick::CARD, \Query::SORT=>BlocK::$POS, \Query::WHERE=>new \Where(\Where::_and([ \Where::_operator(Block::$TO,'=',msTo::PAGE), \Where::_operator(Block::$OID,'=',$id), ]) ), \ModuleTable::SORTABLE=>true, \ModuleTable::FORM_INIT_DATA=>[ Block::$TO => msTo::PAGE, Block::$OID => $id, ], \ModuleTable::TABLE_ID => self::$table_name.'_'.Block::$table_name.'_'.$id, \ModuleTable::COLUMN_RENDER => [ Block::$TEMPLATE => [ \ModuleTable::COLUMN_RENDER_LINK_ID => $link_id, \ModuleTable::COLUMN_RENDER_LINK_CSS_CLASS => 'link', \ModuleTable::COLUMN_RENDER_LINK_MODAL => true, \ModuleTable::COLUMN_RENDER_CARD_CONTROLLER => Block::$controller, \ModuleTable::COLUMN_RENDER_CARD_FORM_METHOD => 'getSettingsForm', //ModuleTable::COLUMN_RENDER_LINK_MODAL => true, ], ] ]; return $values['justData'] ? Block::getTableData( $o ) : Block::drawTable( $o ); }, ], [ eTab::NAME => 'Редактировать', eTab::TYPE=>eTabType::FORM, eTab::CONTENT => function ($values = []) { return self::_getForm($values, static::getFormOptions($values)); }, ], [ eTab::NAME => 'SEO', eTab::TYPE=>eTabType::FORM, eTab::CONTENT => function ($values = []) { $id = $values[self::$ID]; return Seo::getFormTO(msTo::PAGE, $id); }, ], ]; } static function getForm($values = [], $options = []) :array { return [ self::getCommonFormInputs(), [ Form::VIEW =>Form::INPUT, Form::KEY_VALUE =>self::$TO, Form::TYPE =>eInputType::HIDDEN, Form::INPUT_OPT => [ Input::VALUE => msTo::SECTION, ], ], /* [ Form::VIEW =>Form::INPUT, Form::KEY_VALUE =>self::$OID, Form::TYPE =>eInputType::HIDDEN, ], /**/ [ Form::VIEW=>Form::ROW, Form::COLS => [ [ Form::VIEW =>Form::INPUT, Form::COL_CLASSES =>'c c-1-3', Form::KEY_VALUE =>self::$NAME, Form::TYPE =>eInputType::TEXT, Form::INPUT_OPT => [ Input::PLACEHOLDER => $c = V::get(Vars::$NAME), Input::LABEL => $c, ], ], [ Form::VIEW =>Form::INPUT, Form::COL_CLASSES =>'c c-1-3', Form::KEY_VALUE =>self::$TEXT_ID, Form::TYPE =>eInputType::TEXT, Form::INPUT_OPT => [ Input::PLACEHOLDER => $c = V::get(Vars::$TEXT_ID), Input::LABEL => $c, ], ], [ Form::VIEW =>Form::INPUT, Form::COL_CLASSES =>'c c-1-3', Form::KEY_VALUE =>self::$OID, Form::TYPE =>eInputType::SELECT, Form::INPUT_OPT => [ Input::PLACEHOLDER => $c = msTo::getName(msTo::SECTION), Input::LABEL => $c, Input::OPTIONS => Section::getNameList([ \Query::WHERE => new \Where(\Where::_operator(Section::$ACCOUNT,'=',UID)) ]), ], ], [ Form::VIEW =>Form::INPUT, Form::COL_CLASSES =>'c', Form::KEY_VALUE =>self::$TEXT, Form::TYPE =>eInputType::TEXTAREA, Form::INPUT_OPT => [ Input::PLACEHOLDER => $c = V::get(Vars::$TEXT), 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::$NAME, C::TYPE => eColumnType::VARCHAR, C::LENGTH => 1023, C::TH => V::get(Vars::$NAME), ]), new C([ C::VAR_NAME => &self::$TEXT_ID, C::TYPE => eColumnType::VARCHAR, C::LENGTH => 255, C::TH => V::get(Vars::$TEXT_ID), ]), new C([ C::VAR_NAME => &self::$TEXT, C::TYPE => eColumnType::LONGTEXT, C::TH => V::get(Vars::$TEXT), C::HIDDEN => true, ]), new C([ C::VAR_NAME => &self::$TO, C::TYPE => eColumnType::INT, C::HIDDEN => true, ]), new C([ C::VAR_NAME => &self::$OID, C::TYPE => eColumnType::INT, 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 Page(); ///