Sanfona exclusiva para textos como um pequeno resumo.
Envolva o texto que você deseja resumir dentro de um elemento com classui_brief, seja em span, div, etc. (esse é o gatilho)
Pronto! Isso é suficiente. Caso queira, você pode customizar a função:
Determine o limite de caracteres
Coloque no gatilho o atributo data-num, ex: data-num="100". O padrão é 360
Determine o rótulo do botão "Leia Mais"
Coloque no gatilho o atributo data-label, ex: data-label="Continuar leitura" (Padrão: Leia Mais)
Ainda no gatilho, use o atributo data-label-active para alterar o rótulo quando ativo, ex: data-label-active="Esconder" (Padrão: -)
Para alterar a posição do gatilho para contrair o conteúdo, use data-trigger-at-the-end="true". Padrão: false.
Outra opção é desabilitar o botão para retrair o conteúdo, ou seja, ao clicar uma única vez para revelar o conteúdo, o botão não estará mais disponível.
Para isso, use o atributo data-single-click="true".
Para controlar a velocidade de abertura, use o atributo data-speed.
Indique a velocidade (em ms) ou use valores notáveis, como slow, normal (padrão) ou fast.
Também é possível alterar a tag do gatilho, muito útil para aplicar a função dentro de um link sem que esse gere conflito com o <a> em que está contido.
Para isso, use o atributo data-element e indique a tag desejada, com a, span, button, etc.
Use o atributo data-anchor="true" no gatilho para ancorar a página até ele quando clicado
Usuários avançados podem criar funções quando o resumo estiver pronto
Para isso, crie a função callready_brief()
Antes ou depois da animação do resumo, também é possível implementar uma função do tipo callbefore e callback
Para isso, crie as funções callbefore_brief(obj,objHidden) e/ou callback_brief(obj,objHidden) e implemente as ações que irão ocorrer antes ou depois da animação, respectivamente.
Onde obj é o objeto com o texto completo e objHidden é o objeto da parte oculta. Como exemplo, a função pode testar a parte oculta está visível, if(objHidden.is(":visible")){}.
Essas funções não são obrigatórias, ou seja, só serão executadas se existirem. Caso positivo, para evitar duplicidades, lembre-se de implementar as funções callready, callbefore e callback em arquivos específicos, presentes nas respectivas páginas finais, já que o seu objetivo não é genérico.