diff --git a/plugins/portals-list.user.js b/plugins/portals-list.user.js
index 37997cc2..4b4bfbd5 100644
--- a/plugins/portals-list.user.js
+++ b/plugins/portals-list.user.js
@@ -1,7 +1,7 @@
// ==UserScript==
// @id iitc-plugin-portals-list@teo96
// @name IITC plugin: show list of portals
-// @version 0.0.10.@@DATETIMEVERSION@@
+// @version 0.0.11.@@DATETIMEVERSION@@
// @namespace https://github.com/jonatkins/ingress-intel-total-conversion
// @updateURL @@UPDATEURL@@
// @downloadURL @@DOWNLOADURL@@
@@ -13,6 +13,8 @@
// ==/UserScript==
/* whatsnew
+* 0.0.11: Add nominal energy column and # links, fix sort bug when opened even amounts of times, nits
+* 0.0.10: Fixed persistent css problem with alert
* 0.0.9 : bugs hunt
* 0.0.8 : Aborted to avoid problems with Niantic (export portals informations as csv or kml file)
* 0.0.7 : more informations avalaible via tooltips (who deployed, energy, ...), new E/AP column
@@ -45,328 +47,239 @@ window.plugin.portalslist.resP = 0;
window.plugin.portalslist.filter=0;
//fill the listPortals array with portals avalaible on the map (level filtered portals will not appear in the table)
-window.plugin.portalslist.getPortals = function(){
- //filter : 0 = All, 1 = Res, 2 = Enl
- //console.log('** getPortals');
- var retval=false;
-
- window.plugin.portalslist.listPortals = [];
- //get portals informations from IITC
- $.each(window.portals, function(i, portal) {
-
- retval=true;
- var d = portal.options.details;
- var name = d.portalV2.descriptiveText.TITLE;
- var address = d.portalV2.descriptiveText.ADDRESS;
- var img = d.imageByUrl && d.imageByUrl.imageUrl ? d.imageByUrl.imageUrl : DEFAULT_PORTAL_IMG;
- var team = portal.options.team;
- switch (team){
- case 1 :
- window.plugin.portalslist.resP++;
- break;
- case 2 :
- window.plugin.portalslist.enlP++;
- break;
- }
- var level = getPortalLevel(d).toFixed(2);
- var guid = portal.options.guid;
-
-
- //get resonators informations
- var resonators = []; // my local resonator array : reso level, reso deployed by, distance to portal, energy total, max
- var energy = 0;
- var maxenergy=0;
- $.each(portal.options.details.resonatorArray.resonators, function(ind, reso) {
- if(reso) {
- resonators[ind] = [reso.level, window.getPlayerName(reso.ownerGuid), reso.distanceToPortal, reso.energyTotal, RESO_NRG[reso.level]];
- energy += reso.energyTotal;
- maxenergy += RESO_NRG[reso.level];
- } else { resonators[ind] = [0,'',0,0,0]; }
- });
- // Sort resonators array by resonator level
- resonators.sort(function (a, b) {return b[0] - a[0]});
-
- //get shield informations
- var shields = [];
- $.each(d.portalV2.linkedModArray, function(ind, mod) {
- if (mod)
- //shields[ind] = mod.rarity.capitalize().replace('_', ' ');
- shields[ind] = [mod.rarity.substr(0,1).capitalize(), getPlayerName(mod.installingUser)] ;
- else
- shields[ind] = ['', ''];
- });
-
- var APgain= getAttackApGain(d).enemyAp;
- var thisPortal = {'portal':d,'name':name,'team':team,'level':level,'guid':guid, 'resonators':resonators,'energyratio' : Math.floor(energy/maxenergy*100), 'shields':shields, 'APgain':APgain, 'EAP' : (energy/APgain).toFixed(2), 'energy': energy, 'maxenergy':maxenergy, 'lat':portal._latlng.lat, 'lng':portal._latlng.lng, 'address': address, 'img' : img};
- window.plugin.portalslist.listPortals.push(thisPortal);
+window.plugin.portalslist.getPortals = function() {
+ //filter : 0 = All, 1 = Res, 2 = Enl
+ //console.log('** getPortals');
+ var retval=false;
+
+ window.plugin.portalslist.listPortals = [];
+ //get portals informations from IITC
+ $.each(window.portals, function(i, portal) {
+
+ retval=true;
+ var d = portal.options.details;
+ var name = d.portalV2.descriptiveText.TITLE;
+ var address = d.portalV2.descriptiveText.ADDRESS;
+ var img = d.imageByUrl && d.imageByUrl.imageUrl ? d.imageByUrl.imageUrl : DEFAULT_PORTAL_IMG;
+ var team = portal.options.team;
+ switch (team){
+ case 1 :
+ window.plugin.portalslist.resP++;
+ break;
+ case 2 :
+ window.plugin.portalslist.enlP++;
+ break;
+ }
+ var level = getPortalLevel(d).toFixed(2);
+ var guid = portal.options.guid;
+
+
+ //get resonators informations
+ var resonators = []; // my local resonator array : reso level, reso deployed by, distance to portal, energy total, max
+ var energy = 0;
+ var maxenergy=0;
+ $.each(portal.options.details.resonatorArray.resonators, function(ind, reso) {
+ if(reso) {
+ resonators[ind] = [reso.level, window.getPlayerName(reso.ownerGuid), reso.distanceToPortal, reso.energyTotal, RESO_NRG[reso.level]];
+ energy += reso.energyTotal;
+ maxenergy += RESO_NRG[reso.level];
+ } else { resonators[ind] = [0,'',0,0,0]; }
});
-
- return retval;
+ // Sort resonators array by resonator level
+ resonators.sort(function (a, b) {return b[0] - a[0]});
+
+ //get shield informations
+ var shields = [];
+ $.each(d.portalV2.linkedModArray, function(ind, mod) {
+ if (mod) {
+ //shields[ind] = mod.rarity.capitalize().replace('_', ' ');
+ shields[ind] = [mod.rarity.substr(0,1).capitalize(), getPlayerName(mod.installingUser)] ;
+ } else {
+ shields[ind] = ['', ''];
+ }
+ });
+
+ var APgain= getAttackApGain(d).enemyAp;
+ var thisPortal = {'portal': d, 'name': name, 'team': team, 'level': level, 'guid': guid, 'resonators': resonators, 'energyratio': maxenergy ? Math.floor(energy/maxenergy*100) : 0, 'shields': shields, 'APgain': APgain, 'EAP': (energy/APgain).toFixed(2), 'energy': energy, 'maxenergy': maxenergy, 'links': d.portalV2.linkedEdges.length, 'lat': portal._latlng.lat, 'lng': portal._latlng.lng, 'address': address, 'img': img};
+ window.plugin.portalslist.listPortals.push(thisPortal);
+ });
+
+ return retval;
}
-window.plugin.portalslist.displayPL = function() {
- // debug tools
- //var start = new Date().getTime();
- //console.log('***** Start ' + start);
-
- var html = '';
- window.plugin.portalslist.sortOrder=-1;
- window.plugin.portalslist.enlP = 0;
- window.plugin.portalslist.resP = 0;
+window.plugin.portalslist.displayPL = function() {
+ // debug tools
+ //var start = new Date().getTime();
+ //console.log('***** Start ' + start);
- if (window.plugin.portalslist.getPortals()) {
- html += window.plugin.portalslist.portalTable('level', window.plugin.portalslist.sortOrder,window.plugin.portalslist.filter);
- } else {
- html = '
';
- };
- alert('' + html + '
', true, function() {$(".ui-dialog").removeClass('ui-dialog-portalslist');});
- $(".ui-dialog").addClass('ui-dialog-portalslist');
+ var html = '';
+ window.plugin.portalslist.sortOrder=-1;
+ window.plugin.portalslist.enlP = 0;
+ window.plugin.portalslist.resP = 0;
+
+ if (window.plugin.portalslist.getPortals()) {
+ html += window.plugin.portalslist.portalTable('level', window.plugin.portalslist.sortOrder,window.plugin.portalslist.filter);
+ } else {
+ html = '';
+ };
+ alert('' + html + '
', true, function() {
+ $(".ui-dialog").removeClass('ui-dialog-portalslist');
+ $(document).off('.portalslist');
+ });
+ $(".ui-dialog").addClass('ui-dialog-portalslist');
+
+ // Setup sorting
+ $(document).on('click.portalslist', '#portalslist table th', function() {
+ $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,window.plugin.portalslist.filter));
+ });
+ $(document).on('click.portalslist', '#portalslist .filterAll', function() {
+ $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,0));
+ });
+ $(document).on('click.portalslist', '#portalslist .filterRes', function() {
+ $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,1));
+ });
+ $(document).on('click.portalslist', '#portalslist .filterEnl', function() {
+ $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,2));
+ });
- // Setup sorting
- $(document).on('click', '#portalslist table th', function() {
- $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,window.plugin.portalslist.filter));
- });
- $(document).on('click', '#portalslist .filterAll', function() {
- $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,0));
- });
- $(document).on('click', '#portalslist .filterRes', function() {
- $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,1));
- });
- $(document).on('click', '#portalslist .filterEnl', function() {
- $('#portalslist').html(window.plugin.portalslist.portalTable($(this).data('sort'),window.plugin.portalslist.sortOrder,2));
- });
-
- //debug tools
- //end = new Date().getTime();
- //console.log('***** end : ' + end + ' and Elapse : ' + (end - start));
+ //debug tools
+ //end = new Date().getTime();
+ //console.log('***** end : ' + end + ' and Elapse : ' + (end - start));
}
window.plugin.portalslist.portalTable = function(sortBy, sortOrder, filter) {
- // sortOrder <0 ==> desc, >0 ==> asc, i use sortOrder * -1 to change the state
- window.plugin.portalslist.filter=filter;
- var portals=window.plugin.portalslist.listPortals;
-
- //Array sort
- window.plugin.portalslist.listPortals.sort(function(a, b) {
- var retVal = 0;
- switch (sortBy) {
- case 'names':
- retVal = a.name.toLowerCase() < b.name.toLowerCase() ? -1 : 1;
- break;
- case 'r1':
- retVal = b.resonators[0][0] - a.resonators[0][0];
- break;
- case 'r2':
- retVal = b.resonators[1][0] - a.resonators[1][0];
- break;
- case 'r3':
- retVal = b.resonators[2][0] - a.resonators[2][0];
- break;
- case 'r4':
- retVal = b.resonators[3][0] - a.resonators[3][0];
- break;
- case 'r5':
- retVal = b.resonators[4][0] - a.resonators[4][0];
- break;
- case 'r6':
- retVal = b.resonators[5][0] - a.resonators[5][0];
- break;
- case 'r7':
- retVal = b.resonators[6][0] - a.resonators[6][0];
- break;
- case 'r8':
- retVal = b.resonators[7][0] - a.resonators[7][0];
- break;
- case 's1':
- retVal = a.shields[0].toLowerCase() > b.shields[0].toLowerCase() ? -1 : 1;
- break;
- case 's2':
- retVal = a.shields[1].toLowerCase() > b.shields[1].toLowerCase() ? -1 : 1;
- break;
- case 's3':
- retVal = a.shields[2].toLowerCase() > b.shields[2].toLowerCase() ? -1 : 1;
- break;
- case 's4':
- retVal = a.shields[3].toLowerCase() > b.shields[3].toLowerCase() ? -1 : 1;
- break;
- default:
- retVal = b[sortBy] - a[sortBy];
- break;
- }
- if (sortOrder > 0) { retVal = -retVal} //thx @jonatkins
- return retVal;
- });
-
- var sort = window.plugin.portalslist.portalTableSort;
- var html = window.plugin.portalslist.stats();
- html += ''
- + 'Portal | '
- + 'Level | '
- + 'T | '
- + 'R1 | '
- + 'R2 | '
- + 'R3 | '
- + 'R4 | '
- + 'R5 | '
- + 'R6 | '
- + 'R7 | '
- + 'R8 | '
- + 'Energy | '
- + 'S1 | '
- + 'S2 | '
- + 'S3 | '
- + 'S4 | '
- + 'AP Gain | '
- + 'E/AP |
';
-
-
- $.each(portals, function(ind, portal) {
-
- if (filter === 0 || filter === portal.team){
- html += ''
- + '' + window.plugin.portalslist.getPortalLink(portal.portal, portal.guid) + ' | '
- + '' + portal.level + ' | '
- + '' + portal.team + ' | ';
-
- $.each([0, 1, 2, 3 ,4 ,5 ,6 ,7], function(ind, slot) {
-
- var title = 'title="owner: ' + portal.resonators[slot][1] + '
'
- + 'energy: ' + portal.resonators[slot][3] + ' / ' + portal.resonators[slot][4] + ' (' + Math.floor(portal.resonators[slot][3]/portal.resonators[slot][4]*100) + '%)
'
- + 'distance: ' + portal.resonators[slot][2] + 'm';
-
- html += '' + portal.resonators[slot][0] + ' | ';
-
- });
-
- html += '' + portal.energyratio + '% | '
- + '' + portal.shields[0][0] + ' | '
- + '' + portal.shields[1][0] + ' | '
- + '' + portal.shields[2][0] + ' | '
- + '' + portal.shields[3][0] + ' | '
- + '' + portal.APgain + ' | '
- + '' + portal.EAP + ' | ';
-
- html+= '
';
- }
- });
- html += '
';
-
- //html += window.plugin.portalslist.exportLinks();
-
- html += 'Click on portals table headers to sort by that column. '
- + 'Click on
All Portals, Resistant Portals, Enlightened Portals to filter
'
- + 'Thanks to @vita10gy & @xelio for their IITC plugins who inspired me. A
@teo96 production. Vive la Résistance !
';
+ // sortOrder <0 ==> desc, >0 ==> asc, i use sortOrder * -1 to change the state
+ window.plugin.portalslist.filter=filter;
+ var portals=window.plugin.portalslist.listPortals;
- window.plugin.portalslist.sortOrder = window.plugin.portalslist.sortOrder*-1;
- return html;
+ //Array sort
+ window.plugin.portalslist.listPortals.sort(function(a, b) {
+ var retVal = 0;
+ switch (sortBy) {
+ case 'names':
+ retVal = a.name.toLowerCase() < b.name.toLowerCase() ? -1 : 1;
+ break;
+ case 'r1':
+ retVal = b.resonators[0][0] - a.resonators[0][0];
+ break;
+ case 'r2':
+ retVal = b.resonators[1][0] - a.resonators[1][0];
+ break;
+ case 'r3':
+ retVal = b.resonators[2][0] - a.resonators[2][0];
+ break;
+ case 'r4':
+ retVal = b.resonators[3][0] - a.resonators[3][0];
+ break;
+ case 'r5':
+ retVal = b.resonators[4][0] - a.resonators[4][0];
+ break;
+ case 'r6':
+ retVal = b.resonators[5][0] - a.resonators[5][0];
+ break;
+ case 'r7':
+ retVal = b.resonators[6][0] - a.resonators[6][0];
+ break;
+ case 'r8':
+ retVal = b.resonators[7][0] - a.resonators[7][0];
+ break;
+ case 's1':
+ retVal = a.shields[0].toLowerCase() > b.shields[0].toLowerCase() ? -1 : 1;
+ break;
+ case 's2':
+ retVal = a.shields[1].toLowerCase() > b.shields[1].toLowerCase() ? -1 : 1;
+ break;
+ case 's3':
+ retVal = a.shields[2].toLowerCase() > b.shields[2].toLowerCase() ? -1 : 1;
+ break;
+ case 's4':
+ retVal = a.shields[3].toLowerCase() > b.shields[3].toLowerCase() ? -1 : 1;
+ break;
+ default:
+ retVal = b[sortBy] - a[sortBy];
+ break;
+ }
+ if (sortOrder > 0) retVal = -retVal; //thx @jonatkins
+ return retVal;
+ });
+
+ var sort = window.plugin.portalslist.portalTableSort;
+ var html = window.plugin.portalslist.stats();
+ html += ''
+ + 'Portal | '
+ + 'Level | '
+ + 'T | '
+ + 'R1 | '
+ + 'R2 | '
+ + 'R3 | '
+ + 'R4 | '
+ + 'R5 | '
+ + 'R6 | '
+ + 'R7 | '
+ + 'R8 | '
+ + 'Energy | '
+ + '% | '
+ + 'Links | '
+ + 'S1 | '
+ + 'S2 | '
+ + 'S3 | '
+ + 'S4 | '
+ + 'AP Gain | '
+ + 'E/AP |
';
+
+
+ $.each(portals, function(ind, portal) {
+
+ if (filter === 0 || filter === portal.team) {
+ html += ''
+ + '' + window.plugin.portalslist.getPortalLink(portal.portal, portal.guid) + ' | '
+ + '' + portal.level + ' | '
+ + '' + portal.team + ' | ';
+
+ var title;
+ var percent;
+ $.each([0, 1, 2, 3 ,4 ,5 ,6 ,7], function(ind, slot) {
+ percent = portal.resonators[slot][4] ? Math.floor(portal.resonators[slot][3]/portal.resonators[slot][4]*100) : 0;
+ title = 'title="owner: ' + portal.resonators[slot][1] + '
'
+ + 'energy: ' + portal.resonators[slot][3] + ' / ' + portal.resonators[slot][4] + ' (' + percent + '%)
'
+ + 'distance: ' + portal.resonators[slot][2] + 'm';
+
+ html += '' + portal.resonators[slot][0] + ' | ';
+
+ });
+
+ html += '' + prettyEnergy(portal.energy) + ' | '
+ + '' + portal.energyratio + '% | '
+ + '' + portal.links + ' | '
+ + '' + portal.shields[0][0] + ' | '
+ + '' + portal.shields[1][0] + ' | '
+ + '' + portal.shields[2][0] + ' | '
+ + '' + portal.shields[3][0] + ' | '
+ + '' + portal.APgain + ' | '
+ + '' + portal.EAP + ' | ';
+
+ html+= '
';
+ }
+ });
+ html += '
';
+
+ html += 'Click on portals table headers to sort by that column. '
+ + 'Click on
All Portals, Resistant Portals, Enlightened Portals to filter
'
+ + 'Thanks to @vita10gy & @xelio for their IITC plugins who inspired me. A
@teo96 production. Vive la Résistance !
';
+
+ window.plugin.portalslist.sortOrder = window.plugin.portalslist.sortOrder*-1;
+ return html;
}
window.plugin.portalslist.stats = function(sortBy) {
- //console.log('** stats');
- var html = ''
- + 'All Portals : (click to filter) | ' + window.plugin.portalslist.listPortals.length + ' | '
- + 'Resistant Portals : | ' + window.plugin.portalslist.resP +' (' + Math.floor(window.plugin.portalslist.resP/window.plugin.portalslist.listPortals.length*100) + '%) | '
- + 'Enlightened Portals : | '+ window.plugin.portalslist.enlP +' (' + Math.floor(window.plugin.portalslist.enlP/window.plugin.portalslist.listPortals.length*100) + '%) | '
- + '
'
- + '
';
- return html;
-}
-
-//return Html generated to export links
-window.plugin.portalslist.exportLinks = function(){
- var html='';
- var stamp = new Date().getTime();
-
- html+='';
- return html;
-}
-
-window.plugin.portalslist.export = function(fileformat){
- //alert('format :' + fileformat);
- var file = '';
- var uri = '';
-
- switch (fileformat) {
- case 'csv':
- file = window.plugin.portalslist.exportCSV();
- break;
- case 'kml':
- file = window.plugin.portalslist.exportKML();
- break;
- }
-
- if (file !== '') {
- //http://stackoverflow.com/questions/4639372/export-to-csv-in-jquery
- var uri = 'data:application/' + fileformat + 'csv;charset=UTF-8,' + encodeURIComponent(file);
- //window.open(uri);
- }
- return uri;
-}
-window.plugin.portalslist.exportCSV = function(){
- var csv = '';
- var filter = window.plugin.portalslist.filter;
- var portals = window.plugin.portalslist.listPortals;
-
- //headers
- csv += 'Portal\tLevel\tTeam\tR1\tR2\tR3\tR4\tR5\tR6\tR7\tR8\tEnergy\tS1\tS2\tS3\tS4\tAP Gain\tE/AP\tlat\tlong\n';
-
- $.each(portals, function(ind, portal) {
-
- if (filter === 0 || filter === portal.team){
- csv += portal.name + '\t'
- + portal.level + '\t'
- + portal.team + '\t';
-
- $.each([0, 1, 2, 3 ,4 ,5 ,6 ,7], function(ind, slot) {
- csv += portal.resonators[slot][0] + '\t';
- });
-
- csv += portal.energyratio + '\t' + portal.shields[0][0] + '\t' + portal.shields[1][0] + '\t' + portal.shields[2][0] + '\t' + portal.shields[3][0] + '\t' + portal.APgain + '\t' + portal.EAP + '\t';
- csv += portal.lat + '\t' + portal.lng;
- csv += '\n';
- }
- });
-
- return csv;
-}
-
-window.plugin.portalslist.exportKML = function(){
- var kml = '';
- var filter = window.plugin.portalslist.filter;
- // all portals informations are avalaible in the listPortals array
- var portals = window.plugin.portalslist.listPortals;
-
- //headers
- kml = '\n'
- + 'Ingress Export';
-
- // define colored markers as style0 (neutral), style1 (Resistance), style2 (Enlight)
- kml += ''
- + ''
- + '\n';
-
- $.each(portals, function(ind, portal) {
- // add the portal in the kml file only if part of the filter choice
- if (filter === 0 || filter === portal.team){
- // description contain picture of the portal, address and link to the Intel map
- var description = ''
- + ']]>';
-
- kml += 'L' + Math.floor(portal.level) + ' - ' + portal.name + ''
- + '' + description + ''
- + '#style' + portal.team + '';
-
- //coordinates
- kml += '' + portal.lng + ',' + portal.lat + ',0';
- kml += '\n';
- }
- });
- kml += '';
- return kml;
+ //console.log('** stats');
+ var html = ''
+ + 'All Portals : (click to filter) | ' + window.plugin.portalslist.listPortals.length + ' | '
+ + 'Resistant Portals : | ' + window.plugin.portalslist.resP +' (' + Math.floor(window.plugin.portalslist.resP/window.plugin.portalslist.listPortals.length*100) + '%) | '
+ + 'Enlightened Portals : | '+ window.plugin.portalslist.enlP +' (' + Math.floor(window.plugin.portalslist.enlP/window.plugin.portalslist.listPortals.length*100) + '%) | '
+ + '
'
+ + '
';
+ return html;
}
// A little helper functon so the above isn't so messy
@@ -383,29 +296,29 @@ window.plugin.portalslist.portalTableSort = function(name, by) {
// hover: show address
// code from getPortalLink function by xelio from iitc: AP List - https://raw.github.com/breunigs/ingress-intel-total-conversion/gh-pages/plugins/ap-list.user.js
window.plugin.portalslist.getPortalLink = function(portal,guid) {
-
- var latlng = [portal.locationE6.latE6/1E6, portal.locationE6.lngE6/1E6].join();
- var jsSingleClick = 'window.renderPortalDetails(\''+guid+'\');return false';
- var jsDoubleClick = 'window.zoomToAndShowPortal(\''+guid+'\', ['+latlng+']);return false';
- var perma = '/intel?latE6='+portal.locationE6.latE6+'&lngE6='+portal.locationE6.lngE6+'&z=17&pguid='+guid;
-
- //Use Jquery to create the link, which escape characters in TITLE and ADDRESS of portal
- var a = $('',{
- "class": 'help',
- text: portal.portalV2.descriptiveText.TITLE,
- title: portal.portalV2.descriptiveText.ADDRESS,
- href: perma,
- onClick: jsSingleClick,
- onDblClick: jsDoubleClick
- })[0].outerHTML;
- var div = ''+a+'
';
- return div;
+
+ var latlng = [portal.locationE6.latE6/1E6, portal.locationE6.lngE6/1E6].join();
+ var jsSingleClick = 'window.renderPortalDetails(\''+guid+'\');return false';
+ var jsDoubleClick = 'window.zoomToAndShowPortal(\''+guid+'\', ['+latlng+']);return false';
+ var perma = '/intel?latE6='+portal.locationE6.latE6+'&lngE6='+portal.locationE6.lngE6+'&z=17&pguid='+guid;
+
+ //Use Jquery to create the link, which escape characters in TITLE and ADDRESS of portal
+ var a = $('',{
+ "class": 'help',
+ text: portal.portalV2.descriptiveText.TITLE,
+ title: portal.portalV2.descriptiveText.ADDRESS,
+ href: perma,
+ onClick: jsSingleClick,
+ onDblClick: jsDoubleClick
+ })[0].outerHTML;
+ var div = ''+a+'
';
+ return div;
}
var setup = function() {
- $('#toolbox').append(' Portals list');
- $('head').append('