Server IP : 23.254.227.96 / Your IP : 216.73.216.7 Web Server : Apache/2.4.62 (Unix) OpenSSL/1.1.1k System : Linux hwsrv-1277026.hostwindsdns.com 4.18.0-477.13.1.el8_8.x86_64 #1 SMP Tue May 30 14:53:41 EDT 2023 x86_64 User : viralblo ( 1001) PHP Version : 8.1.31 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/local/cwpsrv/var/services/roundcube/public_html/plugins/hide_blockquote/ |
Upload File : |
/** * Hide Blockquotes plugin script * * @licstart The following is the entire license notice for the * JavaScript code in this file. * * Copyright (c) The Roundcube Dev Team * * The JavaScript code in this page is free software: you can redistribute it * and/or modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, either version 3 of * the License, or (at your option) any later version. * * @licend The above is the entire license notice * for the JavaScript code in this file. */ if (window.rcmail) rcmail.addEventListener('init', function() { hide_blockquote(); }); function hide_blockquote() { var limit = rcmail.env.blockquote_limit; if (limit <= 0) return; $('div.message-part div.pre > blockquote', $('#messagebody')).each(function() { var res, text, div, link, q = $(this); // Add new-line character before each blockquote // This fixes counting lines of text, it also prevents // from merging lines from different quoting level $('blockquote').before(document.createTextNode("\n")); text = $.trim(q.text()); res = text.split(/\n/); if (res.length <= limit) { // there can be also a block with very long wrapped line // assume line height = 15px if (q.height() <= limit * 15) return; } div = $('<blockquote class="blockquote-header">') .css({'white-space': 'nowrap', overflow: 'hidden', position: 'relative'}) .text(res[0]); link = $('<span class="blockquote-link"></span>') .css({position: 'absolute', 'z-Index': 2}) .text(rcmail.get_label('hide_blockquote.show')) .data('parent', div) .click(function() { var t = $(this), parent = t.data('parent'), visible = parent.is(':visible'); t.text(rcmail.get_label(visible ? 'hide' : 'show', 'hide_blockquote')) .detach().appendTo(visible ? q : parent).toggleClass('collapsed'); parent[visible ? 'hide' : 'show'](); q[visible ? 'show' : 'hide'](); }); link.appendTo(div); // Modify blockquote q.hide().css({position: 'relative'}).before(div); }); }