/* This file is part of the Calibre-Web (https://github.com/janeczku/calibre-web) * Copyright (C) 2018-2019 hexeth * * This program 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. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ // Move advanced search to side-menu $( 'a[href*="advanced"]' ).parent().insertAfter( '#nav_new' ); $( 'body' ).addClass('blur'); $( 'body.stat' ).addClass( 'stats' ); $( 'body.config' ).addClass( 'admin'); $( 'body.uiconfig' ).addClass( 'admin'); $( 'body.advsearch' ).addClass( 'advanced_search' ); $( 'body.newuser' ).addClass( 'admin' ); $( 'body.mailset' ).addClass( 'admin' ); // Back button curHref = window.location.href.split('/'); prevHref = document.referrer.split('/'); $( '.navbar-form.navbar-left' ) .before( '
' ); if ( history.length === 1 || curHref[0] + curHref[1] + curHref[2] != prevHref[0] + prevHref[1] + prevHref[2] || $( 'body.root' )>length > 0 ) { $( '.plexBack' ).addClass( 'noBack' ); } //Weird missing a after pressing back from edit. setTimeout(function() { if ( $( '.plexBack a').length < 1 ) { $( '.plexBack' ).append(''); } },10); // Home button $( '.plexBack' ).before( '
' ); $( 'a.navbar-brand' ).clone().appendTo( '.home-btn' ).empty().removeClass('navbar-brand'); ///////////////////////////////// // Start of Book Details Work // /////////////////////////////// // Wrap book description in div container if ( $( 'body.book' ).length > 0 ) { description = $( '.comments' ); bookInfo = $( ".author" ).nextUntil("#decription"); $("#decription").detach(); $( '.comments' ).detach(); $( bookInfo ).wrapAll( '
' ); // $( 'h3:contains("Description:")' ).after( '
' ); $( '.languages' ).appendTo( '.bookinfo' ); $('.hr').detach(); if ( $( '.identifiers ').length > 0 ) { console.log(".identifiers length " + $( '.identifiers ').length ); $( '.identifiers' ).before( '
' ); } else { if ( $( '.bookinfo > p:first-child' ).length > 0 ) { console.log(".bookinfo > p:first-child length " + $( '.bookinfo > p' ).length ); $( '.bookinfo > p:first-child' ).first().after( '
' ); } else{ if ( $( '.bookinfo a[href*="/series/"]' ).length > 0 ) { console.log( 'series text found; placing hr below series' ); $( '.bookinfo a[href*="/series/"]' ).parent().after( '
' ); } else { console.log("prepending hr div to top of .bookinfo"); $( '.bookinfo' ).prepend( '
' ); } } } $( '.rating' ).insertBefore( '.hr' ); $( '#remove-from-shelves' ).insertAfter( '.hr' ); $( description ).appendTo('.bookinfo') /* if book description is not in html format, Remove extra line breaks Remove blank lines/unnecessary spaces, split by line break to array Push array into .description div. If there is still a wall of text, find sentences and split wall into groups of three sentence paragraphs. If the book format is in html format, Keep html, but strip away inline styles and empty elements */ // If text is sitting in div as text node if ( $('.comments:has(p)' ).length === 0 ) { newdesc = description.text() .replace(/^(?=\n)$|^\s*|\s*$|\n\n+/gm,"").split(/\n/); $('.comments' ).empty(); $.each(newdesc, function(i, val) { $( 'div.comments' ).append( '

' + newdesc[i] + '

