WME Place Interface Enhancements

Enhancements to various Place interfaces

נכון ליום 08-03-2017. ראה הגרסה האחרונה.

  1. // ==UserScript==
  2. // @name WME Place Interface Enhancements
  3. // @namespace https://greasyfork.org/users/30701-justins83-waze
  4. // @version 0.7.7.6
  5. // @description Enhancements to various Place interfaces
  6. // @include https://www.waze.com/editor/*
  7. // @include https://www.waze.com/*/editor/*
  8. // @include https://beta.waze.com/*
  9. // @exclude https://www.waze.com/user/editor*
  10. // @icon 
  11. // @author JustinS83
  12. // @grant none
  13. // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
  14. // @license GPLv3
  15. // ==/UserScript==
  16. var UpdateObject, MultiAction;
  17.  
  18. (function() {
  19. 'use strict';
  20.  
  21. var settings = {};
  22. var placeMenuSelector = "#edit-buttons > div > div.toolbar-button.waze-icon-place.toolbar-submenu.toolbar-group.toolbar-group-venues.ItemInactive > menu";
  23. var pointStyle = {
  24. pointRadius: 6,
  25. fillOpacity: 0,
  26. strokeColor: '#00ece3',
  27. strokeWidth: '2',
  28. strokeLinecap: 'round'
  29. };
  30. var layerName = "WME PIE";
  31. var newPlaceLayer;
  32. var placementMode = false;
  33. var drawPoly;
  34. var resCategory = "RESIDENCE_HOME";
  35.  
  36. function bootstrap(tries) {
  37. tries = tries || 1;
  38.  
  39. if (window.W &&
  40. window.W.map &&
  41. window.W.model &&
  42. window.W.loginManager.user &&
  43. $) {
  44. init();
  45. } else if (tries < 1000) {
  46. setTimeout(function () {bootstrap(tries++);}, 200);
  47. }
  48. }
  49.  
  50. bootstrap();
  51.  
  52. function init(){
  53. var $section = $("<div>", {style:"padding:8px 16px", id:"WMEPIESettings"});
  54. $section.html([
  55. '<h4><b>WME Place Interface Enhancements</b></h4>',
  56. '<div class="controls-container pie-controls-container" id="divAreaPlaceSizeControls">',
  57. '<div id="divShowAreaPlaceSize" class="controls-container pie-controls-container"><input type="checkbox" id="_cbShowAreaPlaceSize" class="pieSettingsCheckbox" /><label for="_cbShowAreaPlaceSize">Show area Place size</label></div>',
  58. '<div id="divShowAreaPlaceSizeImperial"class="controls-container pie-controls-container" style="padding-left:20px;"><input type="checkbox" id="_cbShowAreaPlaceSizeImperial" class="pieSettingsCheckbox" disabled /><label for ="_cbShowAreaPlaceSizeImperial"> Show imperial </label></div>',
  59. '<div id="divShowAreaPlaceSizeMetric" class="controls-container pie-controls-container" style="padding-left:20px;"><input type="checkbox" id="_cbShowAreaPlaceSizeMetric" class="pieSettingsCheckbox" disabled /><label for ="_cbShowAreaPlaceSizeMetric"> Show metric</label></div>',
  60. '</div>',
  61. '<div class="controls-container pie-controls-container" id="divShowLockButtonsRPP" title="Displays lock level buttons for Residential Place Points"><input type="checkbox" id="_cbShowLockButtonsRPP" class="pieSettingsCheckbox" /><label for="_cbShowLockButtonsRPP">Show lock buttons for RPPs</label></div>',
  62. '<div class="controls-container pie-controls-container" id="divShowPlaceLocatorCrosshair" title="Centers the Place on screen and zooms to the defined level" ><input type="checkbox" id="_cbShowPlaceLocatorCrosshair" class="pieSettingsCheckbox" /><label for="_cbShowPlaceLocatorCrosshair">Show Place locator crosshair</label></br>',
  63. '<span class="controls-container pie-controls-container" style="padding-left:30px;" title="The zoom level to use when centering on a Place">Zoom <select id="piePlaceZoom"><option value="10">10</option><option value="9">9</option><option value="8">8</option><option value="7">7</option><option value="6">6</option><option value="5">5</option><option value="4">4</option><option value="3">3</option><option value="2">2</option><option value="1">1</option><option value="0">0</option></select></span></div>',
  64. '<div class="controls-container pie-controls-container" id="divShowSearchButton" title="Show a magnifying glass next to the Place&#39;s address. Clicking this button will load the address into the search box"><input type="checkbox" id="_cbShowSearchButton" class="pieSettingsCheckbox"/><label for="_cbShowSearchButton" style="white-space:pre-line;">Show search button next to address</label></div>',
  65. '<div class="controls-container pie-controls-container" id="divAddPlaceCategoriesButtons" title=""><input type="checkbox" id="_cbAddPlaceCategoriesButtons" class="pieSettingsCheckbox"/><label for="_cbAddPlaceCategoriesButtons" style="white-space:pre-line;">Add Place category buttons above the categories selection</label></div>',
  66.  
  67. '<fieldset id="fieldNewPlaces" style="border: 1px solid silver; border: 1px solid silver; padding: 8px; border-radius: 4px;">',
  68. '<legend style="margin-bottom:0px; border-bottom-style:none;width:auto;"><h4>New Places</h4></legend>',
  69. '<div id="divEditRPPAfterCreated" class="controls-container pie-controls-container" title="Automatically opens the RPP address edit window and focuses on the House Number entry"><input type="checkbox" id="_cbEditRPPAfterCreated" class="pieSettingsCheckbox"><label for="_cbEditRPPAfterCreated" style="white-space:pre-line;">Edit RPP address after created</label></div>',
  70. '<div id="divUseStreetFromClosestSeg" class="controls-container pie-controls-container" title="Pulls the street name from the closest visible segment and inserts into the new Place&#39;s address"><input type="checkbox" id="_cbUseStreetFromClosestSeg" class="pieSettingsCheckbox"><label for="_cbUseStreetFromClosestSeg" style="white-space:pre-line;">Use street name from closest segment</label></div>',
  71. '<div id="divUseCityFromClosestSeg" class="controls-container pie-controls-container" title="Pulls the city name from the closest visible segment and inserts into the new Place&#39;s address"><input type="checkbox" id="_cbUseCityFromClosestSeg" class="pieSettingsCheckbox"><label for="_cbUseCityFromClosestSeg" style="white-space:pre-line;">Use city name from closest segment</label></div>',
  72. '<div id="divUseAltCity" class="controls-container pie-controls-container" title="When the primary is &quot;No city&quot; try to find an alt street name with a city" style="padding-left:20px; word-wrap: break-word;"><input type="checkbox" id="_cbUseAltCity" class="pieSettingsCheckbox"><label for="_cbUseAltCity" style="white-space:pre-line;">When the primary is &quot;No city&quot; look for an alt city</label></div>',
  73. '<div id="divSkipPLR" class="controls-container pie-controls-container"><input type="checkbox" id="_cbSkipPLR" class="pieSettingsCheckbox"/><label for="_cbSkipPLR" style="white-space:pre-line;">Ignore PLRs & unnamed PR when using closest segment&#39;s name and city</label></div>',
  74. '<div id="divDefaultLockLevel" class="controls-container pie-controls-container" style="left:8px;" title="The lock level to set automatically when creating new Places">Lock level <select id="pieDefaultLockLevel">' + buildLockLevelsList() + '</select></div>',
  75. '</fieldset>',
  76. '<div class="controls-container" id="divPlaceMenuCustomization">',
  77. '<b>Place Menu Customization</b></br>',
  78. buildItemOption(1),
  79. buildItemOption(2),
  80. buildItemOption(3),
  81. buildItemOption(4),
  82. buildItemOption(5),
  83. buildItemOption(6),
  84. buildItemOption(7),
  85. buildItemOption(8),
  86. buildItemOption(9),
  87. buildItemOption(10),
  88. buildItemOption(11),
  89. '</div>'
  90.  
  91. ].join(' '));
  92.  
  93. UpdateObject = require("Waze/Action/UpdateObject");
  94. MultiAction = require("Waze/Action/MultiAction");
  95.  
  96. newPlaceLayer = new OL.Layer.Vector(layerName,{displayInLayerSwitcher: false});
  97. W.map.addLayer(newPlaceLayer);
  98.  
  99. injectCss();
  100. new WazeWrap.Interface.Tab('PIE', $section.html(), init2);
  101. }
  102.  
  103. function buildNewPlaceList(){
  104. //Clear out the Places menu
  105. $(placeMenuSelector).empty();
  106. var cat = "";
  107. var icon = "";
  108. var i;
  109. for(i=0;i<11;i++){
  110. icon = "";
  111. cat = $('#pieItem' + (i+1))[0].value;
  112. icon = $('#pieItem' + (i+1))[0].options[$('#pieItem' + (i+1))[0].selectedIndex].getAttribute("data-icon");
  113. if(cat !== "PARKING_LOT" && cat !== resCategory)
  114. $(placeMenuSelector).append('<div class="toolbar-group-item WazeControlDrawFeature ItemInactive" style="' + (icon !== "" ? "padding-left:0px;" : "") + ' height:40px;" id="piePlaceMainItem' + (i+1) + '" data-category="'+ cat + '"><span class="menu-title ' + icon + '" style="font-size:26px;"><span style="font-size:12px;">' + $('#pieItem' + (i+1))[0].options[$('#pieItem' + (i+1))[0].selectedIndex].innerHTML + '</span></span><div class="drawing-controls"><span class="drawing-control polygon secondary-control" id="piePlaceAreaItem' + (i+1) + '" data-category="' + cat + '" title="Place (area)"></span><span class="drawing-control main-control point" id="piePlacePointItem' + (i+1) + '" data-category="' + cat + '" title="Place (point)"></span></div></div>');
  115. else{
  116. if(cat === resCategory) //force point
  117. $(placeMenuSelector).append('<div class="toolbar-group-item WazeControlDrawFeature ItemInactive" style="padding-left:0px; height:40px;" id="piePlaceMainItem' + (i+1) + '" data-category="'+ cat + '"><span class="menu-title ' + icon + '" style="font-size:26px;"><span style="font-size:12px;">' + $('#pieItem' + (i+1))[0].options[$('#pieItem' + (i+1))[0].selectedIndex].innerHTML + '</span></span></div>');
  118. else //Parking lot - force area
  119. $(placeMenuSelector).append('<div class="toolbar-group-item WazeControlDrawFeature ItemInactive" style="padding-left:1px; height40px;" id="piePlaceAreaItem' + (i+1) + '" data-category="'+ cat + '"><i class="fa fa-product-hunt fa-2x" style="font-size:20px;padding-top:9px;margin-right:5px;"></i><span class="menu-title" style="flex-grow:1;">' + $('#pieItem' + (i+1))[0].options[$('#pieItem' + (i+1))[0].selectedIndex].innerHTML + '</span></div>');
  120. }
  121. }
  122.  
  123. $('[id^="piePlaceMainItem"]').click(function(e){
  124. startPlacementMode($('#' + this.id).data("category"), true);
  125. });
  126.  
  127. $('[id^="piePlaceAreaItem"]').click(function(e){
  128. e.stopPropagation();
  129. startPlacementMode($('#' + this.id).data("category"), false);
  130. });
  131. }
  132.  
  133. function init2(){
  134. //Load settings
  135. loadSettings();
  136. //Set up event handlers
  137. $('#_cbShowAreaPlaceSize').change(function() {
  138. if(this.checked) {
  139. attachPlaceSizeHandlers();
  140. updatePlaceSizeDisplay();
  141. $('#_cbShowAreaPlaceSizeImperial')[0].disabled = false;
  142. $('#_cbShowAreaPlaceSizeMetric')[0].disabled = false;
  143. }
  144. else
  145. {
  146. removePlaceSizeHandlers();
  147. $('#AreaSize').remove();
  148. $('#_cbShowAreaPlaceSizeImperial')[0].disabled = true;
  149. $('#_cbShowAreaPlaceSizeMetric')[0].disabled = true;
  150. }
  151. });
  152.  
  153. $('#_cbShowLockButtonsRPP').change(function() {
  154. if(this.checked) {
  155. attachRPPLockButtonHandlers();
  156. }
  157. else
  158. {
  159. $('#pieRPPLockButtonsContainer').remove();
  160. W.selectionManager.events.unregister("selectionchanged", null, addLockButtons);
  161. W.model.actionManager.events.unregister("afterundoaction",null, addLockButtons);
  162. W.model.actionManager.events.unregister("afterclearactions",null, addLockButtons);
  163. W.model.actionManager.events.unregister("afteraction",null, addLockButtons);
  164. }
  165. });
  166.  
  167. $('#_cbShowPlaceLocatorCrosshair').change(function(){
  168. if(this.checked){
  169. W.selectionManager.events.register("selectionchanged", null, ShowPlaceLocatorCrosshair);
  170. W.model.actionManager.events.register("afterundoaction",null, ShowPlaceLocatorCrosshair);
  171. W.model.actionManager.events.register("afterclearactions",null, ShowPlaceLocatorCrosshair);
  172. W.model.actionManager.events.register("afteraction",null, ShowPlaceLocatorCrosshair);
  173. }
  174. else{
  175. W.selectionManager.events.unregister("selectionchanged", null, ShowPlaceLocatorCrosshair);
  176. W.model.actionManager.events.unregister("afterundoaction",null, ShowPlaceLocatorCrosshair);
  177. W.model.actionManager.events.unregister("afterclearactions",null, ShowPlaceLocatorCrosshair);
  178. W.model.actionManager.events.unregister("afteraction",null, ShowPlaceLocatorCrosshair);
  179. }
  180. });
  181.  
  182. $('#_cbShowSearchButton').change(function(){
  183. if(this.checked){
  184. W.selectionManager.events.register("selectionchanged", null, ShowSearchButton);
  185. W.model.actionManager.events.register("afterundoaction",null, ShowSearchButton);
  186. W.model.actionManager.events.register("afterclearactions",null, ShowSearchButton);
  187. W.model.actionManager.events.register("afteraction",null, ShowSearchButton);
  188. }
  189. else{
  190. W.selectionManager.events.unregister("selectionchanged", null, ShowSearchButton);
  191. W.model.actionManager.events.unregister("afterundoaction",null, ShowSearchButton);
  192. W.model.actionManager.events.unregister("afterclearactions",null, ShowSearchButton);
  193. W.model.actionManager.events.unregister("afteraction",null, ShowSearchButton);
  194. }
  195. });
  196.  
  197. $('#_cbAddPlaceCategoriesButtons').change(function(){
  198. if(this.checked){
  199. W.selectionManager.events.register("selectionchanged", null, AddPlaceCategoriesButtons);
  200. W.model.actionManager.events.register("afterundoaction",null, AddPlaceCategoriesButtons);
  201. W.model.actionManager.events.register("afterclearactions",null, AddPlaceCategoriesButtons);
  202. W.model.actionManager.events.register("afteraction",null, AddPlaceCategoriesButtons);
  203. }
  204. else{
  205. W.selectionManager.events.unregister("selectionchanged", null, AddPlaceCategoriesButtons);
  206. W.model.actionManager.events.unregister("afterundoaction",null, AddPlaceCategoriesButtons);
  207. W.model.actionManager.events.unregister("afterclearactions",null, AddPlaceCategoriesButtons);
  208. W.model.actionManager.events.unregister("afteraction",null, AddPlaceCategoriesButtons);
  209. }
  210. });
  211.  
  212. //Load settings to interface
  213. setChecked('_cbShowAreaPlaceSize', settings.ShowAreaPlaceSize);
  214. setChecked('_cbShowAreaPlaceSizeImperial', settings.ShowAreaPlaceSizeImperial);
  215. setChecked('_cbShowAreaPlaceSizeMetric', settings.ShowAreaPlaceSizeMetric);
  216. setChecked('_cbShowLockButtonsRPP', settings.ShowLockButtonsRPP);
  217. setChecked('_cbEditRPPAfterCreated', settings.EditRPPAfterCreated);
  218. setChecked('_cbUseStreetFromClosestSeg', settings.UseStreetFromClosestSeg);
  219. setChecked('_cbUseCityFromClosestSeg', settings.UseCityFromClosestSeg);
  220. setChecked('_cbShowPlaceLocatorCrosshair', settings.ShowPlaceLocatorCrosshair);
  221. setChecked('_cbUseAltCity', settings.UseAltCity);
  222. setChecked('_cbShowSearchButton', settings.ShowSearchButton);
  223. setChecked('_cbAddPlaceCategoriesButtons', settings.AddPlaceCategoriesButtons);
  224. setChecked('_cbSkipPLR', settings.SkipPLR);
  225. $('#piePlaceZoom')[0].value = settings.PlaceZoom;
  226. $('#pieDefaultLockLevel')[0].value = settings.DefaultLockLevel;
  227.  
  228. if(settings.ShowAreaPlaceSize){
  229. $('#_cbShowAreaPlaceSizeImperial')[0].disabled = false;
  230. $('#_cbShowAreaPlaceSizeMetric')[0].disabled = false;
  231. attachPlaceSizeHandlers();
  232. }
  233.  
  234. if(settings.ShowPlaceLocatorCrosshair){
  235. W.selectionManager.events.register("selectionchanged", null, ShowPlaceLocatorCrosshair);
  236. W.model.actionManager.events.register("afterundoaction",null, ShowPlaceLocatorCrosshair);
  237. W.model.actionManager.events.register("afterclearactions",null, ShowPlaceLocatorCrosshair);
  238. W.model.actionManager.events.register("afteraction",null, ShowPlaceLocatorCrosshair);
  239. ShowPlaceLocatorCrosshair(); //in case the user opened a PL with a Place selected
  240. }
  241.  
  242. if(settings.ShowSearchButton){
  243. W.selectionManager.events.register("selectionchanged", null, ShowSearchButton);
  244. W.model.actionManager.events.register("afterundoaction",null, ShowSearchButton);
  245. W.model.actionManager.events.register("afterclearactions",null, ShowSearchButton);
  246. W.model.actionManager.events.register("afteraction",null, ShowSearchButton);
  247. ShowSearchButton(); //in case the user opened a PL with a Place selected
  248. }
  249.  
  250. if(settings.AddPlaceCategoriesButtons){
  251. W.selectionManager.events.register("selectionchanged", null, AddPlaceCategoriesButtons);
  252. W.model.actionManager.events.register("afterundoaction",null, AddPlaceCategoriesButtons);
  253. W.model.actionManager.events.register("afterclearactions",null, AddPlaceCategoriesButtons);
  254. W.model.actionManager.events.register("afteraction",null, AddPlaceCategoriesButtons);
  255. AddPlaceCategoriesButtons();
  256. }
  257.  
  258. if(settings.ShowLockButtonsRPP)
  259. attachRPPLockButtonHandlers();
  260.  
  261. $('.pieSettingsCheckbox').change(function() {
  262. var settingName = $(this)[0].id.substr(3);
  263. settings[settingName] = this.checked;
  264. saveSettings();
  265. });
  266.  
  267. $('#piePlaceZoom').change(function(){
  268. var settingName = $(this)[0].id.substr(3);
  269. settings[settingName] = $(this)[0].value;
  270. saveSettings();
  271. });
  272.  
  273. $('#pieDefaultLockLevel').change(function(){
  274. settings[$(this)[0].id.substr(3)] = $(this)[0].value;
  275. saveSettings();
  276. });
  277.  
  278. var i;
  279. //Whenever a Place item is changed, read the settings and save to localStorage
  280. $('[id^="pieItem"]').change(function(){
  281. for(i=0;i<11;i++){
  282. settings.NewPlacesList[i] = $('#pieItem'+(i+1))[0].value;
  283. }
  284. saveSettings();
  285. buildNewPlaceList();
  286. });
  287.  
  288. //Load settings into Place Customization list options
  289. for(i=0; i<11;i++)
  290. $('#pieItem'+(i+1))[0].value = settings.NewPlacesList[i];
  291.  
  292. //Build our new menu
  293. buildNewPlaceList();
  294.  
  295. new WazeWrap.Interface.Shortcut('CreateResidentialPlaceShortcut', 'Creates a resdiential Place point', 'wmepie', 'Place Interface Enhancements', settings.CreateResidentialPlaceShortcut, function(){startPlacementMode(resCategory, true);}, null).add();
  296.  
  297. new WazeWrap.Interface.Shortcut('CreateParkingLotShortcut', 'Creates a parking lot Place', 'wmepie', 'Place Interface Enhancements', settings.CreateParkingLotShortcut, function(){startPlacementMode("PARKING_LOT", false);}, null).add();
  298.  
  299. window.addEventListener("beforeunload", function() {
  300. saveSettings();
  301. }, false);
  302.  
  303. }
  304.  
  305. var newPlaceCategory = "";
  306. function startPlacementMode(category, isPoint){
  307. $('#edit-buttons > div > div.toolbar-button.waze-icon-place.toolbar-submenu.toolbar-group.toolbar-group-venues.ItemInactive').removeClass("open");
  308. newPlaceCategory = category;
  309. var polyDrawFeatureOptions = {callbacks : {"done": doneHandler}};
  310. if(isPoint){
  311. $("#map").on('mousemove', MouseMoveHandler);
  312. $("#map").click(function(){endPlacementMode(category, isPoint);});
  313. /*drawPoly = new OpenLayers.Control.DrawFeature(newPlaceLayer, OpenLayers.Handler.Polygon, polyDrawFeatureOptions);
  314. W.map.addControl(drawPoly);
  315. drawPoly.activate();*/
  316. }
  317. else{
  318. drawPoly = new OpenLayers.Control.DrawFeature(newPlaceLayer, OpenLayers.Handler.Polygon, polyDrawFeatureOptions);
  319. W.map.addControl(drawPoly);
  320. drawPoly.activate();
  321.  
  322. }
  323. document.addEventListener('keyup', keyUpHandler, false);
  324. }
  325.  
  326. function doneHandler(geom){
  327. drawPoly.destroy();
  328. createPlace(geom, newPlaceCategory, false);
  329. }
  330.  
  331. function keyUpHandler(e){
  332. if (e.keyCode == 27){
  333. disablePlacementMode();
  334. if(drawPoly !== "undefined")
  335. drawPoly.destroy();
  336. }
  337. else if(e.keyCode == 90 && e.ctrlKey)
  338. drawPoly.undo();
  339. else if(e.keyCode == 89 && e.ctrlKey)
  340. drawPoly.redo();
  341. else if(e.keyCode == 13)
  342. drawPoly.finishSketch();
  343. }
  344.  
  345. function disablePlacementMode(){
  346. $("#map").off('click');//, endPlacementMode);
  347. $("#map").off('mousemove', MouseMoveHandler);
  348. clearLayer();
  349. document.removeEventListener('keyup', keyUpHandler);
  350. }
  351.  
  352. function endPlacementMode(category, isPoint){
  353. disablePlacementMode();
  354. createPlace(getMousePos900913(), category, isPoint);
  355. }
  356.  
  357. function getMousePos900913(){
  358. var mousePosition = $('.WazeControlMousePosition').text().split(" ");
  359. return WazeWrap.Geometry.ConvertTo900913(mousePosition[0], mousePosition[1]);
  360. }
  361.  
  362. function MouseMoveHandler(e){
  363. clearLayer();
  364. drawCircle(getMousePos900913());
  365. }
  366.  
  367. function clearLayer() {
  368. var layer = W.map.getLayersByName(layerName)[0];
  369. layer.removeAllFeatures();
  370. }
  371.  
  372. function drawCircle(e){
  373. var pointFeature = new OL.Feature.Vector(new OL.Geometry.Point(e.lon, e.lat), {}, pointStyle);
  374. W.map.getLayersByName(layerName)[0].addFeatures([pointFeature]);
  375. }
  376.  
  377. function createPlace(pos, category, isPoint){
  378. var PlaceObject = require("Waze/Feature/Vector/Landmark");
  379. var AddPlace = require("Waze/Action/AddLandmark");
  380. var multiaction = new MultiAction();
  381. multiaction.setModel(W.model);
  382.  
  383. var NewPlace = new PlaceObject();
  384. if(isPoint)
  385. NewPlace.geometry = new OL.Geometry.Point(pos.lon, pos.lat);
  386. else{
  387. var points = [];
  388. var i;
  389. for(i=0;i<pos.components[0].components.length;i++){
  390. points.push(new OL.Geometry.Point(pos.components[0].components[i].x, pos.components[0].components[i].y));
  391. }
  392. var ring = new OpenLayers.Geometry.LinearRing(points);
  393. NewPlace.geometry = new OL.Geometry.Polygon([ring]);
  394.  
  395. }
  396.  
  397. NewPlace.attributes.categories.push(category);
  398. if(category === resCategory){
  399. NewPlace._originalResidential = true;
  400. NewPlace.attributes.residential = true;
  401. }
  402. NewPlace.attributes.lockRank = Number(settings.DefaultLockLevel);
  403.  
  404. var closestSeg = WazeWrap.Geometry.findClosestSegment(new OL.Geometry.Point(pos.lon, pos.lat), settings.SkipPLR, settings.SkipPLR);
  405.  
  406. W.model.actionManager.add(new AddPlace(NewPlace));
  407. Waze.selectionManager.select([NewPlace]);
  408.  
  409. if(closestSeg){ //if we were able to find a segment, try to pull the city and/or street name if the options are enabled
  410. var newAttributes, UpdateFeatureAddress = require('Waze/Action/UpdateFeatureAddress'), address = closestSeg.getAddress();
  411.  
  412. newAttributes = {
  413. countryID: address.country.id,
  414. stateID: address.state.id,
  415. emptyCity: address.city.attributes.name ? null : true,
  416. emptyStreet: address.street.name ? null : true
  417. };
  418.  
  419. if(settings.UseStreetFromClosestSeg)
  420. newAttributes.streetName = address.street.name;
  421. else
  422. newAttributes.emptyStreet = true;
  423.  
  424. if(settings.UseCityFromClosestSeg){
  425. var cityName = address.city.attributes.name;
  426.  
  427. if(settings.UseAltCity && cityName === ""){
  428. if(address.altStreets.length > 0){ //segment has alt names
  429. for(var j=0;j<closestSeg.attributes.streetIDs.length;j++){
  430. var altCity = W.model.cities.get(W.model.streets.get(closestSeg.attributes.streetIDs[j]).cityID).attributes;
  431.  
  432. if(altCity.englishName !== null && altCity.englishName !== "")
  433. cityName = altCity.englishName;
  434. }
  435. }
  436. }
  437. if(cityName !== "")
  438. newAttributes.emptyCity = null;
  439. newAttributes.cityName = cityName;
  440. }
  441. else
  442. newAttributes.emptyCity = true;
  443.  
  444. multiaction.doSubAction(new UpdateFeatureAddress(NewPlace, newAttributes));
  445. W.model.actionManager.add(multiaction);
  446. }
  447. else
  448. console.log("WMEPIE - No segment found; cannot set street or city name.");
  449.  
  450. if(category === resCategory && settings.EditRPPAfterCreated)
  451. editRPPAddress();
  452. }
  453.  
  454. function editRPPAddress(rppTries){
  455. rppTries = rppTries || 1;
  456.  
  457. if ($('.edit-button').length > 0) {
  458. $('.edit-button').trigger("click");
  459. $('.house-number:first').focus();
  460.  
  461. } else if (rppTries < 1000) {
  462. console.log("not found");
  463. setTimeout(function () {editRPPAddress(rppTries++);}, 200);
  464. }
  465. }
  466.  
  467. function buildItemOption(itemNumber){
  468. var $section = $("<div>", {style:"padding:8px 16px", id:"piePlaceCat" + itemNumber});
  469. $section.html([
  470. 'Item ',
  471. itemNumber,
  472. buildItemList(itemNumber),
  473. '</br>'
  474. ].join(' '));
  475.  
  476. return $section.html();
  477. }
  478.  
  479. function buildLockLevelsList(){
  480. var $lockLevels = $("<div>");
  481. for(var i=0;i<WazeWrap.User.Rank();i++){
  482. $lockLevels.append("<option value=" + i + ">" + (i+1) + "</option>");
  483. }
  484. return $lockLevels.html();
  485. }
  486.  
  487. function attachRPPLockButtonHandlers(){
  488. $('#pieRPPLockButtonsContainer').remove();
  489. W.selectionManager.events.register("selectionchanged", null, addLockButtons);
  490. W.model.actionManager.events.register("afterundoaction",null, addLockButtons);
  491. W.model.actionManager.events.register("afterclearactions",null, addLockButtons);
  492. W.model.actionManager.events.register("afteraction",null, addLockButtons);
  493. }
  494.  
  495. function attachPlaceSizeHandlers(){
  496. W.selectionManager.events.register("selectionchanged", null, updatePlaceSizeDisplay);
  497. W.model.actionManager.events.register("afteraction",null, updatePlaceSizeDisplay);
  498. W.model.actionManager.events.register("afterundoaction",null, updatePlaceSizeDisplay);
  499. W.model.actionManager.events.register("afterclearactions",null, updatePlaceSizeDisplay);
  500. W.model.actionManager.events.register("noActions",null, noActions);
  501. updatePlaceSizeDisplay();
  502. }
  503.  
  504. function removePlaceSizeHandlers(){
  505. W.selectionManager.events.unregister("selectionchanged", null, updatePlaceSizeDisplay);
  506. W.model.actionManager.events.unregister("afteraction",null, updatePlaceSizeDisplay);
  507. W.model.actionManager.events.unregister("afterundoaction",null, updatePlaceSizeDisplay);
  508. W.model.actionManager.events.unregister("afterclearactions",null, updatePlaceSizeDisplay);
  509. W.model.actionManager.events.unregister("noActions",null, noActions);
  510. }
  511.  
  512. function ShowPlaceLocatorCrosshair(){
  513. $('#pieCrosshairs').remove();
  514. if(W.selectionManager.selectedItems.length > 0){
  515. if(W.selectionManager.selectedItems[0].model.type === "venue"){
  516. var panelWidth = $('#landmark-edit-general').width();
  517. var $crosshairs = $('<div style="float:right; z-index:100; cursor:pointer;" id="pieCrosshairs" title="Zoom and center on Place"><i class="fa fa-crosshairs fa-lg" aria-hidden="true"></i></div>');
  518. $('#landmark-edit-general > form > div:nth-child(1) > i').after($crosshairs);
  519. $('#pieCrosshairs').click(function(){
  520. CenterOnPlace(W.selectionManager.selectedItems[0].model, settings.PlaceZoom);
  521. });
  522. }
  523. }
  524. }
  525.  
  526. function ShowSearchButton(){
  527. $('#pieSearchButton').remove();
  528. if(W.selectionManager.selectedItems.length > 0){
  529. if(W.selectionManager.selectedItems[0].model.type === "venue"){
  530. var $search = $('<div style="float:left; margin-right:5px; position:relative; left:-10px; cursor:pointer;" id="pieSearchButton" title="Fills the search bar with the address"><i class="fa fa-search" aria-hidden="true"></i></div>');
  531. $('#landmark-edit-general > div > div > div').before($search);
  532. $('#pieSearchButton').click(function(){
  533. var address = $('.full-address')[0].innerHTML;
  534. var noCity = I18n.translations[I18n.currentLocale()].edit.address.no_city;
  535. var noStreet = I18n.translations[I18n.currentLocale()].edit.address.no_street;
  536.  
  537. address = address.replace(noCity + ",","");
  538. if(address !== I18n.translations[I18n.currentLocale()].edit.landmark.no_address)
  539. $('.search-query')[0].value = address;
  540. });
  541. }
  542. }
  543. }
  544.  
  545. function AddPlaceCategoriesButtons(){
  546. $('#piePlaceCategoriesButtonsContainer').remove();
  547. if(W.selectionManager.selectedItems.length > 0){
  548. if(W.selectionManager.selectedItems[0].model.type === "venue"){
  549. var $container = $('<div>',{id:'piePlaceCategoriesButtonsContainer', style:'white-space: nowrap;'});
  550. var categoryOptions = $('[id^=pieItem]');
  551.  
  552. var $button = $('<div>',{id:'btnPlaceCatClear', title:'Clear current categories', style:'display:inline-block; cursor:pointer'}).click(function() { onPlaceCategoriesButtonsClick(this.id); });
  553. $button.append('<span class="fa fa-times" style="font-size:20px; color:red;"></span>');
  554. $container.append($button);
  555.  
  556. for(var i=0;i<categoryOptions.length;i++){
  557. var name = categoryOptions[i].options[categoryOptions[i].selectedIndex].innerHTML;
  558. var icon = categoryOptions[i].options[categoryOptions[i].selectedIndex].getAttribute("data-icon");
  559. var divid = 'btnPlaceCat' + categoryOptions[i].value;
  560. if(categoryOptions[i].value !== resCategory && categoryOptions[i].value !== "PARKING_LOT"){
  561. $button = $('<div>',{id:divid, title:name.replace('&amp;', '&'), style:'display:inline-block; cursor:pointer', 'data-category':categoryOptions[i].value}).click(function() { onPlaceCategoriesButtonsClick(this.id); });
  562. $button.append('<span class="'+icon+'" style="font-size:20px;"></span>');
  563.  
  564. $container.append($button);
  565. }
  566. }
  567. }
  568.  
  569. $('.categories.controls').before($container);
  570. }
  571. }
  572.  
  573. function onPlaceCategoriesButtonsClick(buttonid){
  574. if(buttonid === "btnPlaceCatClear"){
  575. var blankCategories = []; //W.selectionManager.selectedItems[0].model.attributes.categories.clone();
  576. //console.log(blankCategories.length);
  577. //blankCategories.splice(0, blankCategories.length);
  578. //console.log(blankCategories);
  579. W.model.actionManager.add(new UpdateObject(W.selectionManager.selectedItems[0].model, { categories: blankCategories }));
  580. }
  581. else{
  582. var newCategories = W.selectionManager.selectedItems[0].model.attributes.categories.clone();
  583. //console.log($('#'+buttonid)[0].getAttribute("data-category"));
  584. newCategories.push($('#'+buttonid)[0].getAttribute("data-category"));
  585. W.model.actionManager.add(new UpdateObject(W.selectionManager.selectedItems[0].model, {categories: newCategories}));
  586. }
  587. }
  588.  
  589. function CenterOnPlace(venue, zoom){
  590. var centroid = venue.geometry.getCentroid();
  591. W.map.setCenter([centroid.x, centroid.y], zoom);
  592. }
  593.  
  594. function isChecked(checkboxId) {
  595. return $('#' + checkboxId).is(':checked');
  596. }
  597.  
  598. function setChecked(checkboxId, checked) {
  599. $('#' + checkboxId).prop('checked', checked);
  600. }
  601.  
  602. function noActions(){
  603. setTimeout(updatePlaceSizeDisplay, 100 ); //have to put in a delay for when the user uses undo to clear all actions - WME updates on top of my changes otherwise.
  604. }
  605.  
  606. function updatePlaceSizeDisplay(){
  607. var count = W.selectionManager.selectedItems.length;
  608. var metersArea = 0;
  609. var bold = false;
  610. if(count === 1){
  611. var venue = W.selectionManager.selectedItems[0];
  612. var isArea = venue.geometry.toString().match(/^POLYGON/);
  613. //var isPoint = venue.geometry.toString().match(/^POINT/);
  614.  
  615. if(venue.model.type === "venue" && isArea){
  616. if($('#AreaSize'))
  617. $('#AreaSize').remove();
  618. metersArea = W.selectionManager.selectedItems[0].model.geometry.getGeodesicArea(W.map.getProjectionObject());
  619.  
  620. if(metersArea > 0 && isArea){
  621. var ftArea = Math.round(metersArea * 10.76391 *100)/100;
  622.  
  623. var list = $('#landmark-edit-general > ul')[0];
  624. var newList = document.createElement("UL");
  625. newList.id = "AreaSize";
  626.  
  627. var newItem = document.createElement("LI");
  628. if(isChecked("_cbShowAreaPlaceSizeMetric")){
  629. newItem.innerHTML = "Area: " + metersArea.toFixed(2) + " m<sup>2</sup>";
  630. newList.appendChild(newItem);
  631. }
  632.  
  633. if(isChecked("_cbShowAreaPlaceSizeImperial")){
  634. newItem = document.createElement("LI");
  635. newItem.innerHTML = "Area: " + ftArea.toFixed(2) + " ft<sup>2</sup>";
  636. newList.appendChild(newItem);
  637. }
  638. if(metersArea < 500){
  639. newItem = document.createElement("LI");
  640. newItem.innerHTML = "<span style='color:red; font-weight:bold;'>Places smaller than 500 m<sup>2</sup>/5382 ft<sup>2</sup> will not show in the client</span>";
  641. newList.appendChild(newItem);
  642. }
  643. if(metersArea > 20000){
  644. newItem = document.createElement("LI");
  645. newItem.innerHTML = "<span style='color:red; font-weight:bold;'>Places larger than 20000 m<sup>2</sup>/215278.2 ft<sup>2</sup> will <i>always</i> show in the client</span>";
  646. newList.appendChild(newItem);
  647. }
  648. if(list.before != null)
  649. list.before(newList);
  650. else{
  651. var parent = $('#landmark-edit-general > ul')[0].parentNode;
  652. parent.insertBefore(newList,$('#landmark-edit-general > ul')[0]);
  653. }
  654.  
  655. $('#AreaSize').addClass("list-unstyled");
  656. $('#AreaSize').addClass("additional-attributes");
  657. }
  658. }
  659. }
  660. }
  661.  
  662. function loadSettings() {
  663. var loadedSettings = $.parseJSON(localStorage.getItem("WMEPIE_Settings"));
  664. var defaultSettings = {
  665. ShowAreaPlaceSize: false,
  666. ShowAreaPlaceSizeImperial: false,
  667. ShowAreaPlaceSizeMetric: false,
  668. ShowLockButtonsRPP: true,
  669. NewPlacesList: W.Config.venues.categories.clone(),
  670. EditRPPAfterCreated: false,
  671. UseStreetFromClosestSeg: false,
  672. UseCityFromClosestSeg: false,
  673. ShowPlaceLocatorCrosshair: false,
  674. PlaceZoom: 6,
  675. DefaultLockLevel: 0,
  676. CreateResidentialPlaceShortcut: "A+r",
  677. CreateParkingLotShortcut: "A+p",
  678. UseAltCity: false,
  679. ShowSearchButton: false,
  680. AddPlaceCategoriesButtons: false,
  681. SkipPLR: false
  682. };
  683. settings = loadedSettings ? loadedSettings : defaultSettings;
  684. for (var prop in defaultSettings) {
  685. if (!settings.hasOwnProperty(prop))
  686. settings[prop] = defaultSettings[prop];
  687. }
  688.  
  689. if(settings.ShowAreaPlaceSizeImperial === false && settings.ShowAreaPlaceSizeMetric === false)
  690. if(Waze.prefs.attributes.isImperial)
  691. settings.ShowAreaPlaceSizeImperial = true;
  692. else
  693. settings.ShowAreaPlaceSizeMetric = true;
  694. }
  695.  
  696. function saveSettings() {
  697. if (localStorage) {
  698. var localsettings = {
  699. ShowAreaPlaceSize: settings.ShowAreaPlaceSize,
  700. ShowAreaPlaceSizeImperial: settings.ShowAreaPlaceSizeImperial,
  701. ShowAreaPlaceSizeMetric: settings.ShowAreaPlaceSizeMetric,
  702. ShowLockButtonsRPP: settings.ShowLockButtonsRPP,
  703. NewPlacesList: settings.NewPlacesList,
  704. EditRPPAfterCreated: settings.EditRPPAfterCreated,
  705. UseStreetFromClosestSeg: settings.UseStreetFromClosestSeg,
  706. UseCityFromClosestSeg: settings.UseCityFromClosestSeg,
  707. ShowPlaceLocatorCrosshair: settings.ShowPlaceLocatorCrosshair,
  708. PlaceZoom: settings.PlaceZoom,
  709. DefaultLockLevel: settings.DefaultLockLevel,
  710. CreateResidentialPlaceShortcut: settings.CreateResidentialPlaceShortcut,
  711. CreateParkingLotShortcut: settings.CreateParkingLotShortcut,
  712. UseAltCity: settings.UseAltCity,
  713. ShowSearchButton: settings.ShowSearchButton,
  714. AddPlaceCategoriesButtons: settings.AddPlaceCategoriesButtons,
  715. SkipPLR: settings.SkipPLR
  716. };
  717.  
  718. for (var name in Waze.accelerators.Actions) {
  719. var TempKeys = "";
  720. if (Waze.accelerators.Actions[name].group == 'wmepie') {
  721. console.log(name);
  722. if (Waze.accelerators.Actions[name].shortcut) {
  723. if (Waze.accelerators.Actions[name].shortcut.altKey === true) {
  724. TempKeys += 'A';
  725. }
  726. if (Waze.accelerators.Actions[name].shortcut.shiftKey === true) {
  727. TempKeys += 'S';
  728. }
  729. if (Waze.accelerators.Actions[name].shortcut.ctrlKey === true) {
  730. TempKeys += 'C';
  731. }
  732. if (TempKeys !== "") {
  733. TempKeys += '+';
  734. }
  735. if (Waze.accelerators.Actions[name].shortcut.keyCode) {
  736. TempKeys += Waze.accelerators.Actions[name].shortcut.keyCode;
  737. }
  738. } else {
  739. TempKeys = "-1";
  740. }
  741. localsettings[name] = TempKeys;
  742. }
  743. }
  744.  
  745. localStorage.setItem("WMEPIE_Settings", JSON.stringify(localsettings));
  746. }
  747. }
  748.  
  749. //Using the same display for lock buttons as ClickSaver (with permission from MapoMatic) - thanks MoM!
  750. function addLockButtons() {
  751. if(W.selectionManager.selectedItems.length > 0){
  752. var item = W.selectionManager.selectedItems[0];
  753. var isRPP = (item.model.type === "venue" && item.model.attributes.residential === true);
  754.  
  755. if(isRPP){
  756. var attr = item.model.attributes;
  757. var autoRank = attr.rank;
  758. var manualRank = attr.lockRank;
  759. var firstManualRank = manualRank;
  760. var userRank = WazeWrap.User.Rank() - 1;
  761. var maxAutoRank = autoRank;
  762. var disabled = false;
  763.  
  764. var $div = $('#pieRPPLockButtonsContainer');
  765. $div.remove();
  766. $div = $('<div>',{id:'pieRPPLockButtonsContainer',style:'margin-bottom:5px;'});
  767. $div.append('<label class="control-label">Lock</label>');
  768. var btnInfos = [];
  769.  
  770. for(var iBtn=0;iBtn<=6;iBtn++){btnInfos.push({r:iBtn,val:iBtn});}
  771. btnInfos.forEach(function(btnInfo){
  772. var selected = (btnInfo.val == manualRank);
  773. disabled = userRank < btnInfo.val;
  774. if (btnInfo.val !== 6) {
  775. $div.append(
  776. $('<div>', {
  777. class:'btn btn-lh' + (selected ? ' btn-lh-selected':'') + (btnInfo.r < 6 & (userRank < btnInfo.r || disabled) ? ' disabled' : '')
  778. })
  779. .text(btnInfo.hasOwnProperty('title') ? btnInfo.title : btnInfo.r + 1)
  780. .data('val',btnInfo.hasOwnProperty('val') ? btnInfo.val : btnInfo.r + 1)
  781. .hover(function() {})
  782. .click(function() {
  783. if((userRank >= $(this).data('val')) && (btnInfo.r < 6)) {
  784. W.model.actionManager.add(new UpdateObject(item.model,{lockRank:($(this).data('val'))}));
  785. addLockButtons();
  786. }
  787. })
  788. );
  789. }
  790. });
  791. $('#landmark-edit-general > div.address-edit.side-panel-section').after($div);
  792. }
  793. }
  794. }
  795.  
  796. function buildItemList(itemNumber){
  797.  
  798. var $places = $("<div>");
  799. $places.html([
  800. '<select id="pieItem' + itemNumber + '">',
  801. '<option value="CAR_SERVICES" data-icon="waze-icon-place-car" style="font-weight:bold;">Car Services</option>',
  802. '<option value="GAS_STATION" data-icon="waze-icon-place-car">Gas Station</option>',
  803. '<option value="GARAGE_AUTOMOTIVE_SHOP" data-icon="waze-icon-place-car">Garage / Automotive Shop</option>',
  804. '<option value="CAR_WASH" data-icon="waze-icon-place-car">Car Wash</option>',
  805. '<option value="CHARGING_STATION" data-icon="waze-icon-place-car">Charging Station</option>',
  806. '<option value="TRANSPORTATION" data-icon="waze-icon-place-transportation" style="font-weight:bold;">Transportation</option>',
  807. '<option value="AIRPORT" data-icon="waze-icon-place-transportation">Airport</option>',
  808. '<option value="BUS_STATION" data-icon="waze-icon-place-transportation">Bus Station</option>',
  809. '<option value="FERRY_PIER" data-icon="waze-icon-place-transportation">Ferry Pier</option>',
  810. '<option value="SEAPORT_MARINA_HARBOR" data-icon="waze-icon-place-transportation">Seaport / Marina / Harbor</option>',
  811. '<option value="SUBWAY_STATION" data-icon="waze-icon-place-transportation">Subway Station</option>',
  812. '<option value="TRAIN_STATION" data-icon="waze-icon-place-transportation">Train Station</option>',
  813. '<option value="BRIDGE" data-icon="waze-icon-place-transportation">Bridge</option>',
  814. '<option value="TUNNEL" data-icon="waze-icon-place-transportation">Tunnel</option>',
  815. '<option value="TAXI_STATION" data-icon="waze-icon-place-transportation">Taxi Station</option>',
  816. '<option value="JUNCTION_INTERCHANGE" data-icon="waze-icon-place-transportation">Junction / Interchange</option>',
  817. '<option value="PROFESSIONAL_AND_PUBLIC" data-icon="waze-icon-place-professional" style="font-weight:bold;">Professional and public</option>',
  818. '<option value="COLLEGE_UNIVERSITY" data-icon="waze-icon-place-professional">College / University</option>',
  819. '<option value="SCHOOL" data-icon="waze-icon-place-professional">School</option>',
  820. '<option value="CONVENTIONS_EVENT_CENTER" data-icon="waze-icon-place-professional">Conventions / Event Center</option>',
  821. '<option value="GOVERNMENT" data-icon="waze-icon-place-professional">Government</option>',
  822. '<option value="LIBRARY" data-icon="waze-icon-place-professional">Library</option>',
  823. '<option value="CITY_HALL" data-icon="waze-icon-place-professional">City Hall</option>',
  824. '<option value="ORGANIZATION_OR_ASSOCIATION" data-icon="waze-icon-place-professional">Organization or Association</option>',
  825. '<option value="PRISON_CORRECTIONAL_FACILITY" data-icon="waze-icon-place-professional">Prison / Correctional Facility</option>',
  826. '<option value="COURTHOUSE" data-icon="waze-icon-place-professional">Courthouse</option>',
  827. '<option value="CEMETERY" data-icon="waze-icon-place-professional">Cemetery</option>',
  828. '<option value="FIRE_DEPARTMENT" data-icon="waze-icon-place-professional">Fire Department</option>',
  829. '<option value="POLICE_STATION" data-icon="waze-icon-place-professional">Police Station</option>',
  830. '<option value="MILITARY" data-icon="waze-icon-place-professional">Military</option>',
  831. '<option value="HOSPITAL_MEDICAL_CARE" data-icon="waze-icon-place-professional">Hospital / Medical Care</option>',
  832. '<option value="OFFICES" data-icon="waze-icon-place-professional">Offices</option>',
  833. '<option value="POST_OFFICE" data-icon="waze-icon-place-professional">Post Office</option>',
  834. '<option value="RELIGIOUS_CENTER" data-icon="waze-icon-place-professional">Religious Center</option>',
  835. '<option value="KINDERGARTEN" data-icon="waze-icon-place-professional">Kindergarten</option>',
  836. '<option value="FACTORY_INDUSTRIAL" data-icon="waze-icon-place-professional">Factory / Industrial</option>',
  837. '<option value="EMBASSY_CONSULATE" data-icon="waze-icon-place-professional">Embassy / Consulate</option>',
  838. '<option value="INFORMATION_POINT" data-icon="waze-icon-place-professional">Information Point</option>',
  839. '<option value="EMERGENCY_SHELTER" data-icon="waze-icon-place-professional">Emergency Shelter</option>',
  840. '<option value="SHOPPING_AND_SERVICES" data-icon="waze-icon-place-shopping" style="font-weight:bold;">Shopping and services</option>',
  841. '<option value="ARTS_AND_CRAFTS" data-icon="waze-icon-place-shopping">Arts & Crafts</option>',
  842. '<option value="BANK_FINANCIAL" data-icon="waze-icon-place-shopping">Bank / Financial</option>',
  843. '<option value="SPORTING_GOODS" data-icon="waze-icon-place-shopping">Sporting Goods</option>',
  844. '<option value="BOOKSTORE" data-icon="waze-icon-place-shopping">Bookstore</option>',
  845. '<option value="PHOTOGRAPHY" data-icon="waze-icon-place-shopping">Photography</option>',
  846. '<option value="CAR_DEALERSHIP" data-icon="waze-icon-place-shopping">Car Dealership</option>',
  847. '<option value="FASHION_AND_CLOTHING" data-icon="waze-icon-place-shopping">Fashion and Clothing</option>',
  848. '<option value="CONVENIENCE_STORE" data-icon="waze-icon-place-shopping">Convenience Store</option>',
  849. '<option value="PERSONAL_CARE" data-icon="waze-icon-place-shopping">Personal Care</option>',
  850. '<option value="DEPARTMENT_STORE" data-icon="waze-icon-place-shopping">Department Store</option>',
  851. '<option value="PHARMACY" data-icon="waze-icon-place-shopping">Pharmacy</option>',
  852. '<option value="ELECTRONICS" data-icon="waze-icon-place-shopping">Electronics</option>',
  853. '<option value="FLOWERS" data-icon="waze-icon-place-shopping">Flowers</option>',
  854. '<option value="FURNITURE_HOME_STORE" data-icon="waze-icon-place-shopping">Furniture / Home Store</option>',
  855. '<option value="GIFTS" data-icon="waze-icon-place-shopping">Gifts</option>',
  856. '<option value="GYM_FITNESS" data-icon="waze-icon-place-shopping">Gym / Fitness</option>',
  857. '<option value="SWIMMING_POOL" data-icon="waze-icon-place-shopping">Swimming Pool</option>',
  858. '<option value="HARDWARE_STORE" data-icon="waze-icon-place-shopping">Hardware Store</option>',
  859. '<option value="MARKET" data-icon="waze-icon-place-shopping">Market</option>',
  860. '<option value="SUPERMARKET_GROCERY" data-icon="waze-icon-place-shopping">Supermarket / Grocery</option>',
  861. '<option value="JEWELRY" data-icon="waze-icon-place-shopping">Jewelry</option>',
  862. '<option value="LAUNDRY_DRY_CLEAN" data-icon="waze-icon-place-shopping">Laundry / Dry Clean</option>',
  863. '<option value="SHOPPING_CENTER" data-icon="waze-icon-place-shopping">Shopping Center</option>',
  864. '<option value="MUSIC_STORE" data-icon="waze-icon-place-shopping">Music Store</option>',
  865. '<option value="PET_STORE_VETERINARIAN_SERVICES" data-icon="waze-icon-place-shopping">Pet Store / Veterinarian Services</option>',
  866. '<option value="TOY_STORE" data-icon="waze-icon-place-shopping">Toy Store</option>',
  867. '<option value="TRAVEL_AGENCY" data-icon="waze-icon-place-shopping">Travel Agency</option>',
  868. '<option value="ATM" data-icon="waze-icon-place-shopping">ATM</option>',
  869. '<option value="CURRENCY_EXCHANGE" data-icon="waze-icon-place-shopping">Currency Exchange</option>',
  870. '<option value="CAR_RENTAL" data-icon="waze-icon-place-shopping">Car Rental</option>',
  871. '<option value="FOOD_AND_DRINK" data-icon="waze-icon-place-food-drink" style="font-weight:bold;">Food and Drink</option>',
  872. '<option value="RESTAURANT" data-icon="waze-icon-place-food-drink">Restaurant</option>',
  873. '<option value="BAKERY" data-icon="waze-icon-place-food-drink">Bakery</option>',
  874. '<option value="DESSERT" data-icon="waze-icon-place-food-drink">Dessert</option>',
  875. '<option value="CAFE" data-icon="waze-icon-place-food-drink">Coffee shop</option>',
  876. '<option value="FAST_FOOD" data-icon="waze-icon-place-food-drink">Fast Food</option>',
  877. '<option value="FOOD_COURT" data-icon="waze-icon-place-food-drink">Food Court</option>',
  878. '<option value="BAR" data-icon="waze-icon-place-food-drink">Bar</option>',
  879. '<option value="ICE_CREAM" data-icon="waze-icon-place-food-drink">Ice Cream</option>',
  880. '<option value="CULTURE_AND_ENTERTAINEMENT" data-icon="waze-icon-place-culture" style="font-weight:bold;">Culture &amp; Entertainment</option>',
  881. '<option value="ART_GALLERY" data-icon="waze-icon-place-culture">Art Gallery</option>',
  882. '<option value="CASINO" data-icon="waze-icon-place-culture">Casino</option>',
  883. '<option value="CLUB" data-icon="waze-icon-place-culture">Club</option>',
  884. '<option value="TOURIST_ATTRACTION_HISTORIC_SITE" data-icon="waze-icon-place-culture">Tourist Attraction / Historic Site</option>',
  885. '<option value="MOVIE_THEATER" data-icon="waze-icon-place-culture">Movie Theater</option>',
  886. '<option value="MUSEUM" data-icon="waze-icon-place-culture">Museum</option>',
  887. '<option value="MUSIC_VENUE" data-icon="waze-icon-place-culture">Music Venue</option>',
  888. '<option value="PERFORMING_ARTS_VENUE" data-icon="waze-icon-place-culture">Performing Arts Venue</option>',
  889. '<option value="GAME_CLUB" data-icon="waze-icon-place-culture">Game Club</option>',
  890. '<option value="STADIUM_ARENA" data-icon="waze-icon-place-culture">Stadium / Arena</option>',
  891. '<option value="THEME_PARK" data-icon="waze-icon-place-culture">Theme Park</option>',
  892. '<option value="ZOO_AQUARIUM" data-icon="waze-icon-place-culture">Zoo / Aquarium</option>',
  893. '<option value="RACING_TRACK" data-icon="waze-icon-place-culture">Racing Track</option>',
  894. '<option value="THEATER" data-icon="waze-icon-place-culture">Theater</option>',
  895. '<option value="OTHER" data-icon="waze-icon-place" style="font-weight:bold;">Other</option>',
  896. '<option value="CONSTRUCTION_SITE" data-icon="">Construction Site</option>',
  897. '<option value="LODGING" data-icon="waze-icon-place-lodging" style="font-weight:bold;">Lodging</option>',
  898. '<option value="HOTEL" data-icon="waze-icon-place-lodging">Hotel</option>',
  899. '<option value="HOSTEL" data-icon="waze-icon-place-lodging">Hostel</option>',
  900. '<option value="CAMPING_TRAILER_PARK" data-icon="waze-icon-place-lodging">Camping / Trailer Park</option>',
  901. '<option value="COTTAGE_CABIN" data-icon="waze-icon-place-lodging">Cottage / Cabin</option>',
  902. '<option value="BED_AND_BREAKFAST" data-icon="waze-icon-place-lodging">Bed & Breakfast</option>',
  903. '<option value="OUTDOORS" data-icon="waze-icon-place-outdoors" style="font-weight:bold;">Outdoors</option>',
  904. '<option value="PARK" data-icon="waze-icon-place-outdoors">Park</option>',
  905. '<option value="PLAYGROUND" data-icon="waze-icon-place-outdoors">Playground</option>',
  906. '<option value="BEACH" data-icon="waze-icon-place-outdoors">Beach</option>',
  907. '<option value="SPORTS_COURT" data-icon="waze-icon-place-outdoors">Sports Court</option>',
  908. '<option value="GOLF_COURSE" data-icon="waze-icon-place-outdoors">Golf Course</option>',
  909. '<option value="PLAZA" data-icon="waze-icon-place-outdoors">Plaza</option>',
  910. '<option value="PROMENADE" data-icon="waze-icon-place-outdoors">Promenade</option>',
  911. '<option value="POOL" data-icon="waze-icon-place-outdoors">Pool</option>',
  912. '<option value="SCENIC_LOOKOUT_VIEWPOINT" data-icon="waze-icon-place-outdoors">Scenic Lookout / Viewpoint</option>',
  913. '<option value="SKI_AREA" data-icon="waze-icon-place-outdoors">Ski Area</option>',
  914. '<option value="NATURAL_FEATURES" data-icon="waze-icon-place-natural" style="font-weight:bold;">Natural Features</option>',
  915. '<option value="ISLAND" data-icon="waze-icon-place-natural">Island</option>',
  916. '<option value="SEA_LAKE_POOL" data-icon="waze-icon-place-natural">Sea / Lake / Pool</option>',
  917. '<option value="RIVER_STREAM" data-icon="waze-icon-place-natural">River / Stream</option>',
  918. '<option value="FOREST_GROVE" data-icon="waze-icon-place-natural">Forest / Grove</option>',
  919. '<option value="FARM" data-icon="waze-icon-place-natural">Farm</option>',
  920. '<option value="CANAL" data-icon="waze-icon-place-natural">Canal</option>',
  921. '<option value="SWAMP_MARSH" data-icon="waze-icon-place-natural">Swamp / Marsh</option>',
  922. '<option value="DAM" data-icon="waze-icon-place-natural">Dam</option>',
  923. '<option value="PARKING_LOT" style="font-weight:bold;">Parking Lot</option>',
  924. '<option value="RESIDENCE_HOME" data-icon="waze-icon-house" style="font-weight:bold;">Residential</option>',
  925. '</select>'
  926. ].join(' '));
  927.  
  928. return $places.html();
  929. }
  930.  
  931. function injectCss() {
  932. var css = [
  933. // Lock button formatting
  934. '.btn-lh {cursor:pointer;padding:1px 6px;height:22px;border:solid 1px #c1c1c1;margin-right:3px;}',
  935. '.btn.btn-lh.btn-lh-selected {background-color:#6999ae;color:white}',
  936. '.btn.btn-lh.btn-lh-selected:hover {color:white}',
  937. '.btn.btn-lh.disabled {color:#909090;background-color:#f7f7f7;}',
  938. '.btn.btn-lh.btn-lh-selected.disabled {color:white;background-color:#6999ae;}',
  939. //Settings Panel
  940. '#sidebar .controls-container.pie-controls-container {padding: 0px;}'
  941. ].join(' ');
  942. $('<style type="text/css">' + css + '</style>').appendTo('head');
  943. }
  944.  
  945. function listPlaces(){
  946. var category = "";
  947. for(i=0; i<W.Config.venues.categories.length; i++){
  948. category = W.Config.venues.categories[i];
  949. console.log(category + " Main");
  950. var subCategories = W.Config.venues.subcategories[category];
  951. for(var j=0; j<subCategories.length;j++){
  952. console.log(subCategories[j]);
  953. }
  954. }
  955. }
  956. })();