// ==UserScript== // // @name Imgbox Tweaker // @version 2.1 // @namespace https://github.com/Purfview/Imgbox-Tweaker // @description Adds custom formatted links, working Copy to clipboard buttons, menu pre-select for 1-click uploading, links centering. // @icon  // @license MIT // // @homepage https://github.com/Purfview/Imgbox-Tweaker // @supportURL https://github.com/Purfview/Imgbox-Tweaker/issues // // @compatible firefox // @compatible opera // @compatible chrome // @compatible safari // @compatible edge // // @require https://code.jquery.com/jquery-3.5.1.min.js // @require https://cdn.jsdelivr.net/gh/sizzlemctwizzle/GM_config@43fd0fe4de1166f343883511e53546e87840aeaf/gm_config.js // @require https://greasemonkey.github.io/gm4-polyfill/gm4-polyfill.js // // @include https://imgbox.com/ // @include https://imgbox.com/upload/edit/* // @include https://imgbox.com/gallery/edit/* // // @grant GM_registerMenuCommand // @grant GM.registerMenuCommand // // @run-at document-start // // @downloadURL none // ==/UserScript== /* //============================================================================== // Version History: //============================================================================== 2.1 - New feature: Works when logged in. 2.0 - Major script rewrite. Namespace change. New feature: Settings menu. New feature: Pre-select menu for 1-click uploading. New feature: After upload auto-load into 'edit' page to get Copy buttons. New feature: All Copy buttons are working. New feature: Fully working centering option. New feature: Support for classic Greasemonkey. 1.1 - Fixed: The script was breaking the upload page. 1.0 - New feature: Working Copy buttons. Added an icon for the script. 0.0.4 - Disabled centering for BBCode boxes (can be enabled with a variable below). 0.0.3 - Fixed: the script wasn't working with the current imgbox. 0.0.2 - Last version from SMz before his disappearance. */ //============================================================================== /** * Sets array elements into placeholders of a pattern. * @param {string} Base pattern. Placeholders as {%i} for the i-th replacement * array. * @param {...string[]} Replacement sources for the pattern. The first array * will set the returned array length. * @return {string[]} Replaced pattern elements. */ function createPatternedArray() { var pattern = arguments[0]; var modArray = []; for (var i = 0; i < arguments[1].length; i++) { modArray[i] = pattern; } for (var j = 1; j < arguments.length; j++) { for (var k = 0; k < modArray.length; k++) { var replacement = arguments[j][k] || ''; modArray[k] = modArray[k].split('{%' + j + '}').join(replacement); } } return modArray; } function copyInfoToClipboard(collect) { document.body.insertBefore(collect,document.body.firstChild); collect.focus(); collect.select(); const x = document.execCommand('copy'); document.body.removeChild(collect); } function startObserver() { const obscfg = { attributes: true }; const obs = new MutationObserver(preselectMenus); obs.observe($('#upload-form')[0], obscfg); } function preselectMenus(mutation, observer) { observer.disconnect(); console.log("Imgbox Tweaker: '#upload-form' mutation detected. Starting preselectMenus()."); // Content preselect let content_index; const content_val = GM_config.get('menu_content'); if (content_val === 'Family Safe Content' ) { content_index = 1; } else if (content_val === 'Adult Content') { content_index = 2; } else { content_index = 0; } $('#dropdown-content-type').find('option[selected="selected"]').removeAttr("selected"); $('#dropdown-content-type option:eq('+content_index+')').attr('selected', "selected"); $('button[data-id="dropdown-content-type"]>.filter-option').text(content_val); $('.dropdown-menu.inner.selectpicker:eq(0)').find('li').removeAttr('class'); $('.dropdown-menu.inner.selectpicker:eq(0)').find('li:eq('+content_index+')').addClass("selected"); // Thumbnail preselect let thumb_index; const thumb_val = GM_config.get('menu_thumb'); if (thumb_val.match('100x100 pixel \\(square\\)' )) { thumb_index = 0; } else if (thumb_val.match('150x150 pixel \\(square\\)' )) { thumb_index = 1; } else if (thumb_val.match('200x200 pixel \\(square\\)' )) { thumb_index = 2; } else if (thumb_val.match('250x250 pixel \\(square\\)' )) { thumb_index = 3; } else if (thumb_val.match('300x300 pixel \\(square\\)' )) { thumb_index = 4; } else if (thumb_val.match('350x350 pixel \\(square\\)' )) { thumb_index = 5; } else if (thumb_val.match('500x500 pixel \\(square\\)' )) { thumb_index = 6; } else if (thumb_val.match('800x800 pixel \\(square\\)' )) { thumb_index = 7; } else if (thumb_val.match('100x100 pixel \\(resized\\)')) { thumb_index = 8; } else if (thumb_val.match('150x150 pixel \\(resized\\)')) { thumb_index = 9; } else if (thumb_val.match('200x200 pixel \\(resized\\)')) { thumb_index = 10; } else if (thumb_val.match('250x250 pixel \\(resized\\)')) { thumb_index = 11; } else if (thumb_val.match('300x300 pixel \\(resized\\)')) { thumb_index = 12; } else if (thumb_val.match('350x350 pixel \\(resized\\)')) { thumb_index = 13; } else if (thumb_val.match('500x500 pixel \\(resized\\)')) { thumb_index = 14; } else if (thumb_val.match('800x800 pixel \\(resized\\)')) { thumb_index = 15; } $('#thumbnail-option').find('option[selected="selected"]').removeAttr("selected"); $('#thumbnail-option option:eq('+thumb_index+')').attr('selected', "selected"); $('button[data-id="thumbnail-option"]>.filter-option').text(thumb_val); $('.dropdown-menu.inner.selectpicker:eq(1)').find('li').removeAttr('class'); $('.dropdown-menu.inner.selectpicker:eq(1)').find('li:eq('+thumb_index+')').addClass("selected"); // Comments preselect let comment_index; const comment_val = GM_config.get('menu_comment'); if (comment_val === 'Enable Comments') { comment_index = 0; } else { comment_index = 1; } $('#comments-option').find('option[selected="selected"]').removeAttr("selected"); $('#comments-option option:eq('+comment_index+')').attr('selected', "selected"); $('button[data-id="comments-option"]>.filter-option').text(comment_val); $('.dropdown-menu.inner.selectpicker:eq(2)').find('li').removeAttr('class'); $('.dropdown-menu.inner.selectpicker:eq(2)').find('li:eq('+comment_index+')').addClass("selected"); // Check if logged in [Gallery preselect is not supported there] if ($('.icon-comments').length) { console.log("Imgbox Tweaker: Login detected. Skiping 'Gallery preselect'."); return; } // Gallery preselect let gallery_index; const gallery_val = GM_config.get('menu_gallery'); if (gallery_val === 'Create a New Gallery') { gallery_index = 0; } else { gallery_index = 1; } $('#gallery-option').find('option[selected="selected"]').removeAttr("selected"); $('#gallery-option option:eq('+gallery_index+')').attr('selected', "selected"); $('button[data-id="gallery-option"]>.filter-option').text(gallery_val); $('.dropdown-menu.inner.selectpicker:eq(3)').find('li').removeAttr('class'); $('.dropdown-menu.inner.selectpicker:eq(3)').find('li:eq('+gallery_index+')').addClass("selected"); if (gallery_index === 1) {$('.new-gallery-title-input-container').addClass("hidden");} } function startImboxTweaker() { // Upload menu-select page if (GM_config.get('preselect_menu')) { if ($('#upload-form').length === 1) { console.log("Imgbox Tweaker: '#upload-form' detected. Starting MutationObserver."); startObserver(); } } // Upload result page if ($('#codes-full').length === 1) { // Check if logged in [there is no Edit page and no Copy butons] let not_login = true; if ($('.icon-comments').length) { not_login = false; } // Go to "upload edit" page to see Copy buttons if (!Boolean(location.href.match('\\/edit\\/')) && not_login) { console.log("Imgbox Tweaker: Restarting into 'upload edit' page."); const edithref = $('div.text-right a').text(); window.location.replace(edithref +'?#'); return; } console.log("Imgbox Tweaker: Upload result page detected. Starting tweaks."); // Display all available outputs $('#codes-full').show().css('visibility', 'visible') .insertBefore('#codes-thumb'); $('#codes-thumb').show().css('visibility', 'visible'); // Extract direct links to full images and thumbs var links = []; $($('#code-html-full').text()).find('img').each(function() { links.push($(this).attr('src')); }); var thumbs = []; $($('#code-html-thumb').text()).find('img').each(function() { thumbs.push($(this).attr('src')); }); // Modify the existing outputs and titles, display all options $('#code-link-full') .text(links.join('\n')) .prev('div').children('span').text('Full size plain'); if(GM_config.get('centered_links')){ $('#code-html-full') .text('