diff --git a/data/config_standard.txt b/data/config_standard.txt index a59d86a3..bf28d427 100644 --- a/data/config_standard.txt +++ b/data/config_standard.txt @@ -358,6 +358,7 @@ "settings_drafts_log_icons": true, "settings_drafts_go_automatic_back": false, "settings_drafts_after_new_logging_view_log": false, + "settings_drafts_after_new_logging_view_log_button": true, "settings_after_new_logging_view_log": false, "settings_listing_hide_external_link_warning": false, "settings_listing_links_new_tab": false, @@ -380,5 +381,6 @@ "settings_dashboard_hide_tb_activity": false, "settings_button_sort_tbs_by_name_log_form": true, "settings_larger_content_width_log_form": true, - "settings_less_space_log_lines_log_form": true + "settings_less_space_log_lines_log_form": true, + "settings_listing_bigger_avatar_with_mouse": true } diff --git a/docu/changelog.md b/docu/changelog.md index 40c97cb6..9f3f2dad 100644 --- a/docu/changelog.md +++ b/docu/changelog.md @@ -2,6 +2,7 @@

+v0.16   v0.15.9   v0.15.8   v0.15.7   @@ -48,6 +49,75 @@ Earlier changelog   +--- +## v0.16: +   
+ +
+(13.06.2024)
+released by 2Abendsegler
+
+ --- ## v0.15.9:    
diff --git a/gc_little_helper_II.user.js b/gc_little_helper_II.user.js index a1fc5adb..c8c1cd99 100644 --- a/gc_little_helper_II.user.js +++ b/gc_little_helper_II.user.js @@ -2,7 +2,7 @@ // @name GC little helper II // @description Some little things to make life easy (on www.geocaching.com). //--> $$000 -// @version 0.15.9 +// @version 0.16 //<-- $$000 // @copyright 2010-2016 Torsten Amshove, 2016-2024 2Abendsegler, 2017-2021 Ruko2010, 2019-2024 capoaira // @author Torsten Amshove; 2Abendsegler; Ruko2010; capoaira @@ -715,6 +715,7 @@ var variablesInit = function(c) { c.settings_drafts_log_icons = getValue("settings_drafts_log_icons", true); c.settings_drafts_go_automatic_back = getValue("settings_drafts_go_automatic_back", false); c.settings_drafts_after_new_logging_view_log = getValue("settings_drafts_after_new_logging_view_log", false); + c.settings_drafts_after_new_logging_view_log_button = getValue("settings_drafts_after_new_logging_view_log_button", true); c.settings_after_new_logging_view_log = getValue("settings_after_new_logging_view_log", false); c.settings_listing_hide_external_link_warning = getValue("settings_listing_hide_external_link_warning", false); c.settings_listing_links_new_tab = getValue("settings_listing_links_new_tab", false); @@ -736,6 +737,7 @@ var variablesInit = function(c) { c.settings_button_sort_tbs_by_name_log_form = getValue("settings_button_sort_tbs_by_name_log_form", true); c.settings_larger_content_width_log_form = getValue("settings_larger_content_width_log_form", true); c.settings_less_space_log_lines_log_form = getValue("settings_less_space_log_lines_log_form", true); + c.settings_listing_bigger_avatar_with_mouse = getValue("settings_listing_bigger_avatar_with_mouse", true); tlc('START userToken'); try { @@ -846,61 +848,69 @@ var mainGSearch = function() { try { // Add links to Google Maps on Google Search Results pages. if (settings_add_links_google_maps_on_google_search) { - function setGMapsLinks() { + function setGMapsLinks(waitCount) { var searchPara = new URLSearchParams(window.location.search).get('q'); if (searchPara) { var mapsUrl = 'https://maps.google.com/maps?q=' + encodeURIComponent(searchPara); - // Examples: "fürstenlager bensheim", "bensheim auerbach". - if ($('a img#lu_map')[0]) { - if ($('a[href*="/maps/place/"] img#lu_map')[0]) return; - var link = $('img#lu_map')[0].closest('a'); - link.href = mapsUrl; - // Example: "N 49° 41.000 E 008° 37.000", an address. - } else if ($('div#lu_map')[0]) { - if ($('a div#lu_map')[0]) return; - var map = $('div#lu_map')[0]; - var link = document.createElement('a'); - link.href = mapsUrl; - map.parentNode.insertBefore(link, map); - link.appendChild(map); - // Example: "Bensheim", "Ukraine", "Rhein" + // Categorie 1: Examples: "Bensheim Auerbach", "Port Kawkas". + if ($('a g-img#lu_map')[0]) { + if (!$('a[href*="/maps?q="] #lu_map')[0]) { + var link = $('#lu_map')[0].closest('a'); + link.href = mapsUrl; + } + // Categorie 2: Example: "N 49° 41.000 E 008° 37.000", an address. + } else if ($('.lu_map_section #lu_map')[0] && $('.lu_map_section .yXg2De .yXg2De div')[0]) { + if (!$('.lu_map_section .yXg2De .yXg2De a[href*="/maps?q="] div')[0]) { + var map = $('.lu_map_section .yXg2De .yXg2De div')[0]; + var link = document.createElement('a'); + link.href = mapsUrl; + map.parentNode.insertBefore(link, map); + link.appendChild(map); + var css = ''; + css += '.yXg2De a div {cursor: pointer;}'; + appendCssStyle(css); + } + // Categorie 3: Example: "Bensheim", "Ukraine", "Rhein", "Fürstenlager Bensheim". } else if ($('div.EeWPwe')[0]) { - if ($('div.EeWPwe a[href*="/maps/place/"]')[0]) return; - var button = ''; - button += ''; - button += '
'; - button += '
'; - button += ''; - button += ''; - button += ''; - button += '
'; - button += '
Open in Maps
'; - button += '
'; - button += '
'; - $('div.EeWPwe').append(button); - // Missing CSS. - var css = ''; - css += '.ZkkK1e.ZkkK1e {line-height: normal; font-family: arial,sans-serif;}'; - css += '.ZkkK1e {-moz-box-sizing: border-box; box-sizing: border-box; border-radius: 18px; cursor: pointer; display: inline-block; height: 36px; min-width: 36px; position: relative; background: #fff; border: 1px solid #dadce0; color: #3c4043;}'; - css += '.POUQwd.WN4Zxc {padding: 7px 0 7px 11px;}'; - css += '.xlY4q, .POUQwd, .XqKfz {-moz-box-sizing: border-box; box-sizing: border-box; display: inline-block; height: 34px; vertical-align: bottom;}'; - css += '.xlY4q.VIZLse {padding-right: 11px;}'; - css += '.xlY4q {font-size: 14px; line-height: 34px; padding: 0 8px; padding-right: 8px;}'; - css += '.VDgVie {text-align: center;}'; - appendCssStyle(css); - // Example: "Nil" + if (!$('div.EeWPwe a[href*="/maps?q="]')[0]) { + var button = ''; + button += ''; + button += '
'; + button += '
'; + button += ''; + button += ''; + button += ''; + button += '
'; + button += '
Open in Maps
'; + button += '
'; + button += '
'; + $('div.EeWPwe').append(button); + // Missing CSS. + var css = ''; + css += '.ZkkK1e.ZkkK1e {line-height: normal; font-family: arial,sans-serif;}'; + css += '.ZkkK1e {-moz-box-sizing: border-box; box-sizing: border-box; border-radius: 18px; cursor: pointer; display: inline-block; height: 36px; min-width: 36px; position: relative; background: #fff; border: 1px solid #dadce0; color: #3c4043;}'; + css += '.POUQwd.WN4Zxc {padding: 7px 0 7px 11px;}'; + css += '.xlY4q, .POUQwd, .XqKfz {-moz-box-sizing: border-box; box-sizing: border-box; display: inline-block; height: 34px; vertical-align: bottom;}'; + css += '.xlY4q.VIZLse {padding-right: 11px;}'; + css += '.xlY4q {font-size: 14px; line-height: 34px; padding: 0 8px; padding-right: 8px;}'; + css += '.VDgVie {text-align: center;}'; + appendCssStyle(css); + } + // Categorie 4: Example: "Nil" } else if ($('div.V1GY4c img')[0]) { - if ($('div.V1GY4c img')[0].closest('a[href]:not([href=""]):not([href=" "])')) return; - var map = $('div.V1GY4c')[0]; - var link = document.createElement('a'); - link.href = mapsUrl; - map.parentNode.insertBefore(link, map); - link.appendChild(map); + if (!$('div.V1GY4c img')[0].closest('a[href]:not([href=""]):not([href=" "])')) { + var map = $('div.V1GY4c')[0]; + var link = document.createElement('a'); + link.href = mapsUrl; + map.parentNode.insertBefore(link, map); + link.appendChild(map); + } } } + waitCount++; if (waitCount <= 25) setTimeout(function(){setGMapsLinks(waitCount);}, 200); } - if (document.readyState === 'loading') document.addEventListener('DOMContentLoaded', setGMapsLinks); - else setGMapsLinks(); + if (document.readyState === 'loading') document.addEventListener('DOMContentLoaded', setGMapsLinks(0)); + else setGMapsLinks(0); } } catch(e) {gclh_error("mainGSearch",e);} }; @@ -1561,6 +1571,7 @@ var mainGC = function() { if (document.location.href.match(/\.com\/hide\//)) { if ($('#btnContinue')[0]) var id = "btnContinue"; else if ($('#ctl00_ContentBody_btnSaveAndPreview')[0]) var id = "ctl00_ContentBody_btnSaveAndPreview"; + else if ($('#btnSaveAndPreview')[0]) var id = "btnSaveAndPreview"; else if ($('#btnSubmit')[0]) var id = "btnSubmit"; else if ($('#btnNext')[0]) var id = "btnNext"; else if ($('#ctl00_ContentBody_btnSubmit')[0]) var id = "ctl00_ContentBody_btnSubmit"; @@ -1937,7 +1948,7 @@ var mainGC = function() { css += ".span-20 {width: " + new_width + "px;}"; } else if (is_page("logform")) { if (settings_larger_content_width_log_form) { - css += ".content-container {width: " + new_width + "px !important; max-width: unset !important;}"; + css += ".content-container, .content-container section, .content-container form {width: " + new_width + "px !important; max-width: unset !important;}"; css += ".form-container {margin-left: 0px !important; margin-right: 0px !important;}"; css += ".breadcrumbs {margin-left: 0px !important; margin-right: 0px !important; padding-left: 0px !important; padding-right: 0px !important;}"; } @@ -2031,7 +2042,7 @@ var mainGC = function() { nav_list.appendChild(sublink); } } - // Search field. + // Navigation, search field. if (settings_bookmarks_search) { var code = "function gclh_search_logs(){"; code += " var search = document.getElementById('navi_search').value.trim();"; @@ -2040,7 +2051,7 @@ var mainGC = function() { code += " else document.location.href = '/seek/nearest.aspx?navi_search='+search;"; code += "}"; injectPageScript(code, "body"); - var searchfield = "
  • "; + var searchfield = "
  • "; $(".Menu, .menu").append(searchfield); } @@ -2195,27 +2206,38 @@ var mainGC = function() { } } -// Automatic processing after logging with new or old log form. +// Automatic processing after cache logging with new or old log form. try { - // Drafts related logging with new or old log form. + // Drafts related cache logging with new or old log form. if ((is_page("cache_listing") && $('#uxViewNewLogLink')[0] && $('#uxNewLogExtraLink')[0]) || (document.location.href.match(/\.com\/seek\/log\.aspx\?PLogGuid=([a-zA-Z0-9-]*)/) && $('#ctl00_ContentBody_LogBookPanel1_lblErrorMessage .Success')[0])) { // Automatic go back to drafts page. if (settings_drafts_go_automatic_back) document.location = 'https://www.geocaching.com/account/drafts'; // Automatic go to view log page. - else if (settings_drafts_after_new_logging_view_log && $('#uxViewNewLogLink')[0]) document.location = $('#uxViewNewLogLink')[0].href + '&gclhDraft'; - // Non Drafts related logging with new log form. + else if (settings_drafts_after_new_logging_view_log && $('#uxViewNewLogLink')[0]) document.location = $('#uxViewNewLogLink')[0].href + '#gclhDraft'; + // Non Drafts related cache logging or edit log with new log form. } else if (is_page("cache_listing") && $('#uxViewNewLogLink')[0] && !$('#uxNewLogExtraLink')[0]) { // Automatic go to view log page. if (settings_after_new_logging_view_log) document.location = $('#uxViewNewLogLink')[0].href; } - // After automatic go to view log page, because of Drafts related logging with new log form. - if (document.location.href.match(/\.com\/seek\/log\.aspx\?LUID=(.*)&gclhDraft/) && $('#ctl00_ContentBody_LogBookPanel1_CoordInfoLinkControl1_uxCoordInfoLinkPanel p')[0]) { - if (!document.location.href.match(/&edit=true/) && !$('#ctl00_ContentBody_LogBookPanel1_btnCancel')[0]) { - $('#ctl00_ContentBody_LogBookPanel1_CoordInfoLinkControl1_uxCoordInfoLinkPanel')[0].style.float = 'none'; - $('#ctl00_ContentBody_LogBookPanel1_CoordInfoLinkControl1_uxCoordInfoLinkPanel p')[0].style.float = 'right'; - $('#ctl00_ContentBody_LogBookPanel1_CoordInfoLinkControl1_uxCoordInfoLinkPanel p').before('

    You have submitted your draft. Submit more drafts.

    '); - } + // After automatic go to view log page, because of Drafts related cache logging with new log form. + if (document.location.href.match(/\.com\/live\/log\/(.*)#gclhDraft/) && settings_drafts_after_new_logging_view_log && settings_drafts_after_new_logging_view_log_button) { + function buildDraftButton(waitCount) { + if ($('.masthead-controls .masthead-control.gclh_editButton')[0] && !$('.masthead-controls .masthead-control.gclh_draftButton')[0]) { + var li = $('.masthead-controls .masthead-control.gclh_editButton').clone(); + if (li && $(li).find('button')[0] && $(li).find('svg')[0] && $(li).find('span')[0]) { + li.removeClass('gclh_editButton'); + li.addClass('gclh_draftButton'); + $(li).find('button').prop('dataset').testid = ''; + $(li).find('button')[0].addEventListener('click', function(){document.location = 'https://www.geocaching.com/account/drafts';}); + $(li).find('svg')[0].remove(); + $(li).find('span')[0].innerHTML = 'Back to Drafts'; + $('.masthead-controls').append(li); + } + } + waitCount++; if (waitCount <= 50) setTimeout(function(){buildDraftButton(waitCount);}, 100); + } + buildDraftButton(0); } } catch(e) {gclh_error("Automatic processing from listing after logging",e);} @@ -3380,6 +3402,12 @@ var mainGC = function() { observer.observe(editCacheNote, {attributes: true}); } } catch(e) {gclh_error("Focus Cachenote-Textarea on Click of the Note",e);} + // Create Character Counter for Personal Cache Note. + try { + $('#cacheNoteText + div').append('
    '); + createCounterElement('personalCacheNoteCount', $('#cacheNoteText')[0], {anchor: $('#gclh_char_count')[0], initLength: $('#srOnlyCacheNote').html().length}) + } catch(e) {gclh_error("Create Character Counter for Personal Cache Note",e);} + // Append CSS. appendCssStyle(css); } @@ -4481,7 +4509,7 @@ var mainGC = function() { if (wordsArr[i].trim() != '') words++; } counterspan.innerHTML = "Loglength:" + (newLogpage ? ' ' : "
    "); - counterelement.innerHTML = '' + $(logfield).val().replace(/\n/g, "\r\n").length + '/4000 (' + words + ' words)'; + counterelement.innerHTML = '' + $(logfield).val().length + '/4000 (' + words + ' words)'; counterspan.appendChild(counterelement); if (!newLogpage) document.getElementById('litDescrCharCount').parentNode.appendChild(counterspan); else { @@ -5092,9 +5120,9 @@ var mainGC = function() { // Save last log text. function saveLastLog() {setValue("last_logtext", $('#gc-md-editor_md')[0].value);} function buildClickForSaveLastLog(waitCount) { - if ($('button.submit-button')[0] && !$('button.submit-button.gclh_build_click')[0]) { - $('button.submit-button')[0].addEventListener('click', saveLastLog, true); - $('button.submit-button').addClass('gclh_build_click'); + if ($('.post-button-container')[0] && !$('.post-button-container.gclh_save_last_log')[0]) { + $('.post-button-container').bind('click', () => { saveLastLog() }); + $('.post-button-container').addClass('gclh_save_last_log'); } waitCount++; if (waitCount <= 50) setTimeout(function(){buildClickForSaveLastLog(waitCount);}, 200); } @@ -5148,16 +5176,16 @@ var mainGC = function() { // The fields difficulty, terrain, favoritePoints and premiumFavoriteScore are available in page data ("__NEXT_DATA__", props.pageProps.loggable), // but the fields have no values. In addition, the watchers are not included there. Therefore, we cannot replace the website reading with this data. function outputAddCacheInfo(aci, waitCount) { - if ($('.loggable-header')[0] && $('.loggable-header .gc-geocache-icon')[0] && $('.loggable-header .geocache-link')[0]) { + if ($('.loggable-header')[0] && $('.loggable-header span:first')[0] && $('.loggable-header .geocache-link')[0]) { if ($('.gclh_aci_working')[0] && !$('.gclh_aci')[0]) { $('.loggable-header').append('' + aci + ''); $('.loggable-header').removeClass('gclh_aci_working'); // Set variable length of cache name. $('.loggable-header .geocache-link')[0].title = $('.loggable-header .geocache-link')[0].innerText; function setMaxwidthOfCacheName(waitCount) { - if (!$('.loggable-header')[0] || !$('.loggable-header .gc-geocache-icon')[0] || !$('.gclh_aci')[0]) return; + if (!$('.loggable-header')[0] || !$('.loggable-header span:first')[0] || !$('.gclh_aci')[0]) return; var newMaxWidth = parseInt(window.getComputedStyle($('.loggable-header')[0]).width) - 38 - - parseInt(window.getComputedStyle($('.loggable-header .gc-geocache-icon')[0]).width) + - parseInt(window.getComputedStyle($('.loggable-header span:first')[0]).width) - ($('.loggable-header .badge')[0] ? parseInt(window.getComputedStyle($('.loggable-header .badge')[0]).width) : 0) - parseInt(window.getComputedStyle($('.gclh_aci')[0]).width); var oldMaxWidth = (parseInt(window.getComputedStyle($('.loggable-header .geocache-link')[0]).maxWidth) ? parseInt(window.getComputedStyle($('.loggable-header .geocache-link')[0]).maxWidth) : 0); @@ -5227,7 +5255,7 @@ var mainGC = function() { }); } function waitForAddCacheInfo(waitCount) { - if ($('.loggable-header')[0] && $('.loggable-header .gc-geocache-icon')[0] && $('.loggable-header .geocache-link')[0] && !$('.gclh_aci_working')[0] && !$('.gclh_aci')[0]) { + if ($('.loggable-header')[0] && $('.loggable-header span:first')[0] && $('.loggable-header .geocache-link')[0] && !$('.gclh_aci_working')[0] && !$('.gclh_aci')[0]) { $('.loggable-header').addClass('gclh_aci_working'); getAddCacheInfo(); } @@ -8780,6 +8808,7 @@ var mainGC = function() { } unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); unsafeWindow.$("#cache_logs_container").addClass('gclh_override_standard_templates_done'); }, 0); @@ -8793,6 +8822,7 @@ var mainGC = function() { } function loadListener(e) { gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); } (document.getElementById("cache_logs_table2") || document.getElementById("cache_logs_table")).addEventListener('DOMNodeInserted', loadListener); @@ -8829,6 +8859,16 @@ var mainGC = function() { unsafeWindow.$(link).addClass("gclh_vup_hasIcon"); } } + // Build event for bigger avatar. + function buildEventShowBiggerAvatar() { + if (!settings_show_thumbnails || !settings_listing_bigger_avatar_with_mouse) return; + var elements = $(document.getElementById("cache_logs_table2") || document.getElementById("cache_logs_table")).find("p.logOwnerAvatar").not(".gclh_avatar_hasEvent"); + for (var i = 0; i < elements.length; i++) { + var link = elements[i]; + link.addEventListener('mouseover', showBiggerAvatar); + unsafeWindow.$(link).addClass("gclh_avatar_hasEvent"); + } + } var lastFired = 0; var global_logs = false; var global_num = 0; @@ -8867,6 +8907,7 @@ var mainGC = function() { } unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); if (isUpvoteActive) updateUpvoteEvents(logs); showFavIcons(); @@ -8918,6 +8959,7 @@ var mainGC = function() { } unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); if (isUpvoteActive) updateUpvoteEvents(logs); if (countLogs === logs.length) setMarkerDisableDynamicLogLoad(); // all logs loaded @@ -8952,7 +8994,7 @@ var mainGC = function() { setTimeout(function() { // Force direct display refresh. $(logsTab).find('tbody').children().remove(); for (var i = 0; i < logs.length; i++) { - if (logs[i] && (logs[i].LogType == log_type || (log_type == "VIP" && (in_array(logs[i].UserName, global_vips) || logs[i].UserName == vip_owner)) || (log_type === "FAV" && logs[i].LogTypeID === 2 && in_array(logs[i].AccountGuid, fav_guids)))) { + if (logs[i] && (logs[i].LogType.toLowerCase() == log_type.toLowerCase() || (logs[i].LogTypeID == 45 && log_type.toLowerCase() == 'owner attention requested') || (logs[i].LogTypeID == 7 && log_type.toLowerCase() == 'reviewer attention requested') || (log_type == "VIP" && (in_array(logs[i].UserName, global_vips) || logs[i].UserName == vip_owner)) || (log_type === "FAV" && logs[i].LogTypeID === 2 && in_array(logs[i].AccountGuid, fav_guids)))) { var newBody = unsafeWindow.$(document.createElement("TBODY")); unsafeWindow.$("#tmpl_CacheLogRow_gclh").tmpl(logs[i]).appendTo(newBody); unsafeWindow.$(document.getElementById("cache_logs_table2") || document.getElementById("cache_logs_table")).append(newBody.children()); @@ -8960,6 +9002,7 @@ var mainGC = function() { } unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); if (isUpvoteActive) updateUpvoteEvents(logs); setMarkerDisableDynamicLogLoad(); @@ -9085,6 +9128,7 @@ var mainGC = function() { unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); if (isUpvoteActive) updateUpvoteEvents(logs); setMarkerDisableDynamicLogLoad(); @@ -9243,6 +9287,7 @@ var mainGC = function() { } unsafeWindow.$('a.tb_images').fancybox({'type': 'image', 'titlePosition': 'inside'}); gclh_add_vip_icon(); + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); showFavIcons(); updateUpvoteEvents(logs); @@ -9396,6 +9441,7 @@ var mainGC = function() { gclh_build_vip_list(); gclh_add_vip_icon(); } + buildEventShowBiggerAvatar(); setLinesColorInCacheListing(); // Remove GC logs, so that the links to the log ids, e.g. from the VIPs or the Latest logs, work again. // (Apparently GS simply creates the 25 logs again when they are gone. And that in the form , there is @@ -10476,6 +10522,20 @@ var mainGC = function() { link.onmouseover = placeToolTip; link.appendChild(span); } + // Build avatar thumbnail without an explicit "load" is necessary if the mouse is just already above the small image which has to be transferred + // to a big image. + function avatarThumbnailWithoutLoad(link) { + var thumb = link.children[0]; + var img = document.createElement('img'); + img.src = thumb.src.replace(/img\.geocaching\.com\/user\/(avatar|display|square250)/, "s3.amazonaws.com/gs-geo-images"); + img.className = "gclh_max"; + img.setAttribute("style", "display: unset;"); + var span = document.createElement('span'); + span.appendChild(img); + link.className += " gclh_thumb"; + link.appendChild(span); + link.addEventListener('mouseover', function(e) {placeToolTip(e, true);}); + } function showBiggerAvatarsLink() { addButtonOverLogs(showBiggerAvatars, "gclh_show_bigger_avatars", true, "Show bigger avatars", "Bigger avatars", "Show bigger avatar images while hovering with the mouse"); } @@ -10497,6 +10557,16 @@ var mainGC = function() { }, 100); } catch(e) {gclh_error("showBiggerAvatars",e);} } + function showBiggerAvatar() { + try { + var link = $(this)[0]; + if (link && link.children[0] && link.children[0].children[0] && !link.children[0].children[1]) { + link.removeEventListener('mouseover', showBiggerAvatar); + link.children[0].children[0].setAttribute("style", "margin-bottom: 0px; height: 48px;"); + avatarThumbnailWithoutLoad(link.children[0]); + } + } catch(e) {gclh_error("showBiggerAvatar",e);} + } // Show gallery images in 2 instead of 4 cols. if (settings_show_big_gallery && (is_page("publicProfile") || document.location.href.match(/\.com\/(seek\/gallery\.aspx?|track\/gallery\.aspx?)/))) { @@ -10936,7 +11006,7 @@ var mainGC = function() { let span = document.createElement('span'); span.setAttribute('class', 'gclhOwner'); if ($('.geocache-owner-name')[0] && $('.geocache-placed-date')[0] && $('.geocache-owner')[0]) { - span.innerHTML = document.querySelector('.geocache-owner-name').innerHTML + ' ' + document.querySelector('.geocache-placed-date').innerHTML; + span.innerHTML = document.querySelector('.geocache-owner-name').innerHTML.replace(' "; - counterspan.appendChild(counterelement); - textbox.parentNode.append(counterspan); - } - createCounterElement('nameCounter', name, 50); - createCounterElement('placedByCounter', placedBy, 50); - createCounterElement('hintCounter', hint, 250); - name.addEventListener("keyup", function() {limitedField(name, document.querySelector('#nameCounter span'), 50);}, false); - name.addEventListener("change", function() {limitedField(name, document.querySelector('#nameCounter span'), 50);}, false); - placedBy.addEventListener("keyup", function() {limitedField(placedBy, document.querySelector('#placedByCounter span'), 50);}, false); - placedBy.addEventListener("change", function() {limitedField(placedBy, document.querySelector('#placedByCounter span'), 50);}, false); - hint.addEventListener("keyup", function() {limitedField(hint, document.querySelector('#hintCounter span'), 250);}, false); - hint.addEventListener("change", function() {limitedField(hint, document.querySelector('#hintCounter span'), 250);}, false); + createCounterElement('nameCounter', name); + createCounterElement('placedByCounter', placedBy); + createCounterElement('hintCounter', hint); var css = '#nameCounter, #placedByCounter, #hintCounter {text-align: right;}'; css += '#nameCounter, #placedByCounter {width: 400px;}'; appendCssStyle(css); @@ -14723,6 +14776,7 @@ var mainGC = function() { tpl = tpl.replace(/#Found-?(\d+)?#/ig, (_match, p1) => p1 ? global_founds+1 - p1 : global_founds+1).replace(/#Found_no-?(\d+)?#/ig, (_match, p1) => p1 ? global_founds - p1 : global_founds) tpl = tpl.replace(/#Me#/ig, global_activ_username).replace(/#Date#/ig, global_date).replace(/#Time#/ig, global_time).replace(/#DateTime#/ig, global_dateTime); tpl = tpl.replace(/#GCTBName#/ig, global_name).replace(/#GCTBCode#/ig, global_code).replace(/#GCTBLink#/ig, global_link); + tpl = tpl.replace(/#GCTBCodeNoBrackets#/ig, global_code.replace('(','').replace(')','')); if (trimIt) tpl = tpl.trim(); return tpl; } @@ -14918,8 +14972,8 @@ var mainGC = function() { //--> $$002 code += 'Public Profile"; html += "
    "; - html += newParameterOn3; html += checkboxy('settings_public_profile_avatar_show_thumbnail', 'Show bigger avatar image while hovering with the mouse') + show_help("This option requires \"Show thumbnails of images\".") + "
    "; - html += newParameterVersionSetzen('0.12') + newParameterOff; html += newParameterOn1; html += checkboxy('settings_public_profile_smaller_privacy_btn', 'Show smaller privacy buttons') + show_help("Replace the text and links for privacy with a clickable icon button.") + "
    "; html += newParameterVersionSetzen('0.14') + newParameterOff; @@ -16698,7 +16750,7 @@ var mainGC = function() { html += "
    Trackables
    "; html += checkboxy('settings_faster_profile_trackables', 'Load trackables faster without images') + show_help("With this option you can stop the load on the trackable pages after the necessary data are loaded. You disclaim of the lengthy load of the images of the trackables. This procedure is much faster as load all data, because every image is loaded separate and not in a bigger bundle like it is for the non image data.") + "
    "; html += "
    Gallery
    "; - var content_settings_show_thumbnails = checkboxy('settings_show_thumbnails', 'Show thumbnails of images') + show_help("With this option the images are displayed as thumbnails to have a preview. If you hover with your mouse over a thumbnail, you can see the big one.

    This works in cache and TB logs, in the cache and TB image galleries and in the public profile image gallery.

    And after pressing button \"Show bigger avatars\" in cache listing, it also works for the avatars in the displayed logs in cache listing.

    And if you activate \"Show bigger avatar image while hovering with the mouse\", it also works for avatars in public profiles.") + "  Max size of big image px
    "; + var content_settings_show_thumbnails = checkboxy('settings_show_thumbnails', 'Show thumbnails of images') + show_help("With this option the images are displayed as thumbnails to have a preview. If you hover with your mouse over a thumbnail, you can see the big one.

    This works for images in cache and TB logs, for avatars in cache logs, for images in the cache and TB image galleries and for images in the public profile image gallery.

    And after pressing button \"Show bigger avatars\" in cache listing, it also works for the avatars in the displayed logs in cache listing.

    And if you activate \"Show bigger avatar image while hovering with the mouse\" in section \"Public Profile\", it also works for the avatar in public profiles.

    And if you activate \"Show bigger avatar image while hovering with the mouse\" in section \"Listing - Logs\", it also works for the avatars in cache logs.") + "  Max size of big image px
    "; html += content_settings_show_thumbnails.replace("show_thumbnails", "show_thumbnailsX1").replace("max_size", "max_sizeX1"); html += "  " + checkboxy('settings_imgcaption_on_topX1', 'Show caption on top'); var content_geothumbs = " (Alternative
    Geothumbs" + show_help("A great alternative to the GC little helper II bigger image functionality with \"Show thumbnails of images\" and \"Show bigger images in gallery\", provides the script Geothumbs (Geocaching Thumbnails).

    The script works like GC little helper II with Firefox, Google Chrome and Opera via Tampermonkey script.

    If you use Geothumbs, you have to uncheck both GC little helper II bigger image functionality \"Show thumbnails of images\" and \"Show bigger images in gallery\".") + ")
    " + "
    "; @@ -16756,9 +16808,7 @@ var mainGC = function() { html += "
    "; html += checkboxy('settings_show_cache_type_icons_in_dashboard', 'Show cache/TB type in front of log type in Latest Activity list') + "
    "; html += checkboxy('settings_show_edit_links_for_logs', 'Show edit links for your own logs') + show_help("With this option direct edit links are shown in your own logs on your dashboard. If you choose such a link, you are immediately in edit mode in your log.") + "
    "; - html += newParameterOn3; html += checkboxy('settings_dashboard_show_logs_in_markdown', 'Show log text in Markdown as it is in cache listing') + "
    "; - html += newParameterVersionSetzen('0.12') + newParameterOff; html += newParameterOn2; html += checkboxy('settings_dashboard_hide_tb_activity', 'Hide all TB/Coin logs in the Latest Activity') + "
    "; html += newParameterVersionSetzen('0.15') + newParameterOff; @@ -16903,9 +16953,7 @@ var mainGC = function() { html += checkboxy('settings_show_vip_listX0', 'Process VIPs') + show_help(content_settings_show_vip_list + "

    You can adjust details about this feature also in the Dashboard topic.") + "
    "; html += "  " + checkboxy('settings_show_owner_vip_list', 'Show owner in VIP list') + show_help("If you enable this option, the owner is a VIP for the cache, so you can see, what happened with the cache (disable, maint, enable, ...). Then the owner is shown not only in VIP list but also in VIP logs.")+ "
    "; html += "  " + checkboxy('settings_show_reviewer_as_vip', 'Show reviewer/publisher in VIP list') + show_help("If you enable this option, the reviewer or publisher of the cache is a VIP for the cache.") + "
    "; - html += newParameterOn3; html += "  " + checkboxy('settings_show_lackey_as_vip', 'Show lackey in VIP list') + show_help("If you enable this option, lackeys which logged the cache are VIPs for the cache. Behind the logs of lackeys are primarily employees of Groundspeak who cache. In addition, administrative logs can also be performed by these lackeys. Administrative user of Groundspeak may also be flagged as lackeys. An example of the latter are the logs for archiving older events.") + "
    "; - html += newParameterVersionSetzen('0.12') + newParameterOff; html += "  " + checkboxy('settings_show_long_vip', 'Show long VIP list (one row per log)') + show_help("This is another type of displaying the VIP list. If you disable this option you get the short list, one row per VIP and the logs as icons beside the VIP. If you enable this option, there is a row for every log.") + "
    "; html += "  " + checkboxy('settings_vip_show_nofound', 'Show a list of VIPs who have not found the cache') + "
    "; html += "  " + checkboxy('settings_make_vip_lists_hideable', 'Make VIP lists in listing hideable') + show_help("With this option you can hide and show the VIP lists \"VIP-List\" and \"VIP-List not found\" in cache listing with one click.") + "
    "; @@ -16958,9 +17006,7 @@ var mainGC = function() { html += checkboxy('settings_add_search_in_logs_func', 'Add "Search in logs" feature') + "
    "; html += checkboxy('settings_show_all_logs_but', 'Show button \"Show all logs\" above the logs') + "
    "; html += checkboxy('settings_show_compact_logbook_but', 'Show button \"Show compact logs\" above the logs') + "
    "; - html += newParameterOn3; html += checkboxy('settings_show_who_gave_favorite_but', 'Show button \"Show who favorited\" above the logs') + show_help("With this option you can choose to show a button \"Show who favorited\" above the logs. Pressing this button will add a favorite icon to the logs of users who gave a favorite. Additionally, a filter for those logs will be added above the logs.

    For performance reasons this functionality must be restricted to caches with 500 favorites or less.") + "
    "; - html += newParameterVersionSetzen(0.12) + newParameterOff; html += checkboxy('settings_show_log_counter_but', 'Show button \"Show log counter\" above the logs') + "
    "; html += "  " + checkboxy('settings_show_log_counter', 'Show log counter when opening cache listing') + "
    "; html += checkboxy('settings_show_bigger_avatars_but', 'Show button \"Show bigger avatars\" above the logs') + "
    "; @@ -16984,6 +17030,9 @@ var mainGC = function() { html += "  " + checkboxy('settings_imgcaption_on_topX0', 'Show caption on top'); html += content_geothumbs; html += "    " + "Spoiler filter " + show_help("If one of these words is found in the caption of the image, there will be no real thumbnail. It is to prevent seeing spoilers. Words have to be divided by |. If the field is empty, no checking is done. Default is \"spoiler|hinweis\".") + "
    "; + html += newParameterOn3; + html += checkboxy('settings_listing_bigger_avatar_with_mouse', 'Show bigger avatar image while hovering with the mouse') + show_help("With this option you can choose if a bigger avatar image will load and shown while hovering with the mouse over the small avatar image.

    This option requires \"Show thumbnails of images\".") + "
    "; + html += newParameterVersionSetzen('0.16') + newParameterOff; html += content_settings_hide_upvotes.replace("settings_hide_upvotes", "settings_hide_upvotesX0"); html += content_settings_smaller_upvotes_icons.replace("settings_smaller_upvotes_icons", "settings_smaller_upvotes_iconsX0"); html += content_settings_no_wiggle_upvotes_click.replace("settings_no_wiggle_upvotes_click", "settings_no_wiggle_upvotes_clickX0"); @@ -16997,15 +17046,16 @@ var mainGC = function() { html += "  " + checkboxy('settings_drafts_color_visited_link', 'Color a visited link') + "
    "; html += "  " + checkboxy('settings_drafts_old_log_form', 'Use old-fashioned log form to log a draft') + show_help("If you enable this option, you always get the old log form instead of the new one to log drafts related logs.

    Please look also the parameter \"Use old-fashioned log form to log non drafts related logs\" in the \"Log\" area.") + "
    "; html += "  " + checkboxy('settings_drafts_log_icons', 'Show logtype icon instead of text') + "
    "; - var content_settings_after_sending_log = 'After sending a new log using the new log form, the listing will appear. After sending a new log using the old log form, the view log page will appear.

    '; - var content_settings_after_sending_draft_related_log1 = checkboxy('settings_drafts_go_automatic_back', 'After sending a draft related log, automatic go back to drafts') + show_help(content_settings_after_sending_log + 'If it was a draft related log, you can enable this option to automatic go back to the drafts page.') + "
    "; - var content_settings_after_sending_draft_related_log2 = checkboxy('settings_drafts_after_new_logging_view_log', 'After sending a draft related log, automatic view log') + show_help(content_settings_after_sending_log + 'If it was a draft related log, you can enable this option to automatic go to view log page.') + "
    "; + var content_settings_after_sending_draft_related_log1 = checkboxy('settings_drafts_go_automatic_back', 'After sending a draft related cache log, automatic go back to drafts') + show_help('If it was a draft related cache log, you can enable this option to automatic go back to the drafts page, instead of going to cache listing.') + "
    "; + var content_settings_after_sending_draft_related_log2 = checkboxy('settings_drafts_after_new_logging_view_log', 'After sending a draft related cache log, automatic view log') + show_help('If it was a draft related cache log, you can enable this option to automatic go to view log page, instead of going to cache listing.') + "
    "; + var content_settings_after_sending_draft_related_log2_button = "  " + checkboxy('settings_drafts_after_new_logging_view_log_button', 'Show button "Back to Drafts" on view log page') + "
    "; html += content_settings_after_sending_draft_related_log1; - html += newParameterOn3; html += content_settings_after_sending_draft_related_log2; + html += newParameterOn3; + html += content_settings_after_sending_draft_related_log2_button; + html += newParameterVersionSetzen('0.16') + newParameterOff; html += checkboxy('settings_drafts_download_show_button', 'Enable draft download feature') + show_help("With this option you can activate the draft download feature. A download button will then appear next to the upload button on the draft page.") + "
    "; html += "  " + checkboxy('settings_drafts_download_change_logdate', 'Change log dates of the drafts in download file') + show_help("With this option you can choose whether the log dates in the drafts is reduced by one second. This is necessary if you might want to upload the drafts in the download file later, after deleting the drafts on the drafts page, as uploading with the same log date is not possible.") + "
    "; - html += newParameterVersionSetzen('0.12') + newParameterOff; html += "
    "; html += "

    "+prepareHideable.replace("#id#","logging")+"

    "; @@ -17019,10 +17069,11 @@ var mainGC = function() { html += checkboxy('settings_unsaved_log_message', 'Show message in case of unsaved log') + "
    "; html += checkboxy('settings_show_add_cache_info_in_log_page', 'Show additional cache info') + show_help("If you enable this option, additional cache information such as the favorite points or the favorite percent are shown in the log form next to the cache name.

    For basic members, no data is displayed for premium member only caches.") + "
    "; html += content_settings_after_sending_draft_related_log1.replace("settings_drafts_go_automatic_back", "settings_drafts_go_automatic_backX0"); - html += newParameterOn3; html += content_settings_after_sending_draft_related_log2.replace("settings_drafts_after_new_logging_view_log", "settings_drafts_after_new_logging_view_logX0"); - html += checkboxy('settings_after_new_logging_view_log', 'After sending a non draft related log, automatic view log') + show_help(content_settings_after_sending_log + 'If it was not a draft related log, you can enable this option to automatic go to view log page.') + "
    "; - html += newParameterVersionSetzen('0.12') + newParameterOff; + html += newParameterOn3; + html += content_settings_after_sending_draft_related_log2_button.replace("settings_drafts_after_new_logging_view_log_button", "settings_drafts_after_new_logging_view_log_buttonX0"); + html += newParameterVersionSetzen('0.16') + newParameterOff; + html += checkboxy('settings_after_new_logging_view_log', 'After sending or edit a non draft related cache log, automatic view log') + show_help('If it was not a draft related cache log or it was an edit of a cache log, you can enable this option to automatic go to view log page, instead of going to cache listing.') + "
    "; var placeholderDescription = "Possible placeholders:
      #Found# : Your founds + 1 (reduce it with a minus followed by a number)
      #Found_no# : Your founds (reduce it with a minus followed by a number)
      #Me# : Your username
      #Owner# : Username of the owner
      #Date# : Actual date
      #Time# : Actual time in format hh:mm
      #DateTime# : Actual date actual time
      #GCTBName# : GC or TB name
      #GCTBLink# : GC or TB link
      #GCTBNameLink# : GC or TB name as a link
      #LogDate# : Content of field \"Date Logged\"
    (Upper and lower case is not required in the placeholders name.)"; html += newParameterOn2; html += checkboxy('settings_hide_locked_tbs_log_form', 'Hide locked trackables from trackable inventory') + show_help("A trackable can be marked as locked in the trackable listing. Locked trackables cannot be logged. With this option you can hide such trackables from trackable inventory.") + "
    "; @@ -17095,7 +17146,7 @@ var mainGC = function() { html += "

    "+prepareHideable.replace("#id#","mail")+"

    "; html += "
    "; - var placeholderDescriptionMail = "Possible placeholders in the mail and message form:
      #Found# : Your founds + 1 (reduce it with a minus followed by a number)
      #Found_no# : Your founds (reduce it with a minus followed by a number)
      #Me# : Your username
      #Receiver# : Username of the receiver
      #Date# : Actual date
      #Time# : Actual time in format hh:mm
      #DateTime# : Actual date actual time
      #GCTBName# : GC or TB name
      #GCTBCode# : GC or TB code in brackets
      #GCTBLink# : GC or TB link in brackets
    (Upper and lower case is not required in the placeholders name.)"; + var placeholderDescriptionMail = "Possible placeholders in the mail and message form:
      #Found# : Your founds + 1 (reduce it with a minus followed by a number)
      #Found_no# : Your founds (reduce it with a minus followed by a number)
      #Me# : Your username
      #Receiver# : Username of the receiver
      #Date# : Actual date
      #Time# : Actual time in format hh:mm
      #DateTime# : Actual date actual time
      #GCTBName# : GC or TB name
      #GCTBCode# : GC or TB code in brackets
      #GCTBCodeNoBrackets# : GC or TB code not in brackets
      #GCTBLink# : GC or TB link in brackets
    (Upper and lower case is not required in the placeholders name.)"; html += " " + "Template" + show_help("The template is automatically added to your mails and messages. You can also use placeholders for variables that will be replaced in the mail and in the message.") + "   ( Possible placeholders" + show_help(placeholderDescriptionMail) + ")
    "; html += " " + "
    "; html += "
    "; @@ -17106,7 +17157,7 @@ var mainGC = function() { html += " " + checkboxy('remove_navi_play', 'Play') + "
    "; html += " " + checkboxy('remove_navi_community', 'Community') + "
    "; html += " " + checkboxy('remove_navi_shop', 'Shop') + "
    "; - html += checkboxy('settings_bookmarks_search', 'Show searchfield. Default value ') + "" + show_help("If you enable this option, there will be a searchfield on the top of all GC pages. In this field you can search for GC Ids, TB Ids, tracking numbers, coordinates, ... . Also you can define a default value if you want (like GC ...).

    This option requires \"Show Linklist on top\".") + "
    "; + html += checkboxy('settings_bookmarks_search', 'Show navigation/search field. Default value ') + "" + show_help("If you enable this option, there will be a navigation/search field on the top of all GC pages. In this field you can navigate respectively search to respectively for geocaches (GC), trackables (TB), geotours (GT), bookmark lists (BM), User codes (PR), geocache logs (GL), tracking code of trackables (6 digits), coordinates, ... .

    Also you can define a default value like for example \"GC\" if you want.

    This option requires \"Show Linklist on top\".") + "
    "; html += checkboxy('settings_show_draft_indicator', 'Show draft indicator') + "
    "; html += "" + show_help("With this option your Linklist will be shown at the navigation menu as a dropdown list beside the others.") + "
    "; @@ -17604,16 +17655,24 @@ var mainGC = function() { handleRadioTopMenu(true); $('#settings_load_logs_with_gclh')[0].addEventListener("click", alert_settings_load_logs_with_gclh, false); $('#settings_drafts_go_automatic_back')[0].addEventListener("click", function() { - if ($('#settings_drafts_go_automatic_back').prop('checked')) $('#settings_drafts_after_new_logging_view_log, #settings_drafts_after_new_logging_view_logX0').prop('checked', false); + if ($('#settings_drafts_go_automatic_back').prop('checked') && $('#settings_drafts_after_new_logging_view_log').prop('checked')) { + $('#settings_drafts_after_new_logging_view_log')[0].click(); + } }, false); $('#settings_drafts_go_automatic_backX0')[0].addEventListener("click", function() { - if ($('#settings_drafts_go_automatic_backX0').prop('checked')) $('#settings_drafts_after_new_logging_view_log, #settings_drafts_after_new_logging_view_logX0').prop('checked', false); + if ($('#settings_drafts_go_automatic_backX0').prop('checked') && $('#settings_drafts_after_new_logging_view_logX0').prop('checked')) { + $('#settings_drafts_after_new_logging_view_logX0')[0].click(); + } }, false); $('#settings_drafts_after_new_logging_view_log')[0].addEventListener("click", function() { - if ($('#settings_drafts_after_new_logging_view_log').prop('checked')) $('#settings_drafts_go_automatic_back,#settings_drafts_go_automatic_backX0').prop('checked', false); + if ($('#settings_drafts_after_new_logging_view_log').prop('checked') && $('#settings_drafts_go_automatic_back').prop('checked')) { + $('#settings_drafts_go_automatic_back')[0].click(); + } }, false); $('#settings_drafts_after_new_logging_view_logX0')[0].addEventListener("click", function() { - if ($('#settings_drafts_after_new_logging_view_logX0').prop('checked')) $('#settings_drafts_go_automatic_back,#settings_drafts_go_automatic_backX0').prop('checked', false); + if ($('#settings_drafts_after_new_logging_view_logX0').prop('checked') && $('#settings_drafts_go_automatic_backX0').prop('checked')) { + $('#settings_drafts_go_automatic_backX0')[0].click(); + } }, false); $('#restore_settings_lines_color_zebra')[0].addEventListener("click", restoreField, false); $('#restore_settings_lines_color_user')[0].addEventListener("click", restoreField, false); @@ -17669,6 +17728,7 @@ var mainGC = function() { setEvForDouPara("settings_show_eventday", "click"); setEvForDouPara("settings_drafts_go_automatic_back", "click"); setEvForDouPara("settings_drafts_after_new_logging_view_log", "click"); + setEvForDouPara("settings_drafts_after_new_logging_view_log_button", "click"); // Events setzen für Parameter, die im GClh Config eine Abhängigkeit derart auslösen, dass andere Parameter aktiviert bzw. // deaktiviert werden müssen. ZB. können Mail Icons in VIP List (Parameter "settings_show_mail_in_viplist") nur aufgebaut @@ -17750,14 +17810,17 @@ var mainGC = function() { setEvForDepPara("settings_show_thumbnails", "settings_imgcaption_on_top"); setEvForDepPara("settings_show_thumbnails", "settings_spoiler_strings"); setEvForDepPara("settings_show_thumbnails", "settings_public_profile_avatar_show_thumbnail"); + setEvForDepPara("settings_show_thumbnails", "settings_listing_bigger_avatar_with_mouse"); setEvForDepPara("settings_show_thumbnailsX0", "settings_hover_image_max_size"); setEvForDepPara("settings_show_thumbnailsX0", "settings_imgcaption_on_top"); setEvForDepPara("settings_show_thumbnailsX0", "settings_spoiler_strings"); setEvForDepPara("settings_show_thumbnailsX0", "settings_public_profile_avatar_show_thumbnail"); + setEvForDepPara("settings_show_thumbnailsX0", "settings_listing_bigger_avatar_with_mouse"); setEvForDepPara("settings_show_thumbnailsX1", "settings_hover_image_max_size"); setEvForDepPara("settings_show_thumbnailsX1", "settings_imgcaption_on_top"); setEvForDepPara("settings_show_thumbnailsX1", "settings_spoiler_strings"); setEvForDepPara("settings_show_thumbnailsX1", "settings_public_profile_avatar_show_thumbnail"); + setEvForDepPara("settings_show_thumbnailsX1", "settings_listing_bigger_avatar_with_mouse"); setEvForDepPara("settings_map_overview_build", "settings_map_overview_zoom"); setEvForDepPara("settings_map_overview_build", "settings_map_overview_layer"); setEvForDepPara("settings_map_overview_build", "settings_map_overview_browse_map_icon"); @@ -17883,6 +17946,10 @@ var mainGC = function() { setEvForDepPara("settings_drafts_cache_link", "settings_drafts_cache_link_new_tab"); setEvForDepPara("settings_drafts_download_show_button", "settings_drafts_download_change_logdate"); setEvForDepPara("settings_searchmap_improve_add_to_list","settings_searchmap_improve_add_to_list_height"); + setEvForDepPara("settings_drafts_after_new_logging_view_log", "settings_drafts_after_new_logging_view_log_button"); + setEvForDepPara("settings_drafts_after_new_logging_view_log", "settings_drafts_after_new_logging_view_log_buttonX0"); + setEvForDepPara("settings_drafts_after_new_logging_view_logX0", "settings_drafts_after_new_logging_view_log_button"); + setEvForDepPara("settings_drafts_after_new_logging_view_logX0", "settings_drafts_after_new_logging_view_log_buttonX0"); // Abhängigkeiten der Linklist Parameter. for (var i = 0; i < 100; i++) { @@ -18374,6 +18441,7 @@ var mainGC = function() { 'settings_drafts_log_icons', 'settings_drafts_go_automatic_back', 'settings_drafts_after_new_logging_view_log', + 'settings_drafts_after_new_logging_view_log_button', 'settings_after_new_logging_view_log', 'settings_listing_hide_external_link_warning', 'settings_listing_links_new_tab', @@ -18394,6 +18462,7 @@ var mainGC = function() { 'settings_button_sort_tbs_by_name_log_form', 'settings_larger_content_width_log_form', 'settings_less_space_log_lines_log_form', + 'settings_listing_bigger_avatar_with_mouse', ); for (var i = 0; i < checkboxes.length; i++) { if (document.getElementById(checkboxes[i])) setValue(checkboxes[i], document.getElementById(checkboxes[i]).checked); @@ -18466,12 +18535,12 @@ var mainGC = function() { var d = "
    "; var s = ""; //--> $$001 - newParameterOn1 = d.replace("#", "06"); - newParameterOn2 = d.replace("#", "10"); - newParameterOn3 = d.replace("#", "03"); - newParameterLL1 = s.replace("#", "06"); - newParameterLL2 = s.replace("#", "10"); - newParameterLL3 = s.replace("#", "03"); + newParameterOn1 = d.replace("#", "03"); + newParameterOn2 = d.replace("#", "06"); + newParameterOn3 = d.replace("#", "10"); + newParameterLL1 = s.replace("#", "03"); + newParameterLL2 = s.replace("#", "06"); + newParameterLL3 = s.replace("#", "10"); //<-- $$001 function newParameterVersionSetzen(version) { var newParameterVers = "= maxLength) + counterelement.innerHTML = `${length}/${maxLength}`; + else counterelement.innerHTML = `${length}/${maxLength}`; + counterspan.appendChild(counterelement); + if (options.anchor) options.anchor.append(counterspan); + else textarea.parentNode.append(counterspan); + textarea.addEventListener("keyup", function() { + limitedField(textarea, $(counterelement).find('span')[0], maxLength, options.showWords); + }, false); + textarea.addEventListener("change", function() { + limitedField(textarea, $(counterelement).find('span')[0], maxLength, options.showWords); + }, false); + } + function limitedField(editor, counterelement, maxLength, showWords) { changed = true; - var length = $(editor).val().replace(/\n/g, "\r\n").length; - if (length >= limitNum) { - counterelement.innerHTML = '' + length + '/' + limitNum + ''; - } else counterelement.innerHTML = length + '/' + limitNum; + var length = $(editor).val().length; + if (length >= maxLength) + counterelement.innerHTML = `${length}/${maxLength}`; + else counterelement.innerHTML = length + '/' + maxLength; if (showWords) { var wordsArr = $(editor).val().replace(/\n/g, ' ').split(' '); var words = 0; diff --git a/images/0.16/Screen01.jpg b/images/0.16/Screen01.jpg new file mode 100644 index 00000000..0fe3a73b Binary files /dev/null and b/images/0.16/Screen01.jpg differ diff --git a/images/0.16/Screen02.jpg b/images/0.16/Screen02.jpg new file mode 100644 index 00000000..2fc565d3 Binary files /dev/null and b/images/0.16/Screen02.jpg differ diff --git a/images/0.16/Screen03.jpg b/images/0.16/Screen03.jpg new file mode 100644 index 00000000..7d832d9a Binary files /dev/null and b/images/0.16/Screen03.jpg differ diff --git a/images/0.16/Screen04.gif b/images/0.16/Screen04.gif new file mode 100644 index 00000000..7d5029a1 Binary files /dev/null and b/images/0.16/Screen04.gif differ diff --git a/images/0.16/Screen05.gif b/images/0.16/Screen05.gif new file mode 100644 index 00000000..052a92e9 Binary files /dev/null and b/images/0.16/Screen05.gif differ diff --git a/images/0.16/Screen06.jpg b/images/0.16/Screen06.jpg new file mode 100644 index 00000000..f11ff088 Binary files /dev/null and b/images/0.16/Screen06.jpg differ diff --git a/images/0.16/Screen07.jpg b/images/0.16/Screen07.jpg new file mode 100644 index 00000000..9c9a327a Binary files /dev/null and b/images/0.16/Screen07.jpg differ diff --git a/last_version.txt b/last_version.txt index bc300b99..8eac30c3 100644 --- a/last_version.txt +++ b/last_version.txt @@ -1 +1 @@ -0.15.9 +0.16