Перейти к публикации
View in the app

A better way to browse. Learn more.

Дизайн и модификация Invision Community

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Toggle subforums for IPB 3.2 - 3.4

Опубликовано:

Мод позволяет сворачивать блоки со списком подфорумов. Сделан по просьбе @justme.

 

В начало шаблона forumIndexTemplate, группа шаблонов "Forum View", добавляем скрипт:

<script type="text/javascript">
var isEnabled = !Prototype.Browser.IE6;
var toggleCookieName = 'subforumsToggle';
var toggleRun = false;

if (isEnabled) {
	document.observe("dom:loaded", toggleInitialize);
}

function toggleSubforums(obj) {
	if (!isEnabled || toggleRun) {
		return false;
	}

	var wrapper = obj.up('.category_block').down('.table_wrap');
	var catblock = obj.up('.category_block');

	Effect.toggle( wrapper, 'blind', {
		duration: 0.4,
		beforeStart: function() {
			toggleRun = true;
		},
		afterFinish: function() {
			toggleRun = false;
			if ( catblock.hasClassName('collapsed') ) {
				catblock.removeClassName('collapsed');
				toggleSetOpenBlocks(obj.id, false);
			} else {
				catblock.addClassName('collapsed');
				toggleSetOpenBlocks(obj.id, true);
			}
		}
	} );
}

function toggleGetOpenBlocks() {
       var cookies = ipb.Cookie.get(toggleCookieName);
       if (cookies) {
           return cookies.split(',');
       }

       return [];
   }

   function toggleSetOpenBlocks(id, isClose) {
       var openBlocks = toggleGetOpenBlocks();
       if (isClose) {
           openBlocks.push(id);
       } else {
           openBlocks = openBlocks.uniq().without(id);
       }

       ipb.Cookie.set(toggleCookieName, openBlocks.join(','), 1);
   }

function toggleInitialize() {
	$$('.category_block').each(function(block) {
		var id = block.down('.toggle').id;
	} );

	toggleGetOpenBlocks().each( function(id) {
           if ( $(id) ) {
			var block = $(id).up('.category_block');
		}
           if (block) {
			block.addClassName('collapsed');
			block.down('.table_wrap').hide();
           }
       } );
   }
</script>

Далее ищем код:

		<h3 class='maintitle'>{$this->lang->words['sub_forum_title']}</h3>

Заменяем на:

		<h3 class='maintitle'>
		{$this->lang->words['sub_forum_title']}
		<a id="subforum_{$forum_data['id']}" class='toggle right' href='#'  title="{parse expression="sprintf( $this->lang->words['toggle_cat'], $this->lang->words['sub_forum_title'] )"}" onclick="toggleSubforums(this);"></a>
	</h3>

Сохраняем шаблон и собственно всё.

Рекомендованные сообщения

Опубликовано:

perfect thanks

  • 2 года спустя...
Опубликовано:

У меня почему-то не заработал мод... Сделал по инструкции, эффекта нет, ничего не поменялось. Должна была кнопка сворачивания появиться?

Опубликовано:

А есть для 3.4 какой-нибудь другой хук, позволяющий сворачивать подфорумы?

Создайте аккаунт или войдите в него для комментирования

Сейчас на странице 0

  • Нет пользователей, просматривающих эту страницу.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.