// ==UserScript== // @name WME Place Interface Enhancements // @namespace https://greasyfork.org/users/30701-justins83-waze // @version 2018.12.03.01 // @description Enhancements to various Place interfaces // @include https://www.waze.com/editor* // @include https://www.waze.com/*/editor* // @include https://beta.waze.com/editor* // @include https://beta.waze.com/*/editor* // @exclude https://www.waze.com/user/editor* // @icon  // @author JustinS83 // @grant none // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js // @require https://greasyfork.org/scripts/27023-jscolor/code/JSColor.js // @require https://greasyfork.org/scripts/37486-wme-utils-hoursparser.js // @require https://greasyfork.org/scripts/38421-wme-utils-navigationpoint/code/WME%20Utils%20-%20NavigationPoint.js?version=251065 // @require https://greasyfork.org/scripts/39208-wme-utils-google-link-enhancer/code/WME%20Utils%20-%20Google%20Link%20Enhancer.js?version=264663 // @contributionURL https://github.com/WazeDev/Thank-The-Authors // @license GPLv3 // @downloadURL none // ==/UserScript== /* global W */ /* global OL */ /* ecmaVersion 2017 */ /* global $ */ /* global jscolor */ /* global I18n */ /* global _ */ /* global WazeWrap */ /* global GoogleLinkEnhancer */ /* global HoursParser */ /* global require */ /* eslint curly: ["warn", "multi-or-nest"] */ var UpdateObject, MultiAction; (function() { 'use strict'; var curr_ver = GM_info.script.version; var settings = {}; var placeMenuSelector = "#edit-buttons > div > div.toolbar-submenu.toolbar-group.toolbar-group-venues.ItemInactive > menu";//"#edit-buttons > div > div.toolbar-button.waze-icon-place.toolbar-submenu.toolbar-group.toolbar-group-venues.ItemInactive > menu"; //"#edit-buttons > div > div.toolbar-submenu.toolbar-group.toolbar-group-venues.ItemInactive > menu"; var placementMode = false; var resCategory = "RESIDENCE_HOME"; var wazePL; let hoursparser; let GLE; var catalog = []; //Layer definitions { var layerName = "WME PIE"; var newPlaceLayer, PLSpotEstimatorLayer, PLSpotEstimatorCalibrationLayer; var PIEPlaceNameLayer; var showStopPointsLayer; var closestSegmentLayer; } //Drawing definitions { var drawPoly, PLSpotEstimatordrawControl, PLSpotEstimatorCalibrationdrawControl; var isDrawing; var pointStyle = { pointRadius: 6, fillOpacity: 0, strokeColor: '#00ece3', strokeWidth: '2', strokeLinecap: 'round' }; //Closest segment var lineStyleToNavPoint = { strokeWidth: 3, strokeColor: '#00ece3', strokeLinecap: 'round', strokeDashstyle: 'dash' }, lineStyleToClosestSeg = { strokeWidth: 4, strokeColor: '#00ece3', strokeLinecap: 'round' }, pointStyleNavPoint = { externalGraphic: '', graphicWidth: 22, graphicHeight: 22 }, pointStyle = { pointRadius: 6, fillColor: 'white', fillOpacity: 1, strokeColor: '#00ece3', strokeWidth: '3', strokeLinecap: 'round' }; } function bootstrap(tries = 1) { if (W && W.map && W.model && W.loginManager.user && $ && jscolor && WazeWrap.Ready) init(); else if (tries < 1000) setTimeout(function () {bootstrap(tries++);}, 200); } bootstrap(); function init(){ loadTranslations(); GLE = new GoogleLinkEnhancer(); hoursparser = new HoursParser(); var $section = $("
", {style:"padding:8px 16px", id:"WMEPIESettings"}); $section.html([ '

' + I18n.t('pie.prefs.title') + '

', '
' + curr_ver + '
', '
', '

' + I18n.t('pie.filter.PlaceFilterPanel') + '

', '
' + I18n.t('pie.filter.filter') + '
', '
', '
', '
', '
', '

' + I18n.t('pie.prefs.PropertiesPanel') + '

', '
', '
', '
', '
', '
', '
', '

