Created
April 25, 2014 18:37
-
-
Save 3ch01c/11299044 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @id iitc-plugin-bookmarks@3ch01c | |
// @name IITC plugin: Bookmarks for maps and portals | |
// @category Controls | |
// @version 0.2.8.20140313.215026 | |
// @namespace https://github.com/3ch01c/ingress-intel-total-conversion | |
// @updateURL none | |
// @downloadURL none | |
// @description [local-2014-03-13-215026] Save your favorite Maps and Portals and move the intel map with a click. Works with sync. | |
// @include https://www.ingress.com/intel* | |
// @include http://www.ingress.com/intel* | |
// @match https://www.ingress.com/intel* | |
// @match http://www.ingress.com/intel* | |
// @grant none | |
// ==/UserScript== | |
function wrapper(plugin_info) { | |
// ensure plugin framework is there, even if iitc is not yet loaded | |
if(typeof window.plugin !== 'function') window.plugin = function() {}; | |
//PLUGIN AUTHORS: writing a plugin outside of the IITC build environment? if so, delete these lines!! | |
//(leaving them in place might break the 'About IITC' page or break update checks) | |
plugin_info.buildName = 'local'; | |
plugin_info.dateTimeVersion = '20140313.215026'; | |
plugin_info.pluginId = 'bookmarks-by-zaso'; | |
//END PLUGIN AUTHORS NOTE | |
// PLUGIN START //////////////////////////////////////////////////////// | |
/*********************************************************************** | |
HOOKS: | |
- pluginBkmrksEdit: fired when a bookmarks/folder is removed, added or sorted, also when a folder is opened/closed; | |
- pluginBkmrksOpenOpt: fired when the "Bookmarks Options" panel is opened (you can add new options); | |
- pluginBkmrksSyncEnd: fired when the sync is finished; | |
***********************************************************************/ | |
//////////////////////////////////////////////////////////////////////// | |
// use own namespace for plugin | |
window.plugin.bookmarks = function() {}; | |
window.plugin.bookmarks.SYNC_DELAY = 5000; | |
window.plugin.bookmarks.KEY_OTHER_BKMRK = 'idOthers'; | |
window.plugin.bookmarks.KEY_STORAGE = 'plugin-bookmarks'; | |
window.plugin.bookmarks.KEY_STATUS_BOX = 'plugin-bookmarks-box'; | |
window.plugin.bookmarks.KEY = {key: window.plugin.bookmarks.KEY_STORAGE, field: 'bkmrksObj'}; | |
window.plugin.bookmarks.UPDATE_QUEUE = {key: 'plugin-bookmarks-queue', field: 'updateQueue'}; | |
window.plugin.bookmarks.UPDATING_QUEUE = {key: 'plugin-bookmarks-updating-queue', field: 'updatingQueue'}; | |
window.plugin.bookmarks.bkmrksObj = {}; | |
window.plugin.bookmarks.statusBox = {}; | |
window.plugin.bookmarks.updateQueue = {}; | |
window.plugin.bookmarks.updatingQueue = {}; | |
window.plugin.bookmarks.enableSync = false; | |
window.plugin.bookmarks.starLayers = {}; | |
window.plugin.bookmarks.starLayerGroup = null; | |
window.plugin.bookmarks.isSmart = undefined; | |
window.plugin.bookmarks.isAndroid = function() { | |
if(typeof android !== 'undefined' && android) { | |
return true; | |
} | |
return false; | |
} | |
/*********************************************************************************************************************/ | |
// Generate an ID for the bookmark (date time + random number) | |
window.plugin.bookmarks.generateID = function() { | |
var d = new Date(); | |
var ID = d.getTime()+(Math.floor(Math.random()*99)+1); | |
var ID = 'id'+ID.toString(); | |
return ID; | |
} | |
// Format the string | |
window.plugin.bookmarks.escapeHtml = function(text) { | |
return text | |
.replace(/&/g, "&") | |
.replace(/</g, "<") | |
.replace(/>/g, ">") | |
.replace(/"/g, """) | |
.replace(/'/g, "'") | |
.replace(/\//g, '/') | |
.replace(/\\/g, '\'); | |
} | |
// Update the localStorage | |
window.plugin.bookmarks.saveStorage = function() { | |
localStorage[plugin.bookmarks.KEY_STORAGE] = JSON.stringify(window.plugin.bookmarks.bkmrksObj); | |
} | |
// Load the localStorage | |
window.plugin.bookmarks.loadStorage = function() { | |
window.plugin.bookmarks.bkmrksObj = JSON.parse(localStorage[plugin.bookmarks.KEY_STORAGE]); | |
} | |
window.plugin.bookmarks.saveStorageBox = function() { | |
localStorage[plugin.bookmarks.KEY_STATUS_BOX] = JSON.stringify(window.plugin.bookmarks.statusBox); | |
} | |
window.plugin.bookmarks.loadStorageBox = function() { | |
window.plugin.bookmarks.statusBox = JSON.parse(localStorage[plugin.bookmarks.KEY_STATUS_BOX]); | |
} | |
window.plugin.bookmarks.upgradeToNewStorage = function() { | |
if(localStorage['plugin-bookmarks-portals-data'] && localStorage['plugin-bookmarks-maps-data']) { | |
var oldStor_1 = JSON.parse(localStorage['plugin-bookmarks-maps-data']); | |
var oldStor_2 = JSON.parse(localStorage['plugin-bookmarks-portals-data']); | |
window.plugin.bookmarks.bkmrksObj.maps = oldStor_1.bkmrk_maps; | |
window.plugin.bookmarks.bkmrksObj.portals = oldStor_2.bkmrk_portals; | |
window.plugin.bookmarks.saveStorage(); | |
localStorage.removeItem('plugin-bookmarks-maps-data'); | |
localStorage.removeItem('plugin-bookmarks-portals-data'); | |
localStorage.removeItem('plugin-bookmarks-status-box'); | |
} | |
} | |
window.plugin.bookmarks.createStorage = function() { | |
if(!localStorage[window.plugin.bookmarks.KEY_STORAGE]) { | |
window.plugin.bookmarks.bkmrksObj.maps = {idOthers:{label:"Others",state:1,bkmrk:{}}}; | |
window.plugin.bookmarks.bkmrksObj.portals = {idOthers:{label:"Others",state:1,bkmrk:{}}}; | |
window.plugin.bookmarks.saveStorage(); | |
} | |
if(!localStorage[window.plugin.bookmarks.KEY_STATUS_BOX]) { | |
window.plugin.bookmarks.statusBox.show = 1; | |
window.plugin.bookmarks.statusBox.page = 0; | |
window.plugin.bookmarks.statusBox.pos = {x:100,y:100}; | |
window.plugin.bookmarks.saveStorageBox(); | |
} | |
} | |
window.plugin.bookmarks.refreshBkmrks = function() { | |
$('#bkmrk_maps > ul, #bkmrk_portals > ul').remove(); | |
window.plugin.bookmarks.loadStorage(); | |
window.plugin.bookmarks.loadList('maps'); | |
window.plugin.bookmarks.loadList('portals'); | |
window.plugin.bookmarks.updateStarPortal(); | |
window.plugin.bookmarks.jquerySortableScript(); | |
} | |
/***************************************************************************************************************************************************************/ | |
// Show/hide the bookmarks box | |
window.plugin.bookmarks.switchStatusBkmrksBox = function(status) { | |
var newStatus = status; | |
if(newStatus === 'switch') { | |
if(window.plugin.bookmarks.statusBox.show === 1) { | |
newStatus = 0; | |
} else { | |
newStatus = 1; | |
} | |
} | |
if(newStatus === 1) { | |
$('#bookmarksBox').css('height', 'auto'); | |
$('#bkmrksTrigger').css('height', '0'); | |
} else { | |
$('#bkmrksTrigger').css('height', '64px'); | |
$('#bookmarksBox').css('height', '0'); | |
} | |
window.plugin.bookmarks.statusBox['show'] = newStatus; | |
window.plugin.bookmarks.saveStorageBox(); | |
} | |
window.plugin.bookmarks.onPaneChanged = function(pane) { | |
if(pane == "plugin-bookmarks") | |
$('#bookmarksBox').css("display", ""); | |
else | |
$('#bookmarksBox').css("display", "none"); | |
} | |
// Switch list (maps/portals) | |
window.plugin.bookmarks.switchPageBkmrksBox = function(elem, page) { | |
window.plugin.bookmarks.statusBox.page = page; | |
window.plugin.bookmarks.saveStorageBox(); | |
$('h5').removeClass('current'); | |
$(elem).addClass('current'); | |
var sectList = '#'+$(elem).attr('class').replace(' current', ''); | |
$('#bookmarksBox .bookmarkList').removeClass('current'); | |
$(sectList).addClass('current'); | |
} | |
// Switch the status folder to open/close (in the localStorage) | |
window.plugin.bookmarks.openFolder = function(elem) { | |
$(elem).parent().parent('li').toggleClass('open'); | |
var typeList = $(elem).parent().parent().parent().parent('div').attr('id').replace('bkmrk_', ''); | |
var ID = $(elem).parent().parent('li').attr('id'); | |
var newFlag; | |
var flag = window.plugin.bookmarks.bkmrksObj[typeList][ID]['state']; | |
if(flag) { newFlag = 0; } | |
else if(!flag) { newFlag = 1; } | |
window.plugin.bookmarks.bkmrksObj[typeList][ID]['state'] = newFlag; | |
window.plugin.bookmarks.saveStorage(); | |
window.runHooks('pluginBkmrksEdit', {"target": "folder", "action": newFlag?"open":"close", "id": ID}); | |
} | |
// Load the HTML bookmarks | |
window.plugin.bookmarks.loadList = function(typeList) { | |
var element = ''; | |
var elementTemp = ''; | |
var elementExc = ''; | |
var returnToMap = ''; | |
if(window.plugin.bookmarks.isSmart) { | |
returnToMap = 'window.show(\'map\');'; | |
} | |
// For each folder | |
var list = window.plugin.bookmarks.bkmrksObj[typeList]; | |
for(var idFolders in list) { | |
var folders = list[idFolders]; | |
var active = ''; | |
// Create a label and a anchor for the sortable | |
var folderDelete = '<span class="folderLabel"><a class="bookmarksRemoveFrom" onclick="window.plugin.bookmarks.removeElement(this, \'folder\');return false;" title="Remove this folder">X</a>'; | |
var folderName = '<a class="bookmarksAnchor" onclick="window.plugin.bookmarks.openFolder(this);return false"><span></span>'+folders['label']+'</a><span><span></span></span></span>'; | |
var folderLabel = folderDelete+folderName; | |
if(folders['state']) { active = ' open'; } | |
if(idFolders === window.plugin.bookmarks.KEY_OTHER_BKMRK) { | |
folderLabel = ''; | |
active= ' othersBookmarks open'; | |
} | |
// Create a folder | |
elementTemp = '<li class="bookmarkFolder'+active+'" id="'+idFolders+'">'+folderLabel+'<ul>'; | |
// For each bookmark | |
var fold = folders['bkmrk']; | |
for(var idBkmrk in fold) { | |
var btn_link; | |
var btn_remove = '<a class="bookmarksRemoveFrom" onclick="window.plugin.bookmarks.removeElement(this, \''+typeList+'\');return false;" title="Remove from bookmarks">X</a>'; | |
var bkmrk = fold[idBkmrk]; | |
var label = bkmrk['label']; | |
var latlng = bkmrk['latlng']; | |
// If it's a map | |
if(typeList === 'maps') { | |
if(bkmrk['label']=='') { label = bkmrk['latlng']+' ['+bkmrk['z']+']'; } | |
btn_link = '<a class="bookmarksLink" onclick="'+returnToMap+'window.map.setView(['+latlng+'], '+bkmrk['z']+');return false;">'+label+'</a>'; | |
} | |
// If it's a portal | |
else if(typeList === 'portals') { | |
var guid = bkmrk['guid']; | |
var btn_link = '<a class="bookmarksLink" onclick="$(\'a.bookmarksLink.selected\').removeClass(\'selected\');'+returnToMap+'window.zoomToAndShowPortal(\''+guid+'\', ['+latlng+']);return false;">'+label+'</a>'; | |
} | |
// Create the bookmark | |
elementTemp += '<li class="bkmrk" id="'+idBkmrk+'">'+btn_remove+btn_link+'</li>'; | |
} | |
elementTemp += '</li></ul>'; | |
// Add folder 'Others' in last position | |
if(idFolders != window.plugin.bookmarks.KEY_OTHER_BKMRK) { element += elementTemp; } | |
else{ elementExc = elementTemp; } | |
} | |
element += elementExc; | |
element = '<ul>'+element+'</ul>'; | |
// Append all folders and bookmarks | |
$('#bkmrk_'+typeList).append(element); | |
} | |
/***************************************************************************************************************************************************************/ | |
window.plugin.bookmarks.findByGuid = function(guid) { | |
var list = window.plugin.bookmarks.bkmrksObj['portals']; | |
for(var idFolders in list) { | |
for(var idBkmrk in list[idFolders]['bkmrk']) { | |
var portalGuid = list[idFolders]['bkmrk'][idBkmrk]['guid']; | |
if(guid === portalGuid) { | |
return {"id_folder":idFolders,"id_bookmark":idBkmrk}; | |
} | |
} | |
} | |
return; | |
} | |
// Append a 'star' flag in sidebar. | |
window.plugin.bookmarks.addStarToSidebar = function() { | |
if(typeof(Storage) === "undefined") { | |
$('#portaldetails > .imgpreview').after(plugin.bookmarks.htmlDisabledMessage); | |
return; | |
} | |
$('.bkmrksStar').remove(); | |
// Prepend a star to mobile status-bar | |
if(window.plugin.bookmarks.isSmart) { | |
$('#updatestatus').prepend(plugin.bookmarks.htmlStar); | |
$('#updatestatus .bkmrksStar').attr('title', ''); | |
} | |
$('#portaldetails > h3.title').before(plugin.bookmarks.htmlStar); | |
window.plugin.bookmarks.updateStarPortal(); | |
} | |
// Update the status of the star (when a portal is selected from the map/bookmarks-list) | |
window.plugin.bookmarks.updateStarPortal = function() { | |
var guid = window.selectedPortal; | |
$('.bkmrksStar').removeClass('favorite'); | |
$('.bkmrk a.bookmarksLink.selected').removeClass('selected'); | |
// If current portal is into bookmarks: select bookmark portal from portals list and select the star | |
if(localStorage[window.plugin.bookmarks.KEY_STORAGE].search(guid) != -1) { | |
var bkmrkData = window.plugin.bookmarks.findByGuid(guid); | |
if(bkmrkData) { | |
$('.bkmrk#'+bkmrkData['id_bookmark']+' a.bookmarksLink').addClass('selected'); | |
$('.bkmrksStar').addClass('favorite'); | |
} | |
} | |
} | |
// Switch the status of the star | |
window.plugin.bookmarks.switchStarPortal = function() { | |
var guid = window.selectedPortal; | |
// If portal is saved in bookmarks: Remove this bookmark | |
if($('.bkmrksStar').hasClass('favorite')) { | |
var bkmrkData = window.plugin.bookmarks.findByGuid(guid); | |
var list = window.plugin.bookmarks.bkmrksObj['portals']; | |
delete list[bkmrkData['id_folder']]['bkmrk'][bkmrkData['id_bookmark']]; | |
$('.bkmrk#'+bkmrkData['id_bookmark']+'').remove(); | |
window.plugin.bookmarks.saveStorage(); | |
window.plugin.bookmarks.updateStarPortal(); | |
window.runHooks('pluginBkmrksEdit', {"target": "portal", "action": "remove", "folder": bkmrkData['id_folder'], "id": bkmrkData['id_bookmark'], "guid":guid}); | |
console.log('BOOKMARKS: removed portal ('+bkmrkData['id_bookmark']+' situated in '+bkmrkData['id_folder']+' folder)'); | |
} | |
// If portal isn't saved in bookmarks: Add this bookmark | |
else{ | |
// Get portal name and coordinates | |
var p = window.portals[guid]; | |
var d = p.options.data; | |
var label = d.title; | |
var lat = p.getLatLng().lat; | |
var lng = p.getLatLng().lng; | |
var latlng = lat+','+lng; | |
var ID = window.plugin.bookmarks.generateID(); | |
// Add bookmark in the localStorage | |
window.plugin.bookmarks.bkmrksObj['portals'][window.plugin.bookmarks.KEY_OTHER_BKMRK]['bkmrk'][ID] = {"guid":guid,"latlng":latlng,"label":label}; | |
window.plugin.bookmarks.saveStorage(); | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksEdit', {"target": "portal", "action": "add", "id": ID}); | |
console.log('BOOKMARKS: added portal '+ID); | |
} | |
} | |
// Add BOOKMARK/FOLDER | |
window.plugin.bookmarks.addElement = function(elem, type) { | |
var ID = window.plugin.bookmarks.generateID(); | |
var typeList = $(elem).parent().parent('div').attr('id'); | |
// Get the label | Convert some characters | Set the input (empty) | |
var input = '#'+typeList+' .addForm input'; | |
var label = $(input).val(); | |
label = window.plugin.bookmarks.escapeHtml(label); | |
$(input).val(''); | |
// Add a map | |
if(type === 'map') { | |
// Get the coordinates and zoom | |
var c = map.getCenter(); | |
var lat = Math.round(c.lat*1E6)/1E6; | |
var lng = Math.round(c.lng*1E6)/1E6; | |
var latlng = lat+','+lng; | |
var zoom = parseInt(map.getZoom()); | |
// Add bookmark in the localStorage | |
window.plugin.bookmarks.bkmrksObj['maps'][plugin.bookmarks.KEY_OTHER_BKMRK]['bkmrk'][ID] = {"label":label,"latlng":latlng,"z":zoom}; | |
} | |
else{ | |
if(label === '') { label = 'Folder'; } | |
var short_type = typeList.replace('bkmrk_', ''); | |
// Add new folder in the localStorage | |
window.plugin.bookmarks.bkmrksObj[short_type][ID] = {"label":label,"state":1,"bkmrk":{}}; | |
} | |
window.plugin.bookmarks.saveStorage(); | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksEdit', {"target": type, "action": "add", "id": ID}); | |
console.log('BOOKMARKS: added '+type+' '+ID); | |
} | |
// Remove BOOKMARK/FOLDER | |
window.plugin.bookmarks.removeElement = function(elem, type) { | |
if(type === 'maps' || type === 'portals') { | |
var typeList = $(elem).parent().parent().parent().parent().parent('div').attr('id'); | |
var ID = $(elem).parent('li').attr('id'); | |
var IDfold = $(elem).parent().parent().parent('li').attr('id'); | |
var guid = window.plugin.bookmarks.bkmrksObj[typeList.replace('bkmrk_', '')][IDfold]['bkmrk'][ID].guid; | |
delete window.plugin.bookmarks.bkmrksObj[typeList.replace('bkmrk_', '')][IDfold]['bkmrk'][ID]; | |
$(elem).parent('li').remove(); | |
if(type === 'portals') { | |
var list = window.plugin.bookmarks.bkmrksObj['portals']; | |
window.plugin.bookmarks.updateStarPortal(); | |
window.plugin.bookmarks.saveStorage(); | |
window.runHooks('pluginBkmrksEdit', {"target": "portal", "action": "remove", "folder": IDfold, "id": ID, "guid": guid}); | |
console.log('BOOKMARKS: removed portal ('+ID+' situated in '+IDfold+' folder)'); | |
} else { | |
window.plugin.bookmarks.saveStorage(); | |
window.runHooks('pluginBkmrksEdit', {"target": "map", "action": "remove", "id": ID}); | |
console.log('BOOKMARKS: removed map '+ID); | |
} | |
} | |
else if(type === 'folder') { | |
var typeList = $(elem).parent().parent().parent().parent('div').attr('id'); | |
var ID = $(elem).parent().parent('li').attr('id'); | |
delete plugin.bookmarks.bkmrksObj[typeList.replace('bkmrk_', '')][ID]; | |
$(elem).parent().parent('li').remove(); | |
window.plugin.bookmarks.saveStorage(); | |
window.plugin.bookmarks.updateStarPortal(); | |
window.runHooks('pluginBkmrksEdit', {"target": "folder", "action": "remove", "id": ID}); | |
console.log('BOOKMARKS: removed folder '+ID); | |
} | |
} | |
window.plugin.bookmarks.deleteMode = function() { | |
$('#bookmarksBox').toggleClass('deleteMode'); | |
} | |
/***************************************************************************************************************************************************************/ | |
// Saved the new sort of the folders (in the localStorage) | |
window.plugin.bookmarks.sortFolder = function(typeList) { | |
var keyType = typeList.replace('bkmrk_', ''); | |
var newArr = {}; | |
$('#'+typeList+' li.bookmarkFolder').each(function() { | |
var idFold = $(this).attr('id'); | |
newArr[idFold] = window.plugin.bookmarks.bkmrksObj[keyType][idFold]; | |
}); | |
window.plugin.bookmarks.bkmrksObj[keyType] = newArr; | |
window.plugin.bookmarks.saveStorage(); | |
window.runHooks('pluginBkmrksEdit', {"target": "folder", "action": "sort"}); | |
console.log('BOOKMARKS: sorted folder'); | |
} | |
// Saved the new sort of the bookmarks (in the localStorage) | |
window.plugin.bookmarks.sortBookmark = function(typeList) { | |
var keyType = typeList.replace('bkmrk_', ''); | |
var list = window.plugin.bookmarks.bkmrksObj[keyType]; | |
var newArr = {}; | |
$('#'+typeList+' li.bookmarkFolder').each(function() { | |
var idFold = $(this).attr('id'); | |
newArr[idFold] = window.plugin.bookmarks.bkmrksObj[keyType][idFold]; | |
newArr[idFold].bkmrk = {}; | |
}); | |
$('#'+typeList+' li.bkmrk').each(function() { | |
window.plugin.bookmarks.loadStorage(); | |
var idFold = $(this).parent().parent('li').attr('id'); | |
var id = $(this).attr('id'); | |
var list = window.plugin.bookmarks.bkmrksObj[keyType]; | |
for(var idFoldersOrigin in list) { | |
for(var idBkmrk in list[idFoldersOrigin]['bkmrk']) { | |
if(idBkmrk == id) { | |
newArr[idFold].bkmrk[id] = window.plugin.bookmarks.bkmrksObj[keyType][idFoldersOrigin].bkmrk[id]; | |
} | |
} | |
} | |
}); | |
window.plugin.bookmarks.bkmrksObj[keyType] = newArr; | |
window.plugin.bookmarks.saveStorage(); | |
window.runHooks('pluginBkmrksEdit', {"target": "bookmarks", "action": "sort"}); | |
console.log('BOOKMARKS: sorted bookmark (portal/map)'); | |
} | |
window.plugin.bookmarks.jquerySortableScript = function() { | |
$(".bookmarkList > ul").sortable({ | |
items:"li.bookmarkFolder:not(.othersBookmarks)", | |
handle:".bookmarksAnchor", | |
placeholder:"sortable-placeholder", | |
helper:'clone', // fix accidental click in firefox | |
forcePlaceholderSize:true, | |
update:function(event, ui) { | |
var typeList = $('#'+ui.item.context.id).parent().parent('.bookmarkList').attr('id'); | |
window.plugin.bookmarks.sortFolder(typeList); | |
} | |
}); | |
$(".bookmarkList ul li ul").sortable({ | |
items:"li.bkmrk", | |
connectWith:".bookmarkList ul ul", | |
handle:".bookmarksLink", | |
placeholder:"sortable-placeholder", | |
helper:'clone', // fix accidental click in firefox | |
forcePlaceholderSize:true, | |
update:function(event, ui) { | |
var typeList = $('#'+ui.item.context.id).parent().parent().parent().parent('.bookmarkList').attr('id'); | |
window.plugin.bookmarks.sortBookmark(typeList); | |
} | |
}); | |
} | |
/***************************************************************************************************************************************************************/ | |
/** OPTIONS ****************************************************************************************************************************************************/ | |
/***************************************************************************************************************************************************************/ | |
// Manual import, export and reset data | |
window.plugin.bookmarks.manualOpt = function() { | |
dialog({ | |
html: plugin.bookmarks.htmlSetbox, | |
dialogClass: 'ui-dialog-bkmrksSet', | |
title: 'Bookmarks Options' | |
}); | |
window.runHooks('pluginBkmrksOpenOpt'); | |
} | |
window.plugin.bookmarks.optAlert = function(message) { | |
$('.ui-dialog-bkmrksSet .ui-dialog-buttonset').prepend('<p class="bkrmks-alert" style="float:left;margin-top:4px;">'+message+'</p>'); | |
$('.bkrmks-alert').delay(2500).fadeOut(); | |
} | |
window.plugin.bookmarks.optPickFolder = function() { | |
dialog({ | |
html: '<p>Enter the name of the folder to export:</p><input type="text" id="copyFolder"></input><button type="button" onclick="window.plugin.bookmarks.optCopy($(\'#copyFolder\').val())">Export</button>', | |
dialogClass: 'ui-dialog-bkmrksSet-copy', | |
title: 'Bookmarks Export' | |
}); | |
} | |
window.plugin.bookmarks.optCopy = function(folder) { | |
var json = null; | |
if (folder !== null) { | |
json = {portals: {}}; | |
var portalFolders = $.parseJSON(localStorage[window.plugin.bookmarks.KEY_STORAGE]).portals; | |
for (var id in portalFolders) { | |
if (portalFolders[id].label === folder) { json.portals[id] = portalFolders[id]; } | |
} | |
} else { json = $.parseJSON(localStorage[window.plugin.bookmarks.KEY_STORAGE]); } | |
json = JSON.stringify(json); | |
if(typeof android !== 'undefined' && android && android.shareString) { | |
return android.shareString(json); | |
} else { | |
dialog({ | |
html: '<p><a onclick="$(\'.ui-dialog-bkmrksSet-copy textarea\').select();">Select all</a> and press CTRL+C to copy it.</p><textarea readonly>'+json+'</textarea>', | |
dialogClass: 'ui-dialog-bkmrksSet-copy', | |
title: 'Bookmarks Export' | |
}); | |
} | |
} | |
window.plugin.bookmarks.optExport = function() { | |
if(typeof android !== 'undefined' && android && android.saveFile) { | |
android.saveFile("IITC-bookmarks.json", "application/json", localStorage[window.plugin.bookmarks.KEY_STORAGE]); | |
} | |
} | |
window.plugin.bookmarks.optPaste = function() { | |
var promptAction = prompt('Press CTRL+V to paste it.', ''); | |
if(promptAction !== null && promptAction !== '') { | |
try { | |
var newKeys = $.parseJSON(promptAction), // try to parse JSON first | |
currKeys = $.parseJSON(localStorage[window.plugin.bookmarks.KEY_STORAGE]); | |
for (var id in newKeys.portals) { // only checks portals for now | |
if (id in currKeys.portals) { | |
// add new bookmarks to folder | |
for (var bkmrkId in newKeys.portals[id].bkmrk) { | |
if (bkmrkId in currKeys.portals[id].bkmrk) { | |
// do nothing | |
} else { | |
// add bookmark | |
currKeys.portals[id].bkmrk[bkmrkId] = newKeys.portals[id].bkmrk[bkmrkId]; | |
} | |
} | |
} else { | |
// add folder | |
currKeys.portals[id] = newKeys.portals[id]; | |
} | |
} | |
localStorage[window.plugin.bookmarks.KEY_STORAGE] = JSON.stringify(currKeys); | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksEdit', {"target": "all", "action": "import"}); | |
console.log('BOOKMARKS: reset and imported bookmarks'); | |
window.plugin.bookmarks.optAlert('Successful. '); | |
} catch(e) { | |
console.warn('BOOKMARKS: failed to import data: '+e); | |
window.plugin.bookmarks.optAlert('<span style="color: #f88">Import failed </span>'); | |
} | |
} | |
} | |
window.plugin.bookmarks.optImport = function() { | |
if (window.requestFile === undefined) return; | |
window.requestFile(function(filename, content) { | |
try { | |
JSON.parse(content); // try to parse JSON first | |
localStorage[window.plugin.bookmarks.KEY_STORAGE] = content; | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksEdit', {"target": "all", "action": "import"}); | |
console.log('BOOKMARKS: reset and imported bookmarks'); | |
window.plugin.bookmarks.optAlert('Successful. '); | |
} catch(e) { | |
console.warn('BOOKMARKS: failed to import data: '+e); | |
window.plugin.bookmarks.optAlert('<span style="color: #f88">Import failed </span>'); | |
} | |
}); | |
} | |
window.plugin.bookmarks.optReset = function() { | |
var promptAction = confirm('All bookmarks will be deleted. Are you sure?', ''); | |
if(promptAction) { | |
delete localStorage[window.plugin.bookmarks.KEY_STORAGE]; | |
window.plugin.bookmarks.createStorage(); | |
window.plugin.bookmarks.loadStorage(); | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksEdit', {"target": "all", "action": "reset"}); | |
console.log('BOOKMARKS: reset all bookmarks'); | |
window.plugin.bookmarks.optAlert('Successful. '); | |
} | |
} | |
window.plugin.bookmarks.optBox = function(command) { | |
if(!window.plugin.bookmarks.isAndroid()) { | |
switch(command) { | |
case 'save': | |
var boxX = parseInt($('#bookmarksBox').css('top')); | |
var boxY = parseInt($('#bookmarksBox').css('left')); | |
window.plugin.bookmarks.statusBox.pos = {x:boxX, y:boxY}; | |
window.plugin.bookmarks.saveStorageBox(); | |
window.plugin.bookmarks.optAlert('Position acquired. '); | |
break; | |
case 'reset': | |
$('#bookmarksBox').css({'top':100, 'left':100}); | |
window.plugin.bookmarks.optBox('save'); | |
break; | |
} | |
} else { | |
window.plugin.bookmarks.optAlert('Only IITC desktop. '); | |
} | |
} | |
/***************************************************************************************************************************************************************/ | |
/** AUTO DRAW **************************************************************************************************************************************************/ | |
/***************************************************************************************************************************************************************/ | |
window.plugin.bookmarks.dialogDrawer = function() { | |
dialog({ | |
html:window.plugin.bookmarks.dialogLoadList, | |
dialogClass:'ui-dialog-autodrawer', | |
title:'Bookmarks - Auto Draw', | |
buttons:{ | |
'DRAW': function() { | |
window.plugin.bookmarks.draw(0); | |
}, | |
'DRAW&VIEW': function() { | |
window.plugin.bookmarks.draw(1); | |
} | |
} | |
}); | |
} | |
window.plugin.bookmarks.draw = function(view) { | |
var latlngs = []; | |
var uuu = $('#bkmrksAutoDrawer a.bkmrk.selected').each(function(i) { | |
var tt = $(this).data('latlng'); | |
latlngs[i] = tt; | |
}); | |
if(latlngs.length >= 2 && latlngs.length <= 3) { | |
// TODO: add an API to draw-tools rather than assuming things about it's internals | |
var newItem; | |
window.plugin.drawTools.setOptions(); | |
if(latlngs.length == 2) { | |
newItem = L.geodesicPolyline(latlngs, window.plugin.drawTools.lineOptions); | |
} else { | |
newItem = L.geodesicPolygon(latlngs, window.plugin.drawTools.polygonOptions); | |
} | |
if($("#bkmrkClearSelection").prop("checked")) | |
$('#bkmrksAutoDrawer a.bkmrk.selected').removeClass('selected'); | |
newItem.addTo(window.plugin.drawTools.drawnItems); | |
// Save in localStorage | |
window.plugin.drawTools.save(); | |
if(window.plugin.bookmarks.isSmart) { | |
window.show('map'); | |
} | |
// Shown the layer if it is hidden | |
if(!map.hasLayer(window.plugin.drawTools.drawnItems)) { | |
map.addLayer(window.plugin.drawTools.drawnItems); | |
} | |
if(view) { | |
map.fitBounds(newItem.getBounds()); | |
} | |
} | |
else{ | |
$('#bkmrksAutoDrawer p').toggle().delay('2500').fadeOut('500'); | |
} | |
} | |
window.plugin.bookmarks.dialogLoadList = function() { | |
var r = 'The "<a href="http://iitc.jonatkins.com/?page=desktop#plugin-draw-tools" target="_BLANK"><strong>Draw Tools</strong></a>" plugin is required.</span>'; | |
if(!window.plugin.bookmarks || !window.plugin.drawTools) { | |
$('.ui-dialog-autodrawer .ui-dialog-buttonset .ui-button:not(:first)').hide(); | |
} | |
else{ | |
var portalsList = JSON.parse(localStorage['plugin-bookmarks']); | |
var element = ''; | |
var elementTemp = ''; | |
var elemGenericFolder = ''; | |
// For each folder | |
var list = portalsList.portals; | |
for(var idFolders in list) { | |
var folders = list[idFolders]; | |
// Create a label and a anchor for the sortable | |
var folderLabel = '<a class="folderLabel" onclick="$(this).siblings(\'div\').toggle();return false;">'+folders['label']+'</a>'; | |
// Create a folder | |
elementTemp = '<div class="bookmarkFolder" id="'+idFolders+'">'+folderLabel+'<div>'; | |
// For each bookmark | |
var fold = folders['bkmrk']; | |
for(var idBkmrk in fold) { | |
var bkmrk = fold[idBkmrk]; | |
var label = bkmrk['label']; | |
var latlng = bkmrk['latlng']; | |
// Create the bookmark | |
elementTemp += '<a class="bkmrk" id="'+idBkmrk+'" onclick="$(this).toggleClass(\'selected\');return false" data-latlng="['+latlng+']">'+label+'</a>'; | |
} | |
elementTemp += '</div></div>'; | |
if(idFolders !== window.plugin.bookmarks.KEY_OTHER_BKMRK) { | |
element += elementTemp; | |
} else { | |
elemGenericFolder += elementTemp; | |
} | |
} | |
element += elemGenericFolder; | |
// Append all folders and bookmarks | |
r = '<div id="bkmrksAutoDrawer">' | |
+ '<label style="margin-bottom: 9px; display: block;">' | |
+ '<input style="vertical-align: middle;" type="checkbox" id="bkmrkClearSelection" checked>' | |
+ ' Clear selection after drawing</label>' | |
+ '<p style="color:red;text-align:center;margin-bottom:9px;">You must select 2 or 3 portals.</p>' | |
+ element | |
+ '</div>'; | |
} | |
return r; | |
} | |
/***************************************************************************************************************************************************************/ | |
/** SYNC *******************************************************************************************************************************************************/ | |
/***************************************************************************************************************************************************************/ | |
// Delay the syncing to group a few updates in a single request | |
window.plugin.bookmarks.delaySync = function() { | |
if(!window.plugin.bookmarks.enableSync) return; | |
clearTimeout(plugin.bookmarks.delaySync.timer); | |
window.plugin.bookmarks.delaySync.timer = setTimeout(function() { | |
window.plugin.bookmarks.delaySync.timer = null; | |
window.plugin.bookmarks.syncNow(); | |
}, window.plugin.bookmarks.SYNC_DELAY); | |
} | |
// Store the updateQueue in updatingQueue and upload | |
window.plugin.bookmarks.syncNow = function() { | |
if(!window.plugin.bookmarks.enableSync) return; | |
$.extend(window.plugin.bookmarks.updatingQueue, window.plugin.bookmarks.updateQueue); | |
window.plugin.bookmarks.updateQueue = {}; | |
window.plugin.bookmarks.storeLocal(window.plugin.bookmarks.UPDATING_QUEUE); | |
window.plugin.bookmarks.storeLocal(window.plugin.bookmarks.UPDATE_QUEUE); | |
window.plugin.sync.updateMap('bookmarks', window.plugin.bookmarks.KEY.field, Object.keys(window.plugin.bookmarks.updatingQueue)); | |
} | |
// Call after IITC and all plugin loaded | |
window.plugin.bookmarks.registerFieldForSyncing = function() { | |
if(!window.plugin.sync) return; | |
window.plugin.sync.registerMapForSync('bookmarks', window.plugin.bookmarks.KEY.field, window.plugin.bookmarks.syncCallback, window.plugin.bookmarks.syncInitialed); | |
} | |
// Call after local or remote change uploaded | |
window.plugin.bookmarks.syncCallback = function(pluginName, fieldName, e, fullUpdated) { | |
if(fieldName === window.plugin.bookmarks.KEY.field) { | |
window.plugin.bookmarks.storeLocal(window.plugin.bookmarks.KEY); | |
// All data is replaced if other client update the data during this client offline, | |
if(fullUpdated) { | |
window.plugin.bookmarks.refreshBkmrks(); | |
return; | |
} | |
if(!e) return; | |
if(e.isLocal) { | |
// Update pushed successfully, remove it from updatingQueue | |
delete window.plugin.bookmarks.updatingQueue[e.property]; | |
} else { | |
// Remote update | |
delete window.plugin.bookmarks.updateQueue[e.property]; | |
window.plugin.bookmarks.storeLocal(window.plugin.bookmarks.UPDATE_QUEUE); | |
window.plugin.bookmarks.refreshBkmrks(); | |
window.runHooks('pluginBkmrksSyncEnd', {"target": "all", "action": "sync"}); | |
console.log('BOOKMARKS: synchronized all'); | |
} | |
} | |
} | |
// syncing of the field is initialed, upload all queued update | |
window.plugin.bookmarks.syncInitialed = function(pluginName, fieldName) { | |
if(fieldName === window.plugin.bookmarks.KEY.field) { | |
window.plugin.bookmarks.enableSync = true; | |
if(Object.keys(window.plugin.bookmarks.updateQueue).length > 0) { | |
window.plugin.bookmarks.delaySync(); | |
} | |
} | |
} | |
window.plugin.bookmarks.storeLocal = function(mapping) { | |
if(typeof(window.plugin.bookmarks[mapping.field]) !== 'undefined' && window.plugin.bookmarks[mapping.field] !== null) { | |
localStorage[mapping.key] = JSON.stringify(window.plugin.bookmarks[mapping.field]); | |
} else { | |
localStorage.removeItem(mapping.key); | |
} | |
} | |
window.plugin.bookmarks.loadLocal = function(mapping) { | |
var objectJSON = localStorage[mapping.key]; | |
if(!objectJSON) return; | |
window.plugin.bookmarks[mapping.field] = mapping.convertFunc | |
? mapping.convertFunc(JSON.parse(objectJSON)) | |
: JSON.parse(objectJSON); | |
} | |
window.plugin.bookmarks.syncBkmrks = function() { | |
window.plugin.bookmarks.loadLocal(window.plugin.bookmarks.KEY); | |
window.plugin.bookmarks.updateQueue = window.plugin.bookmarks.bkmrksObj; | |
window.plugin.bookmarks.storeLocal(window.plugin.bookmarks.UPDATE_QUEUE); | |
window.plugin.bookmarks.delaySync(); | |
} | |
/***************************************************************************************************************************************************************/ | |
/** HIGHLIGHTER ************************************************************************************************************************************************/ | |
/***************************************************************************************************************************************************************/ | |
window.plugin.bookmarks.highlight = function(data) { | |
var guid = data.portal.options.ent[0]; | |
if(window.plugin.bookmarks.findByGuid(guid)) { | |
data.portal.setStyle({fillColor:'red'}); | |
} | |
} | |
window.plugin.bookmarks.highlightRefresh = function(data) { | |
if(_current_highlighter === 'Bookmarked Portals') { | |
if(data.action === 'sync' || data.target === 'portal' || (data.target === 'folder' && data.action === 'remove') || (data.target === 'all' && data.action === 'import') || (data.target === 'all' && data.action === 'reset')) { | |
window.resetHighlightedPortals(); | |
} | |
} | |
} | |
/***************************************************************************************************************************************************************/ | |
/** BOOKMARKED PORTALS LAYER ***********************************************************************************************************************************/ | |
/***************************************************************************************************************************************************************/ | |
window.plugin.bookmarks.addAllStars = function() { | |
var list = window.plugin.bookmarks.bkmrksObj.portals; | |
for(var idFolders in list) { | |
for(var idBkmrks in list[idFolders]['bkmrk']) { | |
var latlng = list[idFolders]['bkmrk'][idBkmrks].latlng.split(","); | |
var guid = list[idFolders]['bkmrk'][idBkmrks].guid; | |
var lbl = list[idFolders]['bkmrk'][idBkmrks].label; | |
window.plugin.bookmarks.addStar(guid, latlng, lbl); | |
} | |
} | |
} | |
window.plugin.bookmarks.resetAllStars = function() { | |
for(guid in window.plugin.bookmarks.starLayers) { | |
var starInLayer = window.plugin.bookmarks.starLayers[guid]; | |
window.plugin.bookmarks.starLayerGroup.removeLayer(starInLayer); | |
delete window.plugin.bookmarks.starLayers[guid]; | |
} | |
window.plugin.bookmarks.addAllStars(); | |
} | |
window.plugin.bookmarks.addStar = function(guid, latlng, lbl) { | |
var star = L.marker(latlng, { | |
title: lbl, | |
icon: L.icon({ | |
iconUrl: '', | |
iconAnchor: [15,40], | |
iconSize: [30,40] | |
}) | |
}); | |
window.plugin.bookmarks.starLayers[guid] = star; | |
star.addTo(window.plugin.bookmarks.starLayerGroup); | |
} | |
window.plugin.bookmarks.editStar = function(data) { | |
if(data.target === 'portal') { | |
if(data.action === 'add') { | |
var guid = window.selectedPortal; | |
var latlng = window.portals[guid].getLatLng(); | |
var lbl = window.portals[guid].options.data.title; | |
var starInLayer = window.plugin.bookmarks.starLayers[data.guid]; | |
window.plugin.bookmarks.addStar(guid, latlng, lbl); | |
} | |
else if(data.action === 'remove') { | |
var starInLayer = window.plugin.bookmarks.starLayers[data.guid]; | |
window.plugin.bookmarks.starLayerGroup.removeLayer(starInLayer); | |
delete window.plugin.bookmarks.starLayers[data.guid]; | |
} | |
} | |
else if((data.target === 'all' && (data.action === 'import' || data.action === 'reset')) || (data.target === 'folder' && data.action === 'remove')) { | |
window.plugin.bookmarks.resetAllStars(); | |
} | |
} | |
/***************************************************************************************************************************************************************/ | |
window.plugin.bookmarks.setupCSS = function() { | |
$('<style>').prop('type', 'text/css').html('#bookmarksBox *{\n display:block;\n padding:0;\n margin:0;\n width:auto;\n height:auto;\n font-family:Verdana,Geneva,sans-serif;\n font-size:13px;\n line-height:22px;\n text-indent:0;\n text-decoration:none;\n -webkit-box-sizing:border-box;\n -moz-box-sizing:border-box;\n box-sizing:border-box;\n}\n\n#bookmarksBox{\n display:block;\n position:absolute !important;\n z-index:4001;\n top:100px;\n left:100px;\n width:231px;\n height:auto;\n overflow:hidden;\n}\n#bookmarksBox .addForm,\n#bookmarksBox #bookmarksTypeBar,\n#bookmarksBox h5{\n height:28px;\n overflow:hidden;\n color:#fff;\n font-size:14px;\n}\n#bookmarksBox #topBar{\n height:15px !important;\n}\n#bookmarksBox #topBar *{\n height: 14px !important;\n}\n#bookmarksBox #topBar *{\n float:left !important;\n}\n#bookmarksBox .handle{\n width:80%;\n text-align:center;\n color:#fff;\n line-height:6px;\n cursor:move;\n}\n#bookmarksBox #topBar .btn{\n display:block;\n width:10%;\n cursor:pointer;\n color:#20a8b1;\n\n font-weight:bold;\n text-align:center;\n line-height:13px;\n font-size:18px;\n}\n\n#bookmarksBox #topBar #bookmarksDel{\n overflow:hidden;\n text-indent:-999px;\n background:#B42E2E;\n}\n\n#bookmarksBox #topBar #bookmarksMin:hover{\n color:#ffce00;\n}\n#bookmarksBox #bookmarksTypeBar{\n clear:both;\n}\n#bookmarksBox h5{\n padding:4px 0 23px;\n width:50%;\n height:93px !important;\n text-align:center;\n color:#788;\n}\n#bookmarksBox h5.current{\n cursor:default;\n background:0;\n color:#fff !important;\n}\n#bookmarksBox h5:hover{\n color:#ffce00;\n background:rgba(0,0,0,0);\n}\n#bookmarksBox #topBar,\n#bookmarksBox .addForm,\n#bookmarksBox #bookmarksTypeBar,\n#bookmarksBox .bookmarkList li.bookmarksEmpty,\n#bookmarksBox .bookmarkList li.bkmrk a,\n#bookmarksBox .bookmarkList li.bkmrk:hover{\n background-color:rgba(8,48,78,.85);\n}\n#bookmarksBox h5,\n#bookmarksBox .bookmarkList li.bkmrk:hover .bookmarksLink,\n#bookmarksBox .addForm *{\n background:rgba(0,0,0,.3);\n}\n#bookmarksBox .addForm *{\n display:block;\n float:left;\n height:28px !important;\n}\n#bookmarksBox .addForm a{\n cursor:pointer;\n color:#20a8b1;\n font-size:12px;\n width:35%;\n text-align:center;\n line-height:20px;\n padding:4px 0 23px;\n}\n#bookmarksBox .addForm a:hover{\n background:#ffce00;\n color:#000;\n text-decoration:none;\n}\n#bookmarksBox .addForm input{\n font-size:11px !important;\n color:#ffce00;\n height:28px;\n padding:4px 8px 1px;\n line-height:12px;\n font-size:12px;\n}\n#bookmarksBox #bkmrk_portals .addForm input{\n width:65%;\n}\n#bookmarksBox #bkmrk_maps .addForm input{\n width:42%;\n}\n#bookmarksBox #bkmrk_maps .addForm a{\n width:29%;\n}\n#bookmarksBox .addForm input:hover,\n#bookmarksBox .addForm input:focus{\n outline:0;\n background:rgba(0,0,0,.6);\n}\n#bookmarksBox .bookmarkList > ul{\n clear:both;\n list-style-type:none;\n color:#fff;\n overflow:hidden;\n overflow-y:auto;\n max-height:580px;\n}\n#bookmarksBox .sortable-placeholder{\n background:rgba(8,48,78,.55);\n box-shadow:inset 1px 0 0 #20a8b1;\n}\n#bookmarksBox .ui-sortable-helper{\n border-top-width:1px;\n}\n#bookmarksBox .bookmarkList{\n display:none;\n}\n#bookmarksBox .bookmarkList.current{\n display:block;\n}\n#bookmarksBox h5,\n#bookmarksBox .addForm *,\n#bookmarksBox ul li.bkmrk,\n#bookmarksBox ul li.bkmrk a{\n height:22px;\n}\n#bookmarksBox h5,\n#bookmarksBox ul li.bkmrk a{\n overflow:hidden;\n cursor:pointer;\n float:left;\n}\n#bookmarksBox ul .bookmarksEmpty{\n text-indent:27px;\n color:#eee;\n}\n#bookmarksBox ul .bookmarksRemoveFrom{\n width:10%;\n text-align:center;\n color:#fff;\n}\n#bookmarksBox ul .bookmarksLink{\n width:90%;\n padding:0 10px 0 8px;\n color:#ffce00;\n}\n#bookmarksBox ul .bookmarksLink.selected{\n color:#03fe03;\n}\n#bookmarksBox ul .othersBookmarks .bookmarksLink{\n width:90%;\n}\n#bookmarksBox ul .bookmarksLink:hover{\n color:#03fe03;\n}\n#bookmarksBox ul .bookmarksRemoveFrom:hover{\n color:#fff;\n background:#e22 !important;\n}\n\n/*---- UI border -----*/\n#bookmarksBox,\n#bookmarksBox *{\n border-color:#20a8b1;\n border-style:solid;\n border-width:0;\n}\n#bookmarksBox #topBar,\n#bookmarksBox ul .bookmarkFolder{\n border-top-width:1px;\n}\n\n#bookmarksBox #topBar,\n#bookmarksBox #bookmarksTypeBar,\n#bookmarksBox .addForm,\n#bookmarksBox ul .bookmarkFolder .folderLabel,\n#bookmarksBox ul li.bkmrk a {\n border-bottom-width:1px;\n}\n#bookmarksBox ul .bookmarkFolder{\n border-right-width:1px;\n border-left-width:1px;\n}\n#bookmarksBox #topBar *,\n#bookmarksBox #bookmarksTypeBar *,\n#bookmarksBox .addForm *,\n#bookmarksBox ul li.bkmrk{\n border-left-width:1px;\n}\n#bookmarksBox #topBar,\n#bookmarksBox #bookmarksTypeBar,\n#bookmarksBox .addForm,\n#bookmarksBox ul .bookmarksRemoveFrom{\n border-right-width:1px;\n}\n#bookmarksBox ul .bookmarkFolder.othersBookmarks li.bkmrk,\n#bookmarksBox ul .bookmarkFolder .folderLabel .bookmarksRemoveFrom{\n border-left-width:0;\n}\n#bkmrksTrigger{\n display:block !important;\n position:absolute;\n overflow:hidden;\n top:0;\n left:277px;\n width:47px;\n margin-top:-36px;\n height:64px;\n height:0;\n cursor:pointer;\n z-index:2999;\n background-position:center bottom;\n background-repeat:no-repeat;\n transition:margin-top 100ms ease-in-out;\n text-indent:-100%;\n text-decoration:none;\n text-align:center;\n}\n#bkmrksTrigger:hover{\n margin-top:0;\n}\n#sidebar #portaldetails h3.title{\n width:auto;\n}\n#bkmrksTrigger, .bkmrksStar span{\n background-image:url();\n}\n.bkmrksStar span{\n display:inline-block;\n float:left;\n margin:3px 1px 0 4px;\n width:16px;\n height:15px;\n overflow:hidden;\n background-repeat:no-repeat;\n}\n.bkmrksStar span, .bkmrksStar.favorite:focus span{\n background-position:left top;\n}\n.bkmrksStar:focus span, .bkmrksStar.favorite span{\n background-position:right top;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder{\n overflow:hidden;\n margin-top:-1px;\n height:auto;\n background:rgba(8,58,78,.7);\n}\n#bookmarksBox .bookmarkList ul li.sortable-placeholder{\n box-shadow:inset -1px 0 0 #20a8b1,inset 1px 0 0 #20a8b1,0 -1px 0 #20a8b1;\n background:rgba(8,58,78,.9);\n}\n#bookmarksBox .bookmarkList .bkmrk.ui-sortable-helper{\n border-right-width:1px;\n border-left-width:1px !important;\n}\n#bookmarksBox .bookmarkList ul li ul li.sortable-placeholder{\n height:23px;\n box-shadow:inset 0 -1px 0 #20a8b1,inset 1px 0 0 #20a8b1;\n}\n\n#bookmarksBox .bookmarkList ul li.bookmarkFolder.ui-sortable-helper,\n#bookmarksBox .bookmarkList ul li.othersBookmarks ul li.sortable-placeholder{\n box-shadow:inset 0 -1px 0 #20a8b1;\n}\n\n#bookmarksBox #topBar #bookmarksDel,\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel:hover .bookmarksRemoveFrom,\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel:hover .bookmarksAnchor{\n border-bottom-width:1px;\n}\n\n/*---------*/\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor span,\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > span,\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > span > span,\n#bookmarksBox .bookmarkList .triangle{\n width:0;\n height:0;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel{\n overflow:visible;\n height:25px;\n cursor:pointer;\n background:#069;\n text-indent:0;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > *{\n height:25px;\n float:left;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor{\n line-height:25px;\n color:#fff;\n width:90%;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor span{\n float:left;\n border-width:5px 0 5px 7px;\n border-color:transparent transparent transparent white;\n margin:7px 7px 0 6px;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder.open .folderLabel .bookmarksAnchor span{\n margin:9px 5px 0 5px;\n border-width:7px 5px 0 5px;\n border-color:white transparent transparent transparent;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > span,\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > span > span{\n display:none;\n border-width:0 12px 10px 0;\n border-color:transparent #20a8b1 transparent transparent;\n margin:-20px 0 0;\n position:relative;\n top:21px;\n left:219px;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel > span > span{\n top:18px;\n left:0;\n border-width:0 10px 9px 0;\n border-color:transparent #069 transparent transparent;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder.open .folderLabel > span,\n#bookmarksBox .bookmarkList .bookmarkFolder.open .folderLabel > span > span{\n display:block;\n display:none;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder.open .folderLabel:hover > span > span{\n border-color:transparent #036 transparent transparent;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel:hover .bookmarksAnchor{\n background:#036;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder ul{\n display:none;\n margin-left:10%;\n}\n#bookmarksBox .bookmarkList .bookmarkFolder.open ul{\n display:block;\n min-height:22px;\n}\n#bookmarksBox .bookmarkFolder.othersBookmarks ul{\n margin-left:0;\n}\n\n/*---- Width for deleteMode -----*/\n#bookmarksBox .bookmarksRemoveFrom{\n display:none !important;\n}\n#bookmarksBox.deleteMode .bookmarksRemoveFrom{\n display:block !important;\n}\n\n#bookmarksBox .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor,\n#bookmarksBox ul .bookmarksLink,\n#bookmarksBox ul .othersBookmarks .bookmarksLink{\n width:100% !important;\n}\n\n#bookmarksBox.deleteMode .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor,\n#bookmarksBox.deleteMode ul .bookmarksLink,\n#bookmarksBox.deleteMode ul .othersBookmarks .bookmarksLink{\n width:90% !important;\n}\n\n/**********************************************\n MOBILE\n**********************************************/\n#bookmarksBox.mobile{\n position:absolute !important;\n width: 100% !important;\n height: 100% !important;\n top: 0 !important;\n left: 0 !important;\n margin: 0 !important;\n padding: 0 !important;\n border: 0 !important;\n background: transparent !important;\n overflow:auto !important;\n}\n#bookmarksBox.mobile .bookmarkList ul,\n#bookmarksBox.mobile .bookmarkList ul li,\n#bookmarksBox.mobile .bookmarkList.current,\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder.open ul{\n width:100% !important;\n display:block !important;\n}\n#bookmarksBox.mobile *{\n box-shadow:none !important;\n border-width:0 !important;\n}\n#bookmarksBox.mobile #topBar #bookmarksMin,\n#bookmarksBox.mobile #topBar .handle{\n display:none !important;\n}\n\n#bookmarksBox.mobile #topBar #bookmarksDel{\n width:100%;\n height:34px !important;\n font-size:13px;\n color:#fff;\n font-weight:normal;\n padding-top:11px;\n text-indent:0;\n}\n\n#bookmarksBox.mobile #bookmarksTypeBar h5{\n cursor:pointer;\n text-align:center;\n float:left;\n width:50%;\n height:auto !important;\n padding:7px 0;\n}\n#bookmarksBox.mobile #bookmarksTypeBar h5.current{\n cursor:default;\n color:#fff;\n}\n#bookmarksBox.mobile #bookmarksTypeBar,\n#bookmarksBox.mobile .bookmarkList .addForm{\n border-bottom:1px solid #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList ul li ul li.bkmrk,\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder .folderLabel{\n height:36px !important;\n clear:both;\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder .folderLabel a,\n#bookmarksBox.mobile .bookmarkList ul li ul li.bkmrk a{\n background:none;\n padding:7px 0;\n height:auto;\n box-shadow:inset 0 1px 0 #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder a.bookmarksRemoveFrom,\n#bookmarksBox.mobile .bookmarkList li.bkmrk a.bookmarksRemoveFrom{\n box-shadow:inset 0 1px 0 #20a8b1,inset -1px 0 0 #20a8b1 !important;\n width:10%;\n background:none !important;\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder a.bookmarksAnchor,\n#bookmarksBox.mobile .bookmarkList li.bkmrk a.bookmarksLink{\n text-indent:10px;\n height:36px;\n line-height:24px;\n overflow:hidden;\n}\n#bookmarksBox.mobile .bookmarkList ul li.bookmarkFolder ul{\n margin-left:0 !important;\n}\n#bookmarksBox.mobile .bookmarkList > ul{\n border-bottom:1px solid #20a8b1 !important;\n}\n\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder.othersBookmarks ul{\n border-top:5px solid #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder,\n#bookmarksBox.mobile .bookmarkList li.bkmrk{\n box-shadow:inset 0 1px 0 #20a8b1, 1px 0 0 #20a8b1, -1px 1px 0 #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList > ul{\n max-height:none;\n/* width:85% !important;*/\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder .folderLabel{\n box-shadow:0 1px 0 #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList ul li.bookmarkFolder ul{\n width:90% !important;\n margin-left:10% !important;\n}\n#bookmarksBox.mobile .bookmarkList ul li.bookmarkFolder.othersBookmarks ul{\n width:100% !important;\n margin-left:0% !important;\n}\n#bookmarksBox.mobile{\n margin-bottom:5px !important;\n}\n#bookmarksBox.mobile #bookmarksTypeBar{\n height:auto;\n}\n#bookmarksBox.mobile .addForm,\n#bookmarksBox.mobile .addForm *{\n height:35px !important;\n padding:0;\n}\n#bookmarksBox.mobile .addForm a{\n line-height:37px;\n}\n\n#bookmarksBox.mobile .addForm a{\n/* width:25% !important;*/\n}\n#bookmarksBox.mobile .addForm input{\n/* width:50% !important;*/\n text-indent:10px;\n}\n#bookmarksBox.mobile #bkmrk_portals .addForm input{\n/* width:75% !important;*/\n}\n#bookmarksBox.mobile #bookmarksTypeBar h5,\n#bookmarksBox.mobile .bookmarkList .addForm a{\n box-shadow:-1px 0 0 #20a8b1 !important;\n}\n#bookmarksBox.mobile .bookmarkList li.bookmarkFolder ul{\n display:none !important;\n min-height:37px !important;\n}\n#updatestatus .bkmrksStar{\n float:left;\n margin:-19px 0 0 -5px;\n padding:0 3px 1px 4px;\n background:#262c32;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor span,\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel > span,\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel > span > span,\n#bookmarksBox.mobile .bookmarkList .triangle{\n width:0 !important;\n height:0 !important;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel .bookmarksAnchor span{\n float:left !important;\n border-width:5px 0 5px 7px !important;\n border-color:transparent transparent transparent white !important;\n margin:7px 3px 0 13px !important;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder.open .folderLabel .bookmarksAnchor span{\n margin:9px 1px 0 12px !important;\n border-width:7px 5px 0 5px !important;\n border-color:white transparent transparent transparent !important;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel > span,\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel > span > span{\n display:none !important;\n border-width:0 12px 10px 0 !important;\n border-color:transparent #20a8b1 transparent transparent !important;\n margin:-20px 0 0 100% !important;\n position:relative !important;\n top:21px !important;\n left:-10px !important;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder .folderLabel > span > span{\n top:18px !important;\n left:0 !important;\n border-width:0 10px 9px 0 !important;\n border-color:transparent #069 transparent transparent !important;\n}\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder.open .folderLabel > span,\n#bookmarksBox.mobile .bookmarkList .bookmarkFolder.open .folderLabel > span > span{\n display:block !important;\n}\n\n/**********************************************\n DIALOG BOX\n**********************************************/\n/*---- Auto Drawer -----*/\n#bkmrksAutoDrawer,\n#bkmrksAutoDrawer p,\n#bkmrksAutoDrawer a{\n display:block;\n padding:0;\n margin:0;\n}\n#bkmrksAutoDrawer .bookmarkFolder{\n margin-bottom:4px;\n border:1px solid #20a8b1;\n}\n#bkmrksAutoDrawer .folderLabel{\n background:#069;\n padding:4px 0;\n color:#fff;\n}\n#bkmrksAutoDrawer .bookmarkFolder div{\n border-top:1px solid #20a8b1;\n padding:6px 0;\n background:rgba(0,0,0,0.3);\n}\n#bkmrksAutoDrawer .bookmarkFolder#idOthers .folderLabel{\n display:none;\n}\n#bkmrksAutoDrawer .bookmarkFolder#idOthers div{\n display:block;\n border-top:none;\n}\n#bkmrksAutoDrawer a{\n text-indent:10px;\n padding:2px 0;\n}\n#bkmrksAutoDrawer .bookmarkFolder div,\n#bkmrksAutoDrawer p{\n display:none;\n}\n#bkmrksAutoDrawer a.bkmrk.selected{\n color:#03dc03;\n}\n\n/*---- Options panel -----*/\n#bkmrksSetbox a{\n display:block;\n color:#ffce00;\n border:1px solid #ffce00;\n padding:3px 0;\n margin:10px auto;\n width:80%;\n text-align:center;\n background:rgba(8,48,78,.9);\n}\n#bkmrksSetbox a.disabled,\n#bkmrksSetbox a.disabled:hover{\n color:#666;\n border-color:#666;\n text-decoration:none;\n}\n/*---- Opt panel - copy -----*/\n.ui-dialog-bkmrksSet-copy textarea{\n width:96%;\n height:120px;\n resize:vertical;\n}').appendTo('head'); | |
} | |
window.plugin.bookmarks.setupContent = function() { | |
var ttt = '\'switch\''; | |
if(!window.plugin.bookmarks.isSmart) { ttt = 1; } | |
plugin.bookmarks.htmlBoxTrigger = '<a id="bkmrksTrigger" class="open" onclick="window.plugin.bookmarks.switchStatusBkmrksBox('+ttt+');return false;">[-] Bookmarks</a>'; | |
plugin.bookmarks.htmlBkmrksBox = '<div id="bookmarksBox">' | |
+'<div id="topBar">' | |
+'<a id="bookmarksMin" class="btn" onclick="window.plugin.bookmarks.switchStatusBkmrksBox(0);return false;" title="Minimize">-</a>' | |
+'<div class="handle">...</div>' | |
+'<a id="bookmarksDel" class="btn" onclick="window.plugin.bookmarks.deleteMode();return false;" title="Show/Hide \'X\' button">Show/Hide "X" button</a>' | |
+'</div>' | |
+'<div id="bookmarksTypeBar">' | |
+'<h5 class="bkmrk_maps current" onclick="window.plugin.bookmarks.switchPageBkmrksBox(this, 0);return false">Maps</h5>' | |
+'<h5 class="bkmrk_portals" onclick="window.plugin.bookmarks.switchPageBkmrksBox(this, 1);return false">Portals</h5>' | |
+'<div style="clear:both !important;"></div>' | |
+'</div>' | |
+'<div id="bkmrk_maps" class="bookmarkList current">' | |
+'<div class="addForm">' | |
+'<input placeholder="Insert label" />' | |
+'<a class="newMap" onclick="window.plugin.bookmarks.addElement(this, \'map\');return false;">+ Map</a>' | |
+'<a class="newFolder" onclick="window.plugin.bookmarks.addElement(this, \'folder\');return false;">+ Folder</a>' | |
+'</div>' | |
+'</div>' | |
+'<div id="bkmrk_portals" class="bookmarkList">' | |
+'<div class="addForm">' | |
+'<input placeholder="Insert label" />' | |
+'<a class="newFolder" onclick="window.plugin.bookmarks.addElement(this, \'folder\');return false;">+ Folder</a>' | |
+'</div>' | |
+'</div>' | |
+'<div style="border-bottom-width:1px;"></div>' | |
+'</div>'; | |
plugin.bookmarks.htmlDisabledMessage = '<div title="Your browser do not support localStorage">Plugin Bookmarks disabled*.</div>'; | |
plugin.bookmarks.htmlStar = '<a class="bkmrksStar" onclick="window.plugin.bookmarks.switchStarPortal();return false;" title="Save this portal in your bookmarks"><span></span></a>'; | |
plugin.bookmarks.htmlCalldrawBox = '<a onclick="window.plugin.bookmarks.dialogDrawer();return false;" title="Draw lines/triangles between bookmarked portals">Auto draw</a>'; | |
plugin.bookmarks.htmlCallSetBox = '<a onclick="window.plugin.bookmarks.manualOpt();return false;">Bookmarks Opt</a>'; | |
var actions = ''; | |
actions += '<a onclick="window.plugin.bookmarks.optReset();return false;">Reset bookmarks</a>'; | |
actions += '<a onclick="window.plugin.bookmarks.optPickFolder();return false;">Copy bookmarks</a>'; | |
actions += '<a onclick="window.plugin.bookmarks.optPaste();return false;">Paste bookmarks</a>'; | |
//if(plugin.bookmarks.isAndroid()) { | |
//actions += '<a onclick="window.plugin.bookmarks.optImport();return false;">Import bookmarks</a>'; | |
//actions += '<a onclick="window.plugin.bookmarks.optExport();return false;">Export bookmarks</a>'; | |
//} else { | |
if(!plugin.bookmarks.isAndroid()) { | |
actions += '<a onclick="window.plugin.bookmarks.optBox(\'save\');return false;">Save box position</a>'; | |
actions += '<a onclick="window.plugin.bookmarks.optBox(\'reset\');return false;">Reset box position</a>'; | |
} | |
plugin.bookmarks.htmlSetbox = '<div id="bkmrksSetbox">' + actions + '</div>'; | |
} | |
/***************************************************************************************************************************************************************/ | |
var setup = function() { | |
window.plugin.bookmarks.isSmart = window.isSmartphone(); | |
// Fired when a bookmarks/folder is removed, added or sorted, also when a folder is opened/closed. | |
if($.inArray('pluginBkmrksEdit', window.VALID_HOOKS) < 0) { window.VALID_HOOKS.push('pluginBkmrksEdit'); } | |
// Fired when the "Bookmarks Options" panel is opened (you can add new options); | |
if($.inArray('pluginBkmrksOpenOpt', window.VALID_HOOKS) < 0) { window.VALID_HOOKS.push('pluginBkmrksOpenOpt'); } | |
// Fired when the sync is finished; | |
if($.inArray('pluginBkmrksSyncEnd', window.VALID_HOOKS) < 0) { window.VALID_HOOKS.push('pluginBkmrksSyncEnd'); } | |
// If the storage not exists or is a old version | |
window.plugin.bookmarks.createStorage(); | |
window.plugin.bookmarks.upgradeToNewStorage(); | |
// Load data from localStorage | |
window.plugin.bookmarks.loadStorage(); | |
window.plugin.bookmarks.loadStorageBox(); | |
window.plugin.bookmarks.setupContent(); | |
window.plugin.bookmarks.setupCSS(); | |
if(!window.plugin.bookmarks.isSmart) { | |
$('body').append(window.plugin.bookmarks.htmlBoxTrigger + window.plugin.bookmarks.htmlBkmrksBox); | |
$('#bookmarksBox').draggable({ handle:'.handle', containment:'window' }); | |
$("#bookmarksBox #bookmarksMin , #bookmarksBox ul li, #bookmarksBox ul li a, #bookmarksBox ul li a span, #bookmarksBox h5, #bookmarksBox .addForm a").disableSelection(); | |
$('#bookmarksBox').css({'top':window.plugin.bookmarks.statusBox.pos.x, 'left':window.plugin.bookmarks.statusBox.pos.y}); | |
}else{ | |
$('body').append(window.plugin.bookmarks.htmlBkmrksBox); | |
$('#bookmarksBox').css("display", "none").addClass("mobile"); | |
if(window.useAndroidPanes()) | |
android.addPane("plugin-bookmarks", "Bookmarks", "ic_action_star"); | |
window.addHook('paneChanged', window.plugin.bookmarks.onPaneChanged); | |
// Remove the star | |
window.addHook('portalSelected', function(data) { | |
if(data.selectedPortalGuid === null) { | |
$('.bkmrksStar').remove(); | |
} | |
}); | |
} | |
$('#toolbox').append(window.plugin.bookmarks.htmlCallSetBox+window.plugin.bookmarks.htmlCalldrawBox); | |
window.plugin.bookmarks.loadList('maps'); | |
window.plugin.bookmarks.loadList('portals'); | |
window.plugin.bookmarks.jquerySortableScript(); | |
if(window.plugin.bookmarks.statusBox['show'] === 0) { window.plugin.bookmarks.switchStatusBkmrksBox(0); } | |
if(window.plugin.bookmarks.statusBox['page'] === 1) { $('#bookmarksBox h5.bkmrk_portals').trigger('click'); } | |
window.addHook('portalDetailsUpdated', window.plugin.bookmarks.addStarToSidebar); | |
// Sync | |
window.addHook('pluginBkmrksEdit', window.plugin.bookmarks.syncBkmrks); | |
window.addHook('iitcLoaded', window.plugin.bookmarks.registerFieldForSyncing); | |
// Highlighter - bookmarked portals | |
window.addHook('pluginBkmrksEdit', window.plugin.bookmarks.highlightRefresh); | |
window.addHook('pluginBkmrksSyncEnd', window.plugin.bookmarks.highlightRefresh); | |
window.addPortalHighlighter('Bookmarked Portals', window.plugin.bookmarks.highlight); | |
// Layer - Bookmarked portals | |
window.plugin.bookmarks.starLayerGroup = new L.LayerGroup(); | |
window.addLayerGroup('Bookmarked Portals', window.plugin.bookmarks.starLayerGroup, false); | |
window.plugin.bookmarks.addAllStars(); | |
window.addHook('pluginBkmrksEdit', window.plugin.bookmarks.editStar); | |
window.addHook('pluginBkmrksSyncEnd', window.plugin.bookmarks.resetAllStars); | |
} | |
// PLUGIN END ////////////////////////////////////////////////////////// | |
setup.info = plugin_info; //add the script info data to the function as a property | |
if(!window.bootPlugins) window.bootPlugins = []; | |
window.bootPlugins.push(setup); | |
// if IITC has already booted, immediately run the 'setup' function | |
if(window.iitcLoaded && typeof setup === 'function') setup(); | |
} // wrapper end | |
// inject code into site context | |
var script = document.createElement('script'); | |
var info = {}; | |
if (typeof GM_info !== 'undefined' && GM_info && GM_info.script) info.script = { version: GM_info.script.version, name: GM_info.script.name, description: GM_info.script.description }; | |
script.appendChild(document.createTextNode('('+ wrapper +')('+JSON.stringify(info)+');')); | |
(document.body || document.head || document.documentElement).appendChild(script); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment