[AddOn] Ocultar/Mostrar categorias no estilo Invision!

3 participantes

Ir para baixo

[AddOn] Ocultar/Mostrar categorias no estilo Invision! Empty [AddOn] Ocultar/Mostrar categorias no estilo Invision!

Mensagem por JScript 10.05.15 18:36


   Ocultar e mostrar categorias como Invision
Que tal ter o mesmo sistema de mostrar e ocultar as categorias igual ao da versão Invision? Eu sei que existem vários códigos com o mesmo propósito deste, mas nunca vi um que funcionasse em todas as versões, menos a Invision pois esse sistema já existe!
   Abaixo o código para ser adicionado somente no "Índice".
Características e aplicação
Criador: @JScript
Versão: 1.0
Versão: Todas as versões
Dificuldade de instalação: Fácil
Resultado da aplicação
O resultado da aplicação será:
[AddOn] Ocultar/Mostrar categorias no estilo Invision! RhaBMjv
Local de instalação
Para fazer a instalação, acesse Painel de Controle ->> Módulos >> HTML e Javascript >> Gestão das páginas Javascript >> Criar um novo Javascript >> Investimento >> No índice >>
   
Código:

        /***
        * Application: toggle Category
        * Description: Show/hide categories!
        * Version: 0.02632015-jq1.9.1
        *        RC1 (Release candidate 1!) - Invision
        * Author: JScript - 2015/03/26 - based on Invision.js
        * This work is free. You can redistribute it and/or modify it
        * under the terms of the WTFPL, Version 2
        */
        $(function() {
          var Autor = "JScript <jscriptbrasil at live dot com>, based on Invision.js";
          style = document.createElement("style"),
              //Versions: |phpBB2----------------------------------------|  |phpBB3-------------|    |PunBB-----------------|  |Invision already have it!|
              oCat = $('#content-container .three-col td:eq(1) .forumline, #main-content .forabg, #main-content .main-head, '),
              oThis = null,
              oTemp = null,
              sEval = '';

          style.type = "text/css";
          style.innerHTML =
              '.contract, .expand {' +
              '  background: url("http://2img.net/i/fa/invision/exp_minus.gif") no-repeat scroll 50% 50% rgba(0, 0, 0, 0);' +
              '  cursor: pointer;' +
              '  float: right;' +
              '  margin-top: 3px;' +
              '}' +
              '.expand {' +
              '  background: url("http://2img.net/i/fa/invision/exp_plus.gif") no-repeat scroll 50% 50% rgba(0, 0, 0, 0);' +
              '}';
          document.getElementsByTagName("head")[0].appendChild(style);

          switch (oCat[0].className) {
              case 'forumline': //phpBB2
                sEval = "oTemp = oThis.find('tr').first();oTemp.addClass('title-bar');" +
                    "oTemp.find('th:last').append('<div onclick=\"toggleCategory(\\'c' + i + '\\');\" id=\"bc' + i + '\" class=\"contract\" style=\"margin-top: -15px;\">&nbsp;&nbsp;&nbsp;</div>');" +
                    "oThis.find('tr').not('.title-bar').addClass('c' + i);";
                break;
              case 'forabg': //phpBB3
                sEval = "oThis.find('ul.topiclist:first dl.icon').append('<div onclick=\"toggleCategory(\\'c' + i + '\\');\" id=\"bc' + i + '\" class=\"contract\">&nbsp;&nbsp;&nbsp;</div>');" +
                    "oThis.find('ul.topiclist.forums').attr('id', 'c' + i);";
                break;
              case 'main-head': //PunBB
                sEval = "oThis.find('h2').append('<div onclick=\"toggleCategory(\\'c' + i + '\\');\" id=\"bc' + i + '\" class=\"contract\">&nbsp;&nbsp;&nbsp;</div>');" +
                    "oThis.next().attr('id', 'c' + i);";
                break;
          }
          for (var i = 0, len = oCat.length; i < len; i++) {
              oThis = $(oCat[i]);
              eval(sEval);
          }

          initCategories();
        });
        // by invision.js
        function initCategories() {
          var id;
          cookies = document.cookie.split('; ');
          for (var i = 0; i < cookies.length; i++) {
              if (cookies[i].charAt(0) == '_') {
                cookie = cookies[i].split('=');
                if (cookie[1] == '1') {
                    id = cookie[0].substring(1);
                    if (document.getElementById(id)) {
                      toggleCategory(id)
                    }
                }
              }
          }
        }
        // by invision.js, modified by JScript
        function toggleCategory(id) {
          var obj = document.getElementById(id);
          var button = document.getElementById('b' + id);
          if (obj) {
              var toggle = obj.style.display == 'none';
              obj.style.display = toggle ? '' : 'none';
          } else {
              var elems = document.getElementsByClassName(id);
              for (var i = 0, len = elems.length; i < len; i++) {
                var toggle = elems[i].style.display == 'none';
                elems[i].style.display = toggle ? '' : 'none';
              }
          }
          button.className = toggle ? 'contract' : 'expand';
          my_setcookie('_' + id, toggle ? '' : '1', true);
          return false
        }
    
   
JScript
JScript
Super Membro

Membro desde : 15/03/2013
Mensagens : 1449
Pontos : 1901

http://jscript.forumeiros.com/

Ir para o topo Ir para baixo

[AddOn] Ocultar/Mostrar categorias no estilo Invision! Empty Re: [AddOn] Ocultar/Mostrar categorias no estilo Invision!

Mensagem por Lineshooter 23.12.15 3:11

Perfeito! Só a visibilidade não ficou muito boa por causa do meu theme, fora isso, muito útil. Usando no Marvel-RPG.


Última edição por Lineshooter em 27.12.16 1:07, editado 1 vez(es)
Lineshooter
Lineshooter
**

Membro desde : 08/03/2014
Mensagens : 69
Pontos : 106

http://marvelrpguniverse.forumeiros.com https://www.facebook.com/rohhvm https://twitter.com/@ohserover

Ir para o topo Ir para baixo

[AddOn] Ocultar/Mostrar categorias no estilo Invision! Empty Re: [AddOn] Ocultar/Mostrar categorias no estilo Invision!

Mensagem por Grizzly 12.12.16 20:45

Havia instalado este JavaScript em meu fórum e ele funcionou muito bem. O problema é que, como consequência para seu funcionamento, o JavaScript basicamente ocultava alguns botões normalmente visíveis em caixas de texto para novos tópicos e respostas rápidas (como aqueles de smileys, mudar de fonte, negrito, itálico, justificado, coloração e etc), como nos prints à seguir:

Novo Tópico: https://i.imgur.com/QnkBvl0.png
Resposta Rápida: https://i.imgur.com/L08S1x7.png

Não sei se é porque meu fórum é phpBB3, se é algo particular do meu fórum em si ou não, mas encontrei este erro e resolvi vir aqui avisar Muito feliz
Grizzly
Grizzly
Novo Membro

Membro desde : 20/06/2015
Mensagens : 25
Pontos : 34

https://arcanarpg.forumeiros.com/

Ir para o topo Ir para baixo

Ir para o topo

- Tópicos semelhantes

 
Permissões neste sub-fórum
Não podes responder a tópicos