', '
', '' + I18n.t('pie.prefs.Zoom') + '
', '
', '
', '
', '
', '
', '
', //'
', '
', '', '
', '
', `
`, `
${I18n.t("pie.prefs.SimplifyFactor")}
`, '
', '
', '

' + I18n.t('pie.prefs.NewPlaces') + '

', '
', '
', '
', '
', '
', '
' + I18n.t('pie.prefs.LockLevel') + '
', '
', '
', '

' + I18n.t('pie.prefs.MapChanges') + '

', '
', '
', '
', '
', '
', '
', I18n.t('pie.prefs.FontSize') + ' px
', I18n.t('pie.prefs.FontColor') + '
', '
', I18n.t('pie.prefs.FontOutlineColor') + '
', I18n.t('pie.prefs.FontOutlineWidth') + ' ', '
', '
', '
', '
', '
', '
', '
', '
', '
', '' + I18n.t('pie.prefs.PlaceMenuCustomization') + '
', buildItemOption(1), buildItemOption(2), buildItemOption(3), buildItemOption(4), buildItemOption(5), buildItemOption(6), buildItemOption(7), buildItemOption(8), buildItemOption(9), buildItemOption(10), buildItemOption(11), '
' ].join(' ')); UpdateObject = require("Waze/Action/UpdateObject"); MultiAction = require("Waze/Action/MultiAction"); //Load settings loadSettings(); var style = new OL.Style({ pointRadius: "${pointRadius}", label : "${labelText}", fontFamily: "Tahoma, Arial, Verdana", labelOutlineColor: settings.PlaceNameFontOutline, labelOutlineWidth: Number(settings.PlaceNameFontOutlineWidth), labelAlign: 'cm', fontColor: settings.PlaceNameFontColor, fontOpacity: 1.0, fontSize: settings.PlaceNameFontSize + "px", labelYOffset: "${yOffset}", fontStyle: "${style}", fontWeight: (settings.PlaceNameFontBold ? 'bold' : ''), pointRadius: 0 }); PIEPlaceNameLayer = new OL.Layer.Vector("PIEPlaceNameLayer",{displayInLayerSwitcher: false, uniqueName: "__PIEPlaceNameLayer", styleMap: new OL.StyleMap(style)}); W.map.addLayer(PIEPlaceNameLayer); PIEPlaceNameLayer.setVisibility(true); newPlaceLayer = new OL.Layer.Vector(layerName,{displayInLayerSwitcher: false}); W.map.addLayer(newPlaceLayer); PLSpotEstimatorLayer = new OL.Layer.Vector("PIEPLSpotEstimatorLayer",{displayInLayerSwitcher: false, uniqueName: "__PIEPLSpotEstimatorLayer"}); W.map.addLayer(PLSpotEstimatorLayer); PLSpotEstimatorLayer.setVisibility(true); PLSpotEstimatorCalibrationLayer= new OL.Layer.Vector("PIEPLSpotEstimatorCalibrationLayer",{displayInLayerSwitcher: false, uniqueName: "__PIEPLSpotEstimatorCalibrationLayer"}); W.map.addLayer(PLSpotEstimatorCalibrationLayer); PLSpotEstimatorCalibrationLayer.setVisibility(true); showStopPointsLayer = new OL.Layer.Vector("PIEShowStopPointsLayer", {displayInLayerSwitcher: false, uniqueName: "__PIEShowStopPointsLayer"}); W.map.addLayer(showStopPointsLayer); showStopPointsLayer.setVisibility(true); closestSegmentLayer = new OL.Layer.Vector("PIEClosestSegment", {displayInLayerSwitcher: false, uniqueName:"__PIEClosesetSegmentLayer"}); W.map.addLayer(closestSegmentLayer); closestSegmentLayer.setVisibility(true); /*var ctl = W.map.controls.find(function(ctrl) { return ctrl.displayClass ==="WazeControlSelectHighlightFeature"; }); var ctlLayers = [].concat(ctl.layers); var myLayer = W.map.getLayersByName('PIEPlaceNameLayer')[0]; ctlLayers.push(myLayer); ctl.setLayer(ctlLayers);*/ //***** Set Google Link Enhancer translations ***** GLE.strings.closedPlace = I18n.t('pie.GLE.closedPlace'); GLE.strings.multiLinked = I18n.t('pie.GLE.multiLinked'); GLE.strings.linkedToThisPlace = I18n.t('pie.GLE.linkedToThisPlace'); GLE.strings.linkedNearby = I18n.t('pie.GLE.linkedNearby'); GLE.strings.linkedToXPlaces = I18n.t('pie.GLE.linkedToXPlaces'); GLE.strings.badLink = I18n.t('pie.GLE.badLink'); GLE.strings.tooFar = I18n.t('pie.GLE.tooFar'); injectCss(); new WazeWrap.Interface.Tab('PIE', $section.html(), init2); } function getActiveEditor(tries = 1) { return new Promise((resolve, reject) => { if (W.geometryEditing.activeEditor) resolve(W.geometryEditing.activeEditor); else { if(tries <= 10) setTimeout(() => resolve(getActiveEditor()), 100); } }); } function init2(){ $('#cboPlaceNameFontWeight').select2({placeholder: "No font weight set", allowClear: true}); $('#divPlaceNamesFontCustomization .select2-choices').css("font-size", "10px"); initColorPicker(); if ($('#colorPickerFont')[0].jscolor){ $('#colorPickerFont')[0].jscolor.fromString(settings.PlaceNameFontColor); $('#colorPickerFontOutline')[0].jscolor.fromString(settings.PlaceNameFontOutline); } //$('#divPlaceNamesFontCustomization .select2-input').remove() //Set up event handlers $('#_cbShowAreaPlaceSize').change(function() { if(this.checked) { attachPlaceSizeHandlers(); updatePlaceSizeDisplay(); $('#_cbShowAreaPlaceSizeImperial')[0].disabled = false; $('#_cbShowAreaPlaceSizeMetric')[0].disabled = false; } else { removePlaceSizeHandlers(); $('#AreaSize').remove(); $('#_cbShowAreaPlaceSizeImperial')[0].disabled = true; $('#_cbShowAreaPlaceSizeMetric')[0].disabled = true; } }); $('#_cbShowPlaceNames').change(function() { PIEPlaceNameLayer.setVisibility(this.checked); if(this.checked) { $('#_cbShowPlaceNamesPoint')[0].disabled = false; $('#_cbShowPlaceNamesArea')[0].disabled = false; $('#_cbShowPlaceNamesPLA')[0].disabled = false; $('#_cbShowPlaceNamesLock')[0].disabled = false; } else { $('#_cbShowPlaceNamesPoint')[0].disabled = true; $('#_cbShowPlaceNamesArea')[0].disabled = true; $('#_cbShowPlaceNamesPLA')[0].disabled = true; $('#_cbShowPlaceNamesLock')[0].disabled = true; } console.log(this.checked); DisplayPlaceNames(); }); $('[id^="_cbShowPlaceNames"]').change(function(){ DisplayPlaceNames(); }); $('#_cbShowExternalProviderTooltip').change(function(){ ToggleExternalProvidersCSS(this.checked); }); $('#_cbShowLockButtonsRPP').change(function() { if(this.checked) attachRPPLockButtonHandlers(); else { $('#pieRPPLockButtonsContainer').remove(); unregisterEvents(addLockButtons); } }); $('#_cbShowPlaceLocatorCrosshair').change(function(){ if(this.checked) registerEvents(ShowPlaceLocatorCrosshair); else unregisterEvents(ShowPlaceLocatorCrosshair); }); $('#_cbShowParkingLotButton').change(function(){ if(this.checked) registerEvents(ShowParkingLotButton); else unregisterEvents(ShowParkingLotButton); }); $('#_cbShowCopyPlaceButton').change(function(){ if(this.checked) registerEvents(ShowCopyPlaceButton); else unregisterEvents(ShowCopyPlaceButton); }); $('#_cbShowSearchButton').change(function(){ if(this.checked) registerEvents(ShowSearchButton); else unregisterEvents(ShowSearchButton); }); $('#_cbAddPlaceCategoriesButtons').change(function(){ if(this.checked) registerEvents(AddPlaceCategoriesButtons); else unregisterEvents(AddPlaceCategoriesButtons); }); $('#_cbMoveAddress').change(function(){ //This is now supported natively in WME (beta as of 2017-10-16) /*if(this.checked) registerEvents(MoveAddress); else unregisterEvents(MoveAddress);*/ }); $('#_cbMoveHNEntry').change(function(){ if(this.checked) registerEvents(MoveHNEntry); else unregisterEvents(MoveHNEntry); }); $('#_cbClearDescription').change(function(){ if(this.checked) registerEvents(ShowClearDescription); else unregisterEvents(ShowClearDescription); }); $('#_cbShowPLSpotEstimatorButton').change(function(){ if(this.checked) registerEvents(ShowPLSpotEstimatorButton); else unregisterEvents(ShowPLSpotEstimatorButton); }); $('#_cbShowNavPointClosestSegmentOnHover').change(function(){ if(this.checked) W.map.events.register("mousemove", null, drawNavPointClosestSegmentLines); else W.map.events.unregister("mousemove", null, drawNavPointClosestSegmentLines); }); $('#_cbShowClosestSegmentSelected').change(function(){ if(this.checked){ W.model.actionManager.events.register('afterundoaction', this, checkSelection); W.model.actionManager.events.register('afteraction', this, checkSelection); W.selectionManager.events.register('selectionchanged', this, checkSelection); W.model.venues.on('objectschanged', ObjectsChanged); } else{ W.model.actionManager.events.unregister('afterundoaction', this, checkSelection); W.model.actionManager.events.unregister('afteraction', this, checkSelection); W.selectionManager.events.unregister('selectionchanged', this, checkSelection); W.model.venues.off('objectschanged', ObjectsChanged); } }); $('#_cbOpenPUR').change(function(){ if(this.checked) W.selectionManager.events.register('selectionchanged', this, openPUR); else W.selectionManager.events.unregister('selectionchanged', this, openPUR); }); $('#_cbEnableGLE').change(function(){ if(this.checked) GLE.enable(); else GLE.disable(); }); $('#_cbEnablePhotoViewer').change(function(){ if(this.checked) $('#launchDiv').css('display', 'block'); else{ hide_visio(); $('#launchDiv').css('display', 'none'); } }); $('#_cbHidePaymentType').change(function(){ if(this.checked) registerEvents(HidePaymentTypePlaceSelected); else unregisterEvents(HidePaymentTypePlaceSelected); }); $('#_cbGeometryMods').change(function(){ if(this.checked) registerEvents(InsertGeometryMods); else unregisterEvents(InsertGeometryMods); }); //Load settings to interface setChecked('_cbShowAreaPlaceSize', settings.ShowAreaPlaceSize); setChecked('_cbShowAreaPlaceSizeImperial', settings.ShowAreaPlaceSizeImperial); setChecked('_cbShowAreaPlaceSizeMetric', settings.ShowAreaPlaceSizeMetric); setChecked('_cbShowLockButtonsRPP', settings.ShowLockButtonsRPP); setChecked('_cbEditRPPAfterCreated', settings.EditRPPAfterCreated); setChecked('_cbUseStreetFromClosestSeg', settings.UseStreetFromClosestSeg); setChecked('_cbUseCityFromClosestSeg', settings.UseCityFromClosestSeg); setChecked('_cbShowPlaceLocatorCrosshair', settings.ShowPlaceLocatorCrosshair); setChecked('_cbShowParkingLotButton', settings.ShowParkingLotButton); setChecked('_cbShowCopyPlaceButton', settings.ShowCopyPlaceButton); setChecked('_cbShowExternalProviderTooltip', settings.ShowExternalProviderTooltip); setChecked('_cbUseAltCity', settings.UseAltCity); setChecked('_cbShowSearchButton', settings.ShowSearchButton); setChecked('_cbAddPlaceCategoriesButtons', settings.AddPlaceCategoriesButtons); setChecked('_cbSkipPLR', settings.SkipPLR); setChecked('_cbShowPlaceNames', settings.ShowPlaceNames); setChecked('_cbShowPlaceNamesPoint', settings.ShowPlaceNamesPoint); setChecked('_cbShowPlaceNamesArea', settings.ShowPlaceNamesArea); setChecked('_cbShowPlaceNamesPLA', settings.ShowPlaceNamesPLA); setChecked('_cbShowPlaceNamesLock', settings.ShowPlaceNamesLock); setChecked('_cbClearDescription', settings.ClearDescription); setChecked('_cbPlaceNameFontBold', settings.PlaceNameFontBold); setChecked('_cbPlaceLocatorCrosshairProdPL', settings.PlaceLocatorCrosshairProdPL); //setChecked('_cbMoveAddress', settings.MoveAddress); //Native support as of 2017-10-24 setChecked('_cbMoveHNEntry', settings.MoveHNEntry); setChecked('_cbShowPLSpotEstimatorButton', settings.ShowPLSpotEstimatorButton); setChecked('_cbShowNavPointClosestSegmentOnHover', settings.ShowNavPointClosestSegmentOnHover); setChecked('_cbShowClosestSegmentSelected', settings.ShowClosestSegmentSelected); setChecked('_cbNavLink', settings.NavLink); setChecked('_cbEnableGLE', settings.EnableGLE); setChecked('_cbOpenPUR', settings.OpenPUR); setChecked('_cbHidePaymentType', settings.HidePaymentType); setChecked('_cbGeometryMods', settings.GeometryMods); setChecked('_cbEnablePhotoViewer', settings.EnablePhotoViewer); if(settings.ShowPlaceNames){ $('#_cbShowPlaceNamesPoint')[0].disabled = false; $('#_cbShowPlaceNamesArea')[0].disabled = false; $('#_cbShowPlaceNamesPLA')[0].disabled = false; $('#_cbShowPlaceNamesLock')[0].disabled = false; } $('#piePlaceZoom')[0].value = settings.PlaceZoom; $('#pieDefaultLockLevel')[0].value = settings.DefaultLockLevel; $('#piePlaceNameFontSize')[0].value = settings.PlaceNameFontSize; $('#piePlaceNameFontOutlineWidth')[0].value = settings.PlaceNameFontOutlineWidth; $('#pieSimplifyFactor')[0].value = settings.SimplifyFactor; if(settings.ShowNavPointClosestSegmentOnHover) W.map.events.register("mousemove", null, drawNavPointClosestSegmentLines); if(settings.ShowAreaPlaceSize){ $('#_cbShowAreaPlaceSizeImperial')[0].disabled = false; $('#_cbShowAreaPlaceSizeMetric')[0].disabled = false; attachPlaceSizeHandlers(); } if(settings.ShowPlaceLocatorCrosshair){ registerEvents(ShowPlaceLocatorCrosshair); ShowPlaceLocatorCrosshair(); //in case the user opened a PL with a Place selected } if(settings.ShowParkingLotButton){ registerEvents(ShowParkingLotButton); ShowParkingLotButton(); //in case the user opened a PL with a Place selected } if(settings.ShowCopyPlaceButton){ registerEvents(ShowCopyPlaceButton); ShowCopyPlaceButton(); } if(settings.ShowExternalProviderTooltip){ //registerEvents(ShowExternalProviderTooltip); //ShowExternalProviderTooltip(); var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if ($(mutation.target).hasClass('select2-chosen')) ShowExternalProviderTooltip(); }); }); observer.observe(document.getElementById('edit-panel'), { childList: true, subtree: true }); } if(settings.ShowSearchButton){ registerEvents(ShowSearchButton); ShowSearchButton(); //in case the user opened a PL with a Place selected } if(settings.AddPlaceCategoriesButtons){ registerEvents(AddPlaceCategoriesButtons); AddPlaceCategoriesButtons(); } if(settings.ClearDescription){ registerEvents(ShowClearDescription); ShowClearDescription(); } //Native support as of 2017-10-24 /*if(settings.MoveAddress){ registerEvents(MoveAddress); MoveAddress(); }*/ if(settings.MoveHNEntry){ registerEvents(MoveHNEntry); MoveHNEntry(); } if(settings.ShowPLSpotEstimatorButton){ registerEvents(ShowPLSpotEstimatorButton); ShowPLSpotEstimatorButton(); } if(settings.ShowLockButtonsRPP) attachRPPLockButtonHandlers(); if(settings.ShowExternalProviderTooltip) ToggleExternalProvidersCSS(true); if(settings.ShowClosestSegmentSelected){ W.model.actionManager.events.register('afterundoaction', null, checkSelection); W.model.actionManager.events.register('afteraction', null, checkSelection); W.selectionManager.events.register('selectionchanged', null, checkSelection); W.model.venues.on('objectschanged', ObjectsChanged); } if(settings.OpenPUR) W.selectionManager.events.register('selectionchanged', null, openPUR); if(settings.EnableGLE) GLE.enable(); //if(settings.EnablePhotoViewer) SetupPhotoViewer(); if(settings.HidePaymentType){ registerEvents(HidePaymentTypePlaceSelected); HidePaymentTypePlaceSelected(); } if(settings.GeometryMods){ registerEvents(InsertGeometryMods); InsertGeometryMods(); } $('.pieSettingsCheckbox').change(function() { var settingName = $(this)[0].id.substr(3); settings[settingName] = this.checked; saveSettings(); }); $('#piePlaceZoom').change(function(){ var settingName = $(this)[0].id.substr(3); settings[settingName] = $(this)[0].value; saveSettings(); }); $('#pieDefaultLockLevel').change(function(){ settings[$(this)[0].id.substr(3)] = $(this)[0].value; saveSettings(); }); $('#_cbPlaceNameFontBold').change(function(){ PIEPlaceNameLayer.styleMap.styles.default.defaultStyle.fontWeight = (this.checked ? 'bold' :''); DisplayPlaceNames(); }); $('#piePlaceNameFontSize').focusout(function(){ var fontSize = $(this)[0].value; if(fontSize == "" || fontSize == "0") $(this)[0].value = 12; settings[$(this)[0].id.substr(3)] = fontSize; saveSettings(); PIEPlaceNameLayer.styleMap.styles.default.defaultStyle.fontSize = fontSize + "px"; DisplayPlaceNames(); }); $('#piePlaceNameFontOutlineWidth').focusout(function(){ var outlineWidth = $(this)[0].value; if(outlineWidth == "" || outlineWidth == "0") $(this)[0].value = 3; settings[$(this)[0].id.substr(3)] = outlineWidth; saveSettings(); PIEPlaceNameLayer.styleMap.styles.default.defaultStyle.labelOutlineWidth = outlineWidth; DisplayPlaceNames(); }); $('#piePlaceNameFontSize').keypress(function(event) { if ((event.which < 48 || event.which > 57)) event.preventDefault(); }); $('#piePlaceNameFontOutlineWidth').keypress(function(event) { if ((event.which < 48 || event.which > 57)) event.preventDefault(); }); $('#pieSimplifyFactor').focusout(function(){ let factor = $(this)[0].value; if(factor == "") $(this)[0].value = 5; if(factor > 10) factor = 10; if(factor<0) factor = 0; settings[$(this)[0].id.substr(3)] = factor; }); var i; //Whenever a Place item is changed, read the settings and save to localStorage $('[id^="pieItem"]').change(function(){ for(i=0;i<11;i++) settings.NewPlacesList[i] = $('#pieItem'+(i+1))[0].value; saveSettings(); buildNewPlaceList(); }); //Load settings into Place Customization list options for(i=0; i<11;i++) $('#pieItem'+(i+1))[0].value = settings.NewPlacesList[i]; //Build our new menu buildNewPlaceList(); //coming back from the HN edit mode now rebuilds the Place menu. W.editingMediator.on('change:editingHouseNumbers', buildNewPlaceList); /********* SHORTCUTS *********/ new WazeWrap.Interface.Shortcut('CreateResidentialPlaceShortcut', 'Creates a resdiential Place point', 'wmepie', 'Place Interface Enhancements', settings.CreateResidentialPlaceShortcut, function(){startPlacementMode(resCategory, true);}, null).add(); new WazeWrap.Interface.Shortcut('CreateParkingLotShortcut', 'Creates a parking lot Place', 'wmepie', 'Place Interface Enhancements', settings.CreateParkingLotShortcut, function(){startPlacementMode("PARKING_LOT", false);}, null).add(); new WazeWrap.Interface.Shortcut('HideAreaPlacesShortcut', 'Toggle hiding area Places', 'wmepie', 'Place Interface Enhancements', settings.ToggleAreaPlacesShortcut, ToggleHideAreaPlaces, null).add(); new WazeWrap.Interface.Shortcut('OrthogonalizeShortcut', 'Orthogonalize Area Place', 'wmepie', 'Place Interface Enhancements', settings.OrthogonalizeShortcut, OrthogonalizePlace, null).add(); new WazeWrap.Interface.Shortcut('SimplifyPlaceShortcut', 'Simplify Area Place', 'wmepie', 'Place Interface Enhancements', settings.SimplifyPlaceShortcut, SimplifyPlace, null).add(); new WazeWrap.Interface.Shortcut('CreateItem1Shortcut', 'Create Item 1', 'wmepie', 'Place Interface Enhancements', settings.CreateItem1Shortcut, function(){PlaceMenuShortcut(1);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem2Shortcut', 'Create Item 2', 'wmepie', 'Place Interface Enhancements', settings.CreateItem2Shortcut, function(){PlaceMenuShortcut(2);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem3Shortcut', 'Create Item 3', 'wmepie', 'Place Interface Enhancements', settings.CreateItem3Shortcut, function(){PlaceMenuShortcut(3);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem4Shortcut', 'Create Item 4', 'wmepie', 'Place Interface Enhancements', settings.CreateItem4Shortcut, function(){PlaceMenuShortcut(4);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem5Shortcut', 'Create Item 5', 'wmepie', 'Place Interface Enhancements', settings.CreateItem5Shortcut, function(){PlaceMenuShortcut(5);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem6Shortcut', 'Create Item 6', 'wmepie', 'Place Interface Enhancements', settings.CreateItem6Shortcut, function(){PlaceMenuShortcut(6);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem7Shortcut', 'Create Item 7', 'wmepie', 'Place Interface Enhancements', settings.CreateItem7Shortcut, function(){PlaceMenuShortcut(7);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem8Shortcut', 'Create Item 8', 'wmepie', 'Place Interface Enhancements', settings.CreateItem8Shortcut, function(){PlaceMenuShortcut(8);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem9Shortcut', 'Create Item 9', 'wmepie', 'Place Interface Enhancements', settings.CreateItem9Shortcut, function(){PlaceMenuShortcut(9);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem10Shortcut', 'Create Item 10', 'wmepie', 'Place Interface Enhancements', settings.CreateItem10Shortcut, function(){PlaceMenuShortcut(10);}, null).add(); new WazeWrap.Interface.Shortcut('CreateItem11Shortcut', 'Create Item 11', 'wmepie', 'Place Interface Enhancements', settings.CreateItem11Shortcut, function(){PlaceMenuShortcut(11);}, null).add(); $("#piePlaceFilter").on("propertychange keyup paste input", UpdatePlaceFilter); $('input[type=radio][name=PlaceFilterToggle]').change(UpdatePlaceFilter); window.addEventListener("beforeunload", function() { saveSettings(); }, false); let extprovobserver = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { /*if ($(mutation.target).hasClass('external-providers-view')) if(W.loginManager.user.normalizedLevel === 1) $('.external-providers-view').parent().parent().remove(); */ for (var i = 0; i < mutation.addedNodes.length; i++) { var addedNode = mutation.addedNodes[i]; // Only fire up if it's a node if (addedNode.nodeType === Node.ELEMENT_NODE && ($(addedNode).hasClass('address-edit-view') || $(addedNode).hasClass('conversation-view'))) { addLockButtons(); updatePlaceSizeDisplay(); AddPlaceCategoriesButtons(); AddHoursParserInterface(); AddEEPJumpButtons(); AddMakePrimaryButtons(); if(settings.ShowPlaceLocatorCrosshair) ShowPlaceLocatorCrosshair(); if(settings.ShowSearchButton) ShowSearchButton(); ShowNavPointLink(); if(settings.ShowParkingLotButton) ShowParkingLotButton(); if(settings.ShowCopyPlaceButton) ShowCopyPlaceButton(); if(settings.GeometryMods) InsertGeometryMods(); } else if(addedNode.nodeType === Node.ELEMENT_NODE && $(addedNode).hasClass('payment-checkbox')){ if(settings.HidePaymentType) _hidePaymentType(); } } }); }); extprovobserver.observe(document.getElementById('edit-panel'), { childList: true, subtree: true }); W.selectionManager.events.register("selectionchanged", null, function(){ if(WazeWrap.getSelectedFeatures().length > 0 && WazeWrap.getSelectedFeatures()[0].model.type === "venue"){ //Trim whitespace from start and end of house number field on Places $('.form-control.house-number').focusout(function(){ $('.form-control.house-number')[0].value = $('.form-control.house-number')[0].value.trim(); }); //Make Website label a clickable link to the set website let placeURL = WazeWrap.getSelectedFeatures()[0].model.attributes.url || ""; $('input[name="url"]').focusout(function(){ placeURL = $('input[name="url"]')[0].value.trim(); if(placeURL == ""){ $('input[name="url"]').parent().parent().find('label').unwrap(); return; } if(!placeURL.startsWith("http")) placeURL = "https://" + placeURL; if($('#websiteLink').length == 0) $('input[name="url"]').parent().parent().find('label').wrap(''); else $('#websiteLink').attr('href', placeURL); }); if(placeURL != ""){ if(!placeURL.startsWith("http")) placeURL = "https://" + placeURL; $('input[name="url"]').parent().parent().find('label').wrap(''); $('input[name="url"]').parent().parent().find('label').css('text-decoration', 'underline'); $('input[name="url"]').parent().parent().find('label').css('cursor', 'pointer'); } } }); //No one really uses this and it is causing issues due to the rotate handle persisting after de-selecting a MC /*W.selectionManager.events.register("selectionchanged", null, function(){ let selectedItems = WazeWrap.getSelectedFeatures(); if(selectedItems.length > 0 && selectedItems[0].model.type === "mapComment") getActiveEditor().then(val => { if((val.mode & OL.Control.ModifyFeature.ROTATE) == 0){ val.mode |= OL.Control.ModifyFeature.ROTATE; val.resetVertices(); } }); });*/ //Always display the link when a point Place is selected, but default to un-linked W.selectionManager.events.register("selectionchanged", null, ShowNavPointLink); W.model.actionManager.events.register('afterundoaction', null, ShowNavPointLink); W.selectionManager.events.register('selectionchanged', null, ShowNavPointLink); W.model.venues.on('objectschanged', ShowNavPointLink); W.model.actionManager.events.register('afteraction', null, function(){ ShowNavPointLink(); if(WazeWrap.getSelectedFeatures().length > 0 && WazeWrap.getSelectedFeatures()[0].model.type == "venue" && WazeWrap.getSelectedFeatures()[0].model.isPoint()){ if($('#placeNavLink').attr("class") == "fa fa-link fa-lg"){ let myPlaceAttr = WazeWrap.getSelectedFeatures()[0].model.attributes; //We only want to do this if the last item changed is our selected Place && it was moved. if(W.model.actionManager.actions[W.model.actionManager.index].feature != undefined && (W.model.actionManager.actions[W.model.actionManager.index].feature.attributes.id == myPlaceAttr.id) && typeof W.model.actionManager.actions[W.model.actionManager.index].oldGeometry != "undefined"){ if(WazeWrap.getSelectedFeatures()[0].model.attributes.entryExitPoints.length > 0){ //We only want to do this if there is an existing nav point let newAttr = {}; let existingAttr = myPlaceAttr.entryExitPoints[0]; if (existingAttr) { for (var prop in existingAttr) { if (existingAttr.hasOwnProperty(prop)){ let value = existingAttr[prop]; if (Array.isArray(value)) value = [].concat(value); newAttr[prop] = value; } } } newAttr._point = new OL.Geometry.Point(myPlaceAttr.geometry.x, myPlaceAttr.geometry.y); newAttr.__proto__.getPoint = function(){ return this._point.clone(); }; W.model.actionManager.add(new UpdateObject(WazeWrap.getSelectedFeatures()[0].model, {'entryExitPoints': [newAttr]})); } //NewPlace.attributes.entryExitPoints.push({entry: true, exit: true, name:"", primary: false, point: new OL.Geometry.Point(pos.lon, pos.lat)}) } } } }); //Obsoleted by WME update released 2017-10-24 /*var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if ($('#dialog-region').find('.venue-image-dialog').length > 0 && $('#detailsWrap').length == 0) ImageDialogEnhancement(); }); });*/ //observer.observe(document.getElementById('dialog-region'), { childList: true, subtree: true }); //Highlight the categories box when the old hospital category is present /*W.selectionManager.events.register("selectionchanged", null, highlightObsoleteHospitalCategory); W.model.actionManager.events.register("afterundoaction",null, highlightObsoleteHospitalCategory); W.model.actionManager.events.register("afterclearactions",null, highlightObsoleteHospitalCategory); W.model.actionManager.events.register("afteraction",null, highlightObsoleteHospitalCategory);*/ W.map.events.register("zoomend", null, DisplayPlaceNames); W.map.events.register("changelayer", null, DisplayPlaceNames); //Shamelessly copied from URO+ var MO_MPLayer = new MutationObserver(MPLayerChanged); MO_MPLayer.observe(W.map.problemLayer.div,{childList : true}); wazePL = document.querySelector('.WazeControlPermalink>a.fa-link'); if(wazePL == null) wazePL = document.querySelector('.permalink'); wazePL.id = 'wazePermalink'; /******** Hours Parser ************/ registerEvents(AddHoursParserInterface); AddHoursParserInterface(); registerEvents(AddEEPJumpButtons); AddEEPJumpButtons(); registerEvents(AddMakePrimaryButtons); AddMakePrimaryButtons(); } function SetupPhotoViewer(){ //Black background let mainDiv=document.createElement('div'); mainDiv.id='photoViewerMainDiv'; $(mainDiv).css({'float':'right','position':'absolute','left':'0px','top':'0px','width':'100%','height':'100%','background-color':'rgb(0, 0, 0, 0.85)','z-index':'1005','overflow-y':'auto','display':'none'}); $('#map').append(mainDiv); //Div options let optDiv=document.createElement('div'); optDiv.id='options'; $(optDiv).css({'position':'absolute','top':'0','width':'100%','height':'100%','z-index':'1011','background-color':'rgb(0, 0, 0, 0.85)', 'display':'none'}); /*optDiv.onclick = function(){ $(optDiv).css('display', 'none'); };*/ $('#map').append(optDiv); let optDiv2=document.createElement('div'); optDiv2.className = 'photoViewerOptionsContainer'; $(optDiv2).css({'text-align':'center','width':'500px', 'position':'relative', 'top':'30px', 'background-color':'black', 'color':'white', 'margin':'0 auto', 'border':'1px solid white', 'border-radius':'12px', 'padding':'10px'}); optDiv2.innerHTML = '
Sort by
Sort order
Keep position after picture deletion
' + '
' + '
'; optDiv.appendChild(optDiv2); $('#photoViewerCancel').click(function(){ $(optDiv).css('display', 'none'); }); let topbar = document.createElement('div'); $(topbar).css({'position':'sticky', 'top':'0px', 'width':'100%', 'height':'23px'}); mainDiv.appendChild(topbar); //Button to quit let quit=document.createElement('button'); quit.innerHTML=I18n.translations[I18n.currentLocale()].toolbar.cancel; $(quit).css({'float':'right','height':'23px','line-height':'23px','margin':'3px','padding':'0 10px','background-color':'#26bae8','color':'white','border':'0','border-radius':'13px'}); quit.onclick = hide_visio; topbar.appendChild(quit); //Button for script options let param=document.createElement('button'); param.innerHTML=''; $(param).css({'float':'right','height':'22px','line-height':'22px','margin':'3px','background-color':'#354148','color':'white','border':'0','border-radius':'11px'}); param.onclick=(function(){ $(optDiv).css('display', 'block'); }); topbar.appendChild(param); //Quantity let quantities=document.createElement('div'); $(quantities).css({'float':'right','height':'22px','line-height':'22px','margin':'3px','padding':'0 8px','background-color':'#354148','color':'white','border':'0','border-radius':'11px'}); let placeqty = document.createElement('div'); $(placeqty).css({'color':'white','display':'inline-block', 'margin-right':'5px'}); placeqty.innerHTML=' '; quantities.appendChild(placeqty); let imageqty = document.createElement('div'); $(imageqty).css({'display':'inline-block'}); imageqty.innerHTML=' '; quantities.appendChild(imageqty); topbar.appendChild(quantities); //Refresh let refresh=document.createElement('div'); refresh.innerHTML=''; $(refresh).css({'float':'right','height':'22px','line-height':'22px','margin':'3px','padding':'0 8px','background-color':'#354148','color':'white','border':'0','border-radius':'11px', 'cursor':'pointer'}); refresh.id="refreshScan"; $(refresh).click(Photos_scan); topbar.appendChild(refresh); let showDiv=document.createElement('div'); showDiv.id='showDiv'; showDiv.style.padding='5px'; mainDiv.appendChild(showDiv); //Icon near chat let launchDiv=document.createElement('div'); launchDiv.id='launchDiv'; $(launchDiv).css({'z-index':'10000 !important', 'title':'test','bottom':'26px','left':'70px','position':'absolute','font-weight':'400', 'display': (settings.EnablePhotoViewer ? 'block' : 'none')}); let tmpdiv=document.createElement('div'); $(tmpdiv).css({'height':'40px','position':'absolute','bottom':'0px','transition':'all 0.3s'}); tmpdiv.onmouseenter=togglePhotoViewerMouseEvent; launchDiv.appendChild(tmpdiv); let launchButton=document.createElement('button'); $(launchButton).css({'filter':'filter:grayscale(100%)','border':'none','background-color':'white','border-radius':'5px 5px 0px 0px','width':'43px','height':'40px'}); launchButton.innerHTML=''; launchButton.id = "photoViewerButton"; tmpdiv.appendChild(launchButton); $('#map').append(launchDiv); $('#sortBy')[0].value = settings.sortBy; $('#sortOrder')[0].value = settings.sortOrder; setChecked('photoViewerPreserveLayout', settings.PhotoViewerPreserveLayout); $('#photoViewerSave').click(function(){ settings.sortBy = $('#sortBy')[0].value; settings.sortOrder = $('#sortOrder')[0].value; settings.PhotoViewerPreserveLayout = isChecked('photoViewerPreserveLayout'); saveSettings(); $(optDiv).css('display', 'none'); Photos_scan(); }); } function togglePhotoViewerMouseEvent(){ //if the Places category is not enabled or all of the Place options are not enabled, don't allow opening the viewer - nothing will display. if(!isChecked("layer-switcher-group_places") || (!isChecked("layer-switcher-item_parking_places") && !isChecked("layer-switcher-item_residential_places") && !isChecked('layer-switcher-item_venues'))){ $('#photoViewerButton').css('cursor', 'not-allowed'); $('#photoViewerButton').attr('title','Enable the Places layers to use this tool'); $('#photoViewerButton').off(); } else{ $('#photoViewerButton').css('cursor', 'pointer'); $('#photoViewerButton').attr('title',''); $('#photoViewerButton').click(show_visio); } } function hide_visio() { $("#photoViewerMainDiv").css('display', 'none'); $("#chat-overlay").css('display', 'block'); $("#launchDiv").css('display', 'inline-block'); $('#photoViewerZoom').remove(); } function show_visio() { $('.save-popover-container').css('z-index', 1011); $('.changes-log-region').css('z-index', 1012); $("#photoViewerMainDiv").css('display', 'block'); $("#chat-overlay").css('display', 'none'); $("#launchDiv").css('display', 'none'); Photos_scan(); } function dynamicSort(property) { var sortOrder = 1; if(property[0] === "-") { sortOrder = -1; property = property.substr(1); } return function (a,b) { if(sortOrder == -1){ if(property === "name") return b.attributes[property].localeCompare(a.attributes[property]); else if(property === "ImageCount") return (parseInt(b.attributes.images.length) - parseInt(a.attributes.images.length)); else return (parseInt(b.attributes[property]) - parseInt(a.attributes[property])); } else{ if(property === "name") return a.attributes[property].localeCompare(b.attributes[property]); else if(property === "ImageCount") return (parseInt(a.attributes.images.length) - parseInt(b.attributes.images.length)); else return (parseInt(a.attributes[property]) - parseInt(b.attributes[property])); } } } function Photos_scan(){ catalog=[]; let venues = []; for (let poi in W.model.venues.objects) venues.push(W.model.venues.getObjectById(poi)); venues.sort(dynamicSort((settings.sortOrder === "sortDesc" ? "-" : "") + settings.sortBy.substr(6))); for (let i=0; i