newbie 1,722 11/03/2014 05:33 AM Последние темы, это встроенный хук в форумный движок.Открыть файл admin/applications/forums/sources/classes/forums/class_forums.phpВ методе hooks_recentTopics найти foreach( $this->forum_by_id as $forumID => $forumData )Ниже добавить if (in_array($forumID, explode(',', $this->memberData['ri_sforums']))) { continue; } А вот хук последние сообщения $exclude = $this->settings['sos_latestdiscussions_forumsexclude'];заменить на $exclude = IPSText::cleanPermString($this->settings['sos_latestdiscussions_forumsexclude'] . ',' . $this->memberData['ri_sforums']); 1 Share this post Link to post
Trotor 27 11/03/2014 01:34 PM В методе hooks_recentTopics найтиТолько со скобкой: foreach( $this->forum_by_id as $forumID => $forumData ) {После скобки добавлять.Работает. заменить наРаботает. Вот только слегка увеличилась нагрузка на главную страницу, можно ли как то оптимизировать мускул запрос? if ( $this->settings['sos_latestdiscussions_distinct'] == 1 ) { ipsRegistry::DB()->allow_sub_select=1; $query = $this->DB->query( "SELECT t.tid, t.title, t.posts, t.views, t.forum_id, p.topic_id, p.author_id, p.pid, p.author_id, p.post_date, p.topic_id, m.member_group_id, members_seo_name, m.members_display_name FROM ".$this->settings['sql_tbl_prefix']."topics t LEFT JOIN ".$this->settings['sql_tbl_prefix']."posts p ON ( t.tid=p.topic_id ) inner JOIN (select topic_id, max(post_date) as datapost from ".$this->settings['sql_tbl_prefix']."posts group by topic_id) as ultimopost on ultimopost.datapost = p.post_date LEFT JOIN ".$this->settings['sql_tbl_prefix']."members m ON ( m.member_id=p.author_id ) WHERE p.queued = 0 and t.approved = 1 and t.posts > 0 and t.forum_id in(".$ids.")".$excludeforums." ORDER BY p.post_date desc LIMIT ".$this->settings['sos_latestdiscussions_number'] ); $outer = $this->DB->execute( $query ); } else { $this->DB->build( array ( 'select' => 'p.author_id, p.topic_id, p.pid, p.author_id, p.post_date, p.topic_id', 'from' => array('posts' => 'p'), 'add_join' => array( 0 => array('select' => 't.tid, t.title, t.posts, t.views, t.forum_id, title_seo', 'from' => array('topics' => 't'), 'where' => 't.tid=p.topic_id', 'type' => 'left'), 1 => array('select' => 'm.member_group_id, members_seo_name, m.members_display_name', 'from' => array( 'members' => 'm' ), 'where' => 'm.member_id=p.author_id', 'type' => 'left') ), 'where' => 'p.queued = 0 and t.approved = 1 and t.posts > 0 and t.forum_id in('.$ids.')'.$excludeforums, 'order' => 'p.post_date desc', 'limit' => array( 0, $this->settings['sos_latestdiscussions_number'] ) ) ); Например выборка на кол-во просмотров (t.views) и кол-во ответов (t.posts) мне не нужна, можно ли их удалить? Share this post Link to post
Trotor 27 02/09/2024 07:38 PM 01.11.2014 в 10:06, newbie сказал: ri_sforums_3.1.4_upd.xml 9.25 kB · 6 скачиваний Пробовал "подпилять" хук - что бы он скрывал не из результатов поиска, а именно сами разделы и подразделы. Не получилось Share this post Link to post