' ); }); $( '.comments' ).fadeIn(100); } //If still a wall of text create 3 sentence paragraphs. if( $( '.comments p' ).length === 1 ) { if ( description.context != undefined ) { newdesc = description.text() .replace(/^(?=\n)$|^\s*|\s*$|\n\n+/gm,"").split(/\n/); } else { newdesc = description.text(); } doc = nlp ( newdesc.toString() ); sentences = doc.map((m)=> m.out( 'text' )); sentences[0] = sentences[0].replace(",",""); $( '.comments p' ).remove(); let size = 3; let sentenceChunks = []; for (var i=0; i'; }); $( 'div.comments' ).append( output ); } else { $.each(description, function(i, val) { // $( description[i].outerHTML ).appendTo( '.comments' ); $( 'div.comments :empty' ).remove(); $( 'div.comments ').attr( 'style', '' ); }); $( 'div.comments' ).fadeIn( 100 ); } // Sexy blurred backgrounds cover = $( '.cover img' ).attr( 'src' ); $( '#loader + .container-fluid' ) .prepend( '
' ); // Fix-up book detail headings publisher = $( '.publishers p span' ).text().split( ':' ); $( '.publishers p span' ).remove(); $.each(publisher, function(i, val) { $( '.publishers' ).append( '' + publisher[i] + '' ); }); $( '.publishers span:nth-child(3)' ).text(function() { return $(this).text().replace(/^\s+|^\t+|\t+|\s+$/g, ""); }); // Fix-up book custom colums headings // real_custom_column = $( '.real_custom_columns' ).text().split( ':' ); real_custom_column = $( '.real_custom_columns' ); // $( '.real_custom_columns' ).remove(); $.each(real_custom_column, function(i, val) { var split = $(this).text().split( ':' ); real_cc_key = split.shift(); real_cc_value = split.join(':'); $( this ).text(""); if (real_cc_value != "") { $( this ).append( '' + real_cc_key + '' + real_cc_value + '' ); } }); //$( '.real_custom_columns:nth-child(3)' ).text(function() { //return $(this).text().replace(/^\s+|^\t+|\t+|\s+$/g, ""); //}); published = $( '.publishing-date p' ) .text().split(': '); $( '.publishing-date p' ).remove(); $.each(published, function(i, val) { $( '.publishing-date' ).append( '' + published[i] + '' ); }); languages = $( '.languages p span' ).text().split( ': ' ); $( '.languages p span' ).remove(); $.each(languages, function(i, val) { $( '.languages' ).append( '' + languages[i] + '' ); }); $( '.book-meta h2:first' ).clone() .prependTo( '.book-meta > .btn-toolbar:first' ); // If only one download type exists still put the items into a drop-drown list. downloads = $( 'a[id^=btnGroupDrop]' ).get(); if ( $( downloads ).length === 1 ) { $( '' ).insertBefore( downloads[downloads.length-1] ); $( downloads ).detach(); $.each(downloads, function(i, val) { $( '
  • ' + downloads[i].outerHTML + '
  • ' ).appendTo( '.leramslist' ); }); $( '.leramslist' ).find( 'span' ).remove(); $( '.leramslist a' ).removeClass( 'btn btn-primary' ).removeAttr( 'role' ); } // Add classes to buttons $( '#sendbtn' ).parent().addClass( 'sendBtn' ); $( '[id*=btnGroupDrop]' ).parent().addClass( 'downloadBtn' ); $( 'read-in-browser' ).parent().addClass( 'readBtn' ); $( '.downloadBtn button:first' ).addClass( 'download-text' ); // Move all options in book details page to the same group $( '[aria-label*="Delete book"]' ) .prependTo( '[aria-label^="Download, send"]' ) .children().removeClass( 'btn-sm' ); $( '.custom_columns' ) .addClass(' btn-group' ) .attr('role', 'group' ) .removeClass( 'custom_columns' ) .prependTo( '[aria-label^="Download, send"]' ); $( '#have_read_cb' ) .after( '' ); $( '#shelf-actions' ).prependTo( '[aria-label^="Download, send"]' ); // Move dropdown lists higher in dom, replace bootstrap toggle with own toggle. $( 'ul[aria-labelledby="read-in-browser"]' ).insertBefore( '.blur-wrapper' ).addClass('readinbrowser-drop'); $( 'ul[aria-labelledby="send-to-kindle"]' ).insertBefore( '.blur-wrapper' ).addClass('sendtokindle-drop'); $( '.leramslist' ).insertBefore( '.blur-wrapper' ); $( 'ul[aria-labelledby="btnGroupDrop1"]' ).insertBefore( '.blur-wrapper' ).addClass('leramslist'); $( '#add-to-shelves' ).insertBefore( '.blur-wrapper' ); $( '#read-in-browser' ).click( function() { $( '.readinbrowser-drop' ).toggle(); }); $('.downloadBtn' ).click( function() { $( '.leramslist' ).toggle(); }); $('#sendbtn2' ).click( function() { $( '.sendtokindle-drop' ).toggle(); }); $('div[aria-label="Add to shelves"]' ).click( function() { $( '#add-to-shelves' ).toggle(); }); // Fix formatting error on book detail languages if ( !$( '.book-meta > .bookinfo > .languages > span:last-of-type' ).text().startsWith(" ") ) { $( '.book-meta > .bookinfo > .languages > span:last-of-type' ).prepend(" "); } //Work to reposition dropdowns. Does not currently solve for //screen resizing function dropdownToggle() { topPos = $( '.book-meta > .btn-toolbar:first' ).offset().top if ( $( '#read-in-browser' ).length > 0 ) { position = $( '#read-in-browser' ).offset().left if ( position + $( '.readinbrowser-drop' ).width() > $( window ).width() ) { positionOff = position + $( '.readinbrowser-drop' ).width() - $( window ).width(); ribPosition = position - positionOff - 5 $( '.readinbrowser-drop' ).attr("style", "left: " + ribPosition + "px !important; right: auto; top: " + topPos + "px"); } else { $( '.readinbrowser-drop' ).attr("style", "left: " + position + "px !important; right: auto; top: " + topPos + "px"); } } if ( $( '#sendbtn2' ).length > 0 ) { position = $( '#sendbtn2' ).offset().left if ( position + $( '.sendtokindle-drop' ).width() > $( window ).width() ) { positionOff = position + $( '.sendtokindle-drop' ).width() - $( window ).width(); ribPosition = position - positionOff - 5 $( '.sendtokindle-drop' ).attr("style", "left: " + ribPosition + "px !important; right: auto; top: " + topPos + "px"); } else { $( '.sendtokindle-drop' ).attr("style", "left: " + position + "px !important; right: auto; top: " + topPos + "px"); } } if ( $( '.downloadBtn' ).length > 0 ) { position = $( '#btnGroupDrop1' ).offset().left if ( position + $( '.leramslist' ).width() > $( window ).width() ) { positionOff = position + $( '.leramslist' ).width() - $( window ).width(); dlPosition = position - positionOff - 5 $( '.leramslist' ).attr("style", "left: " + dlPosition + "px !important; right: auto; top: " + topPos + "px"); } else { $( '.leramslist' ).attr("style", "left: " + position + "px !important; right: auto; top: " + topPos + "px"); } } if ( $( 'div[aria-label="Add to shelves"]' ).length > 0 ) { position = $( 'div[aria-label="Add to shelves"]' ).offset().left if ( position + $( '#add-to-shelves' ).width() > $( window ).width() ) { positionOff = position + $( '#add-to-shelves' ).width() - $( window ).width(); adsPosition = position - positionOff - 5 $( '#add-to-shelves' ).attr("style", "left: " + adsPosition + "px !important; right: auto; top: " + topPos + "px"); } else { $( '#add-to-shelves' ).attr("style", "left: " + position + "px !important; right: auto; top: " + topPos + "px"); } } } dropdownToggle(); $( window ).on( 'resize', function() { dropdownToggle(); }); // Clone book rating for mobile view. $( '.book-meta > .bookinfo > .rating' ).clone().insertBefore( '.book-meta > .description' ).addClass('rating-mobile'); } /////////////////////////////// // End of Book Details Work // ///////////////////////////// ///////////////////////////////// // Start of Global Work // /////////////////////////////// // Hide dropdown and collapse menus on click-off $(document).mouseup(function (e) { var container = new Array(); container.push($('ul[aria-labelledby="read-in-browser"]')); container.push($('.sendtokindle-drop')); container.push($('.leramslist')); container.push($('#add-to-shelves')); container.push($('.navbar-collapse.collapse.in')); $.each(container, function(key, value) { if (!$(value).is(e.target) // if the target of the click isn't the container... && $(value).has(e.target).length === 0) // ... nor a descendant of the container { if ( $(value).hasClass('dropdown-menu') ) { $(value).hide(); } else { if ( $(value).hasClass('collapse') ) { $(value).collapse('toggle'); } } } }); }); // Split path name to array and remove blanks url = window.location.pathname // Move create shelf $( '#nav_createshelf' ).prependTo( '.your-shelves' ); // Create drop-down for profile and move elements to it $( '#main-nav' ) .prepend( '' ); $( '#top_user' ).parent().addClass( 'dropdown' ).appendTo( '.profileDropli' ); $( '#nav_about' ).addClass( 'dropdown' ).appendTo( '.profileDropli' ); $( '#register' ).parent().addClass( 'dropdown' ).appendTo( '.profileDropli' ); $( '#logout' ).parent().addClass( 'dropdown' ).appendTo( '.profileDropli' ); // Remove the modals except from some areas where they are needed bodyClass = $( 'body' ).attr( 'class' ).split(' '); modalWanted = ['admin', 'editbook', 'config', 'uiconfig']; if ( $.inArray( bodyClass[0], modalWanted) != -1 ) { } else { $(' a:not(.dropdown-toggle) ') .removeAttr( 'data-toggle', 'data-target', 'data-remote' ); } // Add classes to global buttons $( '#top_tasks' ).parent().addClass( 'top_tasks' ); $( '#top_admin' ).parent().addClass( 'top_admin' ); $( '#form-upload' ).parent().addClass( 'form-upload' ); // Search button work $( 'input#query' ).focus(function() { $( 'form[role="search"]' ).addClass( 'search-focus' ); }); $( 'input#query' ).focusout(function() { setTimeout(function() { $( 'form[role="search"]' ).removeClass( 'search-focus' ); }, 100); }); // Check if dropdown goes out of viewport and add class $(document).on('click','.dropdown-toggle',function() { // Add .offscreen if part of container not visible $('.dropdown-menu:visible').filter(function(){ return $(this).visible() === false; }).each(function(){ $(this).addClass('offscreen'); }); }); // Fade out content on page unload // delegate all clicks on "a" tag (links) /*$(document).on("click", "a:not(.btn-toolbar a, a[href*='shelf/remove'], .identifiers a, .bookinfo , .btn-group > a, #add-to-shelves a, #book-list a, .stat.blur a )", function () { // get the href attribute var newUrl = $(this).attr("href"); // veryfy if the new url exists or is a hash if (!newUrl || newUrl[0] === "#") { // set that hash location.hash = newUrl; return; } now, fadeout the html (whole page) $( '.blur-wrapper' ).fadeOut(250); $(".row-fluid .col-sm-10").fadeOut(500,function () { // when the animation is complete, set the new location location = newUrl; }); // prevent the default browser behavior. return false; });*/ // Collapse long text into read-more $( 'div.comments' ).readmore( { collapsedHeight: 134, heightMargin: 45, speed: 300, moreLink: 'READ MORE', // ToDo: make translateable lessLink: 'READ LESS', // ToDo: make translateable }); ///////////////////////////////// // End of Global Work // /////////////////////////////// // Author Page Background Blur if ( $( 'body.author' ).length >0 ) { cover = $( '.author-bio img' ).attr( 'src' ); $( '#loader + .container-fluid' ) .prepend( '
    ' ); $( '.blur-wrapper' ).prepend( '' ); // Place undefined cover images inside container if ( $( '.bg-blur[src="undefined"]' ).length > 0 ) { $( '.bg-blur' ).before( '
    ' ); $( 'img.bg-blur' ).appendTo( '.undefined-img' ); } } // Ereader Page - add class to iframe body on ereader page after it loads. backurl = '../../book/' + url[2] $( 'body.epub #title-controls' ) .append('
    ') $( 'body.stat .col-sm-10 p:first' ).insertAfter( '#libs' ); // Check if link is external and force _blank attribute $(function(){ // document ready $( 'a' ).filter(function () { return this.hostname && this.hostname !== location.hostname; }).each(function () { $(this).addClass("external").attr( 'target', '_blank' ); }); }); // Check if lists are empty and add class to buttons if ( $.trim( $('#add-to-shelves').html() ).length === 0 ) { $( '#add-to-shelf' ).addClass( 'empty-ul' ); } shelfLength = $('#add-to-shelves li').length emptyLength = 0 $('#add-to-shelves').on('click','li a',function(){ console.log('#remove-from-shelves change registered' ); emptyLength++ setTimeout(function() { if ( emptyLength >= shelfLength ) { console.log('list is empty; adding empty-ul class' ); $( '#add-to-shelf' ).addClass( 'empty-ul' ); } else { console.log('list is not empty; removing empty-ul class' ); $( '#add-to-shelf' ).removeClass( 'empty-ul' ); } },100); }); if ( $.trim( $( 'ul[aria-labelledby="read-in-browser"] li' ).html() ).length === 0 ) { $('#read-in-browser').addClass('empty-ul'); } // Shelf Buttons and Tooltips if ( $( 'body.shelf' ).length > 0 ) { $( 'div[data-target="#DeleteShelfDialog"]' ) .before( '
    ' ) .appendTo( '.shelf-btn-group' ) .addClass( 'delete-shelf-btn' ); $( 'a[href*="edit"]' ) .appendTo( '.shelf-btn-group' ) .addClass( 'edit-shelf-btn' ); $( 'a[href*="order"]' ) .appendTo( '.shelf-btn-group' ) .addClass( 'order-shelf-btn' ); $( '.delete-shelf-btn' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '.delete-shelf-btn' ).text(), // 'Delete Shelf' 'data-placement': 'bottom' }) .addClass('delete-btn-tooltip'); $( '.edit-shelf-btn' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '.edit-shelf-btn' ).text(), // 'Edit Shelf' 'data-placement': 'bottom' }) .addClass('edit-btn-tooltip'); $( '.order-shelf-btn' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '.order-shelf-btn' ).text(), //'Reorder Shelf' 'data-placement': 'bottom' }) .addClass('order-btn-tooltip'); } // Rest of Tooltips $( '.home-btn > a' ).attr({ 'data-toggle': 'tooltip', 'title': $(document.body).attr('data-text'), // Home 'data-placement': 'bottom' }) .addClass('home-btn-tooltip'); $( '.plexBack > a' ).attr({ 'data-toggle': 'tooltip', 'title': $(document.body).attr('data-textback'), // Back 'data-placement': 'bottom' }) .addClass('back-btn-tooltip'); $( '#top_tasks' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#top_tasks' ).text(), // 'Tasks' 'data-placement': 'bottom', 'data-viewport': '#main-nav' }) .addClass('tasks-btn-tooltip'); $( '#top_admin' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#top_admin' ).attr('data-text'), // Settings 'data-placement': 'bottom', 'data-viewport': '#main-nav' }) .addClass('admin-btn-tooltip'); $( '.profileDrop' ).attr({ 'title': $( '#top_user' ).attr('data-text'), //Account 'data-placement': 'bottom', 'data-toggle-two': 'tooltip', 'data-viewport': '#main-nav' }) .addClass('send-btn-tooltip dropdown'); $( '#btn-upload' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#btn-upload' ).parent().text() , // 'Upload' 'data-placement': 'bottom', 'data-viewport': '#main-nav' }) .addClass('upload-btn-tooltip'); $( '#add-to-shelf' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '#add-to-shelf' ).text() , // 'Add to Shelf' 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('addtoshelf-btn-tooltip'); $( '#have_read_cb' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#have_read_cb').attr('data-unchecked'), 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('readunread-btn-tooltip'); $( '#have_read_cb:checked' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#have_read_cb').attr('data-checked'), 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('readunread-btn-tooltip'); $( 'button#delete' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( 'button#delete' ).text(), //'Delete' 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('delete-book-btn-tooltip'); $( '#have_read_cb' ).click(function() { if ( $( '#have_read_cb:checked' ).length > 0 ) { $( this ).attr('data-original-title', $('#have_read_cb').attr('data-checked')); } else { $( this).attr('data-original-title', $('#have_read_cb').attr('data-unchecked')); } }); $( '.btn-group[aria-label="Edit/Delete book"] a' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#edit_book' ).text(), // 'Edit' 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('edit-btn-tooltip'); $( '#sendbtn' ).attr({ 'data-toggle': 'tooltip', 'title': $( '#sendbtn' ).attr('data-text'), 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('send-btn-tooltip'); $( '#sendbtn2' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '#sendbtn2' ).text(), // 'Send to Kindle', 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }) .addClass('send-btn-tooltip'); $( '#read-in-browser' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '#read-in-browser' ).text(), 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar'}) .addClass('send-btn-tooltip'); $( '#btnGroupDrop1' ).attr({ 'data-toggle-two': 'tooltip', 'title': $( '#btnGroupDrop1' ).text(), 'data-placement': 'bottom', 'data-viewport': '.btn-toolbar' }); if ( $( 'body.epub').length === 0 ) { $(document).ready(function(){ $('[data-toggle="tooltip"]').tooltip({container: 'body', trigger: 'hover'}); $('[data-toggle-two="tooltip"]').tooltip({container: 'body', trigger: 'hover'}); $( '#btn-upload' ).attr('title', " "); }); $( '[data-toggle-two="tooltip"]' ).click(function(){ $('[data-toggle-two="tooltip"]').tooltip('hide'); }); $( '[data-toggle="tooltip"]' ).click(function(){ $('[data-toggle="tooltip"]').tooltip('hide'); }); } $( '#read-in-browser a' ).attr('target',""); if ( $( '.edit-shelf-btn').length > 1 ) { $( '.edit-shelf-btn:first').remove(); } if ( $( '.order-shelf-btn').length > 1 ) { $( '.order-shelf-btn:first').remove(); } $( '#top_user > span.hidden-sm' ).clone().insertBefore( '.profileDropli' ); $( '.navbar-collapse.collapse.in').before(''); // Get rid of leading white space recentlyAdded = $( '#nav_new a:contains("Recently")' ).text().trim(); $('#nav_new a:contains("Recently")').contents().filter(function() { return this.nodeType == 3 }).each(function(){ this.textContent = this.textContent.replace(' Recently Added',recentlyAdded); }); // Change shelf textValue shelfText = $( '.shelf .discover h2:first' ).text().replace(':',' —').replace(/\'/g,''); $( '.shelf .discover h2:first' ).text(shelfText); shelfText = $( '.shelforder .col-sm-10 .col-sm-6.col-lg-6.col-xs-6 h2:first' ).text().replace(':',' —').replace(/\'/g,''); $( '.shelforder .col-sm-10 .col-sm-6.col-lg-6.col-xs-6 h2:first' ).text(shelfText); function mobileSupport() { if ( $( window ).width() <= 768 ) { //Move menu to collapse $( '.row-fluid > .col-sm-2:first' ).appendTo( '.navbar-collapse.collapse:first'); if ( $( '.sidebar-backdrop' ).length < 1 ) { $( '.navbar-collapse.collapse:first' ).after( '' ); } } else { //Move menu out of collapse $( '.col-sm-2:first' ).insertBefore( '.col-sm-10:first'); $( '.sidebar-backdrop' ).remove(); } } // LayerCake plug if ( $(' body.stat p').length > 0 ) { $(' body.stat p').append(" and layer.Cake"); str = $(' body.stat p').html().replace(".",""); $(' body.stat p').html(str); } // Collect delete buttons in editbook to single dropdown $( '.editbook .text-center.more-stuff' ).prepend( '' ); deleteButtons = $( '.editbook .text-center.more-stuff a' ).removeClass('btn btn-danger' ).attr( 'type', '').get(); $( deleteButtons ).detach(); $( '.editbook .text-center.more-stuff h4' ).remove(); $.each(deleteButtons, function(i, val) { $( '
  • ' + deleteButtons[i].outerHTML + '
  • ' ).appendTo( '.delete-dropdown' ); }); // Turn off bootstrap animations $(function() { $.support.transition = false; }) mobileSupport(); // Only call function once resize is complete //var id; $( window ).on('resize',function() { // clearTimeout(id); // id = setTimeout(mobileSupport, 500); mobileSupport(); });