您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Bookmark, share your favourite places
当前为
// ==UserScript== // @name WME Bookmarks // @description Bookmark, share your favourite places // @namespace https://gf.qytechs.cn/fr/scripts/4515-wme-bookmarks // @version 1.00.6 // @icon  // @match *://*.waze.com/*editor* // @exclude *://*.waze.com/user/editor* // @connect limageenboite.fr // @grant GM_addElement // @grant GM_xmlhttpRequest // @author Sebiseba // @copyright Sebiseba 2014-2023 // @require https://gf.qytechs.cn/scripts/24851-wazewrap/code/WazeWrap.js // ==/UserScript== /* global W, WazeWrap, $, I18n, OpenLayers, require */ /* jshint -W097 */ 'use strict'; // Thanks // All beta testers // Bellhouse for German translation /******** BOOKMARKS ***********/ const BKM_UPDATE_NOTES = `<b>NEW:</b><br> <b>FIXES:</b><br> - Auto change Server (usa/intl)<br><br>`; async function onWazeWrapReady() { var BKMversion = GM_info.script.version, timer, histoNavTimer, link={}, bookmarks_Layer=[], countries=[], countriesS=[], count = 0, debug = 1; // Script variables var lang, text1, text2, text3, tset; // Language variables var BKMusername, BKMcountryActive, BKMEditHandle, BKMmapSearch; // DOM variables var _oldP='', _newP='', _prev=[], _next=[], _cur='', _stopUpdPos=false; // Prev/Next variables // ************* // ** ICONS ** // ************* var di = 'data:image/png;base64,'; var iconAddLinkMap = di + 'iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAO4SURBVHjarJVbTBx1FMZ/MzvsbheXQEthy02DNPVlpUpKmgj2sgaykkrbUGolJqaYlIcaE9OGtighGtN6SV80xhgftGkffFAiTcEaaIwmNlqKdgtJoaQsl3Ip2AuwLOzuzPFhBhVlKS3+k8n/zMw53/edL/M/AytdL4qbCsmhVDQAdsmC1+qKCXTeeOxx+nFxHAQalf+XQBGMrFTwP8shdvE+CJTLCgnmbSiTFJwUBnphPASb8jlMBYfZZ+X55SHA59U9LxuUffJj5ZciaSdE8Il4G0SeqhOhSD5ARAFQHqqDUim0pdBYU0XGuSEIDgDjwCXI88E6FX46z0kCHFqcYIfA2TjcZbLRlcHPr5SzqikIQ0EgDNwCgkB/BG+lnelh6LtObfwOyuQoIXSEERRGmKEDF3s9G/nEvxWagzA2CkxZ4KOAgJYCsZ5JVq99hNvXh5awqELk1d0wK0SvdBMZHSOUlc7qZ7agne6Au7eBSWDMuuZAyQIJTII7qZjA+SBrnpT4BH7xr0rlbEUltow1kJ0Ed8LwXhtM37PA55VPAZnAkAFOtZxflCZKBL5X4nTwgkCTAltlr93DmWI/togDIhG4FYK+a8BNS/kUkAPKoCEyrR5nM29yE+GCCX3/r8gvfpuT5i07YTxmdjE8CMZF4B6QCspEBJnUfqDPtu3f5UscNJ+5tSgteg8nLn4LbmAuDOockA44wRYBuSu/02fbRu5/LV+CoA0Ah+Oruny6j+SGmWz/hqhHB6cKig2e2Ax630QXHsd2AG4oskwCU72mnTpWW1v59kefbcA1MZyktl8OXT1j8KgdEgwgCnhSe3EQjjcW1EVtoQ1V/Xx/Tc3L7+6pRG1uBs1hR/7omsGp7u9qnIrlrYUEQLFRwA3ctDzAUNC0U8cOHhS51CFSVy/yXOmM5OUFAvBSJgDr5qpI79Xzq0WcPpkiecSzDNgcACUh4XRdfb3oVztNcF/JtKxf3zkCmzIXpHulnOSAOAtmBXt79n3AC6z948IDB0Q6O0WOHDWVm+AkL7CwyPK7QHbg7u0mbSJtWdZ4vb3XBgdFGt4xwXNzrwT+Vu5bmFy07Fn/unnilE9PtraKtLaJUVI6I9nZv/aAL2tR8Adfe56urpbpgQGRqiqZhQ8b/vlXXAmyBijp6a/tNgwSi4svf9ff/9YX0PIbeLwQ04EYYIAWg1jUHMp6BMJzZkwMdN2KDYiKFf+lTnG5vk5KTExxj49vv2MeH08c1TGrUBcIG9ZDMe/n4+iCij8HAJTXkX9j47cVAAAAAElFTkSuQmCC'; // ********************* // ** HELPER FUNCTION ** // ********************* function getId(node) { return document.getElementById(node); } function getElementsByClassName(classname, node) { node || (node = document.getElementsByTagName('body') [0]); for (var a = [], re = new RegExp('\\b' + classname + '\\b'), els = node.getElementsByTagName('*'), i = 0, j = els.length; i < j; i++) { re.test(els[i].className) && a.push(els[i]); } return a; } function getLink(pl) { var a=pl.split('?'), b=a[1].split('&'); link.MP="0" link.UR="0" link.MC="0"; for (var i = 0; b[i]; i++) { var e = b[i].split('='); switch(e[0]){ case 'env': link.env = e[1]; break; case "lat": link.lat = e[1]; break; case 'lon': link.lon = e[1]; break; case 'zoomLevel': link.zoom = e[1]; break; case "layers": link.layers = e[1]; break; // old format case "s": link.layers = e[1]; break; // new format case 'mapProblem': link.MP = e[1]; break; case 'mapUpdateRequest': link.UR = e[1]; break; case 'mapComments': link.MC = e[1]; break; case 'segments': link.segments = e[1]; break; case 'nodes': link.nodes = e[1]; break; case 'venues': link.venues = e[1]; break; default: break; } } //Object.keys(link).sort(); } function getName() { var name, topCity = W.model.topCityId; if (topCity == null) { name = lang[16]; } else { name = W.model.cities.getObjectById(topCity).attributes.name; if (name === undefined) { name = lang[16]; } else { name = W.model.cities.getObjectById(topCity).attributes.name; } } return name; } function isJsonString(str) { try { JSON.parse(str); } catch (e) { return false; } return true; } function pad(str) { str = str.toString(); return str.length < 2 ? pad('0' + str, 2) : str; } function toTimestamp(remDate,remTime){ var d = remDate.split("-"); var t = remTime.split(":"); var datum = new Date(d[0], d[1]-1, d[2], t[0], t[1]).getTime(); return datum; } function checkReminder() { var toSave=[], a = JSON.parse(localStorage.WMEBookmarks); for (var p in a) { if(!a.hasOwnProperty(p)) continue; //Redo Bookmark var bNew={}; bNew.country=a[p].country; bNew.name=a[p].name; bNew.perma=a[p].perma; bNew.comm=a[p].comm; bNew.share=a[p].share; bNew.reminder=a[p].reminder; if (a[p].reminder != null && a[p].reminder != "" && a[p].reminder < Date.now()) { if (debug) { console.log('WME Bookmarks: Check Reminder', a[p].reminder); } bNew.reminder=null; WazeWrap.Alerts.info("WME Bookmarks", a[p].name+"\n"+a[p].comm, true, false); if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: UPDATE', BKMusername, bNew); } BKMupdateBookmarks('UPDATE',BKMusername, bNew, ''); } } //Store Bookmark toSave.push(bNew); } localStorage.setItem('WMEBookmarks', JSON.stringify(toSave)); } // **************** // ** MAIN HTML ** // **************** var waitforzoom = 1 function BKMinit() { if (W.model.getTopCountry() === null) { //Create content if (waitforzoom == 1) { waitforzoom = 0; var zoom = document.createElement('section'); zoom.id = 'bookmarks-zoom'; var content = '<div style="float:left;margin-left:5px;color:red;text-align: center;"><b><u>Zoom in to start WME Bookmarks</u></b></div>'; zoom.innerHTML = content; zoom.id = 'sidepanel-bookmarks-zoom'; zoom.className = 'sidepanel-bookmarks-zoom'; tab.appendChild(zoom); } setTimeout(BKMinit, 500); return; } else if (waitforzoom == 0) { document.querySelector("#sidepanel-bookmarks-zoom > div").style.display = 'none'; } BKMusername = W.loginManager.user.userName; BKMcountryActive = W.model.getTopCountry().name; BKMEditHandle = document.querySelector("#primary-toolbar") BKMmapSearch = getElementsByClassName('search-query', getId('search')) [0]; // Verify localStorages if ('undefined' === typeof localStorage.WMEBookmarks || !isJsonString(localStorage.WMEBookmarks)) { localStorage.setItem('WMEBookmarks', '[]'); } if ('undefined' === typeof localStorage.WMEBookmarksShared || !isJsonString(localStorage.WMEBookmarksShared)) { localStorage.setItem('WMEBookmarksShared', '[]'); } if ('undefined' === typeof localStorage.WMEHistoric || !isJsonString(localStorage.WMEHistoric)) { localStorage.setItem('WMEHistoric', '[]'); } if ('undefined' === typeof localStorage.WMECopyPastePOI || !isJsonString(localStorage.WMECopyPastePOI)) { localStorage.setItem('WMECopyPastePOI', '[]'); } if ('undefined' === typeof localStorage.WMEBookmarksSettings || !isJsonString(localStorage.WMEBookmarksSettings)) { localStorage.setItem('WMEBookmarksSettings', '{"version":'+null+',"zoom":true,"layers":true,"layersPaste":true,"server":false,"synchro":true,"backup":"ins","lclic":false,"lcopy":false}'); } if ('undefined' === typeof localStorage.WMEPrevNext || !isJsonString(localStorage.WMEPrevNext)) { localStorage.setItem('WMEPrevNext', '{"prev":[],"next":[]}'); } BMKcheckStorage(); // Translation var BKMLang = I18n.locale; if (BKMLang == 'fr') { lang = new Array('Favoris', 'Partage des amis', 'Partage ', 'Historique', 'Sauvegarde / Restauration', 'Synchroniser', 'Nom', 'Copier / Restaurer POI', 'Valider', 'Annuler', 'Ajouter', 'Supprimer', 'Partager', 'Relocaliser', 'Commentaire', 'Changer', 'Sans Nom', 'Chercher une adresse, un lieu, ID ou permalien', 'C\'est parti !', 'Erreur', 'Réussi !', 'Stop', 'Paramètres', 'Pseudos', 'Rappel'); text1 = ' Copiez ces données dans un fichier TXT pour les conserver.<br/>Collez vos données pour les restaurer.'; text2 = ' Écrivez les pseudos avec qui vous souhaitez partager le favoris. Le séparateur se mettra automatiquement.'; text3 = ' Lorsque vous êtes synchronisé avec le serveur, le script envoie des données à celui-ci.<br>Les données sont: Pseudo, coordonnées, pays, nom du favoris, commentaires et pseudo des partages.<br>Effacer les données serveur du script supprime toutes traces de votre profil.'; tset = new Array('Appliquer le zoom', 'Appliquer les calques (depuis les favoris)', 'Changement auto de serveur (usa/intl)', 'Synchroniser avec le serveur du script', 'Effacer les données locales', 'Effacer les données serveur du script', 'Tri : Favoris le plus récent en haut','Appliquer les calques (depuis la recherche)','Effacer l\'historique','Nouveau','Ajouter','Coloriser le dernier lien visité','Activer le copier/restaurer des POI','Activer l\'historique de navigation','Sélectionner les objets de l\'historique'); } else if (BKMLang == 'de') { lang = new Array('Favoriten', 'Von Freunden geteilt', 'Teilen ', 'Verlauf', 'Sichern / Wiederherstellen', 'Synchronisieren', 'Name', 'POI kopieren / wiederherstellen', 'Abschicken', 'Abbrechen', 'Hinzufügen', 'Löschen', 'Teilen', 'Ort aktualisieren', 'Kommentar', 'Ändern', '(ohne Namen)', 'Adresse, Ort, ID oder Permalink suchen', 'Auf geht\'s!', 'Fehler', 'Erfolgreich!', 'Stop', 'Einstellungen', 'Usernamen','Erinnern'); text1 = ' Daten zur Sicherung in eine TXT-Datei sichern.<br/>Zur Wiederherstellung Daten hier einfügen.'; text2 = ' Usernamen des Users eintragen, mit dem du den Favoriten teilen willst. Trennzeichen werden automatisch eingefügt.'; text3 = ' Beim Synchronisieren mit dem Server werden folgende Daten übermittelt:<br>Username, Koordinaten, Land, Name des Favoriten, Kommentare und Usernamen, mit denen geteilt wurde.<br>Server-Daten löschen entfernt alle deiner Spuren auf dem Server.'; tset = new Array('Zoomstufe sichern', 'Ebenen sichern (da favoriten)', 'Server automatisch wechseln (US/ROW)', 'Mit Server synchronisieren', 'Lokale Daten löschen', 'Server-Daten löschen', 'Sortieren : Letzte Favoriten oben', 'Ebenen sichern (da suchleiste)','Verlauf löschen','Neue','Hinzufügen','Markiere den zuletzt besuchten Link','Aktivieren Sie Kopieren / Wiederherstellen POI','Browserverlauf aktivieren','Objektauswahl aus dem Verlauf zulassen'); } else { lang = new Array('Bookmarks', 'Friends\'s Sharing', 'Sharing ', 'Historic', 'Backup / Restore', 'Synchronization', 'Name', 'Copy / Restore POI', 'Submit', 'Cancel', 'Add', 'Delete', 'Share', 'Relocate', 'Comment', 'Change', 'Unnamed', 'Search for an address, place, ID or permalink', 'Let\'s Go !', 'Error', 'Success !', 'Stop', 'Settings', 'Nicknames','Reminder'); text1 = ' Copy data into a TXT file to preserve them.<br/>Paste your data to restore them.'; text2 = ' Write the nick you want to share the bookmark. The separator will be inserted automatically'; text3 = ' When you are synchronized with the server, the script sends data to it <br>Data is: Nickname, coordinates, country, name of bookmarks, comments and nicknames shares <br> Clear script data server deletes all traces of your profile.'; tset = new Array('Apply Zoom', 'Apply Layers (from bookmarks)', 'Auto change Server (usa/intl)', 'Synchro with script server', 'Clear local storage data', 'Clear script server data', 'Sort : Bookmark more recent on top', 'Apply Layers (from searchbar)','Clear historic','New','Add','Highlight last visited link','Enable copying / restoring POIs','Activate browsing history','Allow objects selection from history'); } // Then running WazeWrap.Interface.ShowScriptUpdate(GM_info.script.name, BKMversion, BKM_UPDATE_NOTES, 'https://gf.qytechs.cn/scripts/4515-wme-bookmarks/', 'https://www.waze.com/forum/viewtopic.php?t=106910'); enhancedSearch(); BKMtableCountries(); BKMcss(); checkPOI(); checkReminder(); W.map.events.register('moveend', W.map, mapLoaded); W.model.actionManager.events.register("afterclearactions", null, enhancedSearch); window.setInterval(checkPermaLink, 1000); window.setInterval(checkReminder, 60000); function enhancedSearch(){ setTimeout(function () { BKMmapSearch = getElementsByClassName('search-query', getId('search')) [0]; if (typeof (BKMmapSearch) === 'undefined') { if (debug) { console.info('WME Bookmarks - BKMmapSearch : NOK'); } setTimeout(enhancedSearch, 500); return; } BKMmapSearch.placeholder = lang[17]; BKMmapSearch.removeEventListener('paste', BKMPastePerma, false); BKMmapSearch.addEventListener('paste', BKMPastePerma, false); }, 100); } } function BKMtableCountries() { if (localStorage.WMEBookmarks) { var a = JSON.parse(localStorage.WMEBookmarks); for (var p in a) { if(!a.hasOwnProperty(p)) continue; var pays = a[p].country; if (pays && pays.length > 0) { if (countries.indexOf(pays) == - 1) { countries.push(pays); } } } if (debug) { console.log('WME Bookmarks : Mains Countries listed', countries); } select(countries, 'selectCountry'); } if (localStorage.WMEBookmarksShared) { var b = JSON.parse(localStorage.WMEBookmarksShared); for (p in b) { if(!b.hasOwnProperty(p)) continue; pays = b[p].country; if (pays && pays.length > 0) { if (countriesS.indexOf(pays) == - 1) { countriesS.push(pays); } } } if (debug) { console.log('WME Bookmarks : Shared Countries listed', countriesS); } select(countriesS, 'selectCountryS'); } } function BKMcss() { var Scss = document.createElement('style'); Scss.type = 'text/css'; var css = '.BKMbutton {float:left;margin-right:5px;color:#7f0;cursor:pointer;}'; css += '#divContent {box-shadow: 0 4px 10px #aaa;width:98%}'; css += '.BKMbuttonSync {padding:6px 10px;border-radius:5px;border:2px solid #C2C2C2;background-color:#CBCBCB;cursor:pointer;}'; css += '.BKMbuttonSync:hover {background-color:#93C4D3;}'; css += '.divHead {clear:both;height:28px;padding-left:5px;font-weight:bold;background-color:#CBCBCB;}'; css += '.divHeadName {float:left;text-align:left;vertical-align:bottom;}'; css += '.divHeadCountry {float:right;}'; css += '#selectCountry, #selectCountryS {height:22px;background-color:#CBCBCB;border:0;}'; css += '.divBKM {clear:both;line-height:21px;height:24px;border:1px solid #ededed;border-top:0;background-color:#ffffff;}'; css += '.divName {float:left;text-align:left;padding-left:5px;padding-top:2px;}'; css += '.divName a {text-decoration:none;}'; css += '.divIcons {float:right;height:16px;}'; css += '.divSubMenu {float:right;height:24px;min-width:60px;}'; css += '#BKMedit {clear:both;display:none;margin-bottom:10px;height:133px;border:2px solid #C2C2C2;box-shadow: 0 4px 10px #aaa;}'; css += '.divEditTitre {line-height:24px;height:24px;border-bottom:1px solid #C2C2C2;}'; css += '.divEdit {float:left;width:50px;height:23px;text-align:left;padding-left:5px;font-weight:bold;background-color:#CBCBCB;}'; css += '#divEditName {float:left;width:190px;height:22px;padding:0;padding-left:5px;border:0;margin:0;}'; css += '#divComm {float:left;width:100%;line-height:24px;height:23px;padding-left:5px;text-align:left;font-weight:bold;background-color:#CBCBCB;border-bottom:1px solid #C2C2C2;}'; css += '#divCommEdit {float:left;width:100%;height:81px;border:0;margin:0;padding:2px;resize:none;}'; css += '#divBackupTxt, #divSettingsContent {width:279px;min-height:150px;margin:2px 0 10px;resize:none;background-color:white;border:2px solid #C2C2C2;font-size:12px;}'; css += '#divShareTxt {float:left;width:100%;height:118px;resize:none;margin-bottom:5px;border:0;border-bottom:1px solid #C2C2C2;}'; css += '.divComment {clear:both;position:relative;top:1px;display:none;padding:1px 0 3px 20px;text-align:left;background-color:#dddddd;border-bottom:1px solid #C2C2C2;}'; css += '.BKMsync {padding: 5px 15px;}'; css += '#divBackup p, #BKMedit p, #divSettings p {margin:0;line-height:20px;text-align:justify;padding:5px;font-size:11px;}'; css += '.fabkm {font-size:16px;padding:6px 4px;}'; css += '.iconPoint, .iconZone {float:left; margin-left:2px; background-image:url(//editor-assets.waze.com/production/img/toolbarcad3e904c322a28bc0d9d3f9a9b06f8c.png);}' css += '.iconPoint {background-position:-50px 0px; width:16px; height:16px; margin-top:2px;}' css += '.iconZone {background-position:0px 0px; width:17px; height:21px;}'; Scss.innerHTML = css; document.body.appendChild(Scss); BKMmainHtml(); } // Create a tab for Bookmarks async function addBookmarksTab() { const {tabLabel, tabPane} = W.userscripts.registerSidebarTab('Bookmarks'); tabLabel.innerHTML = '<span class="fa fa-star"></span>'; tabLabel.title = 'Bookmarks'; tabPane.id = 'sidepanel-Bookmarks'; await W.userscripts.waitForElementConnected(tabPane); return Promise.resolve(tabPane); } var tab = await addBookmarksTab(); function BKMmainHtml() { var settings = JSON.parse(localStorage.WMEBookmarksSettings); //Create content for Prev/Next actions var prev=document.createElement('div'); prev.id='prevIcon'; (settings.histonav === true ? prev.style.display='block' : prev.style.display='none'); prev.className='toolbar-button toolbar-button-with-label ItemDisabled'; prev.innerHTML='<div class="item-container"><div class="item-icon w-icon" title="Previous"><span class="fa fa-chevron-left"></span></div></div>'; BKMEditHandle.append(prev) getId('prevIcon').onclick=NavPrev; var next=document.createElement('div'); next.id='nextIcon'; (settings.histonav === true ? next.style.display='block' : next.style.display='none'); next.className='toolbar-button toolbar-button-with-label ItemDisabled'; next.innerHTML='<div class="item-container"><div class="item-icon w-icon" title="Next"><span class="fa fa-chevron-right"></span></div></div>'; BKMEditHandle.append(next) getId('nextIcon').onclick=NavNext; //Create content in favorite's tab var addon = document.createElement('section'); addon.id = 'bookmarks-addon'; // Bookmarks header var content = '<div style="float:left;margin-left:5px;"><b><a href="https://gf.qytechs.cn/scripts/4515-wme-bookmarks" target="_blank"><u>WME Bookmarks</u></a></b> v' + BKMversion + '</div>'; content += '<div style="clear:both;float:left;width:100%;margin:5px;">'; content += '<div style="float:left;width:34px;"><span id="iconBookmarks" class="fabkm fa fa-star" title="' + lang[0] + '" style="color:#36c;font-size:20px;"></span></div>'; content += '<div id="shareButton" style="float:left;width:34px;"><span id="iconShare" class="fabkm fa fa-share-alt-square" title="' + lang[1] + '" style="color:#bbb;font-size:20px;"></span></div>'; content += '<div style="float:left;width:34px;"><span id="iconHisto" class="fabkm fa fa-history" title="' + lang[3] + '" style="color:#bbb;font-size:20px;"></span></div>'; content += '<div id="copypButton" style="float:left;width:34px;"><span id="iconCopy" class="fabkm fa fa-copy" title="' + lang[7] + '" style="color:#bbb;font-size:20px;"></span></div>'; content += '<div style="float:left;width:34px;"><span id="iconBackup" class="fabkm fa fa-cube " title="' + lang[4] + '" style="color:#bbb;font-size:20px;"></span></div>'; content += '<div style="float:left;width:34px;"><span id="iconSettings" class="fabkm fa fa-sliders" title="' + lang[22] + '" style="color:#bbb;font-size:20px;"></span></div>'; content += '</div><div style="clear:both;"></div><div id="BKMedit"></div>'; // Edit and Share containers content += '<div id="divContent">'; // Principal container // Bookmarks tab content += '<div id="divBookmarks" style="margin-bottom:30px;visibility:hidden;"><div class="divHead" id="divBookmarksHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-star"></span>' + lang[6] + 's</div>'; content += '<div class="divHeadCountry"><select type="text" name="Country" id="selectCountry"></select></div>'; content += '</div><div id="divBookmarksContent"></div></div>'; // Friends Share tab content += '<div id="divShare" style="margin-bottom:10px;visibility:hidden;"><div class="divHead" id="divShareHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-share-alt-square"></span>' + lang[1] + '</div>'; content += '<div class="divHeadCountry"><select type="text" name="Country" id="selectCountryS"></select></div>'; content += '</div><div id="divShareContent"></div></div>'; // Historic tab content += '<div id="divHisto" style="margin-bottom:10px;visibility:hidden;"><div class="divHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-history"></span>' + lang[3] + '</div>'; content += '</div><div id="divHistoContent"></div></div>'; // Copy/paste tab content += '<div id="divCopy" style="margin-bottom:10px;visibility:hidden;"><div class="divHead" id="divCopyHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-copy"></span>'+lang[7]+'</div>'; content += '</div><div id="divCopyContent"></div></div>'; // Backup tab content += '<div id="divBackup" style="margin-bottom:10px;visibility:hidden;"><div class="divHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-cube"></span>' + lang[4] + '</div>'; content += '<div class="divIcons"><a href="#"><span id="backupValid" class="fabkm fa fa-check" title="' + lang[4] + '" style="color:#0b0;"></a></div></div>'; content += '<input type="radio" id="bckNew" name="typeBck" ' + (settings.backup=="new" ? ' checked' : '') + ' value="new" style="margin-left: 40px;" /> '+ tset[9]; content += '<input type="radio" id="bckAdd" name="typeBck" ' + (settings.backup=="add" ? ' checked' : '') + ' value="add" style="margin-left: 40px;" /> '+ tset[10]; content += '<textarea id="divBackupTxt"></textarea><p><span class="fabkm fa fa-info-circle" style="padding:0;color:#36c;"></span>' + text1 + '</p></div>'; // Settings tab content += '<div id="divSettings" style="margin-bottom:10px;visibility:hidden;"><div class="divHead">'; content += '<div class="divHeadName"><span class="fabkm fa fa-sliders"></span>' + lang[22] + '</div>'; content += '</div><div id="divSettingsContent" style="padding:3px;line-height:22px;">'; content += '<input type="checkbox" id="chkSort" ' + (settings.sort ? ' checked' : '') + ' /> ' + tset[6] + '<br />'; content += '<input type="checkbox" id="chkZoom" ' + (settings.zoom ? ' checked' : '') + ' /> ' + tset[0] + '<br />'; content += '<input type="checkbox" id="chkLayers" ' + (settings.layers ? ' checked' : '') + ' /> ' + tset[1] + '<br />'; content += '<input type="checkbox" id="chkLayersPaste" ' + (settings.layersPaste ? ' checked' : '') + ' /> ' + tset[7] + '<br />'; content += '<input type="checkbox" id="chkServer" ' + (settings.server ? ' checked' : '') + ' /> ' + tset[2] + '<br />'; content += '<input type="checkbox" id="chkSynchro" ' + (settings.synchro ? ' checked' : '') + ' /> ' + tset[3] + '<br />'; content += '<input type="checkbox" id="chkLastClic" ' + (settings.lclic ? ' checked' : '') + ' /> ' + tset[11] + '<br />'; content += '<input type="checkbox" id="chkCopyPaste" ' + (settings.lcopy ? ' checked' : '') + ' /> ' + tset[12] + '<br />'; content += '<input type="button" id="razButton1" value="" style="height: 13px;" /> ' + tset[4] + '<br />'; content += '<input type="button" id="razButton2" value="" style="height: 13px;" /> ' + tset[5] + '<br />'; content += '<input type="button" id="razButton3" value="" style="height: 13px;" /> ' + tset[8] + '<br /><hr style="margin:5px 0;border-top:1px solid #ededed;" />'; content += '<input type="checkbox" id="chkHistoNav" ' + (settings.histonav ? ' checked' : '') + ' /> ' + tset[13] + '<br />'; content += '<input type="checkbox" id="chkHistoSelect" ' + (settings.histoselect ? ' checked' : '') + ' /> ' + tset[14] + '<br />'; content += '</div><p><span class="fabkm fa fa-info-circle" style="padding:0;color:#36c;"></span>' + text3 + '</p></div></div>'; addon.innerHTML = content; addon.id = 'sidepanel-bookmarks'; addon.className = 'sidepanel-bookmarks'; tab.appendChild(addon); // Tabs actions select(countries, 'selectCountry'); select(countriesS, 'selectCountryS'); bookmarksToggle(); getId('iconBookmarks').onclick = (function () { bookmarksToggle(); }); getId('iconShare').onclick = (function () { shareToggle(); }); getId('iconHisto').onclick = (function () { histoToggle(); }); getId('iconCopy').onclick = (function () { copyToggle(); }); getId('iconBackup').onclick = (function () { backupToggle(); }); getId('iconSettings').onclick = (function () { settingsToggle(); }); // Buttons actions getId('bckNew').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); a.backup="new"; localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('bckAdd').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); a.backup="add"; localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkSort').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkSort').checked ? a.sort=true : a.sort=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkZoom').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkZoom').checked ? a.zoom=true : a.zoom=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkLayers').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkLayers').checked ? a.layers=true : a.layers=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkLayersPaste').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkLayersPaste').checked ? a.layersPaste=true : a.layersPaste=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkServer').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkServer').checked ? a.server=true : a.server=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkSynchro').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); if (getId('chkSynchro').checked) { a.synchro=true; $('#iconShare').css('display', 'block'); $('#shareButton').animate({ width: '34px' }, 250); } else { a.synchro=false; $('#shareButton').animate({ width: '0' }, 250); $('#iconShare').css('display', 'none'); } localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkLastClic').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkLastClic').checked ? a.lclic=true : a.lclic=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkCopyPaste').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); if (getId('chkCopyPaste').checked) { a.lcopy=true; $('#iconCopy').css('display', 'block'); $('#copypButton').animate({ width: '34px' }, 250); } else { a.lcopy=false; $('#copypButton').animate({ width: '0' }, 250); $('#iconCopy').css('display', 'none'); } localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('razButton1').onclick = (function () { var answer = window.confirm(tset[4] + ' ?'); if (answer) { localStorage.setItem('WMEBookmarks', '[]'); BKMtableCountries(); select(countries, 'selectCountry'); } }); getId('razButton2').onclick = (function () { var answer = window.confirm(tset[5] + ' ?'); if (answer) { initBookmarks(); } }); getId('razButton3').onclick = (function () { var answer = window.confirm(tset[8] + ' ?'); if (answer) { localStorage.setItem('WMEHistoric', '[]'); } }); getId('chkHistoNav').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); if (getId('chkHistoNav').checked) { a.histonav=true; $('#prevIcon').css('display', 'block'); $('#nextIcon').css('display', 'block'); } else { a.histonav=false; $('#prevIcon').css('display', 'none'); $('#nextIcon').css('display', 'none'); } localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); getId('chkHistoSelect').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); (getId('chkHistoSelect').checked ? a.histoselect=true : a.histoselect=false) localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); if (debug) { console.info('WME Bookmarks HTML loaded'); } // Button on the map setTimeout(function () { var addNodeButton = document.createElement('div'); addNodeButton.id = 'addNodeButton'; addNodeButton.className = 'fabkm fa fa-thumb-tack BKMbutton'; addNodeButton.onclick = BKMinsertPermalink; getElementsByClassName('topbar')[0].insertBefore(addNodeButton,getElementsByClassName('location-info-region')[0]); getElementsByClassName('topbar')[0].style.padding = '0 10px'; addNodeButton.onmouseover = (function () { getId('addNodeButton').style.opacity = '1'; }); addNodeButton.onmouseout = (function () { getId('addNodeButton').style.opacity = '0.6'; }); }, 1000); if (getId('chkSynchro').checked === false) { $('#iconShare').css('display', 'none'); $('#shareButton').animate({ width: '0' }, 250); } if (getId('chkCopyPaste').checked === false) { $('#iconCopy').css('display', 'none'); $('#copypButton').animate({ width: '0' }, 250); } BMKcheckAutoSave(); BKMaddButtonIfLoad(); timer = setTimeout(BKMcheckActiveCountry, 5000); //Bookmarks Layer WazeWrap.Interface.AddLayerCheckbox("display", "Bookmarks", true, LayerToggled); // createToggler(); checklayer("__WME_Bookmarks"); // (JSON.parse(localStorage.WMEBookmarksSettings).showBookmark == true ? getId('layer-switcher-item_bookmarks').checked=true : false); // bookmarks_Layer.setVisibility(JSON.parse(localStorage.WMEBookmarksSettings).showBookmark); bookmarks_Layer.setVisibility(true) } function autoSwitchToBKMTab() { var _restoreDrawerTab = $('#drawer').find('[selected="true"]').children('.w-icon')[0] || 'none-selected'; if (!$(_restoreDrawerTab).hasClass('w-icon-script')) { document.querySelector('.w-icon-script').dispatchEvent(new MouseEvent('click', { view: (typeof unsafeWindow !== 'undefined' ? unsafeWindow : window), bubbles: true, cancelable: true, button: 0 })); } document.querySelector('.fa-star').closest('a[href^="#userscript"').dispatchEvent(new MouseEvent('click', { view: (typeof unsafeWindow !== 'undefined' ? unsafeWindow : window), bubbles: true, cancelable: true, button: 0 })); } // *************** // ** BOOKMARKS ** // *************** function initBookmarks() { if (debug) { console.log('WME Bookmarks: Send: ' + BKMusername + ' to init'); } var url = 'https://limageenboite.fr/bkm.php?initbookmarks=' + BKMusername var datas = null var method = 'POST' GM.xmlHttpRequest({ method: method, url: url, data: datas, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (debug) { console.log('WME Bookmarks: Server Response: ', data.responseText); } if (data.responseText != 'Check') { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:red;">' + lang[19] + '</span></div>'; setTimeout(getBookmarks, 1000); } else { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:darkgreen;">' + lang[20] + '</span></div>'; BKMaddButtonIfLoad(); setTimeout(reloadHtmlBookmarks, 1000); } } }); } function getBookmarks() { var listFav = localStorage.WMEBookmarks; var url = 'https://limageenboite.fr/bkm.php?getbookmarks=' + BKMusername var datas = null var method = 'GET' GM.xmlHttpRequest({ method: method, url: url, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (isJsonString(data.responseText)) { var s1 = JSON.stringify(JSON.parse(data.responseText), Object.keys(JSON.parse(data.responseText)).sort()); var s2 = JSON.stringify(JSON.parse(listFav), Object.keys(JSON.parse(listFav)).sort()); if ((s1 == s2) !== true && data.responseText && getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: From BKM Server: ', decodeURIComponent(data.responseText.replace(/\\x/g, '%'))); } if (debug) { console.log('WME Bookmarks: From BKM local : ', listFav); } clearTimeout(timer); $('addNodeButton').hide(); getId('addNodeButton').style.height='0'; getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span>' + lang[5] + '</div><div class="divIcons"><span id="SyncCancel" class="fabkm fa fa-window-close" title="' + lang[9] + '" style="color:red;"></span></div>'; if (data.responseText != '[]') { var servToPC = '<div id="serv2Loc" class="BKMbuttonSync" style="float:left;"><span class="fabkm fa fa-cloud"></span> <span class="fabkm fa fa-chevron-circle-right" style="font-size:20px;color:#36c;"></span> <span class="fabkm fa fa-laptop"></span></div>'; } else { servToPC = ''; } if (listFav != '[]') { var PCToServ = '<div id="loc2Serv" class="BKMbuttonSync" style="float:right;"><span class="fabkm fa fa-laptop"></span> <span class="fabkm fa fa-chevron-circle-right" style="font-size:20px;color:#36c;"></span> <span class="fabkm fa fa-cloud"></span></div>'; } else { PCToServ = ''; } getId('divBookmarksContent').innerHTML = '<div class="BKMsync" style="clear:both;height:60px;"><div class="BKMsync">'+ servToPC + PCToServ +'</div>'; if (getId('serv2Loc')) getId('serv2Loc').onclick = (function(){serv2Loc(data.responseText);}); if (getId('loc2Serv')) getId('loc2Serv').onclick = (function(){loc2Serv();}); } else { reloadHtmlBookmarks(); if (debug) { console.log('WME Bookmarks: Bookmarks Sync !'); console.log(JSON.stringify(JSON.parse(listFav))); } } } else { if (debug) { console.log('WME Bookmarks: Server not responding or data corrupted'); } clearTimeout(timer); $('addNodeButton').hide(); getId('addNodeButton').style.height='0'; getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span>' + lang[5] + '</div><div class="divIcons"><a href="#"><span id="SyncCancel" class="fabkm fa fa-window-close" title="' + lang[9] + '" style="color:red;"></span></a></div>'; getId('divBookmarksContent').innerHTML = '<div class="BKMsync" style="padding-bottom:20px;"><div id="servhs" class="BKMbuttonSync" style="background-color:#F77;"><span style="color:red;">Error</span> <span style="font-size:10px;">Server not responding or data corrupted<br/>Click me for desync</span></div></div>'; getId('servhs').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); a.synchro=false; $('#iconShare').animate({ width: '0' }, 200); $('#shareButton').animate({ width: '0' }, 250); localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); reloadHtmlBookmarks(); getId('chkSynchro').checked=false; }); } } }); function serv2Loc(data) { localStorage.setItem('WMEBookmarks', data); BKMaddButtonIfLoad(); reloadHtmlBookmarks(); } function loc2Serv() { getId('divBookmarksContent').innerHTML = ''; BKMaddButtonIfLoad(); // BKMpostBookmarks(); } } function reloadHtmlBookmarks() { var content = '<div class="divHeadName"><span class="fabkm fa fa-star" style="font-size:16px;padding:6px;"></span>' + lang[6] + 's</div>'; content += '<div class="divHeadCountry"><select type="text" name="Country" id="selectCountry"></select></div>'; getId('divBookmarksHead').innerHTML = content; select(countries, 'selectCountry'); getId('selectCountry').addEventListener("change", (function () { clearTimeout(timer); // BKMcheckActiveCountry(); BKMcountryActive = getId('selectCountry').value; getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); })); getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); BKMtableCountries(); } function BKMpostBookmarks() { var a = JSON.parse(localStorage.WMEBookmarks), toSave=[]; for (var p in a) { if(!a.hasOwnProperty(p)) continue; var bNew={}; bNew.country=encodeURIComponent(a[p].country); bNew.name=encodeURIComponent(a[p].name); bNew.perma=a[p].perma; bNew.comm=encodeURIComponent(a[p].comm); bNew.share=a[p].share; bNew.reminder=a[p].reminder; toSave.push(bNew); } if (debug) { console.log('WME Bookmarks: Send Data: ', JSON.stringify(toSave)); } var url = "https://limageenboite.fr/bkm.php" var datas = "nickname="+BKMusername+"&postbookmarks=" + JSON.stringify(toSave) var method = 'POST' GM.xmlHttpRequest({ method: method, url: url, data: datas, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (debug) { console.log('WME Bookmarks: Server Response: ', data.responseText); } if (data.responseText != 'Check') { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:red;">' + lang[19] + '</span></div>'; setTimeout(getBookmarks, 1000); } else { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:darkgreen;">' + lang[20] + '</span></div>'; BKMaddButtonIfLoad(); setTimeout(reloadHtmlBookmarks, 1000); } } }); } function BKMupdateBookmarks(action, owner, data, arg) { var bNew = {}; bNew.action=action; bNew.owner=owner; bNew.arg=arg; bNew.data=data; if (debug) { console.log('WME Bookmarks: Send Update: ', bNew); } var url = "https://limageenboite.fr/bkm.php" var datas = "addbookmark=" + JSON.stringify(bNew) var method = 'POST' if (debug) { console.log('WME Bookmarks: url: ' + url + 'data: ' + datas + 'method: ' + method); } GM.xmlHttpRequest({ method: method, url: url, data: datas, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (debug) { console.log('WME Bookmarks: Server Response: ', data.responseText); } if (data.responseText != 'Check') { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:red;">' + lang[19] + '</span></div>'; setTimeout(getBookmarks, 1000); } else { getId('divBookmarksHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:darkgreen;">' + lang[20] + '</span></div>'; BKMaddButtonIfLoad(); setTimeout(reloadHtmlBookmarks, 1000); } } }); } function BKMtableHtml(container, data, i) { // Bookmarks & Share table (HTML); var div = document.createElement('div'); div.className = 'divBKM'; div.id = container + i; //(data.comm != '' ? div.style.backgroundColor = '#e0fffc' : div.style.backgroundColor = '#ffffff'); getId(container).appendChild(div); // if (debug) { console.log("xxx ",data); } //NAME var divName = document.createElement('div'); divName.className = 'divName'; var divNameA = document.createElement('a'); divNameA.href = '#'; divNameA.id='link'+i; divNameA.innerHTML = '<b>' + data.name.substring(0, 26) + '</b>'; divNameA.onclick = (function() { BKMjump(data.country,data.perma,divNameA.id); }); if (getId('chkLastClic').checked) { var a=JSON.parse(localStorage.WMEBookmarksSettings); if (divNameA.id===a.lastclic) { divNameA.style.color='#26BAE8'; a.lastclic=divNameA.id; } localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); } if (data.comm != '') { divNameA.onmouseover = (function () { getId(container + i).style.backgroundColor = '#CBCBCB'; getId(container + i).style.borderBottom = '1px dashed #ededed'; getId(container + '_Comm_' + i).style.display = 'block'; }); divNameA.onmouseout = (function () { getId(container + i).style.backgroundColor = '#e0fffc'; getId(container + i).style.borderBottom = '1px solid #ededed'; getId(container + '_Comm_' + i).style.display = 'none'; }); } divName.appendChild(divNameA); div.appendChild(divName); // SUBMENU var divSubMenu = document.createElement('div'); divSubMenu.className = 'divSubMenu'; divSubMenu.onmouseover = (function () { divMainMenu.style.display='block'; divSubMenu.style.display='none'; }); div.appendChild(divSubMenu); var divSubExpand = document.createElement('div'); var divSubExpandA = document.createElement('a'); divSubExpand.className = 'divIcons'; divSubExpandA.innerHTML = '<span class="fabkm fa fa-ellipsis-v" style="color:#BBB;"></span>'; divSubExpand.appendChild(divSubExpandA); divSubMenu.appendChild(divSubExpand); if (data.comm != '') { var divSubComment = document.createElement('div'); var divSubCommentA = document.createElement('a'); divSubComment.className = 'divIcons'; divSubCommentA.innerHTML = '<span class="fabkm fa fa-sticky-note" title="' + data.comm + '" style="color:#36c;"></span>'; divSubComment.appendChild(divSubCommentA); divSubMenu.appendChild(divSubComment); } if (typeof(data.reminder) != "undefined" && data.reminder != null && data.reminder != "") { var divSubReminder = document.createElement('div'); var divSubReminderA = document.createElement('a'); divSubReminder.className = 'divIcons'; divSubReminderA.innerHTML = '<span class="fabkm fa fa-clock-o" title="'+lang[24]+'" style="color:#36c;" id="iconReminder_' + i + '"></span>'; divSubReminder.appendChild(divSubReminderA); divSubMenu.appendChild(divSubReminder); } if (data.share != null && data.share != '') { var divSubShare = document.createElement('div'); var divSubShareA = document.createElement('a'); divSubShare.className = 'divIcons'; divSubShareA.innerHTML = '<span class="fabkm fa fa-share-alt-square" title="' + lang[12] + '" style="color:#36c;"></span>'; divSubShare.appendChild(divSubShareA); divSubMenu.appendChild(divSubShare); } // MENU var divMainMenu = document.createElement('div'); divMainMenu.className = 'divSubMenu'; divMainMenu.style.display = 'none'; divMainMenu.onmouseleave = (function () { divMainMenu.style.display='none'; divSubMenu.style.display='block'; }); div.appendChild(divMainMenu); // COMMENT var divComment = document.createElement('div'); divComment.className = 'divIcons'; var divCommentA = document.createElement('a'); if (data.comm != '') { divCommentA.innerHTML = '<span class="fabkm fa fa-sticky-note" title="' + data.comm + '" style="color:#36c;"></span>'; divCommentA.onmouseover = (function () { getId(container + i).style.backgroundColor = '#CBCBCB'; getId(container + i).style.borderBottom = '1px dashed #77aacc'; getId(container + '_Comm_' + i).style.display = 'block'; }); divCommentA.onmouseout = (function () { getId(container + i).style.backgroundColor = '#e0fffc'; getId(container + i).style.borderBottom = '1px solid #ededed'; getId(container + '_Comm_' + i).style.display = 'none'; }); } else { divCommentA.innerHTML = '<span class="fabkm fa fa-sticky-note" title="' + lang[10] + '" style="color:#bbb;"></span>'; } divCommentA.href = '#'; divCommentA.onclick = (function () { getId('BKMedit').style.height = '133px'; BKMhtmlEditName(container, data); }); divComment.appendChild(divCommentA); divMainMenu.appendChild(divComment); // RELOCATE var divLocate = document.createElement('div'); divLocate.className = 'divIcons'; var divLocateA = document.createElement('a'); divLocateA.innerHTML = '<span class="fabkm fa fa-map-marker" title="' + lang[13] + '" style="color:#bbb;" id="iconRelocate_' + i + '"></span>'; divLocateA.href = '#'; divLocateA.onclick = (function(){ getId('iconRelocate_'+i).style.color="#36c"; setTimeout(function(){ BKMrelocate(data.perma,data.name,i)}, 200); }); divLocate.appendChild(divLocateA); divMainMenu.appendChild(divLocate); // REMINDER var divReminder = document.createElement('div'); divReminder.className = 'divIcons'; var divReminderA = document.createElement('a'); if (typeof(data.reminder) != "undefined" && data.reminder != null && data.reminder != "") { var d= new Date(parseInt(data.reminder)).toString(), t=d.split(" "); divReminderA.innerHTML = '<span class="fabkm fa fa-clock-o" title="'+t[3]+"-"+pad(new Date(t[1]+'01, 01').getMonth()+1)+"-"+t[2]+" "+t[4].slice(0,5)+'" style="color:#36c;" id="iconReminder_' + i + '"></span>'; } else { divReminderA.innerHTML = '<span class="fabkm fa fa-clock-o" title="'+lang[24]+'" style="color:#bbb;" id="iconReminder_' + i + '"></span>'; } divReminderA.href = '#'; divReminderA.onclick = (function(){ getId('iconReminder_'+i).style.color="#36c"; getId('BKMedit').style.height = '60px'; BKMhtmlReminder(container, data,i); }); divReminder.appendChild(divReminderA); divMainMenu.appendChild(divReminder); // SHARE if (container == 'divBookmarksContent' && getId('chkSynchro').checked === true) { var divShare = document.createElement('div'); divShare.className = 'divIcons'; var divShareA = document.createElement('a'); if (data.share) { divShareA.innerHTML = '<span class="fabkm fa fa-share-alt-square" title="' + data.share + '" style="color:#36c;"></span>'; } else { divShareA.innerHTML = '<span class="fabkm fa fa-share-alt-square" title="' + lang[12] + '" style="color:#bbb;"></span>'; } divShareA.href = '#'; divShareA.onclick = (function () { getId('BKMedit').style.height = '225px'; BKMedit(data); }); divShare.appendChild(divShareA); divMainMenu.appendChild(divShare); } // SUPPR var divSuppr = document.createElement('div'); divSuppr.className = 'divIcons'; var divSupprA = document.createElement('a'); if (container == 'divShareContent') { divSupprA.innerHTML = '<span class="fabkm fa fa-share-alt-square" title="' + lang[21] + '" style="color:red;"></span>'; } else { divSupprA.innerHTML = '<span class="fabkm fa fa-times" title="' + lang[11] + '" style="color:red;"></span>'; } divSupprA.href = '#'; divSupprA.onclick = (function(){BKMsuppr(data.name,data.perma,container);}); divSuppr.appendChild(divSupprA); divMainMenu.appendChild(divSuppr); //COMMENT TEXT var divSeeComment = document.createElement('div'); divSeeComment.className = 'divComment'; divSeeComment.id = container + '_Comm_' + i; divSeeComment.innerHTML = data.comm; div.appendChild(divSeeComment); } // *************** // ** SHARED ** // *************** function getShared() { var listFav = localStorage.WMEBookmarksShared; var url = 'https://limageenboite.fr/bkm.php?getshared='+ BKMusername var datas = null var method = 'GET' GM.xmlHttpRequest({ method: method, url: url, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { var s1 = JSON.stringify(JSON.parse(data.responseText), Object.keys(JSON.parse(data.responseText)).sort()); var s2 = JSON.stringify(JSON.parse(listFav), Object.keys(JSON.parse(listFav)).sort()); if ((s1 == s2) !== true && data.responseText && getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: From Share Server: ', JSON.parse(data.responseText)); } if (debug) { console.log('WME Bookmarks: From Share local: ', JSON.parse(listFav)); } localStorage.setItem('WMEBookmarksShared', data.responseText); reloadHtmlShared(); } else { reloadHtmlShared(); if (debug) { console.log('WME Bookmarks: Shared Sync !'); } } } }); } function BKMedit(data) { //Show Share DIV clearTimeout(timer); $('#BKMedit').slideDown(200); $('#divContent').slideUp(1000); var content1 = '<div class="divEditTitre"><div class="divEdit" style="width:80px;">' + lang[6] + '</div><input type="text" id="divEditName" style="width:165px;" value="'+ data.name.replace(/"/g, '"') +'" readonly /><input type="hidden" id="permalink" value="' + data.perma.lon +'|'+ data.perma.lat + '" />'; content1 += '<div class="divIcons"><a href="#"><span id="shareValid" class="fabkm fa fa-check" title="' + lang[8] + '" style="font-size:16px;padding:6px;color:#0b0;"></a></div>'; content1 += '</div><textarea id="divShareTxt"></textarea><p><span class="fabkm fa fa-info-circle" title="Info" style="font-size:16px;padding:6px;color:#36c;"></span>' + text2 + '</p>'; getId('BKMedit').innerHTML = content1; if (!data.share) { data.share = lang[23]; getId('divShareTxt').style.color = '#aaa'; } getId('divShareTxt').onclick = (function () { if (getId('divShareTxt').value == lang[23]) { getId('divShareTxt').value = ''; getId('divShareTxt').style.color = '#000'; } }); getId('divShareTxt').innerHTML = data.share; getId('divShareTxt').onkeyup = (function () { var t = getId('divShareTxt').value; if (t === '') { getId('divShareTxt').innerHTML = data.share; } getId('divShareTxt').value = t.replace(',', ';').replace(' ', ';').replace(';;', ';'); }); getId('shareValid').onclick = (function () { data.share = getId('divShareTxt').value; if (data.share !== lang[23]) { var toSave=[]; var a = JSON.parse(localStorage.WMEBookmarks); for (var p in a) { if(!a.hasOwnProperty(p)) continue; //Redo Bookmark var bNew={}; bNew.country=a[p].country; bNew.name=a[p].name; bNew.perma=a[p].perma; bNew.comm=a[p].comm; bNew.reminder=a[p].reminder; if (getId('permalink').value == a[p].perma.lon+'|'+a[p].perma.lat) { bNew.share=data.share; if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: SHARE', BKMusername, bNew); } BKMupdateBookmarks('SHARE', BKMusername, bNew, ''); } } else { bNew.share=a[p].share; } //Store Bookmark toSave.push(bNew); } localStorage.setItem('WMEBookmarks', JSON.stringify(toSave)); } $('#divContent').slideDown(1000); $('#BKMedit').slideUp(500); }); // BKMcheckActiveCountry(); getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); } function reloadHtmlShared() { var content = '<div class="divHeadName"><span class="fabkm fa fa-share-alt-square" style="font-size:16px;padding:6px;"></span>' + lang[1] + '</div>'; content += '<div class="divHeadCountry"><select type="text" name="Country" id="selectCountryS"></select></div>'; getId('divShareHead').innerHTML = content; select(countriesS, 'selectCountryS'); getId('selectCountryS').addEventListener("change", (function () { clearTimeout(timer); // BKMcheckActiveCountry(); BKMcountryActive = getId('selectCountryS').value; getId('divShareContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divShareContent'); })); getId('divShareContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divShareContent'); } // *************** // ** HISTORY ** // *************** function BKMaddHisto(perma) { // Add link in historic var lStorage=JSON.parse(localStorage.WMEHistoric), bNew={}; if (Object.keys(lStorage).length >= 30) { lStorage.splice(0, 1); } bNew.date=new Date().toLocaleString(); bNew.perma=perma; bNew.name=getName(); lStorage.push(bNew); localStorage.setItem('WMEHistoric', JSON.stringify(lStorage)); loadBookmarks('WMEHistoric', 'divHistoContent'); } function BKMhistoHtml(data) { // Historic table (HTML) var div = document.createElement('div'); div.className = 'divBKM'; var divName = document.createElement('div'); divName.className = 'divName'; var divNameA = document.createElement('a'); divNameA.href = '#'; divNameA.innerHTML = '<font size=-2>'+ data.date +' </font><b>'+ data.name.substring(0, 28) +'</b>'; divNameA.onclick = (function(){BKMjump(W.model.getTopCountry().name, data.perma,'');}); divName.appendChild(divNameA); div.appendChild(divName); // SUPPR var divSuppr = document.createElement('div'); divSuppr.className = 'divIcons'; var divSupprA = document.createElement('a'); divSupprA.innerHTML = '<span class="fabkm fa fa-times" title="' + lang[11] + '" style="color:red;"></span>'; divSupprA.href = '#'; divSupprA.onclick = (function(){BKMsuppr(data.name,data.perma,'divHistoContent');}); divSuppr.appendChild(divSupprA); div.appendChild(divSuppr); getId('divHistoContent').appendChild(div); } // *************** // ** BACKUP ** // *************** function BKMbackup() { var a = localStorage.WMEBookmarks, toshow = ''; getId('divBackupTxt').value=''; if (a) { a = JSON.parse(a); for (var p in a) { if(!a.hasOwnProperty(p)) continue; var permalink = a[p].perma.lon +"|"+ a[p].perma.lat; if (typeof(a[p].perma.zoom) !== 'undefined') { permalink += "|"+ a[p].perma.zoom; } else { permalink += "|"; } if (typeof(a[p].perma.layers) !== 'undefined') { permalink += "|"+ a[p].perma.layers; } else { permalink += "|"; } // Objects if (typeof(a[p].perma.segments) !== 'undefined') { permalink += "|s:"+ a[p].perma.segments; } else if (typeof(a[p].perma.nodes) !== 'undefined') { permalink += "|n:"+ a[p].perma.nodes; } else if (typeof(a[p].perma.venues) !== 'undefined') { permalink += "|v:"+ a[p].perma.venues; } else { permalink += "|"; } // New filters if (typeof(a[p].perma.env) !== 'undefined') { permalink += "|"+ a[p].perma.env; } else { permalink += "|"; } if (typeof(a[p].perma.MP) !== 'undefined') { permalink += "|"+ a[p].perma.MP; } else { permalink += "|"; } if (typeof(a[p].perma.UR) !== 'undefined') { permalink += "|"+ a[p].perma.UR; } else { permalink += "|"; } if (typeof(a[p].perma.MC) !== 'undefined') { permalink += "|"+ a[p].perma.MC; } else { permalink += "|"; } if (typeof(a[p].comm) !== 'undefined') { permalink += ";"+ a[p].comm; } else { permalink += ";"; } if (typeof(a[p].share) !== 'undefined') { permalink += ";"+ a[p].share; } else { permalink += ";"; } //Push to generate CSV toshow += a[p].country +";"+ a[p].name +";"+ permalink +"\n"; } getId('divBackupTxt').value=toshow; getId('divBackupTxt').onclick=(function () { getId('divBackupTxt').focus(); getId('divBackupTxt').select(); }); } getId('backupValid').onclick = backup; function backup() { if (getId('bckAdd').checked===true) { var lStorage=JSON.parse(localStorage.WMEBookmarks); } else { //bckNew localStorage.setItem('WMEBookmarks', '[]'); lStorage=[]; } var a = getId('divBackupTxt').value; var b = a.split('\n'); for (var i=0; b[i]; i++){ var c = b[i].split(';'); var bNew ={}; bNew.country = c[0]; bNew.name = c[1]; bNew.perma=BKMconvertPermalink(c[2]); bNew.comm = c[3]; bNew.share = c[4]; if (lStorage.map(function(e) { return e.perma.lon; }).indexOf(bNew.perma.lon) == -1 && lStorage.map(function(e) { return e.perma.lat; }).indexOf(bNew.perma.lat) == -1) { lStorage.push(bNew); } //Add new entry only } localStorage.setItem('WMEBookmarks', JSON.stringify(lStorage)); BKMtableCountries(); bookmarksToggle(); if (getId('chkSynchro').checked === true) { BKMpostBookmarks(); } } } // ******************** // ** COPY/PASTE POI ** // ******************** function checkPOI(){ if ($('#venue-edit-general').length == 1 && getId('chkCopyPaste').checked) { var editLM = $('.venue-panel-header-content'); if (editLM.length==1) { var copyattribDiv = $('#wme-copyattrib-fr'); if (copyattribDiv.length==0) { copyattribDiv=document.createElement('div'); copyattribDiv.id='wme-copyattrib-fr'; $(copyattribDiv).css({'float':'right','padding':'4px','border-radius':'5px','box-shadow':'rgba(0, 0, 0, 0.1) 0px 1px 6px 0px'}); editLM[0].parentNode.insertBefore(copyattribDiv, editLM[0].nextSibling); if (localStorage.WMECopyPastePOI.indexOf(WazeWrap.getSelectedFeatures()[0].model.attributes.id) == "-1") { var copyBtn=document.createElement('span'); copyBtn.innerHTML='<i class="fa fa-copy" data-original-title="" title="Copy attributes" style="color:#fff;"></i>'; copyBtn.style.margin='0 3px'; copyBtn.onclick=CopyAttrib; $(copyattribDiv).css({'background-color':'#26bae8'}); copyattribDiv.appendChild(copyBtn); } else { var pasteBtn=document.createElement('span'); pasteBtn.innerHTML='<i class="fa fa-paste" data-original-title="" title="Restore attributes" style="color:#555;"></i>'; pasteBtn.style.margin='0 3px'; pasteBtn.onclick=PasteAttrib; $(copyattribDiv).css({'background-color':'#ffc107'}); copyattribDiv.appendChild(pasteBtn); } } } } setTimeout(checkPOI, 2000); } function CopyAttrib(){ //JSON for POI info var PoiAttr={}, venue = WazeWrap.getSelectedFeatures()[0].model.attributes, lStorage = JSON.parse(localStorage.WMECopyPastePOI); //Get geometry if (typeof(WazeWrap.getSelectedFeatures()[0].model.geometry.components) != 'undefined') { var currentPOI = WazeWrap.getSelectedFeatures()[0].model.geometry.components[0].clone().components; var coord, Geo = "" for(var i=0; i<currentPOI.length;i++){ coord = currentPOI[i]; if(i < currentPOI.length-1){ coord = coord.transform(W.map.getProjectionObject(), W.map.getOLMap().displayProjection); // coord = coord.transform(W.map.projection, W.map.displayProjection); Geo += `${coord.x},${coord.y} `; } PoiAttr.geometry = Geo; PoiAttr.geoX = venue.geometry.bounds.right.toString(); PoiAttr.geoY = venue.geometry.bounds.top.toString(); PoiAttr.type="zone"; } } else { currentPOI = WazeWrap.getSelectedFeatures()[0].model.attributes; PoiAttr.geometry = ""; PoiAttr.geoX = currentPOI.geometry.x.toString(); PoiAttr.geoY = currentPOI.geometry.y.toString(); PoiAttr.type="point"; } PoiAttr.id=venue.id; PoiAttr.aliases=venue.aliases.toString(); (venue.brand==null ? PoiAttr.brand = 'null' : PoiAttr.brand = venue.brand) PoiAttr.categories=venue.categories.toString(); PoiAttr.categoryAttributes=JSON.stringify(venue.categoryAttributes); PoiAttr.description=venue.description; //PoiAttr.entryExitPoints=venue.entryExitPoints.toString(); PoiAttr.externalProviderIDs=JSON.stringify(venue.externalProviderIDs).replace(/"/g,""); (typeof(venue.houseNumber)=="undefined" ? PoiAttr.houseNumber = 'null' : PoiAttr.houseNumber = venue.houseNumber) PoiAttr.name=venue.name; PoiAttr.openingHours=""; //for (var i=0; venue.openingHours[i]; i++) { PoiAttr.openingHours = PoiAttr.openingHours + JSON.stringify(venue.openingHours[i]).replace(/"/g,"") + ";"; } PoiAttr.openingHours=venue.openingHours.toString(); (venue.phone==null ? PoiAttr.phone = 'null' : PoiAttr.phone = venue.phone) PoiAttr.services=venue.services.toString(); (venue.url==null ? PoiAttr.url = 'null' : PoiAttr.url = venue.url) //Add in localStorage lStorage.push(PoiAttr); localStorage.setItem('WMECopyPastePOI', JSON.stringify(lStorage)); // if (getId('chkSynchro').checked === true) { // if (debug) { console.log('WME Bookmarks: ADD Copy Cloud', PoiAttr); } // BKMupdateCopy('ADD', BKMusername, PoiAttr); // } W.selectionManager.unselectAll(); autoSwitchToBKMTab(); getId('iconCopy').click(); } function PasteAttrib(){ var a = JSON.parse(localStorage.WMECopyPastePOI); var toSave=[]; for (var i = 0; a[i]; i++) { if (JSON.stringify(a[i].id) == JSON.stringify(WazeWrap.getSelectedFeatures()[0].model.attributes.id)) { try { var geom=a[i].geometry; delete(a[i].geometry); delete(a[i].geoX); delete(a[i].geoY); if (a[i].aliases.length == 0) { delete(a[i].aliases); } else { var m=[], n=a[i].aliases.split(","); for (var j = 0; n[j]; j++) { m.push(n[j]); } a[i].aliases = m; } m=[] n=a[i].categories.split(","); for (j = 0; n[j]; j++) { m.push(n[j]); } if(m == WazeWrap.getSelectedFeatures()[0].model.attributes.categories) { delete(a[i].categories); } else { a[i].categories = m; } if (a[i].categoryAttributes == '{}' || a[i].categoryAttributes == 'null') { delete(a[i].categoryAttributes); } if (a[i].brand == 'null') { delete(a[i].brand); } if (a[i].houseNumber == 'null') { delete(a[i].houseNumber); } delete(a[i].externalProviderIDs); delete(a[i].openingHours); if (a[i].phone == 'null') { delete(a[i].phone); } if (a[i].services.length == 0) { delete(a[i].services); } else { m=[] n=a[i].services.split(","); for ( j = 0; n[j]; j++) { m.push(n[j]); } a[i].services = m; } if (a[i].url == 'null') { delete(a[i].url); } if (a[i].type == "zone") { //restore geometry if zone var lines = geom.split(' '); for(var k=0; k < lines.length; k++){ if (lines[k] !== "") { var t=lines[k].split(','); // var pt = WazeWrap.Geometry.ConvertTo900913(t[0], t[1]); lines[k] = new OpenLayers.Geometry.Point(t[0], t[1]); // lines[k] = new OpenLayers.Geometry.Point(pt.lon, pt.lat); } } saveNewPlaceGeometry(lines); } delete(a[i].type); if (debug) { console.log('WME Bookmarks: Paste Attrib', a[i]); } W.model.actionManager.add(new (require("Waze/Action/UpdateObject"))(WazeWrap.getSelectedFeatures()[0].model, a[i])); // if (getId('chkSynchro').checked === true){ BKMupdateCopy('DELETE', BKMusername, a[i].id); } delete(a[i].id); autoSwitchToBKMTab(); getId('iconCopy').click(); } catch (err) { console.log("Copy Venue Attributes : Problem", err); } } else { toSave.push(a[i]); } } W.selectionManager.unselectAll(); localStorage.setItem('WMECopyPastePOI', JSON.stringify(toSave)); loadBookmarks('WMECopyPastePOI', 'divCopyContent'); function saveNewPlaceGeometry(newGeom){ let selected = WazeWrap.getSelectedFeatures()[0].model; let originalGeometry = selected.geometry.clone(); let ls = new OpenLayers.Geometry.LineString(newGeom); let newGeometry = new OpenLayers.Geometry.Polygon(new OpenLayers.Geometry.LinearRing(ls.components)); let UFG = require("Waze/Action/UpdateFeatureGeometry"); console.log(originalGeometry) console.log(newGeometry) W.model.actionManager.add(new UFG(selected, W.model.venues, originalGeometry, newGeometry)); } } function getCopyPaste() { var listFav = localStorage.WMECopyPastePOI; var url = 'https://limageenboite.fr/bkm.php?getcopypaste=' + BKMusername var datas = null var method = 'GET' GM.xmlHttpRequest({ method: method, url: url, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (isJsonString(data.responseText)) { var s1 = JSON.stringify(JSON.parse(data.responseText), Object.keys(JSON.parse(data.responseText)).sort()); var s2 = JSON.stringify(JSON.parse(listFav), Object.keys(JSON.parse(listFav)).sort()); if ((s1 == s2) !== true && data.responseText && getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: From Copy Server: ', data.responseText.replace(/\\/g, "")); } if (debug) { console.log('WME Bookmarks: From Copy local : ', listFav); } clearTimeout(timer); $('addNodeButton').hide(); getId('addNodeButton').style.height='0'; getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span>' + lang[5] + '</div><div class="divIcons"><span id="SyncCancel" class="fabkm fa fa-window-close" title="' + lang[9] + '" style="color:red;"></span></div>'; if (data.responseText != '[]') { var servToPC = '<div id="serv2Loc" class="BKMbuttonSync" style="float:left;"><span class="fabkm fa fa-cloud"></span> <span class="fabkm fa fa-chevron-circle-right" style="font-size:20px;color:#36c;"></span> <span class="fabkm fa fa-laptop"></span></div>'; } else { servToPC = ''; } if (listFav != '[]') { var PCToServ = '<div id="loc2Serv" class="BKMbuttonSync" style="float:right;"><span class="fabkm fa fa-laptop"></span> <span class="fabkm fa fa-chevron-circle-right" style="font-size:20px;color:#36c;"></span> <span class="fabkm fa fa-cloud"></span></div>'; } else { PCToServ = ''; } getId('divCopyContent').innerHTML = '<div class="BKMsync" style="clear:both;height:60px;"><div class="BKMsync">'+ servToPC + PCToServ +'</div>'; if (getId('serv2Loc')) getId('serv2Loc').onclick = (function(){serv2LocCP(data.responseText);}); if (getId('loc2Serv')) getId('loc2Serv').onclick = (function(){loc2ServCP();}); } else { reloadHtmlCopy(); if (debug) { console.log('WME Bookmarks: Copy Paste POI Sync !'); } } } else { if (debug) { console.log('WME Bookmarks: Server not responding or data corrupted'); } clearTimeout(timer); $('addNodeButton').hide(); getId('addNodeButton').style.height='0'; getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span>' + lang[5] + '</div><div class="divIcons"><a href="#"><span id="SyncCancel" class="fabkm fa fa-window-close" title="' + lang[9] + '" style="color:red;"></span></a></div>'; getId('divCopyContent').innerHTML = '<div class="BKMsync" style="padding-bottom:20px;"><div id="servhs" class="BKMbuttonSync" style="background-color:#F77;"><span style="color:red;">Error</span> <span style="font-size:10px;">Server not responding or data corrupted<br/>Click me for desync</span></div></div>'; getId('servhs').onclick = (function () { var a=JSON.parse(localStorage.WMEBookmarksSettings); a.synchro=false; $('#iconCopy').css('display', 'none'); $('#copypButton').animate({ width: '0' }, 250); localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); reloadHtmlCopy(); getId('chkSynchro').checked=false; }); } } }); function serv2LocCP(data) { localStorage.setItem('WMECopyPastePOI', data); BKMaddButtonIfLoad(); reloadHtmlCopy(); } function loc2ServCP() { getId('divCopyContent').innerHTML = ''; BKMaddButtonIfLoad(); // BKMpostCopy(); } } function reloadHtmlCopy() { var content = '<div class="divHeadName"><span class="fabkm fa fa-star" style="font-size:16px;padding:6px;"></span>' + lang[6] + 's</div>'; getId('divCopyHead').innerHTML = content; getId('divCopyContent').innerHTML = ''; loadBookmarks('WMECopyPastePOI', 'divCopyContent'); } function BKMpostCopy() { var listFav = localStorage.WMECopyPastePOI; if (debug) { console.log('WME Copy POI: Send Data: ', JSON.parse(listFav)); } var url = "https://limageenboite.fr/bkm.php" var datas = "nickname="+BKMusername+"&postcopypaste=" + listFav var method = 'POST' GM.xmlHttpRequest({ method: method, url: url, data: datas, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (debug) { console.log('WME Bookmarks: Server Response: ', data.responseText); } if (data.responseText != 'Check') { getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:red;">' + lang[19] + '</span></div>'; setTimeout(getCopyPaste, 1000); } else { getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:darkgreen;">' + lang[20] + '</span></div>'; BKMaddButtonIfLoad(); setTimeout(reloadHtmlCopy, 1000); } } }); } function BKMupdateCopy(action, owner, data) { var bNew = {}; bNew.action=action; bNew.owner=owner; bNew.data=data; if (debug) { console.log('WME Copy POI: Send Update: ', bNew); } var url = "https://limageenboite.fr/bkm.php" var datas = "addcopypaste=" + JSON.stringify(bNew) var method = 'POST' GM.xmlHttpRequest({ method: method, url: url, data: datas, headers:{ "Content-Type": "application/x-www-form-urlencoded" }, onload: function(data) { if (debug) { console.log('WME Bookmarks: Server Response: ', data); } if (data.responseText != 'Check') { getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:red;">' + lang[19] + '</span></div>'; setTimeout(getCopyPaste, 1000); } else { getId('divCopyHead').innerHTML = '<div class="divHeadName"><span class="fabkm fa fa-random"></span><span style="color:darkgreen;">' + lang[20] + '</span></div>'; BKMaddButtonIfLoad(); setTimeout(reloadHtmlCopy, 1000); } } }); } function BKMcopyPasteHtml(data) { // copy paste table (HTML) if (data.name ==="") { data.name = '<b>Sans Nom</b> <font size=-2>(ID: '+data.id+')</font>'; } else { data.name = '<b>'+ data.name.substring(0, 37) +'</b>' } var div = document.createElement('div'); //Icon var icon = document.createElement('div'); (data.type=="point" ? icon.className = 'iconPoint' : icon.className = 'iconZone') div.appendChild(icon); //Text div.className = 'divBKM'; var divName = document.createElement('div'); divName.className = 'divName'; var divNameA = document.createElement('a'); divNameA.href = '#'; divNameA.innerHTML = data.name; divNameA.onclick = (function(){ W.map.setCenter(new OpenLayers.LonLat(parseFloat(data.geoX), parseFloat(data.geoY))); objectsIsLoaded('vn:'+ data.id); }); divName.appendChild(divNameA); div.appendChild(divName); // Suppr var divSuppr = document.createElement('div'); divSuppr.className = 'divIcons'; var divSupprA = document.createElement('a'); divSupprA.innerHTML = '<span class="fabkm fa fa-times" title="' + lang[11] + '" style="color:red;"></span>'; divSupprA.href = '#'; divSupprA.onclick = (function(){ BKMsuppr(data.name,data,'divCopyContent'); }); divSuppr.appendChild(divSupprA); div.appendChild(divSuppr); getId('divCopyContent').appendChild(div); } // *************************** // ** ACTIONS WITH BOOKMARK ** // **************************** function BKMhtmlEditName(container, data) { //Show Edit DIV clearTimeout(timer); $('#BKMedit').slideDown(200); if (container == 'divBookmarksContent') { getId('BKMedit').style.height = '133px'; } var content1 = '<div class="divEditTitre"><div class="divEdit">' + lang[6] + '</div><input type="text" id="divEditName" value="' + data.name + '" /><input type="hidden" id="permalink" value="' + data.perma.lon +'|'+ data.perma.lat + '" />'; content1 += '<div class="divIcons"><a href="#"><span id="EditValid" class="fabkm fa fa-check" title="' + lang[8] + '" style="font-size:16px;padding:6px;color:#0b0;"></a></div>'; content1 += '</div><div id="divComm">' + lang[14] + '</div></div><textarea id="divCommEdit">'; if (data.comm === '') { content1 += ''; } else { content1 += data.comm; } content1 += '</textarea>'; getId('BKMedit').innerHTML = content1; getId('divEditName').focus(); getId('divEditName').select(); getId('EditValid').onclick = (function(){ BKMeditName(container,"name"); }); } function BKMhtmlReminder(container, data,i) { //Show Edit DIV clearTimeout(timer); $('#BKMedit').slideDown(200); var content1 = '<div class="divEditTitre"><div class="divEdit">' + lang[6] + '</div><div>' + data.name + '</div><input type="hidden" id="permalink" value="' + data.perma.lon +'|'+ data.perma.lat + '" />' + '<div class="divIcons"><a href="#"><span id="RemCancel" class="fabkm fa fa-close" title="' + lang[9] + '" style="font-size:16px;color:#f00;"></a>' + '<a href="#"><span id="RemValid" class="fabkm fa fa-check" title="' + lang[8] + '" style="font-size:16px;color:#0b0;"></a></div><input style="width:135px;" id="remDate" type="date" /><input id="remTime" type="time" /></div></div>'; getId('BKMedit').innerHTML = content1; if (typeof(data.reminder) != "undefined" && data.reminder != null && data.reminder != "") { var d=new Date(parseInt(data.reminder)).toString(); } else { d=new Date().toString(); } var t=d.split(" "); getId('remDate').value = t[3] + "-" + pad(new Date(t[1]+'01, 01').getMonth()+1) + "-" + t[2]; getId('remTime').value = t[4].slice(0,5); getId('RemValid').onclick = (function(){ if (getId('remDate').value == "") { getId('remDate').value = t[3] + "-" + pad(new Date(t[1]+'01, 01').getMonth()+1) + "-" + t[2]; } if (getId('remDate').value != "") { if (getId('remTime').value == "") { getId('remTime').value = "00:00"; } BKMeditName(container,"date"); } else { $('#BKMedit').slideUp(200); } }); getId('RemCancel').onclick = (function(){ $('#BKMedit').slideUp(200); getId('iconReminder_'+i).style.color='#bbb'; }); } function BKMeditName(container,type) { //Action after editing name or comment (DB) $('#BKMedit').slideUp(200); var toSave=[]; //Bookmarks list update if (container === 'divBookmarksContent') { var a = JSON.parse(localStorage.WMEBookmarks); for (var p in a) { if(!a.hasOwnProperty(p)) continue; //Redo Bookmark var bNew={}; bNew.country=a[p].country; bNew.name=a[p].name; bNew.perma=a[p].perma; bNew.comm=a[p].comm; bNew.share=a[p].share; bNew.reminder=a[p].reminder; if (getId('permalink').value == a[p].perma.lon+'|'+a[p].perma.lat) { if (type == "name") { bNew.name=getId('divEditName').value; bNew.comm=getId('divCommEdit').value; } else { // type = date bNew.reminder=toTimestamp(getId('remDate').value, getId('remTime').value); } if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: UPDATE', BKMusername, bNew); } BKMupdateBookmarks('UPDATE',BKMusername, bNew, ''); } } //Store Bookmark toSave.push(bNew); } localStorage.setItem('WMEBookmarks', JSON.stringify(toSave)); } //Sharing list update else { a = JSON.parse(localStorage.WMEBookmarksShared); for (p in a) { if(!a.hasOwnProperty(p)) continue; //Redo Bookmark bNew={}; bNew.owner=a[p].owner; bNew.country=a[p].country; bNew.name=a[p].name; bNew.perma=a[p].perma; bNew.comm=a[p].comm; bNew.share=a[p].share; bNew.reminder=a[p].reminder; if (getId('permalink').value == a[p].perma.lon+'|'+a[p].perma.lat) { bNew.name=getId('divEditName').value; bNew.comm=getId('divCommEdit').value; if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: UPDATE', a[p].owner, bNew); } BKMupdateBookmarks('UPDATE',a[p].owner, bNew, ''); } } //Store Bookmark toSave.push(bNew); } localStorage.setItem('WMEBookmarksShared', JSON.stringify(toSave)); } //Reload HTML // BKMcheckActiveCountry(); if (container == 'divBookmarksContent') { getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); } else { getId('divShareContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divShareContent'); } } function BKMsuppr(name, id, container) { //Action after delete a bookmark (DB) clearTimeout(timer); if (debug) { console.info('WME Bookmarks Suppr: ', id); } var answer = window.confirm(lang[11] + ' ' + name.replace(/<\/?[^>]+(>|$)/g, "") + ' ?'); if (answer) { var toSave=[]; if (container === 'divHistoContent') { var a = JSON.parse(localStorage.WMEHistoric); for (var i = 0; a[i]; i++) { var bNew={}; bNew.date=a[i].date; bNew.perma=a[i].perma; bNew.name=a[i].name; if (JSON.stringify(bNew.perma) !== JSON.stringify(id)) { toSave.push(bNew); } } localStorage.setItem('WMEHistoric', JSON.stringify(toSave)); getId('divHistoContent').innerHTML = ''; loadBookmarks('WMEHistoric', 'divHistoContent'); } else if (container === 'divCopyContent') { a = JSON.parse(localStorage.WMECopyPastePOI); for (i = 0; a[i]; i++) { if (a[i].id != id.id) { toSave.push(a[i]); } else { // if (getId('chkSynchro').checked === true) { // if (debug) { console.log('WME Copy POI: DELETE', BKMusername, bNew); } // BKMupdateCopy('DELETE', BKMusername, id.id); // } } } localStorage.setItem('WMECopyPastePOI', JSON.stringify(toSave)); getId('divCopyContent').innerHTML = ''; loadBookmarks('WMECopyPastePOI', 'divCopyContent'); } else if (container === 'divBookmarksContent') { // Suppr own bookmark a = JSON.parse(localStorage.WMEBookmarks); for (i = 0; a[i]; i++) { bNew={}; bNew.country=a[i].country; bNew.name=a[i].name; bNew.perma=a[i].perma; bNew.comm=a[i].comm; bNew.share=a[i].share; bNew.reminder=a[i].reminder; if (JSON.stringify(bNew.perma) !== JSON.stringify(id)) { toSave.push(bNew); } else { if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: DELETE', BKMusername, bNew); } BKMupdateBookmarks('DELETE', BKMusername, bNew, ''); } } } localStorage.setItem('WMEBookmarks', JSON.stringify(toSave)); getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); } else { // Unshare a bookmark a = JSON.parse(localStorage.WMEBookmarksShared); for (i = 0; a[i]; i++) { bNew={}; bNew.owner = a[i].owner; bNew.country = a[i].country; bNew.name = a[i].name; bNew.perma = a[i].perma; bNew.comm = a[i].comm; bNew.share = a[i].share; bNew.reminder=a[i].reminder; if (JSON.stringify(bNew.perma) !== JSON.stringify(id)) { toSave.push(bNew); } else { if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: UNSHARE', a[i].owner, bNew); } BKMupdateBookmarks('UNSHARE', BKMusername, bNew, ''); } } } localStorage.setItem('WMEBookmarksShared', JSON.stringify(toSave)); getId('divShareContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divShareContent'); } getId('BKMedit').style.display = 'none'; } // BKMcheckActiveCountry(); } function BKMrelocate(oldPerma, name, iconId) { // Action after relocate a bookmark (DB) clearTimeout(timer); var answer = window.confirm(lang[13] + ' Lon/Lat/Zoom ? (' + name + ')'); if (answer) { var toSave=[]; link={}; getLink(document.getElementsByClassName('WazeControlPermalink')[0].getElementsByClassName('permalink')[0].href); //Bookmarks list update if (getId('divBookmarks').style.visibility == 'visible') { var a = JSON.parse(localStorage.WMEBookmarks); for (var i = 0; a[i]; i++) { var bNew={}; bNew.country = a[i].country; bNew.name = a[i].name; bNew.perma = a[i].perma; bNew.comm = a[i].comm; bNew.share = a[i].share; bNew.reminder=a[i].reminder; if (JSON.stringify(bNew.perma) === JSON.stringify(oldPerma)) { bNew.perma = link; if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: RELOCATE New', BKMusername, bNew.perma, oldPerma); } BKMupdateBookmarks('RELOCATE', BKMusername, bNew, oldPerma); } } toSave.push(bNew); } localStorage.setItem('WMEBookmarks', JSON.stringify(toSave)); getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); } //Sharing list update if (getId('divShare').style.visibility == 'visible') { a = JSON.parse(localStorage.WMEBookmarksShared); for (i = 0; a[i]; i++) { bNew={}; bNew.owner = a[i].owner; bNew.country = a[i].country; bNew.name = a[i].name; bNew.perma = a[i].perma; bNew.comm = a[i].comm; bNew.share = a[i].share; bNew.reminder=a[i].reminder; if (JSON.stringify(bNew.perma) === JSON.stringify(oldPerma)) { bNew.perma = link; if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: RELOCATE',a[i].owner, bNew, oldPerma); } BKMupdateBookmarks('RELOCATE', a[i].owner, bNew, oldPerma); } } toSave.push(bNew); } localStorage.setItem('WMEBookmarksShared', JSON.stringify(toSave)); getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divBookmarksContent'); } } getId('iconRelocate_'+iconId).style.color="#bbb"; // BKMcheckActiveCountry(); } function BKMinsertPermalink() { // Action when you add a new permalink (DB) BKMcountryActive = W.model.getTopCountry().name; link={}; getLink(document.getElementsByClassName('WazeControlPermalink')[0].getElementsByClassName('permalink')[0].href); //JSON for new permalink var bNew={}; bNew.country=BKMcountryActive; bNew.name=getName(); bNew.perma=link; bNew.comm=''; bNew.share=''; //Add in localStorage var lStorage = JSON.parse(localStorage.WMEBookmarks); lStorage.push(bNew); localStorage.setItem('WMEBookmarks', JSON.stringify(lStorage)); if (getId('chkSynchro').checked === true) { if (debug) { console.log('WME Bookmarks: ADD', BKMusername, bNew); } BKMupdateBookmarks('ADD', BKMusername, bNew, ''); } //Add in HTML table BKMtableHtml ('divBookmarksContent', bNew, 9999); BKMhtmlEditName('divBookmarksContent', bNew); //Reload Select list if new country if (countries.indexOf(BKMcountryActive) == - 1) { BKMtableCountries(); select(countries, 'selectCountry'); } W.selectionManager.unselectAll(); autoSwitchToBKMTab(); } function BKMPastePerma() { // Action when you paste a permalink setTimeout(function () { var exp = new RegExp('/(https?://(?:www.|beta.|(?!www))[^s.]+.[^s]{2,}|www.[^s]+.[^s]{2,})', 'g'); var a = BKMmapSearch.value; var b = BKMmapSearch.innerHTML; link={}; //console.log("a",a, a.match(exp)); //console.log("b",b, b.match(exp)); //Paste a permalink if (a.match(/waze/g) && a.match(/editor/g) && a.match(/lon/g) && a.match(/lat/g)) { // WME getLink(a); if (debug) { console.log('WME Bookmarks WME link: ', link); } BKMjump(BKMcountryActive,link,'paste'); setTimeout((function(){BKMaddHisto(link);}), 2500); } else if (a.match(/waze/g) && a.match(/livemap/g) && a.match(/latlng/g)) { // Livemap before 2021 b=a.split('?') var c=b[1].split('&') var d=c[0].split('=') var e=d[1].split('%2C') var f=c[2].split('='); link.lat = e[0]; link.lon = e[1]; link.zoom = (f[1]-12); if (debug) { console.log('WME Bookmarks Livemap link: ', link); } BKMjump(BKMcountryActive,link,'paste'); setTimeout((function(){BKMaddHisto(link);}), 2500); } else if (a.match(/waze/g) && (a.match(/live-map/g) && a.match(/to/g) || a.match(/ul/g))) { // Livemap 2021 b=a.split('=ll.') c=b[1].split('%2C'); link.lat = c[0]; link.lon = c[1]; if (debug) { console.log('WME Bookmarks Livemap link 2021: ', link); } BKMjump(BKMcountryActive,link,'paste'); setTimeout((function(){BKMaddHisto(link);}), 2500); } else if (a.match(exp) && a.match(/google/g) && a.match(/map/g) && a.match(/@/g)) { // Google Map URL b=a.split('@') c=b[1].split('/') d=c[0].split(','); link.lat = d[0]; link.lon = d[1]; link.zoom = (d[2].substring(0, d[2].length-1)); if (debug) { console.log('WME Bookmarks Google link: ', link); } BKMjump(BKMcountryActive,link,'paste'); setTimeout((function(){BKMaddHisto(link);}), 2500); } //Paste an ID else if (a.match(/\./g) && isNaN(a.replace(".",""))===false && a.length > 20) { //venue if (debug) { console.log('WME Bookmarks paste a venue: ', a); } objectsIsLoaded('vn:'+ a); } else if (isNaN(a)===false && a.length > 7) { //Segment or node if (debug) { console.log('WME Bookmarks paste a segment or node: ', a); } objectsIsLoaded('sg:'+ a); } //Reinit search-query }, 100); } function BKMjump(country,data,action) { // Action when you click a link //lastclic if (/link/.test(action) && getId('chkLastClic')) { for (var i=1; getId("link"+i); i++) { getId("link"+i).style.color='#59899e'; if ("link"+i===action) { getId("link"+i).style.color='#26bae8'; var a=JSON.parse(localStorage.WMEBookmarksSettings); a.lastclic=action; localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); } } } //Move to W.map.setCenter(OpenLayers.Layer.SphericalMercator.forwardMercator(parseFloat(data.lon), parseFloat(data.lat))); if (debug) { console.log('BKMjump',country,data,action); } //Options if (getId('chkZoom').checked && data.zoom) { W.map.getOLMap().zoomTo(data.zoom); } if (getId('chkServer').checked) { W.model.events.register("mergeend", null, mapLoaded); } if (action != 'paste' && getId('chkLayers').checked && data.layers) { layersLoaded(data.layers); } // layers when bookmarks if (action === 'paste' && getId('chkLayersPaste').checked && data.layers) { layersLoaded(data.layers); } // layers when paste form searchbar if (typeof (data.segments) != 'undefined') { objectsIsLoaded('sg:'+ data.segments); } else if (typeof (data.nodes) != 'undefined') { objectsIsLoaded('nd:'+ data.nodes); } else if (typeof (data.venues)!= 'undefined') { objectsIsLoaded('vn:'+ data.venues); } else if (typeof (data.MC) != 'undefined' && data.MC != 0) { objectsIsLoaded('mc:'+ data.MC); } else if (typeof (data.UR) != 'undefined' && data.UR != 0) { objectsIsLoaded('ur:'+ data.UR); } else if (typeof (data.MP) != 'undefined' && data.MP != 0) { objectsIsLoaded('mp:'+ data.MP); } else { colorSearch(); } //Reload list if country is changed if (country != W.model.getTopCountry().name) { getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); } BKMaddButtonIfLoad(); } // ************ // ** MISC ** // ************ function loadBookmarks(storage, dContainer) { //Fill HTML with localstorage var lStorage = localStorage.getItem(storage), bookmarkList=[]; if (lStorage) { getId(dContainer).innerHTML = ''; var a = JSON.parse(lStorage); if (getId('chkSort').checked) { a.reverse(); } var i=1; for (var p in a) { if(!a.hasOwnProperty(p)) continue; if (dContainer == 'divCopyContent') { BKMcopyPasteHtml(a[p]); } else if (dContainer == 'divHistoContent') { BKMhistoHtml(a[p]); } if (a[p].country == BKMcountryActive) { BKMtableHtml(dContainer, a[p], i); bookmarkList.push({name:a[p].name, lon:a[p].perma.lon, lat:a[p].perma.lat}); i++; } } update_bookmarks_layer(bookmarkList); } } function BKMaddButtonIfLoad() { //Show Pin if WME (permalink) is ready var a = getElementsByClassName('WazeControlPermalink') [0].innerHTML; if (!a.match(/lon/g)) { getId('addNodeButton').style.height='0'; $('addNodeButton').hide(); setTimeout(BKMaddButtonIfLoad, 500); return; } else { $('addNodeButton').show(); } } function BMKcheckStorage() { var settings = JSON.parse(localStorage.WMEBookmarksSettings); if (!settings.version) { //Convert if (debug) { console.info('WME Bookmarks : Convert old data to new JSON'); } var a = JSON.parse(localStorage.getItem('WMEBookmarks')), lStorage=[]; localStorage.setItem('WMEBookmarksShared', '[]'); localStorage.setItem('WMEBookmarks', '[]'); localStorage.setItem('WMEHistoric', '[]'); for (var p in a) { if(!a.hasOwnProperty(p)) continue; //Redo Bookmark var bNew={}; bNew.country=a[p].country; bNew.name=a[p].name; bNew.perma=BKMconvertPermalink(a[p].coord); bNew.comm=a[p].comm; bNew.share=a[p].share; bNew.reminder=a[p].reminder; //Store Bookmark lStorage.push(bNew); } localStorage.setItem('WMEBookmarks', JSON.stringify(lStorage)); if (debug) { console.info('WME Bookmarks : New JSON > localStorage Ok !'); } // Memorize version settings.version=BKMversion; localStorage.WMEBookmarksSettings=JSON.stringify(settings); } } function BKMcheckActiveCountry() { // Check Country and update select var BKMcountryActiveWME = W.model.getTopCountry().name; if (BKMcountryActive != BKMcountryActiveWME) { if (debug) { console.log('WME Bookmarks Country changed : ' + BKMcountryActive + ' > ' + BKMcountryActiveWME); } BKMcountryActive = BKMcountryActiveWME; select(countries, 'selectCountry'); select(countriesS, 'selectCountryS'); loadBookmarks('WMEBookmarks', 'divBookmarksContent'); loadBookmarks('WMEBookmarksShared', 'divShareContent'); getId('selectCountry').addEventListener("change",(function () { clearTimeout(timer); BKMcheckActiveCountry(); BKMcountryActive = getId('selectCountry').value; getId('divBookmarksContent').innerHTML = ''; loadBookmarks('WMEBookmarks', 'divBookmarksContent'); getId('iconBookmarks').click(); })); getId('selectCountryS').addEventListener("change",(function () { clearTimeout(timer); BKMcheckActiveCountry(); BKMcountryActive = getId('selectCountryS').value; getId('divShareContent').innerHTML = ''; loadBookmarks('WMEBookmarksShared', 'divShareContent'); getId('iconShare').click(); })); } clearTimeout(timer); setTimeout(timer = setTimeout(BKMcheckActiveCountry, 5000),100); } function BMKcheckAutoSave() { //Show shared if sync with server if (getId('chkSynchro').checked === true) { $('#iconShare').animate({ width: '24px' }, 200); } else { $('#iconShare').animate({ width: '0' }, 200); } } function select(cArray, selectlist) { // Fill select //Add countries in select BKMcountryActive = W.model.getTopCountry().name; var CSelect = getId(selectlist); if (CSelect !== null) { CSelect.innerHTML = ''; for (var k = 0; cArray[k]; k++) { var cList = document.createElement('option'); cList.value =cArray[k]; cList.text = cArray[k]; if (cArray[k] == BKMcountryActive) cList.selected = true; CSelect.appendChild(cList); } //If country not listed if (cArray.indexOf(BKMcountryActive) == - 1) { cList = document.createElement('option'); cList.value = BKMcountryActive; cList.text = BKMcountryActive; cList.selected = true; CSelect.appendChild(cList); } } } function mapLoaded() { // Test map server and change it if necessary if(typeof(W.model.getTopCountry()) === 'undefined' || W.model.getTopCountry() === null) { setTimeout(mapLoaded, 500); return; } var loc=W.model.getTopCountry().env.replace('NA','usa').toLowerCase(); if (getId('chkServer').checked && loc !== W.app.getAppRegionCode()) { var a = JSON.parse(localStorage.mapLocation); a[loc]=a[W.app.getAppRegionCode()]; localStorage.setItem('mapLocation', JSON.stringify(a)); // W.map.mapState.updateMapLocation(loc); W.app.changeAppRegion(loc) } } function layersLoaded(layers) { // Load layers when jump var num = Number(layers).toString(2); num = num.split('').reverse().join(''); // First : groups layerCheck("group_issues", num.charAt(0)); layerCheck("group_map_issues", num.charAt(1)); layerCheck("group_parking_issues", num.charAt(7)); layerCheck("group_places", num.charAt(11)); layerCheck("group_road", num.charAt(15)); layerCheck("group_display", num.charAt(20)); layerCheck("group_cities", num.charAt(27)); // Second : items layerCheck("item_map_problems", num.charAt(2)); layerCheck("item_closed_map_problems", num.charAt(3)); layerCheck("item_update_requests", num.charAt(4)); layerCheck("item_closed_update_requests", num.charAt(5)); layerCheck("item_place_update_requests", num.charAt(6)); layerCheck("item_residential_place_update_requests", num.charAt(30)); layerCheck("item_parking_map_problems", num.charAt(8)); layerCheck("item_parking_closed_map_problems", num.charAt(9)); layerCheck("item_parking_place_update_requests", num.charAt(10)); layerCheck("item_venues", num.charAt(12)); layerCheck("item_residential_places", num.charAt(13)); layerCheck("item_parking_places", num.charAt(14)); layerCheck("item_road", num.charAt(16)); layerCheck("item_junction_boxes", num.charAt(17)); layerCheck("item_closures", num.charAt(18)); layerCheck("item_speed_cameras", num.charAt(19)); layerCheck("item_railroad_crossings", num.charAt(34)); layerCheck("item_house_numbers", num.charAt(31)); layerCheck("item_satellite_imagery", num.charAt(21)); layerCheck("item_area_managers", num.charAt(22)); layerCheck("item_gps_points", num.charAt(23)); layerCheck("item_editable_areas", num.charAt(25)); layerCheck("item_live_users", num.charAt(24)); layerCheck("item_disallowed_turns", num.charAt(29)); layerCheck("item_map_comments", num.charAt(26)); layerCheck("item_city_names", num.charAt(28)); function layerCheck(layerName, state) { try { if ($('#layer-switcher-'+layerName).prop('checked') && state==0 || $('#layer-switcher-'+layerName).prop('checked')===false && state==1) { $('#layer-switcher-'+layerName).click(); } } catch (e) { console.log("error while check layers: ", e); } } } function objectsIsLoaded(selObjects) { if (debug) { console.log('objectsIsLoaded',selObjects); } if (selObjects) { var objectsList = [], idObj=selObjects.substring(3).split(','); try { for (var i=0; idObj[i]; i++) { // Identify type switch (selObjects.substring(0, 2)) { case 'sg': var objType = W.selectionManager.model.segments.objects[idObj[i]]; var type = I18n.translations[I18n.locale].layers.name.segments; break; case 'nd': objType = W.selectionManager.model.nodes.objects[idObj[i]]; type = I18n.translations[I18n.locale].layers.name.nodes; break; case 'vn': objType = W.selectionManager.model.venues.objects[idObj[i]]; type = I18n.translations[I18n.locale].layers.name.landmarks; break; case 'ur': objType = "ur"; type = I18n.translations[I18n.locale].layers.name.update_requests; break; case 'mp': objType = "mp"; type = I18n.translations[I18n.locale].layers.name.problems; break; case 'mc': objType = W.selectionManager.model.mapComments.objects[idObj[i]]; type = I18n.translations[I18n.locale].layers.name.comments; break; default : break; } // Try to select if ((typeof objType === 'undefined' || typeof objType === 'string') && typeof W.map.updateRequestLayer.featureMarkers[idObj[i]] === 'undefined' && typeof W.map.problemLayer.featureMarkers[String(idObj[i].replace('%2F','/'))] === 'undefined' ) { count++; if (debug) { console.info('LOOP (' + count + '): try to select '+type+' :' + idObj[i]); } if (count >= 10) { alert(type +'\n'+ I18n.translations[I18n.locale].problems.panel.more_info.not_available); count=0; setTimeout(function () { BKMmapSearch.style.backgroundColor = ''; BKMmapSearch.style.color=''; BKMmapSearch.value=''; BKMmapSearch.placeholder=lang[17]; }, 2000); return; } setTimeout((function(){ objectsIsLoaded(selObjects); }), 750); return; } else { if (debug) { console.info('LOOP : found '+type+' :' + idObj[i]); } if (selObjects.substring(0, 2) === 'ur') { W.map.updateRequestLayer.featureMarkers[idObj[i]].marker.icon.$div[0].click(); } else if (selObjects.substring(0, 2) === 'mp') { W.map.problemLayer.featureMarkers[String(idObj[i].replace('%2F','/'))].marker.icon.$div[0].click(); } else if (selObjects.substring(0, 2) === 'vn') { objectsList.push(W.model.venues.objects[idObj[i]]); } else if (selObjects.substring(0, 2) === 'nd') { objectsList.push(W.model.nodes.objects[idObj[i]]); } else if (selObjects.substring(0, 2) === 'mc') { objectsList.push(W.model.mapComments.objects[idObj[i]]); } else { objectsList.push(W.model.segments.objects[idObj[i]]); } count=0; setTimeout(function () { BKMmapSearch.style.backgroundColor = ''; BKMmapSearch.style.color=''; BKMmapSearch.value=''; BKMmapSearch.placeholder=lang[17]; }, 2000); } } } catch (e) { console.log("error while getting selected item: ", e); } selObjects = ''; if (objType !== "none") { W.selectionManager.unselectAll(); W.selectionManager.setSelectedModels(objectsList); } colorSearch(type); } } function BKMconvertPermalink(data) { //Redo permalink if (data) { var l=data.split("|"), link = {}; link.env=l[5]; link.lat=l[1]; link.lon=l[0]; link.zoom=l[2]; link.layers=l[3]; link.MP=l[6]; link.UR=l[7]; link.MC=l[8]; if (l[4]) { switch (l[4].substring(0, 1)) { case 's': link.segments = l[4].substring(2); break; case 'n': link.nodes = l[4].substring(2); break; case 'v': link.venues = l[4].substring(2); break; } } Object.keys(link).sort(); return link; } } function colorSearch(msg) { setTimeout(function () { BKMmapSearch.style.backgroundColor='#4d4d4d'; BKMmapSearch.style.color='white'; (msg ? msg=msg+': ' : msg='') BKMmapSearch.value=msg+lang[18]; }, 500); setTimeout(function () { BKMmapSearch.style.backgroundColor = ''; BKMmapSearch.style.color=''; BKMmapSearch.value=''; BKMmapSearch.placeholder=lang[17]; }, 2000); } // *********************** // ** ANIMATE FUNCTIONS ** // *********************** function bookmarksToggle() { $('#divBookmarks').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideDown(); $('#iconBookmarks').css('color', '#36c'); $('#divShare').slideUp(); $('#iconShare').css('color', '#bbb'); $('#divHisto').slideUp(); $('#iconHisto').css('color', '#bbb'); $('#divCopy').slideUp(); $('#iconCopy').css('color', '#bbb'); $('#divBackup').slideUp(); $('#iconBackup').css('color', '#bbb'); $('#divSettings').slideUp(); $('#iconSettings').css('color', '#bbb'); $('#BKMedit').slideUp(200); // BKMcheckActiveCountry(); reloadHtmlBookmarks(); if (getId('chkSynchro').checked === true) { getBookmarks(); } } function shareToggle() { $('#divShare').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideUp(); $('#iconBookmarks').css('color', '#bbb'); $('#divShare').slideDown(); $('#iconShare').css('color', '#36c'); $('#divHisto').slideUp(); $('#iconHisto').css('color', '#bbb'); $('#divCopy').slideUp(); $('#iconCopy').css('color', '#bbb'); $('#divBackup').slideUp(); $('#iconBackup').css('color', '#bbb'); $('#divSettings').slideUp(); $('#iconSettings').css('color', '#bbb'); $('#BKMedit').slideUp(200); // BKMcheckActiveCountry(); getShared(); } function histoToggle() { $('#divHisto').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideUp(); $('#iconBookmarks').css('color', '#bbb'); $('#divShare').slideUp(); $('#iconShare').css('color', '#bbb'); $('#divHisto').slideDown(); $('#iconHisto').css('color', '#36c'); $('#divCopy').slideUp(); $('#iconCopy').css('color', '#bbb'); $('#divBackup').slideUp(); $('#iconBackup').css('color', '#bbb'); $('#divSettings').slideUp(); $('#iconSettings').css('color', '#bbb'); $('#BKMedit').slideUp(200); loadBookmarks('WMEHistoric', 'divHistoContent'); } function copyToggle() { $('#divCopy').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideUp(); $('#iconBookmarks').css('color', '#bbb'); $('#divShare').slideUp(); $('#iconShare').css('color', '#bbb'); $('#divHisto').slideUp(); $('#iconHisto').css('color', '#bbb'); $('#divCopy').slideDown(); $('#iconCopy').css('color', '#36c'); $('#divBackup').slideUp(); $('#iconBackup').css('color', '#bbb'); $('#divSettings').slideUp(); $('#iconSettings').css('color', '#bbb'); $('#BKMedit').slideUp(200); reloadHtmlCopy(); // if (getId('chkSynchro').checked === true) { getCopyPaste(); } } function backupToggle() { $('#divBackup').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideUp(); $('#iconBookmarks').css('color', '#bbb'); $('#divShare').slideUp(); $('#iconShare').css('color', '#bbb'); $('#divHisto').slideUp(); $('#iconHisto').css('color', '#bbb'); $('#divCopy').slideUp(); $('#iconCopy').css('color', '#bbb'); $('#divBackup').slideDown(); $('#iconBackup').css('color', '#36c'); $('#divSettings').slideUp(); $('#iconSettings').css('color', '#bbb'); $('#BKMedit').slideUp(200); BKMbackup(); } function settingsToggle() { $('#divSettings').css('visibility', 'visible'); $('#divContent').css('display', 'block'); $('#divBookmarks').slideUp(); $('#iconBookmarks').css('color', '#bbb'); $('#divShare').slideUp(); $('#iconShare').css('color', '#bbb'); $('#divHisto').slideUp(); $('#iconHisto').css('color', '#bbb'); $('#divCopy').slideUp(); $('#iconCopy').css('color', '#bbb'); $('#divBackup').slideUp(); $('#iconBackup').css('color', '#bbb'); $('#divSettings').slideDown(); $('#iconSettings').css('color', '#36c'); $('#BKMedit').slideUp(200); } // ******************** // ** BOOKMARK LAYER ** // ******************** function checklayer(layer) { if(W.map.getLayersBy("uniqueName",layer).length === 0) { var LU_style=new OpenLayers.Style({ pointRadius: 2, fontWeight: "normal", label : "${labelText}", fontFamily: "Tahoma, Courier New", labelOutlineColor: "#FFFFFF", labelOutlineWidth: 2, fontColor: '#000000', fontSize: "10px" }); if (layer=="__WME_Bookmarks") { bookmarks_Layer=new OpenLayers.Layer.Vector("Bookmarks", { displayInLayerSwitcher: true, uniqueName: layer, shortcutKey: "S+b" //styleMap: new OpenLayers.StyleMap(LU_style) }); bookmarks_Layer.setVisibility(true); W.map.addLayer(bookmarks_Layer); I18n.translations[I18n.locale].layers.name[layer]="Bookmarks"; } } } function createToggler(){ // Layers switcher // test with script toggler---------------- var oldTogglers=document.querySelectorAll('.togglers'); oldTogglers.forEach(function(elt,indx){ if(elt.id != "toolboxUl"){ if (oldTogglers[indx].querySelector('.layer-switcher-group_scripts') === null) { var newScriptsToggler=document.createElement('li'); newScriptsToggler.className='group'; newScriptsToggler.innerHTML='<div class="controls-container main toggler">\<input class="layer-switcher-group_scripts toggle" id="layer-switcher-group_scripts" type="checkbox">\<label for="layer-switcher-group_scripts">\<span class="label-text">Scripts</span>\</label>\</div>\<ul class="children">\</ul>'; oldTogglers[indx].appendChild(newScriptsToggler); } var groupScripts=document.querySelector('.layer-switcher-group_scripts').parentNode.parentNode; var newScriptsChildren=getElementsByClassName("children", groupScripts)[0]; var WMECS_toggleUser=document.createElement('li'); WMECS_toggleUser.innerHTML='<div class="controls-container toggler">\<input class="layer-switcher-item_WME_bookmarks toggle" id="layer-switcher-item_WME_bookmarks" type="checkbox">\<label for="layer-switcher-item_WME_bookmarks">\<span class="label-text">Bookmarks</span>\</label>\</div>'; newScriptsChildren.appendChild(WMECS_toggleUser); var toggleUser=getId('layer-switcher-item_WME_bookmarks'); newScriptsChildren.appendChild(WMECS_toggleUser); var groupToggler=getId('layer-switcher-group_scripts'); groupToggler.checked=(typeof(localStorage.groupScriptsToggler) !=="undefined" ? JSON.parse(localStorage.groupScriptsToggler) : true); toggleUser.disabled=!groupToggler.checked; toggleUser.addEventListener('click', function(e) { bookmarks_Layer.setVisibility(e.target.checked); var a=JSON.parse(localStorage.WMEBookmarksSettings); a.showBookmark=e.target.checked; localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); }); groupToggler.addEventListener('click', function(e) { toggleUser.disabled=!e.target.checked; bookmarks_Layer.setVisibility(toggleUser.checked ? e.target.checked : toggleUser.checked); localStorage.setItem('groupScriptsToggler', e.target.checked); }); } }); } function LayerToggled(checked){ bookmarks_Layer.setVisibility(checked); // var a=JSON.parse(localStorage.WMEBookmarksSettings); // a.showBookmark=checked; // localStorage.setItem('WMEBookmarksSettings', JSON.stringify(a)); } function update_bookmarks_layer(bookmarkList) { if (bookmarks_Layer.visibility == true && bookmarkList.length != 0) { bookmarks_Layer.destroyFeatures(); for (var k=0; k < bookmarkList.length; k++) { var marker=new OpenLayers.Feature.Vector(Geometrize(bookmarkList[k].lon, bookmarkList[k].lat), null, { fillOpacity: 1, fontSize: 15, fontColor: "#ffff00", label: bookmarkList[k].name, labelYOffset: 22, labelOutlineColor: "#ff0000", labelOutlineWidth: 5, stroke: true, strokeColor: "#ff0000", strokeWidth: 15, strokeDashstyle: "solid" }); var showBookmarks_Layer=W.map.layers.find(function (l) { return l.uniqueName == "__WME_Bookmarks"; }); showBookmarks_Layer.addFeatures(marker); } } } function Geometrize(lat, lon) { var polyPoints= new OpenLayers.Geometry.Point(lat,lon).transform( new OpenLayers.Projection("EPSG:4326") , W.map.getProjectionObject()); var polygon=new OpenLayers.Geometry.Polygon(new OpenLayers.Geometry.LinearRing(polyPoints)); return polygon; } // ************************* // ** PREV/NEXT FUNCTIONS ** // ************************* function updatePos(){ if(_stopUpdPos)return; var perma = getPermalink(); var DPerma = DecodePermalink(perma); if(DPerma.zoom < 4) return; if(_cur == perma) return; if(_cur !== ''){ var newDPerma = DecodePermalink(perma); var oldDPerma = DecodePermalink(_cur); if(oldDPerma['lat'] == newDPerma['lat'] && oldDPerma['lon'] == newDPerma['lon'] && oldDPerma['zoom'] == newDPerma['zoom']){ function checkElm(type, patt){ _cur = _cur.replace(patt, ''); if(typeof(newDPerma[type]) !== 'undefined'){ _cur = _cur + perma.match(patt)[1]; } } checkElm('layers', /(&s=[\d]+)/); checkElm('segments', /(&segments=[\d,]+)/); checkElm('nodes', /(&nodes=[\d]+)/); checkElm('venues', /(&venues=[\d.-]+)/); checkElm('mapComments', /(&mapComments=[\d.-]+)/); return; } _prev.unshift(_cur); } _cur = perma; if(_prev.length > 0) { getId('prevIcon').className='toolbar-button toolbar-button-with-label'; } if(_next.length == 0) { getId('nextIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } else { getId('nextIcon').className='toolbar-button toolbar-button-with-label'; } // Limit historic to 20 while(_prev.length > 19)_prev.pop(); var a={}; a.prev=_prev; a.next=_next; localStorage.setItem('WMEPrevNext', JSON.stringify(a)); } function NavNext(e){ if(e.ctrlKey || e.altKey){ clearHistoric(e,false); return; } if(_next.length > 0){ _prev.unshift(_cur); _cur = _next.shift(); getId('prevIcon').className='toolbar-button toolbar-button-with-label'; if(_next.length === 0) { getId('nextIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } var a={}; a.prev=_prev; a.next=_next; localStorage.setItem('WMEPrevNext', JSON.stringify(a)); RelocateMap(); } else getId('nextIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } function NavPrev(e){ if(e.ctrlKey || e.altKey){ clearHistoric(e, true); return; } if(_prev.length > 0){ _next.unshift(_cur); _cur = _prev.shift(); getId('nextIcon').className='toolbar-button toolbar-button-with-label'; if(_prev.length === 0) { getId('prevIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } var a={}; a.prev=_prev; a.next=_next; localStorage.setItem('WMEPrevNext', JSON.stringify(a)); RelocateMap(); } else getId('prevIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } function clearHistoric(e, isPrev){ if(e.altKey){ _prev.splice(0, _prev.length); getId('prevIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; _next.splice(0, _next.length); getId('nextIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } else{ if(isPrev){ _prev.splice(0, _prev.length); getId('prevIcon').className='toolbar-button toolbar-button-with-label ItemDisabled'; } else{ _next.splice(0, _next.length); getId('nextIcon').innerHTML='<i class="fa fa-arrow-circle-right"></i>'; } } } function getPermalink(){ return document.getElementsByClassName('WazeControlPermalink')[0].getElementsByClassName('permalink')[0].href; } function checkPermaLink(){ _newP = getPermalink(); if(_newP != _oldP){ _oldP = _newP; updatePos(); } } function DecodePermalink(perma){ var DecodedPerma = []; perma = perma.replace(/#$/, ''); var patt = /[?&](\w+)=([\w\d-.,]+)/g; var res = perma.match(patt); for(var i=0; i < res.length; i++){ patt = /[?&](\w+)=([\w\d-.,]+)/; var nres = res[i].match(patt); DecodedPerma[nres[1]] = nres[2]; } return DecodedPerma; } function RelocateMap(){ _stopUpdPos = true; if (getId('chkHistoSelect').checked) { W.selectionManager.unselectAll(); } var DecodedPerma = DecodePermalink(_cur); W.map.setCenter(OpenLayers.Layer.SphericalMercator.forwardMercator(parseFloat(DecodedPerma.lon), parseFloat(DecodedPerma.lat))); W.map.getOLMap().zoomTo(DecodedPerma.zoom); updateSelectedItems(); } function updateSelectedItems(){ if(_cur == '')return; _stopUpdPos = true; var DecodedPerma = DecodePermalink(_cur); var tmp; if(typeof(DecodedPerma['segments']) !== 'undefined'){ if(!selectSegments(DecodedPerma['segments'].split(",")))return; } else if(typeof(DecodedPerma['venues']) !== 'undefined'){ tmp = W.model.venues.getObjectById(DecodedPerma['venues']); if(tmp === 'undefined')return; selectItem([tmp]); } else if(typeof(DecodedPerma['nodes']) !== 'undefined'){ tmp = W.model.nodes.getObjectById(DecodedPerma['nodes']); if(tmp === 'undefined')return; selectItem([tmp]); } else if(typeof(DecodedPerma['mapComments']) !== 'undefined'){ TMP + W.model.mapComments.getObjectById(DecodedPerma['mapComments']); if(tmp === 'undefined')return; selectItem([tmp]); } _stopUpdPos = false; function selectSegments(segList){ var segObj = []; for(var i=0; i<segList.length; i++){ var theSeg = W.model.segments.getObjectById(segList[i]); if(typeof(theSeg) !== 'undefined')segObj.push(theSeg); } if(segObj.length > 0){ selectItem(segObj); return true; } return false; } function selectItem(obj){ if(getId('chkHistoNav').checked && getId('chkHistoSelect').checked) { W.selectionManager.setSelectedModels(obj); } } } console.log('WME Bookmarks : ' + BKMversion + ' starting'); BKMinit(); } const _timeouts = { onWmeReady: undefined, } function checkTimeout(obj) { if (obj.toIndex) { if (_timeouts[obj.timeout]?.[obj.toIndex]) { window.clearTimeout(_timeouts[obj.timeout][obj.toIndex]); delete (_timeouts[obj.timeout][obj.toIndex]); } } else { if (_timeouts[obj.timeout]) { window.clearTimeout(_timeouts[obj.timeout]); } _timeouts[obj.timeout] = undefined; } } function log(message) { if (typeof message === 'string') { console.log('%cWME Bookmarks: %c' + message, 'color:black', 'color:#d97e00'); } else { console.log('%cWME Bookmarks:', 'color:black', message); } } function onWmeReady(tries = 1) { if (typeof tries === 'object') { tries = 1; } checkTimeout({ timeout: 'onWmeReady' }); if (WazeWrap?.Ready) { log('WazeWrap is ready. Proceeding with initialization.'); onWazeWrapReady(); } else if (tries < 1000) { log(`WazeWrap is not in Ready state. Retrying ${tries} of 1000.`); _timeouts.onWmeReady = window.setTimeout(onWmeReady, 200, ++tries); } else { log('onWmeReady timed out waiting for WazeWrap Ready state.'); } } function onWmeInitialized() { if (W.userscripts?.state?.isReady) { log('W is ready and in "wme-ready" state. Proceeding with initialization.'); onWmeReady(); } else { log('W is ready, but not in "wme-ready" state. Adding event listener.'); document.addEventListener('wme-ready', onWmeReady, { once: true }); } } function bootstrap() { if (!W) { log('W is not available. Adding event listener.'); document.addEventListener('wme-initialized', onWmeInitialized, { once: true }); } else { onWmeInitialized(); } } bootstrap();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址