您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds filtering and pop-up infobox for UR, MP and camera markers
当前为
// ==UserScript== // @name UROverview Plus (URO+) // @namespace http://greasemonkey.chizzum.com // @description Adds filtering and pop-up infobox for UR, MP and camera markers // @include https://*.waze.com/*editor* // @include https://editor-beta.waze.com/* // @grant none // @version 3.44 // ==/UserScript== /* TO-DO ITEMS ======================================================================================================================= Bug fixes - MUST BE CLEARED BEFORE RELEASE ======================================================================================================================= None ======================================================================================================================= Proposed functionality ======================================================================================================================= Display full UR submission time/date in popup Extend unstacking to cameras Restricted turn info popup Place filtering - by last user to edit - collapsible filter subcategories First-run information - show quickstart guide to URO features if no existing settings are present (i.e. new installation) User-defined setting presets ======================================================================================================================= New functionality in progress ======================================================================================================================= Addition of segment and place watchlist functionality */ function uroGlobals() { uroVersion = "3.44"; uroReleaseDate = "20150425"; uroChanges = [ "Managed areas can be given user-defined names", "Popup now shows userID instead of 'undefined' for temporary users" ]; uroBetaChanges = [ ]; uroShowDebugOutput = true; uroCtrlsHidden = false; uroCurrentTab = 1; uroFID = -1; uroShownFID = -1; uroShownPopupType = null; uroInhibitSave = true; uroPopupTimer = -2; uroPopupShown = false; uroSetupListeners = true; uroRootContainer = null; uroPlacesRoot = null; uroMaskLayer = null; uroCustomMarkerFID = null; uroConfirmIntercepted = false; uroCustomMarkerList = []; uroPendingURSessionIDs = []; uroRequestedURSessionIDs = []; uroMouseInPopup = false; uroURControlsIdx = null; uroProblemControlsIdx = null; uroMaskActive = false; uroTurnsLayerIdx = null; uroNullCamLayer = false; uroNullOpenLayers = false; uroNullRootContainer = false; uroNullURLayer = false; uroNullProblemLayer = false; uroNullMapViewport = false; uroURDialogIsOpen = false; uroSelectedURID = null; uroPendingCommentDataRefresh = false; uroWaitingCommentDataRefresh = false; uroExpectedCommentCount = null; uroCachedLastCommentID = null; uroPlaceSelected = false; uroMouseIsDown = false; uroBackfilling = false; uroUserID = -1; uroURSCurrentCount = 0; uroURSPrevCount = 0; uroDOMHasTurnProblems = false; uroBetaEditor = false; uroPracticeMode = false; uroWazeBitsPresent = 0; uroCWLGroups = new Array(); uroCamWatchObjects = new Array(); uroSegWatchObjects = new Array(); uroPlaceWatchObjects = new Array(); uroFilteredCameraIDs = new Array(); uroFriendlyAreaNames = new Array(); uroAreaNameHoverTime = -1; uroAreaNameHoverObj = null; uroAreaNameOverlayShown = false; uroANEditHovered = false; uroAMPosX = null; uroAMPosY = null; dteControlsIdx = -1; dteOldestFullDrive = new Date(0); dteEpoch = new Date(0); dteTopID = ''; uroUserTabId = ''; uroUnstackedMasterID = null; uroStackList = new Array(); uroStackType = null; uroIcons = [ // stuff used within the URO tabbed UI // 0 = group collapse/group expand [ "", "" ], // 1 = addtogroup active/addtogroup idle [ "", "" ], // 2 = goto active/goto idle [ "", "" ], // replacements for native UR/problem markers // 3 = normal/selected open roadworks UR [ "", "" ], // 4 = normal/selected closed roadworks UR [ "", "" ], // 5 = normal/selected open closure UR [ "", "" ], // 6 = normal/selected closed closure UR [ "", "" ], // 7 = normal/selected open event UR [ "", "" ], // 8 = normal/selected closed event UR [ "", "" ], // 9 = normal/selected open note UR [ "", "" ], // 10 = normal/selected closed note UR [ "", "" ] ]; uroMarkers = [ // 0 = comment count circle [""], // 1 = green comment marker [""], // 2 = yellow (own) comment marker [""] ]; } function uroBootstrap() { var bGreasemonkeyServiceDefined = false; try { bGreasemonkeyServiceDefined = (typeof Components.interfaces.gmIGreasemonkeyService === "object"); } catch (err) { /* Ignore */ } if (typeof unsafeWindow === "undefined" || ! bGreasemonkeyServiceDefined) { unsafeWindow = ( function () { var dummyElem = document.createElement('p'); dummyElem.setAttribute('onclick', 'return window;'); return dummyElem.onclick(); }) (); } /* begin running the code! */ uroInitialise(); } function uroAddLog(logtext) { if(uroShowDebugOutput) console.log('URO+: '+logtext); } function uroGetCBChecked(cbID) { return(document.getElementById(cbID).checked); } function uroGetElmValue(elmID) { return(document.getElementById(elmID).value); } function uroSetStyleDisplay(elm,style) { document.getElementById(elm).style.display = style; } function uroSetOnClick(elm,fn) { document.getElementById(elm).onclick = fn; } function uroAddEventListener(elm,eventType,eventFn,eventBool) { document.getElementById(elm).addEventListener(eventType, eventFn, eventBool); } function uroFirstTimerWelcomePack() { uroAddLog('welcome new users to Club URO...'); // to be completed... } function uroShowUpdateNotes() { uroAddLog('let existing users know what\'s new in this release'); var alertMsg = 'URO+ Update Notes...\n\n'; alertMsg += 'Thanks for upgrading to URO+ '+uroVersion+' ('+uroReleaseDate+'). What\'s changed?\n\n'; if(uroChanges.length > 0) { for(var loop=0; loop < uroChanges.length; loop++) { alertMsg += '* '+uroChanges[loop]+'\n'; } } if((uroBetaEditor) && (uroBetaChanges.length > 0)) { alertMsg += '\nFor WME Beta:\n'; for(var loop=0; loop < uroBetaChanges.length; loop++) { alertMsg += '* '+uroBetaChanges[loop]+'\n'; } } alert(alertMsg); } function uroAdvertiseCustomIcons() { uroAddLog('advertise the benefits of custom UR icons...'); var confirmMsg = 'URO+ Installation/Upgrade Processing...\n\n'; confirmMsg += 'Hi there. One of the features of URO+ that a lot of users find useful is the ability to use a custom marker for URs which have been tagged with a specific keyword in their description text.\n\n'; confirmMsg += 'Markers are defined for [ROADWORKS], [CONSTRUCTION], [CLOSURE], [EVENT] and [NOTE] tags.\n\n'; confirmMsg += 'Would you like me to automatically enable these custom markers?\n\n'; confirmMsg += 'If you change your mind later on, they can be enabled/disabled via the Misc tab within the URO+ settings'; if(confirm(confirmMsg) == true) { document.getElementById('_cbCustomRoadworksMarkers').checked = true; document.getElementById('_cbCustomConstructionMarkers').checked = true; document.getElementById('_cbCustomClosuresMarkers').checked = true; document.getElementById('_cbCustomEventsMarkers').checked = true; document.getElementById('_cbCustomNotesMarkers').checked = true; } } function uroGatherSettings(container) { var options = ''; var urOptions = document.getElementById(container).getElementsByTagName('input'); for (var optIdx=0;optIdx<urOptions.length;optIdx++) { var id = urOptions[optIdx].id; if((id.indexOf('_cb') == 0)||(id.indexOf('_text') == 0)||(id.indexOf('_input') == 0)) { options += ':' + id; if(urOptions[optIdx].type == 'checkbox') options += ',' + urOptions[optIdx].checked.toString(); else if((urOptions[optIdx].type == 'text')||(urOptions[optIdx].type == 'number')) options += ',' + urOptions[optIdx].value.toString(); } } return options; } function uroGatherCamWatchList() { var liststr = ''; for(var loop=0;loop<uroCamWatchObjects.length;loop++) { camObj = uroCamWatchObjects[loop]; if((camObj.fid != undefined) && (camObj.persistent == true)) { if(loop > 0) liststr += ':'; liststr += camObj.fid+','; liststr += camObj.watch.lon+','; liststr += camObj.watch.lat+','; liststr += camObj.watch.type+','; liststr += camObj.watch.azymuth+','; liststr += camObj.watch.speed+','; liststr += camObj.watch.validated+','; liststr += camObj.groupID+','; liststr += camObj.server; } } return liststr; } function uroGatherSegWatchList() { var liststr = ''; for(var loop=0;loop<uroSegWatchObjects.length;loop++) { segObj = uroSegWatchObjects[loop]; if((segObj.fid != undefined) && (segObj.persistent == true)) { if(loop > 0) liststr += ':'; liststr += segObj.fid+','; liststr += segObj.watch.left+','; liststr += segObj.watch.right+','; liststr += segObj.watch.bottom+','; liststr += segObj.watch.top+','; liststr += segObj.watch.fromNode+','; liststr += segObj.watch.toNode+','; liststr += segObj.watch.fwdDir+','; liststr += segObj.watch.revDir+','; liststr += segObj.watch.length+','; liststr += segObj.watch.level+','; liststr += segObj.watch.rank+','; liststr += segObj.watch.roadType+','; liststr += segObj.watch.updatedOn+','; liststr += segObj.groupID+','; liststr += segObj.server; } } return liststr; } function uroGatherPlaceWatchList() { var liststr = ''; for(var loop=0;loop<uroPlaceWatchObjects.length;loop++) { placeObj = uroPlaceWatchObjects[loop]; if((placeObj.fid != undefined) && (placeObj.persistent == true)) { if(loop > 0) liststr += ':'; liststr += placeObj.fid+','; liststr += placeObj.watch.left+','; liststr += placeObj.watch.right+','; liststr += placeObj.watch.bottom+','; liststr += placeObj.watch.top+','; liststr += placeObj.watch.name+','; liststr += placeObj.watch.imageCount+','; liststr += placeObj.watch.residential+','; liststr += placeObj.watch.updatedOn+','; liststr += placeObj.groupID+','; liststr += placeObj.server; } } return liststr; } function uroGatherCWLGroups() { var liststr = ''; for(var loop=0;loop<uroCWLGroups.length;loop++) { groupObj = uroCWLGroups[loop]; if(groupObj.groupID != -1) { if(loop > 0) liststr += ':'; liststr += groupObj.groupID+','; liststr += groupObj.groupName+','; liststr += groupObj.groupCollapsed; } } return liststr; } function uroGatherFriendlyAreaNames() { var liststr = ''; for(var loop=0;loop<uroFriendlyAreaNames.length;loop++) { fnObj = uroFriendlyAreaNames[loop]; if(loop > 0) liststr += ':'; liststr += fnObj.fName+','; liststr += fnObj.area+','; liststr += fnObj.server; } return liststr; } function uroSaveSettings() { if(uroInhibitSave) return; if (localStorage) { localStorage.UROverviewUROptions = uroGatherSettings('uroCtrlURs'); localStorage.UROverviewMPOptions = uroGatherSettings('uroCtrlMPs'); localStorage.UROverviewCameraOptions = uroGatherSettings('uroCtrlCameras'); localStorage.UROverviewMiscOptions = uroGatherSettings('uroCtrlMisc'); localStorage.UROverviewPlacesOptions = uroGatherSettings('uroCtrlPlaces'); localStorage.UROverviewCamWatchList = uroGatherCamWatchList(); localStorage.UROverviewSegWatchList = uroGatherSegWatchList(); localStorage.UROverviewPlaceWatchList = uroGatherPlaceWatchList(); localStorage.UROverviewCWLGroups = uroGatherCWLGroups(); localStorage.UROverviewFriendlyAreaNames = uroGatherFriendlyAreaNames(); localStorage.UROverviewCurrentVersion = uroVersion; } } function uroApplySettings(settings) { var options = settings.split(':'); for(var optIdx=0;optIdx<options.length;optIdx++) { var fields = options[optIdx].split(','); if(fields[0].indexOf('_cb') == 0) { if(document.getElementById(fields[0]) != null) { document.getElementById(fields[0]).checked = (fields[1] == 'true'); } } else if((fields[0].indexOf('_input') == 0)||(fields[0].indexOf('_text') == 0)) { if(document.getElementById(fields[0]) != null) document.getElementById(fields[0]).value = fields[1]; } } } function uroApplyCamWatchList() { var objects = localStorage.UROverviewCamWatchList.split(':'); uroCamWatchObjects = new Array(); for(var objIdx=0;objIdx<objects.length;objIdx++) { var fields = objects[objIdx].split(','); // following two bits of code add in blank fields if the user has updated their copy of URO+ from an // older version which didn't include support for either of these field types // add default groupID field if(fields.length == 7) { fields.push(0); } // set default groupID value to 0 (no group) if(fields[7] == -1) { fields[7] = 0; } // add default server field if(fields.length == 8) { fields.push('??'); } // set default server value to unknown if(fields[8] == 0) { fields[8] = '??'; } uroCamWatchObjects.push(new uroCamWatchObj(true,fields[0],fields[1],fields[2],fields[3],fields[4],fields[5],fields[6],fields[7],fields[8])); } } function uroApplySegWatchList() { var objects = localStorage.UROverviewSegWatchList.split(':'); uroSegWatchObjects = new Array(); for(var objIdx=0;objIdx<objects.length;objIdx++) { var fields = objects[objIdx].split(','); uroSegWatchObjects.push(new uroSegWatchObj(true,fields[0],fields[1],fields[2],fields[3],fields[4],fields[5],fields[6],fields[7],fields[8],fields[9],fields[10],fields[11],fields[12],fields[13],fields[14],fields[15])); } } function uroApplyPlaceWatchList() { var objects = localStorage.UROverviewPlaceWatchList.split(':'); uroPlaceWatchObjects = new Array(); for(var objIdx=0;objIdx<objects.length;objIdx++) { var fields = objects[objIdx].split(','); uroPlaceWatchObjects.push(new uroPlaceWatchObj(true,fields[0],fields[1],fields[2],fields[3],fields[4],fields[5],fields[6],fields[7],fields[8],fields[9],fields[10])); } } function uroApplyCWLGroups() { var objects = localStorage.UROverviewCWLGroups.split(':'); uroCWLGroups = new Array(); for(var objIdx=0;objIdx<objects.length;objIdx++) { var fields = objects[objIdx].split(','); if(fields.length < 2) { fields.push(false); } uroCWLGroups.push(new uroOWLGroupObj(fields[0],fields[1],(fields[2] == 'true'))); } } function uroApplyFriendlyAreaNames() { var objects = localStorage.UROverviewFriendlyAreaNames.split(':'); uroFriendlyAreaNames = new Array(); for(var objIdx=0;objIdx<objects.length;objIdx++) { var fields = objects[objIdx].split(','); uroFriendlyAreaNames.push(new uroAFNObj(fields[0],parseFloat(fields[1]),fields[2])); } uroReplaceAreaNames(true); } function uroLoadSettings() { var isNewInstall = true; var isUpgradeInstall = true; var notifyAboutCustomIcons = true; uroAddLog('loadSettings()'); if (localStorage.UROverviewUROptions) { uroAddLog('recover UR tab settings'); uroApplySettings(localStorage.UROverviewUROptions); isNewInstall = false; } if (localStorage.UROverviewCameraOptions) { uroAddLog('recover camera tab settings'); uroApplySettings(localStorage.UROverviewCameraOptions); isNewInstall = false; } if (localStorage.UROverviewMPOptions) { uroAddLog('recover MP tab settings'); uroApplySettings(localStorage.UROverviewMPOptions); isNewInstall = false; } if (localStorage.UROverviewPlacesOptions) { uroAddLog('recover Places tab settings'); uroApplySettings(localStorage.UROverviewPlacesOptions); isNewInstall = false; } if (localStorage.UROverviewMiscOptions) { uroAddLog('recover misc tab settings'); uroApplySettings(localStorage.UROverviewMiscOptions); isNewInstall = false; if(localStorage.UROverviewCurrentVersion) { notifyAboutCustomIcons = false; } else { if(uroGetCBChecked('_cbCustomRoadworksMarkers') == true) notifyAboutCustomIcons = false; if(uroGetCBChecked('_cbCustomConstructionMarkers')== true) notifyAboutCustomIcons = false; if(uroGetCBChecked('_cbCustomClosuresMarkers') == true) notifyAboutCustomIcons = false; if(uroGetCBChecked('_cbCustomEventsMarkers') == true) notifyAboutCustomIcons = false; if(uroGetCBChecked('_cbCustomNotesMarkers') == true) notifyAboutCustomIcons = false; } } if(localStorage.UROverviewCWLGroups) { uroAddLog('recover CWL groups'); uroApplyCWLGroups(); isNewInstall = false; } else { uroAddLog('set default CWL group'); uroCWLGroups.push(new uroOWLGroupObj(0,'No group',false)); } if(localStorage.UROverviewCamWatchList) { uroAddLog('recover camera watchlist'); uroApplyCamWatchList(); uroGetCurrentCamWatchListObjects(); isNewInstall = false; } if(localStorage.UROverviewSegWatchList) { uroAddLog('recover segment watchlist'); uroApplySegWatchList(); uroGetCurrentSegWatchListObjects(); isNewInstall = false; } if(localStorage.UROverviewPlaceWatchList) { uroAddLog('recover places watchlist'); uroApplyPlaceWatchList(); //uroGetCurrentPlaceWatchListObjects(); isNewInstall = false; } if(localStorage.UROverviewCurrentVersion) { uroAddLog('comparing install versions'); if(localStorage.UROverviewCurrentVersion == uroVersion) { isUpgradeInstall = false; } } if(localStorage.UROverviewFriendlyAreaNames) { uroAddLog('recover friendly area names'); uroApplyFriendlyAreaNames(); isNewInstall = false; } if(isNewInstall) { uroFirstTimerWelcomePack(); } else if(isUpgradeInstall) { uroShowUpdateNotes(); } if(notifyAboutCustomIcons) { uroAdvertiseCustomIcons(); } uroInhibitSave = false; } function uroDefaultSettings() { if(confirm('Resetting URO+ settings cannot be undone\nAre you sure you want to do this?') == true) { var defaultSettings = ''; defaultSettings += '[UROverviewUROptions][len=1544]:_cbFilterWazeAuto,false:_cbFilterIncorrectTurn,false:_cbFilterIncorrectAddress,false:_cbFilterIncorrectRoute,false:_cbFilterMissingRoundabout,false:_cbFilterGeneralError,false:_cbFilterTurnNotAllowed,false:_cbFilterIncorrectJunction,false:_cbFilterMissingBridgeOverpass,false:_cbFilterWrongDrivingDirection,false:_cbFilterMissingExit,false:_cbFilterMissingRoad,false:_cbFilterBlockedRoad,false:_cbFilterMissingLandmark,false:_cbFilterUndefined,false:_cbFilterRoadworks,false:_cbFilterConstruction,false:_cbFilterClosure,false:_cbFilterEvent,false:_cbFilterNote,false:_cbInvertURFilter,false:_cbFilterOpenUR,false:_cbFilterClosedUR,false:_cbFilterSolved,false:_cbFilterUnidentified,false:_cbEnableMinAgeFilter,false:_inputFilterMinDays,:_cbEnableMaxAgeFilter,false:_inputFilterMaxDays,:_cbURDescriptionMustBePresent,false:_cbURDescriptionMustBeAbsent,false:_cbEnableKeywordMustBePresent,false:_textKeywordPresent,:_cbEnableKeywordMustBeAbsent,false:_textKeywordAbsent,:_cbCaseInsensitive,false:_cbHideMyComments,false:_cbHideAnyComments,false:_cbHideIfLastCommenter,false:_cbHideIfNotLastCommenter,false:_cbHideIfReporterLastCommenter,false:_cbHideIfReporterNotLastCommenter,false:_cbEnableMinCommentsFilter,false:_inputFilterMinComments,:_cbEnableMaxCommentsFilter,false:_inputFilterMaxComments,:_cbHideMyFollowed,false:_cbHideMyUnfollowed,false:_cbEnableCommentAgeFilter2,false:_inputFilterCommentDays2,:_cbEnableCommentAgeFilter,false:_inputFilterCommentDays,:_cbURUserIDFilter,false:_cbURResolverIDFilter,false:_cbNoFilterForTaggedURs,false[END]'; defaultSettings += '[UROverviewCameraOptions][len=827]:_cbShowWorldCams,true:_cbShowUSACams,true:_cbShowNonWorldCams,true:_cbShowOnlyMyCams,false:_cbShowApprovedCams,true:_cbShowNonApprovedCams,true:_cbShowOlderCreatedNonApproved,false:_inputCameraMinCreatedDays,:_cbShowOlderUpdatedNonApproved,false:_inputCameraMinUpdatedDays,:_cbShowSpeedCams,true:_cbShowIfMPHSpeedSet,true:_cbShowIfKPHSpeedSet,true:_cbShowIfNoSpeedSet,true:_cbShowRedLightCams,true:_cbShowDummyCams,true:_cbHideCreatedByMe,false:_cbHideCreatedByRank0,false:_cbHideCreatedByRank1,false:_cbHideCreatedByRank2,false:_cbHideCreatedByRank3,false:_cbHideCreatedByRank4,false:_cbHideCreatedByRank5,false:_cbHideUpdatedByMe,false:_cbHideUpdatedByRank0,false:_cbHideUpdatedByRank1,false:_cbHideUpdatedByRank2,false:_cbHideUpdatedByRank3,false:_cbHideUpdatedByRank4,false:_cbHideUpdatedByRank5,false:_cbHideCWLCams,false[END]'; defaultSettings += '[UROverviewMPOptions][len=563]:_cbMPFilterMissingJunction,false:_cbMPFilterMissingRoad,false:_cbMPFilterCrossroadsJunctionMissing,false:_cbMPFilterDrivingDirectionMismatch,false:_cbMPFilterRoadTypeMismatch,false:_cbMPFilterRestrictedTurn,false:_cbMPFilterUnknownProblem,false:_cbMPFilterTurnProblem,false:_cbMPFilterReopenedProblem,false:_cbInvertMPFilter,false:_cbMPFilterClosed,false:_cbMPFilterSolved,false:_cbMPFilterUnidentified,false:_cbMPClosedUserIDFilter,false:_cbMPNotClosedUserIDFilter,false:_cbMPFilterLowSeverity,false:_cbMPFilterMediumSeverity,false:_cbMPFilterHighSeverity,false[END]'; defaultSettings += '[UROverviewMiscOptions][len=702]:_cbNativeConvoMarkers,true:_cbNativeBetaConvoMarkers,true:_cbCommentCount,false:_cbURBackfill,false:_inputUnstackSensitivity,15:_inputUnstackZoomLevel,3:_cbCustomRoadworksMarkers,false:_cbCustomConstructionMarkers,false:_cbCustomClosuresMarkers,false:_cbCustomEventsMarkers,false:_cbCustomNotesMarkers,false:_cbInhibitURPopup,false:_cbInhibitMPPopup,false:_cbInhibitCamPopup,false:_cbInhibitSegPopup,false:_cbInhibitLandmarkPopup,false:_cbInhibitPUPopup,false:_cbWhiteBackground,false:_inputCustomBackgroundRed,255:_inputCustomBackgroundGreen,255:_inputCustomBackgroundBlue,255:_cbHideAMLayer,false:_cbDisablePlacesFiltering,false:_cbDisablePendingQuestions,false:_cbEnableDTE,false:_cbEnableSRS,false[END]'; defaultSettings += '[UROverviewCWLGroups][len=16]0,No group,false[END]'; defaultSettings += '[UROverviewPlacesOptions][len=5106]:_cbFilterUneditablePlaceUpdates,false:_cbFilterLockRankedPlaceUpdates,false:_cbFilterNewPlacePUR,false:_cbFilterUpdatedDetailsPUR,false:_cbFilterNewPhotoPUR,false:_cbFilterFlaggedPUR,false:_cbLeavePURGeos,false:_cbInvertPURFilters,false:_cbPURFilterLowSeverity,false:_cbPURFilterMediumSeverity,false:_cbPURFilterHighSeverity,false:_cbEnablePURMinAgeFilter,false:_inputPURFilterMinDays,:_cbEnablePURMaxAgeFilter,false:_inputPURFilterMaxDays,:_cbPlaceFilterEditedLessThan,false:_inputFilterPlaceEditMinDays,:_cbPlaceFilterEditedMoreThan,false:_inputFilterPlaceEditMaxDays,:_cbHidePlacesL0,false:_cbHidePlacesL1,false:_cbHidePlacesL2,false:_cbHidePlacesL3,false:_cbHidePlacesL4,false:_cbHidePlacesL5,false:_cbHidePhotoPlaces,false:_cbHideNoPhotoPlaces,false:_cbPlacesFilter-CAR_SERVICES,false:_cbPlacesFilter-GAS_STATION,false:_cbPlacesFilter-PARKING_LOT,false:_cbPlacesFilter-GARAGE_AUTOMOTIVE_SHOP,false:_cbPlacesFilter-CAR_WASH,false:_cbPlacesFilter-CHARGING_STATION,false:_cbPlacesFilter-TRANSPORTATION,false:_cbPlacesFilter-AIRPORT,false:_cbPlacesFilter-BUS_STATION,false:_cbPlacesFilter-FERRY_PIER,false:_cbPlacesFilter-SEAPORT_MARINA_HARBOR,false:_cbPlacesFilter-SUBWAY_STATION,false:_cbPlacesFilter-TRAIN_STATION,false:_cbPlacesFilter-BRIDGE,false:_cbPlacesFilter-TUNNEL,false:_cbPlacesFilter-TAXI_STATION,false:_cbPlacesFilter-JUNCTION_INTERCHANGE,false:_cbPlacesFilter-PROFESSIONAL_AND_PUBLIC,false:_cbPlacesFilter-COLLEGE_UNIVERSITY,false:_cbPlacesFilter-SCHOOL,false:_cbPlacesFilter-CONVENTIONS_EVENT_CENTER,false:_cbPlacesFilter-GOVERNMENT,false:_cbPlacesFilter-LIBRARY,false:_cbPlacesFilter-CITY_HALL,false:_cbPlacesFilter-ORGANIZATION_OR_ASSOCIATION,false:_cbPlacesFilter-PRISON_CORRECTIONAL_FACILITY,false:_cbPlacesFilter-COURTHOUSE,false:_cbPlacesFilter-CEMETERY,false:_cbPlacesFilter-FIRE_DEPARTMENT,false:_cbPlacesFilter-POLICE_STATION,false:_cbPlacesFilter-MILITARY,false:_cbPlacesFilter-HOSPITAL_MEDICAL_CARE,false:_cbPlacesFilter-OFFICES,false:_cbPlacesFilter-POST_OFFICE,false:_cbPlacesFilter-RELIGIOUS_CENTER,false:_cbPlacesFilter-KINDERGARDEN,false:_cbPlacesFilter-FACTORY_INDUSTRIAL,false:_cbPlacesFilter-EMBASSY_CONSULATE,false:_cbPlacesFilter-INFORMATION_POINT,false:_cbPlacesFilter-SHOPPING_AND_SERVICES,false:_cbPlacesFilter-ARTS_AND_CRAFTS,false:_cbPlacesFilter-BANK_FINANCIAL,false:_cbPlacesFilter-SPORTING_GOODS,false:_cbPlacesFilter-BOOKSTORE,false:_cbPlacesFilter-PHOTOGRAPHY,false:_cbPlacesFilter-CAR_DEALERSHIP,false:_cbPlacesFilter-FASHION_AND_CLOTHING,false:_cbPlacesFilter-CONVENIENCE_STORE,false:_cbPlacesFilter-PERSONAL_CARE,false:_cbPlacesFilter-DEPARTMENT_STORE,false:_cbPlacesFilter-PHARMACY,false:_cbPlacesFilter-ELECTRONICS,false:_cbPlacesFilter-FLOWERS,false:_cbPlacesFilter-FURNITURE_HOME_STORE,false:_cbPlacesFilter-GIFTS,false:_cbPlacesFilter-GYM_FITNESS,false:_cbPlacesFilter-SWIMMING_POOL,false:_cbPlacesFilter-HARDWARE_STORE,false:_cbPlacesFilter-MARKET,false:_cbPlacesFilter-SUPERMARKET_GROCERY,false:_cbPlacesFilter-JEWELRY,false:_cbPlacesFilter-LAUNDRY_DRY_CLEAN,false:_cbPlacesFilter-SHOPPING_CENTER,false:_cbPlacesFilter-MUSIC_STORE,false:_cbPlacesFilter-PET_STORE_VETERINARIAN_SERVICES,false:_cbPlacesFilter-TOY_STORE,false:_cbPlacesFilter-TRAVEL_AGENCY,false:_cbPlacesFilter-ATM,false:_cbPlacesFilter-CURRENCY_EXCHANGE,false:_cbPlacesFilter-CAR_RENTAL,false:_cbPlacesFilter-FOOD_AND_DRINK,false:_cbPlacesFilter-RESTAURANT,false:_cbPlacesFilter-BAKERY,false:_cbPlacesFilter-DESSERT,false:_cbPlacesFilter-CAFE,false:_cbPlacesFilter-FAST_FOOD,false:_cbPlacesFilter-FOOD_COURT,false:_cbPlacesFilter-BAR,false:_cbPlacesFilter-ICE_CREAM,false:_cbPlacesFilter-CULTURE_AND_ENTERTAINEMENT,false:_cbPlacesFilter-ART_GALLERY,false:_cbPlacesFilter-CASINO,false:_cbPlacesFilter-CLUB,false:_cbPlacesFilter-TOURIST_ATTRACTION_HISTORIC_SITE,false:_cbPlacesFilter-MOVIE_THEATER,false:_cbPlacesFilter-MUSEUM,false:_cbPlacesFilter-MUSIC_VENUE,false:_cbPlacesFilter-PERFORMING_ARTS_VENUE,false:_cbPlacesFilter-GAME_CLUB,false:_cbPlacesFilter-STADIUM_ARENA,false:_cbPlacesFilter-THEME_PARK,false:_cbPlacesFilter-ZOO_AQUARIUM,false:_cbPlacesFilter-RACING_TRACK,false:_cbPlacesFilter-THEATER,false:_cbPlacesFilter-OTHER,false:_cbPlacesFilter-CONSTRUCTION_SITE,false:_cbPlacesFilter-LODGING,false:_cbPlacesFilter-HOTEL,false:_cbPlacesFilter-HOSTEL,false:_cbPlacesFilter-CAMPING_TRAILER_PARK,false:_cbPlacesFilter-COTTAGE_CABIN,false:_cbPlacesFilter-BED_AND_BREAKFAST,false:_cbPlacesFilter-OUTDOORS,false:_cbPlacesFilter-PARK,false:_cbPlacesFilter-PLAYGROUND,false:_cbPlacesFilter-BEACH,false:_cbPlacesFilter-SPORTS_COURT,false:_cbPlacesFilter-GOLF_COURSE,false:_cbPlacesFilter-PLAZA,false:_cbPlacesFilter-PROMENADE,false:_cbPlacesFilter-POOL,false:_cbPlacesFilter-SCENIC_LOOKOUT_VIEWPOINT,false:_cbPlacesFilter-SKI_AREA,false:_cbPlacesFilter-NATURAL_FEATURES,false:_cbPlacesFilter-ISLAND,false:_cbPlacesFilter-SEA_LAKE_POOL,false:_cbPlacesFilter-RIVER_STREAM,false:_cbPlacesFilter-FOREST_GROVE,false:_cbPlacesFilter-FARM,false:_cbPlacesFilter-CANAL,false:_cbPlacesFilter-SWAMP_MARSH,false:_cbPlacesFilter-DAM,false:_cbFilterPrivatePlaces,false:_cbInvertPlacesFilter,false[END]'; document.getElementById('_txtSettings').value = defaultSettings; uroTextToSettings(); document.getElementById('_txtSettings').value = ''; } } function uroSettingsToText() { var txtSettings = ''; uroSaveSettings(); for(var lsEntry in localStorage) { if(lsEntry.indexOf('UROverview') == 0) { txtSettings += '['+lsEntry+'][len=' + localStorage[lsEntry].length + ']' + localStorage[lsEntry] + '[END]'; } } document.getElementById('_txtSettings').value = txtSettings; document.getElementById('_txtSettings').focus(); document.getElementById('_txtSettings').select(); } function uroTextToSettings() { var txtSettings = ''; txtSettings = uroGetElmValue('_txtSettings'); if(txtSettings.indexOf('[END]') == -1) return; var subText = txtSettings.split('[END]'); for(var i=0;i<subText.length;i++) { var bPos = subText[i].indexOf(']'); if(bPos != -1) { var settingID = subText[i].substr(1,bPos-1); subText[i] = subText[i].substr(bPos+1); bPos = subText[i].indexOf(']'); if(bPos != -1) { var settingLength = subText[i].substr(5,bPos-5); subText[i] = subText[i].substr(bPos+1); if(subText[i].length == settingLength) { localStorage[settingID] = subText[i]; } } } } uroLoadSettings(); } function uroClearSettingsText() { document.getElementById('_txtSettings').value = ''; } function uroDateToDays(dateToConvert) { var dateNow = new Date(); var elapsedSinceEpoch = dateNow.getTime(); var elapsedSinceEvent = elapsedSinceEpoch - dateToConvert; dateNow.setHours(0); dateNow.setMinutes(0); dateNow.setSeconds(0); dateNow.setMilliseconds(0); var elapsedSinceMidnight = elapsedSinceEpoch - dateNow.getTime(); if(elapsedSinceEvent < elapsedSinceMidnight) { // event occurred today... return 0; } else { // event occurred at some point prior to midnight this morning, so return a minimum value of 1... return 1 + Math.floor((elapsedSinceEvent - elapsedSinceMidnight) / 86400000); } } function uroGetURAge(urObj,ageType) { if(ageType == 0) { if((urObj.attributes.driveDate == null)||(urObj.attributes.driveDate == 0)) return -1; return uroDateToDays(urObj.attributes.driveDate); } else if(ageType == 1) { if((urObj.attributes.resolvedOn == null)||(urObj.attributes.resolvedOn == 0)) return -1; return uroDateToDays(urObj.attributes.resolvedOn); } else { return -1; } } function uroGetPURAge(purObj) { if(purObj.attributes.venueUpdateRequests[0].attributes.dateAdded != null) { return uroDateToDays(purObj.attributes.venueUpdateRequests[0].attributes.dateAdded); } else { return -1; } } function uroGetCameraAge(camObj, mode) { if(mode == 0) { if(camObj.attributes.updatedOn == null) return -1; return uroDateToDays(camObj.attributes.updatedOn); } if(mode == 1) { if(camObj.attributes.createdOn == null) return -1; return uroDateToDays(camObj.attributes.createdOn); } } function uroGetCommentAge(commentObj) { if(commentObj.createdOn == null) return -1; return uroDateToDays(commentObj.createdOn); } function uroParseDaysAgo(days) { if(days == 0) return 'today'; else if(days == 1) return '1 day ago'; else return days+' days ago'; } function uroIsCameraSpeedValid(camObj) { // returns 1 if the entered speed converts correctly into a multiple of 10MPH // returns -1 if the entered speed does not convert correctly // returns 0 if no speed data is present, or if the entered speed is 0 if(camObj.attributes.speed != null) { var speed = Math.round(camObj.attributes.speed /1.609); if(speed == 0) return 0; else if(speed % 10 == 0) return 1; else return -1; } else return 0; } // -------------------------------------------------------------------------------------------------------------------- // AREA FRIENDLYNAME STUFF // -------------------------------------------------------------------------------------------------------------------- function uroAFNObj(fName, area, server) { this.fName = fName; this.area = area; this.server = server; } function uroUpdateAreaName(name, server, area) { var foundExisting = false; for(var i=0; i<uroFriendlyAreaNames.length; i++) { if((uroFriendlyAreaNames[i].server == server) && (uroFriendlyAreaNames[i].area == area)) { if(name == "") { uroFriendlyAreaNames.splice(i,1); foundExisting = true; } else { uroFriendlyAreaNames[i].fName = name; foundExisting = true; } } } if((foundExisting == false) && (name != "")) { uroFriendlyAreaNames.push(new uroAFNObj(name,area,server)); } uroReplaceAreaNames(true); } function uroAreaNameHover() { if((uroAreaNameHoverObj == null) || (uroAreaNameHoverObj != this)) { uroAreaNameHoverTime = 0; } uroAreaNameHoverObj = this; } function uroAreaNameUnHover() { if(uroANEditHovered == true) { return false; } if(uroAreaNameOverlayShown) { uroAreaNameHoverObj.removeChild(uroANEditBox); } uroAreaNameHoverObj = null; uroAreaNameHoverTime = -1; uroAreaNameOverlayShown = false; } function uroANEditHover() { uroANEditHovered = true; uroAddEventListener('uroANEditBox','mouseout',uroANEditUnHover,false); uroAddEventListener('uroANEditBox','click',uroANEditClick,false); } function uroANEditUnHover() { var newName = document.getElementById('_textAreaName').value; // sanitise name to avoid conflicts with config storage delimiters... newName = newName.replace(',',''); newName = newName.replace(':',''); var server = W.location.code; var area = uroGetAreaArea(uroAreaNameHoverObj.parentNode.children[1]); uroAreaNameHoverObj.removeChild(uroANEditBox); uroAreaNameOverlayShown = false; uroANEditHovered = false; uroUpdateAreaName(newName, server, area) } function uroANEditClick(e) { // this traps the click to prevent it falling through to the underlying area name element and // potentially causing the map view to be relocated to that area... e.stopPropagation(); } function uroGetAreaArea(listObj) { var area = listObj.getElementsByTagName('span')[0].innerHTML; area = parseFloat(area.split(' ')[0]); return area; } function uroAreaNameOverlaySetup() { uroAreaNameOverlayShown = true; uroANEditBox = document.createElement('div'); uroANEditBox.id = "uroANEditBox"; uroANEditBox.style.position = "absolute"; uroANEditBox.style.top = '7px'; uroANEditBox.style.left = '2px'; uroANEditBox.style.width = "99%"; uroAreaNameHoverObj.appendChild(uroANEditBox); uroANEditBox.onmouseover = uroANEditHover(); var existingName = uroAreaNameHoverObj.innerHTML; var italicTagPos = existingName.indexOf(' <i>'); if(italicTagPos == -1) { existingName = ""; } else { existingName = existingName.substr(0,italicTagPos); } uroANEditBox.innerHTML = '<input type="text" style="font-size:14px; line-height:16px; height:22px; width:100%" id="_textAreaName" value="'+existingName+'">'; } function uroReplaceAreaNames(replaceAfterNameChange) { if(document.getElementById('sidepanel-areas') == undefined) { return; } if(replaceAfterNameChange == false) { if(document.getElementById('sidepanel-areas').getElementsByClassName('result-list')[0].id == "friendlyNamed") { return; } } var panelRootObj = document.getElementById('sidepanel-areas').getElementsByClassName('result-list')[0]; var areaCount = panelRootObj.children.length; if(areaCount == 0) { return; } var localisedManagedArea = I18n.translations[I18n.locale].user.areas.managed_area; for(loop=0; loop < areaCount; loop++) { var childObjPElems = panelRootObj.children[loop].getElementsByTagName('p'); var title = childObjPElems[0].innerHTML; if(title.indexOf(localisedManagedArea) > -1) { var area = uroGetAreaArea(childObjPElems[1]); childObjPElems[0].innerHTML = localisedManagedArea; for(fnIdx=0; fnIdx < uroFriendlyAreaNames.length; fnIdx++) { fnObj = uroFriendlyAreaNames[fnIdx]; if((fnObj.area == area) && (fnObj.server == W.location.code)) { childObjPElems[0].innerHTML = fnObj.fName +' <i>('+localisedManagedArea+')</i>'; usingFriendlyName = true; break; } } var titleObj = panelRootObj.getElementsByClassName('title')[loop]; titleObj.addEventListener("mouseover", uroAreaNameHover, false); titleObj.addEventListener("mouseout", uroAreaNameUnHover, false); titleObj.style.cursor = "text"; } } document.getElementById('sidepanel-areas').getElementsByClassName('result-list')[0].id = "friendlyNamed"; } // -------------------------------------------------------------------------------------------------------------------- // WATCHLIST STUFF // -------------------------------------------------------------------------------------------------------------------- // Generic Functions function uroTypeCast(varin) { if(varin == "null") return null; if(typeof varin == "string") return parseInt(varin); return varin; } function uroOWLGroupObj(groupID, groupName, groupCollapsed) { groupID = uroTypeCast(groupID); this.groupID = groupID; this.groupName = groupName; this.groupCount = 0; this.groupCollapsed = groupCollapsed; } // Camera Functions function uroCamWatchObjCheckProps(type, azymuth, speed, validated, lat, lon) { if(type != null) type = uroTypeCast(type); if(azymuth != null) azymuth = uroTruncate(uroTypeCast(azymuth)%360); if(speed != null) speed = uroTruncate(uroTypeCast(speed)); if(typeof validated == "string") validated = (validated == "true"); if(lat != null) lat = uroTruncate(uroTypeCast(lat)); if(lon != null) lon = uroTruncate(uroTypeCast(lon)); this.type = type; this.azymuth = azymuth; this.speed = speed; this.validated = validated; this.lat = lat; this.lon = lon; } function uroCamWatchObj(persistent, fid, lon, lat, type, azymuth, speed, validated, groupID, server) { fid = uroTypeCast(fid); groupID = uroTypeCast(groupID); if(typeof persistent == "string") persistent = (persistent == "true"); this.fid = fid; this.persistent = persistent; this.loaded = false; this.server = server; this.groupID = groupID; this.watch = new uroCamWatchObjCheckProps(type, azymuth, speed, validated, lat, lon); this.current = new uroCamWatchObjCheckProps(null, null, null, null, null, null); } function uroCamDataChanged(idx) { camObj = uroCamWatchObjects[idx]; if(camObj.loaded == false) return false; if(camObj.current.type != camObj.watch.type) return true; if(camObj.current.azymuth != camObj.watch.azymuth) return true; if(camObj.current.speed != camObj.watch.speed) return true; if(camObj.current.validated != camObj.watch.validated) return true; if(camObj.current.lat != camObj.watch.lat) return true; if(camObj.current.lon != camObj.watch.lon) return true; return false; } function uroIsCamOnWatchList(fid) { for(var loop=0;loop<uroCamWatchObjects.length;loop++) { if(uroCamWatchObjects[loop].fid == fid) return loop; } return -1; } function uroAddCurrentCamWatchData(idx, lat, lon, type, azymuth, speed, validated, server) { camObj = uroCamWatchObjects[idx]; camObj.loaded = true; camObj.server = server; camObj.current = new uroCamWatchObjCheckProps(type, azymuth, speed, validated, lat, lon) return(uroCamDataChanged(idx)); } function uroAddCamToWatchList() { if(uroIsCamOnWatchList(uroShownFID) == -1) { camObj = W.model.cameras.objects[uroShownFID]; uroCamWatchObjects.push(new uroCamWatchObj(true, uroShownFID, camObj.geometry.x, camObj.geometry.y, camObj.attributes.type, camObj.attributes.azymuth, camObj.attributes.speed, camObj.attributes.validated, 0, W.location.code)); uroAddCurrentCamWatchData(uroCamWatchObjects.length-1, camObj.geometry.y, camObj.geometry.x, camObj.attributes.type, camObj.attributes.azymuth, camObj.attributes.speed, camObj.attributes.validated, W.location.code); uroAddLog('added camera '+uroShownFID+' to watchlist'); uroOWLUpdateHTML(); } } function uroRemoveCamFromWatchList() { camidx = uroIsCamOnWatchList(uroShownFID); if(camidx != -1) { uroCamWatchObjects.splice(camidx,1); uroAddLog('removed camera '+uroShownFID+' from watchlist'); uroOWLUpdateHTML(); } } function uroUpdateCamWatchList() { var camIdx = uroIsCamOnWatchList(uroShownFID); if(camIdx != -1) { var camObj = W.model.cameras.objects[uroShownFID]; uroCamWatchObjects[camIdx].watch = new uroCamWatchObjCheckProps(camObj.attributes.type, camObj.attributes.azymuth, camObj.attributes.speed, camObj.attributes.validated, camObj.geometry.y, camObj.geometry.x); } } function uroClearCamWatchList() { if(confirm('Removing all cameras from the OWL cannot be undone\nAre you sure you want to do this?') == true) { uroCamWatchObjects = new Array(); uroOWLUpdateHTML(); } } function uroRetrieveCameras(lat, lon) { var camPos = new OpenLayers.LonLat(); var camChanged = false; camPos.lon = lon; camPos.lat = lat; camPos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); var camURL = 'https://' + document.location.host; camURL += Waze.Config.api_base; camURL += '/Features?language=en&cameras=true&bbox='; var latl = camPos.lat - 0.25; var latu = camPos.lat + 0.25; var lonl = camPos.lon - 0.25; var lonr = camPos.lon + 0.25; camURL += lonl+','+latl+','+lonr+','+latu; uroAddLog('retrieving camera data around '+camPos.lon+','+camPos.lat); camReq = new XMLHttpRequest(); camReq.open('GET',camURL,false); try { camReq.send(); uroAddLog('response '+camReq.status+' received'); if (camReq.status === 200) { camData = JSON.parse(camReq.responseText); for(var camIdx = 0; camIdx < camData.cameras.objects.length; camIdx++) { camObj = camData.cameras.objects[camIdx]; var listIdx = uroIsCamOnWatchList(camObj.id); if(listIdx != -1) { camPos.lon = camObj.geometry.coordinates[0]; camPos.lat = camObj.geometry.coordinates[1]; camPos.transform(new OpenLayers.Projection("EPSG:4326"),new OpenLayers.Projection("EPSG:900913")); camPos.lon = uroTruncate(camPos.lon); camPos.lat = uroTruncate(camPos.lat); camChanged |= uroAddCurrentCamWatchData(listIdx, camPos.lat, camPos.lon, camObj.type, camObj.azymuth, camObj.speed, camObj.validated, W.location.code); } else if(camObj.validated == false) { } } } else { uroAddLog('request failed (status != 200)'); } } catch(err) { uroAddLog('camera load request failed (exception '+err+' caught)'); } return camChanged; } function uroGetCurrentCamWatchListObjects() { var camChanged = false; var camsChanged = new Array(); var camsDeleted = new Array(); for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { camObj = uroCamWatchObjects[camidx]; if((camObj.loaded == false) && ((camObj.server == W.location.code) || (camObj.server == '??'))) { if(typeof W.model.cameras.objects[camObj.fid] == 'object') { if(W.model.cameras.objects[camObj.fid].state != "Delete") { wazeObj = W.model.cameras.objects[camObj.fid]; camChanged |= uroAddCurrentCamWatchData(camidx, wazeObj.geometry.y, wazeObj.geometry.x, wazeObj.attributes.type, wazeObj.attributes.azymuth, wazeObj.attributes.speed, wazeObj.attributes.validated); } else { camChanged |= uroRetrieveCameras(camObj.watch.lat, camObj.watch.lon); } } else { camChanged |= uroRetrieveCameras(camObj.watch.lat, camObj.watch.lon); } } } if(camChanged) { for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { if(uroCamDataChanged(camidx)) { camsChanged.push(uroCamWatchObjects[camidx]); } } } for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { camObj = uroCamWatchObjects[camidx]; if((camObj.loaded == false) && (camObj.server == W.location.code)) { camsDeleted.push(camObj); } } if((camsChanged.length > 0) || (camsDeleted.length > 0)) { var alertStr = 'Camera WatchList Alert!!!\r\n'; for(var camidx=0;camidx<camsChanged.length;camidx++) { alertStr += 'Camera ID '+camsChanged[camidx].fid+' in group "'+uroFindCWLGroupByIdx(camsChanged[camidx].groupID)+'" has been changed\r\n'; } for(var camidx=0;camidx<camsDeleted.length;camidx++) { alertStr += 'Camera ID '+camsDeleted[camidx].fid+' in group "'+uroFindCWLGroupByIdx(camsDeleted[camidx].groupID)+'" has been deleted\r\n'; } alert(alertStr); } } function uroClearDeletedCameras() { for(var camidx=uroCamWatchObjects.length-1;camidx>=0;camidx--) { if(uroCamWatchObjects[camidx].loaded == false) { uroShownFID = uroCamWatchObjects[camidx].fid; uroRemoveCamFromWatchList(); } } } function uroClearUnknownServerCameras() { var confirmMsg = 'Cameras with an unknown server cannot be automatically verified by URO+.\n'; confirmMsg += 'It is recommended that you manually load WME from each server (World, USA/Canada and Israel) to give URO+ a chance of locating these cameras.\n'; confirmMsg += 'If the cameras then continue to show up as an unknown server, it is safe to delete them...\n\n'; confirmMsg += 'Do you still wish to proceed with deleting all unknown server cameras?'; if(confirm(confirmMsg) == true) { for(var camidx=uroCamWatchObjects.length-1;camidx>=0;camidx--) { if(uroCamWatchObjects[camidx].server == '??') { uroShownFID = uroCamWatchObjects[camidx].fid; uroRemoveCamFromWatchList(); } } } } function uroRescanCamWatchList() { for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { uroCamWatchObjects[camidx].loaded = false; } uroGetCurrentCamWatchListObjects(); uroOWLUpdateHTML(); } function uroGotoCam() { var camidx = this.id.substr(13); var camPos = new OpenLayers.LonLat(); camPos.lon = uroCamWatchObjects[camidx].watch.lon; camPos.lat = uroCamWatchObjects[camidx].watch.lat; W.map.setCenter(camPos,4); W.map.camerasLayer.setVisibility(true); return false; } function uroSetCamGroup() { var camidx = this.id.substr(13); return false; } // Segment Functions function uroSegWatchObjCheckProps(left, right, bottom, top, fromNode, toNode, fwdDir, revDir, length, level, rank, roadType, updatedOn) { if(left != null) left = uroTruncate(uroTypeCast(left)); if(right != null) right = uroTruncate(uroTypeCast(right)); if(bottom != null) bottom = uroTruncate(uroTypeCast(bottom)); if(top != null) top = uroTruncate(uroTypeCast(top)); if(fromNode != null) fromNode = uroTypeCast(fromNode); if(toNode != null) toNode = uroTypeCast(toNode); if(fwdDir != null) fwdDir = uroTypeCast(fwdDir); if(revDir != null) revDir = uroTypeCast(revDir); if(length != null) length = uroTypeCast(length); if(level != null) level = uroTypeCast(level); if(rank != null) rank = uroTypeCast(rank); if(roadType != null) roadType = uroTypeCast(roadType); if(updatedOn != null) updatedOn = uroTypeCast(updatedOn); this.left = left; this.right = right; this.bottom = bottom; this.top = top; this.fromNode = fromNode; this.toNode = toNode; this.fwdDir = fwdDir; this.revDir = revDir; this.length = length; this.level = level; this.rank = rank; this.roadType = roadType; this.updatedOn = updatedOn; } function uroSegWatchObj(persistent, fid, left, right, bottom, top, fromNode, toNode, fwdDir, revDir, length, level, rank, roadType, updatedOn, groupID, server) { fid = uroTypeCast(fid); groupID = uroTypeCast(groupID); if(typeof persistent == "string") persistent = (persistent == "true"); this.fid = fid; this.persistent = persistent; this.loaded = false; this.server = server; this.groupID = groupID; this.watch = new uroSegWatchObjCheckProps(left, right, bottom, top, fromNode, toNode, fwdDir, revDir, length, level, rank, roadType, updatedOn); this.current = new uroSegWatchObjCheckProps(null, null, null, null, null, null, null, null, null, null, null, null, null); } function uroSegDataChanged(idx) { segObj = uroSegWatchObjects[idx]; if(segObj.loaded == false) return false; if(segObj.current.left != segObj.watch.left) return true; if(segObj.current.right != segObj.watch.right) return true; if(segObj.current.bottom != segObj.watch.bottom) return true; if(segObj.current.top != segObj.watch.top) return true; if(segObj.current.fromNode != segObj.watch.fromNode) return true; if(segObj.current.toNode != segObj.watch.toNode) return true; if(segObj.current.fwdDir != segObj.watch.fwdDir) return true; if(segObj.current.revDir != segObj.watch.revDir) return true; if(segObj.current.length != segObj.watch.length) return true; if(segObj.current.level != segObj.watch.level) return true; if(segObj.current.rank != segObj.watch.rank) return true; if(segObj.current.roadType != segObj.watch.roadType) return true; if(segObj.current.updatedOn != segObj.watch.updatedOn) return true; return false; } function uroIsSegOnWatchList(fid) { for(var loop=0;loop<uroSegWatchObjects.length;loop++) { if(uroSegWatchObjects[loop].fid == fid) return loop; } return -1; } function uroAddCurrentSegWatchData(idx, left, right, bottom, top, fromNode, toNode, fwdDir, revDir, length, level, rank, roadType, updatedOn, server) { segObj = uroSegWatchObjects[idx]; segObj.loaded = true; segObj.server = server; segObj.current = new uroSegWatchObjCheckProps(left, right, bottom, top, fromNode, toNode, fwdDir, revDir, length, level, rank, roadType, updatedOn); return(uroSegDataChanged(idx)); } function uroClearSegWatchList() { if(confirm('Removing all segments from the OWL cannot be undone\nAre you sure you want to do this?') == true) { uroSegWatchObjects = new Array(); uroOWLUpdateHTML(); } } function uroAddUpdateSegWatchList() { selectedCount = W.selectionManager.selectedItems.length; if(selectedCount == 0) { return; } for(var loop=0;loop < selectedCount; loop++) { var segObj = W.selectionManager.selectedItems[loop].model.attributes; var fid = segObj.id; var idx = uroIsSegOnWatchList(fid); if(idx != -1) { uroSegWatchObjects[idx].watch = new uroSegWatchObjCheckProps(segObj.geometry.bounds.left, segObj.geometry.bounds.right, segObj.geometry.bounds.bottom, segObj.geometry.bounds.top, segObj.fromNodeID, segObj.toNodeID, segObj.fwdDirection, segObj.revDirection, segObj.length, segObj.level, segObj.rank, segObj.roadType, segObj.updatedOn); uroAddLog('updated watchlist details for segment '+fid); } else { uroSegWatchObjects.push(new uroSegWatchObj(true, fid, segObj.geometry.bounds.left, segObj.geometry.bounds.right, segObj.geometry.bounds.bottom, segObj.geometry.bounds.top, segObj.fromNodeID, segObj.toNodeID, segObj.fwdDirection, segObj.revDirection, segObj.length, segObj.level, segObj.rank, segObj.roadType, segObj.updatedOn, 0, W.location.code)); uroAddCurrentSegWatchData(uroSegWatchObjects.length-1, segObj.geometry.bounds.left, segObj.geometry.bounds.right, segObj.geometry.bounds.bottom, segObj.geometry.bounds.top, segObj.fromNodeID, segObj.toNodeID, segObj.fwdDirection, segObj.revDirection, segObj.length, segObj.level, segObj.rank, segObj.roadType, segObj.updatedOn, W.location.code); uroAddLog('added segment '+fid+' to watchlist'); } } //uroOWLUpdateHTML(); } function uroRemoveSegFromWatchList() { selectedCount = W.selectionManager.selectedItems.length; if(selectedCount == 0) { return; } for(var loop=0;loop < selectedCount; loop++) { var fid = W.selectionManager.selectedItems[loop].model.attributes.id; var idx = uroIsSegOnWatchList(fid); if(idx != -1) { uroSegWatchObjects.splice(idx,1); uroAddLog('removed segment '+fid+' from watchlist'); } } //uroOWLUpdateHTML(); } function uroRetrieveSegments(lat, lon) { var pos = new OpenLayers.LonLat(); var changed = false; pos.lon = lon; pos.lat = lat; pos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); var URL = 'https://' + document.location.host; URL += Waze.Config.api_base; URL += '/Features?roadTypes=1%2C2%2C3%2C4%2C5%2C6%2C7%2C8%2C9%2C10%2C11%2C12%2C13%2C14%2C15%2C16%2C17%2C18%2C19%2C20%2C21'; URL += '&bbox='; var latl = pos.lat - 0.25; var latu = pos.lat + 0.25; var lonl = pos.lon - 0.25; var lonr = pos.lon + 0.25; URL += lonl+','+latl+','+lonr+','+latu; URL += '&language=en'; uroAddLog('retrieving segment data around '+pos.lon+','+pos.lat); req = new XMLHttpRequest(); req.open('GET',URL,false); try { req.send(); uroAddLog('response '+req.status+' received'); if (req.status === 200) { data = JSON.parse(req.responseText); for(var idx = 0; idx < data.segments.objects.length; idx++) { obj = data.segments.objects[idx]; var listIdx = uroIsSegOnWatchList(obj.id); if(listIdx != -1) { //pos.lon = obj.geometry.coordinates[0]; //pos.lat = obj.geometry.coordinates[1]; //pos.transform(new OpenLayers.Projection("EPSG:4326"),new OpenLayers.Projection("EPSG:900913")); //camPos.lon = uroTruncate(camPos.lon); //camPos.lat = uroTruncate(camPos.lat); //camChanged |= uroAddCurrentCamWatchData(listIdx, camPos.lat, camPos.lon, camObj.type, camObj.azymuth, camObj.speed, camObj.validated, W.location.code); } else if(obj.validated == false) { } } } else { uroAddLog('request failed (status != 200)'); } } catch(err) { uroAddLog('segment load request failed (exception '+err+' caught)'); } return changed; } function uroGetCurrentSegWatchListObjects() { var segChanged = false; var segsChanged = new Array(); var segsDeleted = new Array(); for(var idx=0;idx<uroSegWatchObjects.length;idx++) { segObj = uroSegWatchObjects[idx]; if((segObj.loaded == false) && ((segObj.server == W.location.code) || (segObj.server == '??'))) { var segLat = (segObj.watch.top + segObj.watch.bottom) / 2; var segLon = (segObj.watch.right + segObj.watch.left) / 2; if(typeof W.model.segments.objects[segObj.fid] == 'object') { if(W.model.segments.objects[segObj.fid].state != "Delete") { wazeObj = W.model.segments.objects[segObj.fid]; segChanged |= uroAddCurrentSegWatchData(idx, wazeObj.geometry.bounds.left, wazeObj.geometry.bounds.right, wazeObj.geometry.bounds.bottom, wazeObj.geometry.bounds.top, wazeObj.fromNodeID, wazeObj.toNodeID, wazeObj.fwdDirection, wazeObj.revDirection, wazeObj.length, wazeObj.level, wazeObj.rank, wazeObj.roadType, wazeObj.updatedOn, W.location.code); } else { segChanged |= uroRetrieveSegments(segLat, segLon); } } else { segChanged |= uroRetrieveSegments(segLat, segLon); } } } if(segChanged) { for(var idx=0;idx<uroSegWatchObjects.length;idx++) { if(uroSegDataChanged(idx)) { segsChanged.push(uroSegWatchObjects[idx]); } } } for(var idx=0;idx<uroSegWatchObjects.length;idx++) { segObj = uroSegWatchObjects[idx]; if((segObj.loaded == false) && (segObj.server == W.location.code)) { segsDeleted.push(segObj); } } if((segsChanged.length > 0) || (segsDeleted.length > 0)) { var alertStr = 'Segment WatchList Alert!!!\r\n'; for(var idx=0;idx<segsChanged.length;idx++) { alertStr += 'Segment ID '+segsChanged[idx].fid+' in group "'+uroFindCWLGroupByIdx(segsChanged[idx].groupID)+'" has been changed\r\n'; } for(var idx=0;idx<segsDeleted.length;idx++) { alertStr += 'Segment ID '+segsDeleted[idx].fid+' in group "'+uroFindCWLGroupByIdx(segsDeleted[idx].groupID)+'" has been deleted\r\n'; } alert(alertStr); } } // Places Functions function uroPlaceWatchObjCheckProps(left, right, bottom, top, name, imageCount, residential, updatedOn) { if(left != null) left = uroTruncate(uroTypeCast(left)); if(right != null) right = uroTruncate(uroTypeCast(right)); if(bottom != null) bottom = uroTruncate(uroTypeCast(bottom)); if(top != null) top = uroTruncate(uroTypeCast(top)); if(imageCount != null) imageCount = uroTypeCast(imageCount); if(typeof residential == "string") residential = (residential == "true"); if(updatedOn != null) updatedOn = uroTypeCast(updatedOn); this.left = left; this.right = right; this.bottom = bottom; this.top = top; this.name = name; this.imageCount = imageCount; this.residential = residential; this.updatedOn = updatedOn; } function uroPlaceWatchObj(persistent, fid, left, right, bottom, top, imageCount, name, residential, updatedOn, groupID, server) { groupID = uroTypeCast(groupID); if(typeof persistent == "string") persistent = (persistent == "true"); this.fid = fid; this.persistent = persistent; this.loaded = false; this.server = server; this.groupID = groupID; this.watch = new uroPlaceWatchObjCheckProps(left, right, bottom, top, name, imageCount, residential, updatedOn); this.current = new uroPlaceWatchObjCheckProps(null, null, null, null, null, null, null, null); } function uroPlaceDataChanged(idx) { placeObj = uroPlaceWatchObjects[idx]; if(placeObj.loaded == false) return false; if(placeObj.current.left != placeObj.watch.left) return true; if(placeObj.current.right != placeObj.watch.right) return true; if(placeObj.current.bottom != placeObj.watch.bottom) return true; if(placeObj.current.top != placeObj.watch.top) return true; if(placeObj.current.name != placeObj.watch.name) return true; if(placeObj.current.imageCount != placeObj.watch.imageCount) return true; if(placeObj.current.residential != placeObj.watch.residential) return true; if(placeObj.current.updatedOn != placeObj.watch.updatedOn) return true; return false; } function uroIsPlaceOnWatchList(fid) { for(var loop=0;loop<uroPlaceWatchObjects.length;loop++) { if(uroPlaceWatchObjects[loop].fid == fid) return loop; } return -1; } function uroClearPlaceWatchList() { if(confirm('Removing all places from the OWL cannot be undone\nAre you sure you want to do this?') == true) { uroPlaceWatchObjects = new Array(); uroOWLUpdateHTML(); } } function uroTruncate(val) { if(val == null) return val; if(val < 0) return Math.ceil(val); return Math.floor(val); } function uroHighlightCWLEntry() { this.style.backgroundColor = '#FFFFAA'; return false; } function uroUnhighlightCWLEntry() { var camidx = this.id.substr(8); var changed = uroCamDataChanged(camidx); var deleted = (uroCamWatchObjects[camidx].loaded == false); if(uroCamWatchObjects[camidx].server != W.location.code) { if(uroCamWatchObjects[camidx].server == '??') this.style.backgroundColor = '#A0A0A0'; else this.style.backgroundColor = '#AAFFAA'; } else if(changed) this.style.backgroundColor = '#AAAAFF'; else if(deleted) this.style.backgroundColor = '#FFAAAA'; else this.style.backgroundColor = '#FFFFFF'; return false; } function uroCWLIconHighlight() { iconType = this.id.substr(11,1); this.src = uroIcons[iconType][0]; return false; } function uroCWLIconLowlight() { iconType = this.id.substr(11,1); this.src = uroIcons[iconType][1]; return false; } function uroRemoveFromCWL() { uroShownFID = uroCamWatchObjects[this.id.substr(18)].fid; uroRemoveCamFromWatchList(); } function uroSetCamGroups() { for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { camObj = uroCamWatchObjects[camidx]; camGroup = parseInt(uroGetElmValue("_uroGroupSelect-"+camidx)); camObj.groupID = camGroup; } } function uroPopulateCWLGroupSelect() { var selector = document.getElementById('_uroCWLGroupSelect'); while(selector.options.length > 0) { selector.options.remove(0); } for(var loop=0;loop<uroCWLGroups.length;loop++) { var groupObj = uroCWLGroups[loop]; if(groupObj.groupID != -1) { selector.options.add(new Option(groupObj.groupName,groupObj.groupID)); } } } function uroGetNextCWLGroupID() { var nextID = 1; for(var loop=0;loop<uroCWLGroups.length;loop++) { if(uroCWLGroups[loop].groupID >= nextID) { nextID = uroCWLGroups[loop].groupID + 1; } } return nextID; } function uroFindCWLGroupByName(groupName) { var groupID = -1; for(var loop=0;loop<uroCWLGroups.length;loop++) { if((uroCWLGroups[loop].groupName == groupName) && (uroCWLGroups[loop].groupID != -1)) { groupID = uroCWLGroups[loop].groupID; break; } } return groupID; } function uroFindCWLGroupByIdx(groupIdx) { var groupName = ''; for(var loop=0;loop<uroCWLGroups.length;loop++) { if(uroCWLGroups[loop].groupID == groupIdx) { groupName = uroCWLGroups[loop].groupName; break; } } return groupName; } function uroAddCWLGroup() { var groupID = uroGetNextCWLGroupID(); var groupName = uroGetElmValue('_uroCWLGroupEntry'); if(uroFindCWLGroupByName(groupName) == -1) { uroCWLGroups.push(new uroOWLGroupObj(groupID,groupName,false)); uroPopulateCWLGroupSelect(); } } function uroRemoveCWLGroup() { var selector = document.getElementById('_uroCWLGroupSelect'); var groupID = parseInt(selector.selectedOptions[0].value); if(groupID == 0) return false; // prevent deletion of the default group for(var loop=0;loop<uroCamWatchObjects.length;loop++) { var cwObj = uroCamWatchObjects[loop]; if(cwObj.groupID == groupID) { cwObj.groupID = 0; } } for(var loop=0;loop<uroCWLGroups.length;loop++) { var groupObj = uroCWLGroups[loop]; if(groupObj.groupID == groupID) { groupObj.groupID = -1; } } uroOWLUpdateHTML(); } function uroAssignCameraToGroup() { var camidx = this.id.substr(13); var selector = document.getElementById('_uroCWLGroupSelect'); uroCamWatchObjects[camidx].groupID = parseInt(selector.selectedOptions[0].value); uroOWLUpdateHTML(); return false; } function uroAddBtnEvl(btnID, evlType, evlFunction) { btnObj = document.getElementById(btnID); if(btnObj != null) { btnObj.addEventListener(evlType, evlFunction, true); } } function uroCWLGroupCollapseExpand() { var groupidx = this.id.substr(18); if(uroCWLGroups[groupidx].groupCollapsed == true) uroCWLGroups[groupidx].groupCollapsed = false; else uroCWLGroups[groupidx].groupCollapsed = true; uroOWLUpdateHTML(); return false; } function uroOWLUpdateHTML() { var camTypes = new Array("","","Speed", "Dummy", "Red Light"); var selectedGroup = 0; iHTML = ''; if(document.getElementById('_uroCWLGroupSelect') != null) { selectedGroup = document.getElementById('_uroCWLGroupSelect').selectedIndex; } iHTML = '<br><b>Camera Watchlist:</b><br><br>'; iHTML += '<div id="_uroCWLCamList" style="height:65%;overflow:auto;">'; for(var groupidx=0;groupidx<uroCWLGroups.length;groupidx++) { var groupObj = uroCWLGroups[groupidx]; iHTML += '<div id="_uroCWLGroup-'+groupidx+'">'; if(groupObj.groupCollapsed == true) { iHTML += '<img src="'+uroIcons[0][1]+'" id="_uroCWLGroupState-'+groupidx+'">'; } else { iHTML += '<img src="'+uroIcons[0][0]+'" id="_uroCWLGroupState-'+groupidx+'">'; } iHTML += '<b>'+groupObj.groupName+'</b><br>'; groupObj.groupCount = 0; for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { camObj = uroCamWatchObjects[camidx]; if(camObj.groupID == groupObj.groupID) { groupObj.groupCount++; var changed = uroCamDataChanged(camidx); var deleted = (camObj.loaded == false); iHTML += '<div id="_uroCWL-'+camidx+'" style="padding:3px;border-width:2px;border-style:solid;border-color:#FFFFFF;background-color:'; if(camObj.server != W.location.code) { if(camObj.server == '??') iHTML += '#A0A0A0;'; else iHTML += '#AAFFAA;'; } else if(changed) iHTML += '#AAAAFF;'; else if(deleted) iHTML += '#FFAAAA;'; else iHTML += '#FFFFFF;'; if(groupObj.groupCollapsed == true) iHTML += 'display:none;">'; else iHTML += 'display:block;">'; iHTML += 'ID: '+camObj.fid; iHTML += ' ('+camObj.server+')'; iHTML += ' Type: '+camTypes[camObj.watch.type]; if(camObj.server != W.location.code) { if(camObj.server == '??') { iHTML += '<br><i>Unknown server</i>'; } else { iHTML += '<br><i>Not on this server</i>'; } } else if(deleted) { iHTML += '<br>DELETED'; } else if(changed) { if(camObj.current.type != camObj.watch.type) { iHTML += '<br> Type changed'; iHTML += ' ('+camObj.watch.type+' to '+camObj.current.type+')'; } if(camObj.current.azymuth != camObj.watch.azymuth) { iHTML += '<br> Azimuth changed'; iHTML += ' ('+camObj.watch.azymuth+' to '+camObj.current.azymuth+')'; } if(camObj.current.speed != camObj.watch.speed) { iHTML += '<br> Speed changed'; iHTML += ' ('+camObj.watch.speed+' to '+camObj.current.speed+')'; } if(camObj.current.validated != camObj.watch.validated) { iHTML += '<br> Approval state changed'; iHTML += ' ('+camObj.watch.validated+' to '+camObj.current.validated+')'; } if(camObj.current.lat != camObj.watch.lat) { iHTML += '<br> Latitude changed'; iHTML += ' ('+camObj.watch.lat+' to '+camObj.current.lat+')'; } if(camObj.current.lon != camObj.watch.lon) { iHTML += '<br> Longitude changed'; iHTML += ' ('+camObj.watch.lon+' to '+camObj.current.lon+')'; } } if(camObj.server == W.location.code) { if(deleted == false) { iHTML += ' <img id="_uroCWLIcon1-'+camidx+'" src="'+uroIcons[1][1]+'">'; } iHTML += ' <img id="_uroCWLIcon2-'+camidx+'" src="'+uroIcons[2][1]+'">'; } iHTML += '</div>'; } } iHTML += '</div>'; } iHTML += '</div><div id="_uroCWLControls">'; iHTML += '<hr>Group control:<br>'; iHTML += '<select id="_uroCWLGroupSelect" style="width:40%;height:22px;"></select> <input type="button" id="_btnCWLGroupDel" value="Delete group"><br>'; iHTML += '<input type="text" id="_uroCWLGroupEntry" style="width:40%;height:22px;"> <input type="button" id="_btnCWLGroupAdd" value="Add group">'; iHTML += '<br><input type="button" id="_btnRescanCamWatchList" value="Refresh Camera Data"><br><br>'; iHTML += '<b>Remove cameras from OWL:</b><br>'; iHTML += '<input type="button" id="_btnRemoveDeletedCameras" value="Deleted"> '; iHTML += '<input type="button" id="_btnRemoveUnknownServerCameras" value="Unknown Server"> '; iHTML += '<input type="button" id="_btnClearCamWatchList" value="ALL Cameras">'; iHTML += '</div>'; uroOWL.innerHTML = iHTML; for(var camidx=0;camidx<uroCamWatchObjects.length;camidx++) { document.getElementById("_uroCWL-"+camidx).onmouseover = uroHighlightCWLEntry; document.getElementById("_uroCWL-"+camidx).onmouseleave = uroUnhighlightCWLEntry; if(uroCamWatchObjects[camidx].server == W.location.code) { var icon1 = document.getElementById("_uroCWLIcon1-"+camidx); var icon2 = document.getElementById("_uroCWLIcon2-"+camidx); if(icon1 != null) { icon1.onmouseover = uroCWLIconHighlight; icon1.onmouseleave = uroCWLIconLowlight; icon1.onclick = uroAssignCameraToGroup; } if(icon2 != null) { icon2.onmouseover = uroCWLIconHighlight; icon2.onmouseleave = uroCWLIconLowlight; icon2.onclick = uroGotoCam; } } } uroAddBtnEvl('_btnClearCamWatchList', 'click', uroClearCamWatchList); uroAddBtnEvl('_btnRemoveDeletedCameras', 'click', uroClearDeletedCameras); uroAddBtnEvl('_btnRemoveUnknownServerCameras', 'click', uroClearUnknownServerCameras); uroAddBtnEvl('_btnRescanCamWatchList', 'click', uroRescanCamWatchList); uroAddBtnEvl('_btnCWLGroupDel', 'click', uroRemoveCWLGroup); uroAddBtnEvl('_btnCWLGroupAdd', 'click', uroAddCWLGroup); if(document.getElementById('_uroCWLGroupSelect') != null) { uroAddLog('populating CWL group list'); uroPopulateCWLGroupSelect(); var selector = document.getElementById('_uroCWLGroupSelect'); if(selectedGroup >= selector.length) { selectedGroup = 0; } selector.selectedIndex = selectedGroup; } for(var groupidx=0;groupidx<uroCWLGroups.length;groupidx++) { if(uroCWLGroups[groupidx].groupCount == 0) { uroSetStyleDisplay('_uroCWLGroup-'+groupidx,'none'); } else { uroSetOnClick('_uroCWLGroupState-'+groupidx,uroCWLGroupCollapseExpand); } } } // -------------------------------------------------------------------------------------------------------------------- // END OF WATCHLIST STUFF // -------------------------------------------------------------------------------------------------------------------- function uroIsOnIgnoreList(fid) { if(sessionStorage.UROverview_FID_IgnoreList.indexOf('fid:'+fid) == -1) return false; else return true; } function uroEnableIgnoreListControls() { var btnState = "visible"; if(sessionStorage.UROverview_FID_IgnoreList == '') { btnState = "hidden"; } document.getElementById('_btnUndoLastHide').style.visibility = btnState; document.getElementById('_btnClearSessionHides').style.visibility = btnState; uroFilterItems(); } function uroAddToIgnoreList() { if(!uroIsOnIgnoreList(uroShownFID)) { sessionStorage.UROverview_FID_IgnoreList += 'fid:'+uroShownFID; uroAddLog('added fid '+uroShownFID+' to ignore list'); uroAddLog(sessionStorage.UROverview_FID_IgnoreList); uroDiv.style.visibility = 'hidden'; uroEnableIgnoreListControls(); W.map.events.register("mousemove", null, uroFilterItemsOnMove); } return false; } function uroRemoveFromIgnoreList(fid) { var ignorelist = sessionStorage.UROverview_FID_IgnoreList; var fidpos = ignorelist.indexOf('fid:'+fid); if(fidpos != -1) { var preFID = ignorelist.slice(0,fidpos); ignorelist = ignorelist.slice(fidpos+1); fidpos = ignorelist.indexOf('fid:'); if(fidpos == -1) ignorelist = ''; else ignorelist = ignorelist.slice(fidpos); sessionStorage.UROverview_FID_IgnoreList = preFID + ignorelist; uroAddLog('removed fid '+fid+' from ignore list'); uroAddLog(sessionStorage.UROverview_FID_IgnoreList); uroEnableIgnoreListControls(); } } function uroRemoveLastAddedIgnore() { var ignorelist = sessionStorage.UROverview_FID_IgnoreList; var fidpos = ignorelist.lastIndexOf('fid:'); if(fidpos != -1) { ignorelist = ignorelist.slice(0,fidpos); sessionStorage.UROverview_FID_IgnoreList = ignorelist; uroAddLog('removed last fid from ignore list'); uroAddLog(sessionStorage.UROverview_FID_IgnoreList); uroEnableIgnoreListControls(); } } function uroRemoveAllIgnores() { sessionStorage.UROverview_FID_IgnoreList = ''; uroEnableIgnoreListControls(); } function uroKeywordPresent(desc, keyword) { if(uroGetCBChecked('_cbCaseInsensitive') == true) re = RegExp(keyword,'i'); else re = RegExp(keyword); if(desc.search(re) == -1) return false; else return true; } function uroClickify(desc) { var linkStartPos = desc.indexOf('http://'); if(linkStartPos == -1) linkStartPos = desc.indexOf('https://'); if(linkStartPos != -1) { var descPreLink = desc.slice(0,linkStartPos); var descURL = desc.slice(linkStartPos); var linkEndPos = descURL.indexOf(' '); var descPostLink = ''; if(linkEndPos != -1) { descPostLink = descURL.slice(linkEndPos); descURL = descURL.slice(0,linkEndPos); } var linkTarget = ''; if(descURL.indexOf('cryosphere') != -1) linkTarget = '_cryosphere'; else if(descURL.indexOf('waze.com') != -1) linkTarget = '_wazeUR'; desc = descPreLink + '<a target="'+linkTarget+'" href="'+descURL+'">here</a>' + descPostLink; } return desc; } function uroRefreshUpdateRequestSessions() { for (var urID in W.model.mapUpdateRequests.objects) { var reqPos = uroRequestedURSessionIDs.indexOf(urID); var pendPos = uroPendingURSessionIDs.indexOf(urID); if(W.model.updateRequestSessions.objects[urID] == null) { if((reqPos == -1) && (pendPos == -1)) { uroPendingURSessionIDs.push(urID); } } else { if(reqPos != -1) { uroRequestedURSessionIDs.splice(reqPos,1); } if(pendPos != -1) { uroPendingURSessionIDs.splice(pendPos,1); } } } var idList = []; while((idList.length < 500) && (uroPendingURSessionIDs.length)) { var id = uroPendingURSessionIDs.pop(); idList.push(id); uroRequestedURSessionIDs.push(id); } if(idList.length > 0) { uroAddLog('grabbing updateRequestSessions with IDs '+idList); W.model.updateRequestSessions.get(idList); } if((uroPendingURSessionIDs.length) || (uroRequestedURSessionIDs.length)) { setTimeout(uroRefreshUpdateRequestSessions,10); } } function uroURHasMyComments(fid) { var nComments = W.model.updateRequestSessions.objects[fid].comments.length; if(nComments == 0) return false; for(var cidx=0; cidx<nComments; cidx++) { if(W.model.updateRequestSessions.objects[fid].comments[cidx].userID == uroUserID) return true; } return false; } function uroACMObj(urID, customType, hasMyComments, nComments) { this.urID = urID; this.customType = customType; this.hasMyComments = hasMyComments; this.nComments = nComments; } function uroAddCustomMarkers(urID, customType, hasMyComments, nComments) { var useCustomMarker = false; if(customType == 0) useCustomMarker = (uroGetCBChecked('_cbCustomRoadworksMarkers')); else if(customType == 1) useCustomMarker = (uroGetCBChecked('_cbCustomConstructionMarkers')); else if(customType == 2) useCustomMarker = (uroGetCBChecked('_cbCustomClosuresMarkers')); else if(customType == 3) useCustomMarker = (uroGetCBChecked('_cbCustomEventsMarkers')); else if(customType == 4) useCustomMarker = (uroGetCBChecked('_cbCustomNotesMarkers')); if(!useCustomMarker) customType = -1; uroCustomMarkerList.push(new uroACMObj(urID, customType, hasMyComments, nComments)); } function uroRenderCustomMarkers() { var markersToAdd = uroCustomMarkerList.length; var useDefaultConvoMarker = false; var addCommentCount = false; if((uroGetCBChecked('_cbNativeConvoMarkers')) && (uroBetaEditor == false)) useDefaultConvoMarker = true; if((uroGetCBChecked('_cbNativeBetaConvoMarkers')) && (uroBetaEditor == true)) useDefaultConvoMarker = true; if(uroGetCBChecked('_cbCommentCount')) addCommentCount = true; var divElem = document.getElementById(W.map.updateRequestLayer.id); if(divElem.childNodes.length > 0) { for(var objIdx = 0; objIdx < uroCustomMarkerList.length; objIdx++) { var urID = uroCustomMarkerList[objIdx].urID; var customType = uroCustomMarkerList[objIdx].customType; var hasMyComments = uroCustomMarkerList[objIdx].hasMyComments; var nComments = uroCustomMarkerList[objIdx].nComments; if(nComments > 0) { var elmID = "commentCount_"+urID; if(addCommentCount) { // add a new comment count bubble if the UR doesn't already have one if(document.getElementById(elmID) == null) { var newSpan = '<span id="'+elmID+'" style="position:absolute;top:-9px;left:-11px;pointer-events:none;z-index:1">'; // define the comment-count holding span within the span used to hold the empty bubble image, and before the image is // added to the HTML, to avoid z-indexing issues when adjacent comment count bubbles are overlapped... newSpan += '<span id="'+elmID+"_inner"+'" style="position:absolute;top:4px;left:11px;font-size:11px;;pointer-events:none"></span>'; newSpan += '<img src="'+uroMarkers[0]+'">'; newSpan += '</span>'; W.map.updateRequestLayer.markers[urID].icon.$div.prepend(newSpan); } var styleLeft; if(nComments < 10) styleLeft = '11px'; else if(nComments < 100) styleLeft = '8px'; else styleLeft = '5px'; document.getElementById(elmID+"_inner").innerHTML = nComments; document.getElementById(elmID+"_inner").style.left = styleLeft; } else { // remove comment count bubble from this UR marker if one has previously been // added and the user has now disabled the option... if(document.getElementById(elmID) != null) { document.getElementById(elmID).remove(); document.getElementById(elmID+"_inner").remove(); } } var elmID = "convoMarker_"+urID; if(useDefaultConvoMarker == false) { if(document.getElementById(elmID) == null) { // z-index needs to be set to 1 here so that when a new comment is added to a UR and WME re-renders the native // conversation marker, the custom marker remains on top... var newSpan = '<span id="'+elmID+'" style="position:absolute;top:-9px;left:18px;pointer-events:none;z-index:1">'; if(hasMyComments) newSpan += '<img src="'+uroMarkers[2]+'">'; else newSpan += '<img src="'+uroMarkers[1]+'">'; newSpan += '</span>'; W.map.updateRequestLayer.markers[urID].icon.imageDiv.classList.remove("has-comments") W.map.updateRequestLayer.markers[urID].icon.$div.prepend(newSpan); } } else { // remove custom conversation marker from this UR if one has previously been // added and the user has now disabled this option if(document.getElementById(elmID) != null) { document.getElementById(elmID).remove(); } W.map.updateRequestLayer.markers[urID].icon.imageDiv.classList.add("has-comments") } } var elmID = "customMarker_"+urID; if(customType != -1) { if(document.getElementById(elmID) == null) { var newSpan = '<span id="'+elmID+'" style="position:absolute;pointer-events:none;"></span>'; W.map.updateRequestLayer.markers[urID].icon.$div.prepend(newSpan); } customType = uroGetCustomMarkerIdx(customType); if(W.model.updateRequestSessions.objects[urID] != undefined) { if(W.model.updateRequestSessions.objects[urID].open == false) customType += 1; } var customMarker = '<img src="'+uroIcons[customType][0]+'">'; document.getElementById(elmID).innerHTML = customMarker; } else { if(document.getElementById(elmID) != null) { document.getElementById(elmID).remove(); } } } } } function uroChangeCustomMarkers(urID,isHighlighted,customType) { if(document.getElementById('customMarker_'+urID) != null) { if(W.model.updateRequestSessions.objects[urID].open == false) customType += 1; if(isHighlighted == true) { document.getElementById('customMarker_'+urID).innerHTML = '<img src="'+uroIcons[customType][1]+'">'; } else { document.getElementById('customMarker_'+urID).innerHTML = '<img src="'+uroIcons[customType][0]+'">'; } } } function uroFilterPlaces() { if(uroFilterPreamble() == false) return; if(uroPlaceSelected == true) return; if(uroGetCBChecked('_cbDisablePlacesFiltering') == true) return; var filterCats = []; for(var i=0; i<W.Config.venues.categories.length; i++) { parentCategory = W.Config.venues.categories[i]; if(uroGetCBChecked('_cbPlacesFilter-'+parentCategory) == true) { filterCats.push(parentCategory); for(var ii=0; ii<W.Config.venues.subcategories[parentCategory].length; ii++) { subCategory = W.Config.venues.subcategories[parentCategory][ii]; filterCats.push(subCategory); } } else { for(var ii=0; ii<W.Config.venues.subcategories[parentCategory].length; ii++) { subCategory = W.Config.venues.subcategories[parentCategory][ii]; if(uroGetCBChecked('_cbPlacesFilter-'+subCategory) == true) { filterCats.push(subCategory); } } } } for(var v=0; v<W.map.landmarkLayer.features.length; v++) { placeStyle = 'visible'; lmObj = W.map.landmarkLayer.features[v]; // when an area place is selected, the drag points for editing the place outline now get added as objects into W.map.landmarkLayer.features, // however none of these objects have the .model property - we must therefore check each entry in features[] to see if it has .model before // attempting to filter it... if(lmObj.model != undefined) { if(lmObj.model.attributes.id < 0) { // don't apply filtering to newly-created places - this allows the user to leave their filtering settings unchanged whilst // adding a new place which, once saved, would then be hidden... break; } editDate = lmObj.model.attributes.updatedOn; if(editDate == undefined) { // where a place has never been edited since its creation, use the creation date instead... editDate = lmObj.model.attributes.createdOn; } if(editDate != undefined) { editDaysAgo = uroDateToDays(editDate); if(uroGetCBChecked('_cbPlaceFilterEditedLessThan')) { if(editDaysAgo < document.getElementById('_inputFilterPlaceEditMinDays').value) { placeStyle = 'hidden'; } } if(uroGetCBChecked('_cbPlaceFilterEditedMoreThan')) { if(editDaysAgo > document.getElementById('_inputFilterPlaceEditMaxDays').value) { placeStyle = 'hidden'; } } } if(placeStyle == 'visible') { lockLevel = lmObj.model.attributes.lockRank; if ((uroGetCBChecked('_cbHidePlacesL0')) && (lockLevel == 0)) placeStyle = 'hidden'; if ((uroGetCBChecked('_cbHidePlacesL1')) && (lockLevel == 1)) placeStyle = 'hidden'; if ((uroGetCBChecked('_cbHidePlacesL2')) && (lockLevel == 2)) placeStyle = 'hidden'; if ((uroGetCBChecked('_cbHidePlacesL3')) && (lockLevel == 3)) placeStyle = 'hidden'; if ((uroGetCBChecked('_cbHidePlacesL4')) && (lockLevel == 4)) placeStyle = 'hidden'; if ((uroGetCBChecked('_cbHidePlacesL5')) && (lockLevel == 5)) placeStyle = 'hidden'; } if(placeStyle == 'visible') { nPhotos = 0; for(var loop=0; loop<lmObj.model.attributes.images.length; loop++) { if(lmObj.model.attributes.images[loop].attributes.approved) nPhotos++; } if((uroGetCBChecked('_cbHideNoPhotoPlaces')) && (nPhotos == 0)) placeStyle = 'hidden'; if((uroGetCBChecked('_cbHidePhotoPlaces')) && (nPhotos != 0)) placeStyle = 'hidden'; } if(placeStyle == 'visible') { if((lmObj.model.attributes.residential == true) && (uroGetCBChecked('_cbFilterPrivatePlaces') == true)) { placeStyle = 'hidden'; } else { for(var cat=0; cat<filterCats.length; cat++) { if(lmObj.model.attributes.categories.contains(filterCats[cat])) { placeStyle = 'hidden'; break; } } } } } if(uroGetCBChecked('_cbInvertPlacesFilter') == true) { if(placeStyle == 'hidden') placeStyle = 'visible'; else placeStyle = 'hidden'; } geoID = W.map.landmarkLayer.features[v].geometry.id; // area places... if(document.getElementById(uroPlacesRoot).getElementsByTagName('path')[geoID] != null) { document.getElementById(uroPlacesRoot).getElementsByTagName('path')[geoID].style.visibility = placeStyle; } // point places... if(document.getElementById(uroPlacesRoot).getElementsByTagName('circle')[geoID] != null) { document.getElementById(uroPlacesRoot).getElementsByTagName('circle')[geoID].style.visibility = placeStyle; } } for(var pu in W.map.placeUpdatesLayer.markers) { puObj = W.map.placeUpdatesLayer.markers[pu]; if(W.map.placeUpdatesLayer.getVisibility() == true) { placeStyle = 'visible'; if(uroGetCBChecked('_cbFilterUneditablePlaceUpdates') == true) { if(puObj.model.attributes.permissions == 0) { placeStyle = 'hidden'; } if(W.model.loginManager.isLoggedIn()) { if(W.model.loginManager.user.rank < puObj.model.attributes.lockRank) { placeStyle = 'hidden'; } } } if(uroGetCBChecked('_cbFilterLockRankedPlaceUpdates') == true) { if(puObj.model.attributes.lockRank != 0) { placeStyle = 'hidden'; } } if(uroGetCBChecked("_cbFilterFlaggedPUR") == true) { if(puObj.icon.imageDiv.className.indexOf('flag') != -1) { placeStyle = 'hidden'; } } if(uroGetCBChecked("_cbFilterNewPlacePUR") == true) { if(puObj.icon.imageDiv.className.indexOf('add_venue') != -1) { placeStyle = 'hidden'; } } if(uroGetCBChecked("_cbFilterUpdatedDetailsPUR") == true) { if((puObj.icon.imageDiv.className.indexOf('update_venue') != -1) || (puObj.icon.imageDiv.className.indexOf('multiple') != -1)) { placeStyle = 'hidden'; } } if(uroGetCBChecked("_cbFilterNewPhotoPUR") == true) { if(puObj.icon.imageDiv.className.indexOf('add_image') != -1) { placeStyle = 'hidden'; } } if(uroGetCBChecked('_cbInvertPURFilters') == true) { if(placeStyle == 'hidden') placeStyle = 'visible'; else placeStyle = 'hidden'; } if(uroGetCBChecked('_cbEnablePURMinAgeFilter') == true) { if(uroGetPURAge(puObj.model) < uroGetElmValue('_inputPURFilterMinDays')) placeStyle = 'hidden'; } if(uroGetCBChecked('_cbEnablePURMaxAgeFilter') == true) { if(uroGetPURAge(puObj.model) > uroGetElmValue('_inputPURFilterMaxDays')) placeStyle = 'hidden'; } var purSeverity = puObj._getSeverity(); if((uroGetCBChecked('_cbPURFilterHighSeverity')) && (purSeverity == "high")) placeStyle = 'hidden'; if((uroGetCBChecked('_cbPURFilterMediumSeverity')) && (purSeverity == "medium")) placeStyle = 'hidden'; if((uroGetCBChecked('_cbPURFilterLowSeverity')) && (purSeverity == "low")) placeStyle = 'hidden'; puObj.icon.imageDiv.style.visibility = placeStyle; if(uroGetCBChecked('_cbLeavePURGeos') == false) { if(puObj.model != undefined) { if(puObj.model.geometry != undefined) { puGeo = document.getElementById(puObj.model.geometry.id); if(puGeo != null) { puGeo.style.visibility = placeStyle; } } } } } } } function uroFilterCameras() { if(uroFilterPreamble() == false) return; var camLayer = document.getElementById(uroRootContainer+'_svgRoot'); if(camLayer == null) { if(uroNullCamLayer == false) { uroAddLog('caught null camLayer'); uroNullCamLayer = true; } return; } uroNullCamLayer = false; if(uroMouseIsDown == false) W.map.camerasLayer.redraw(); for (var uroCamObj in W.model.cameras.objects) { var uroCam = W.model.cameras.objects[uroCamObj]; var uroCamStyle = 'visible'; if(W.model.users.objects[uroCam.attributes.createdBy] != null) { var uroCamCreator = W.model.users.objects[uroCam.attributes.createdBy].userName; var uroCamCreatorRank = W.model.users.objects[uroCam.attributes.createdBy].rank; } else { var uroCamCreator = ''; var uroCamCreatorRank = -1; } if(W.model.users.objects[uroCam.attributes.updatedBy] != null) { var uroCamUpdater = W.model.users.objects[uroCam.attributes.updatedBy].userName; var uroCamUpdaterRank = W.model.users.objects[uroCam.attributes.updatedBy].rank; } else { var uroCamUpdater = ''; var uroCamUpdaterRank = -1; } var uroCamApproved = uroCam.attributes.validated; var uroCamType = uroCam.attributes.type; if(uroGetCBChecked('_cbShowOnlyMyCams') == true) { if((uroUserID != uroCam.attributes.createdBy)&&(uroUserID != uroCam.attributes.updatedBy)) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbShowWorldCams') == false) || (uroGetCBChecked('_cbShowUSACams') == false) || (uroGetCBChecked('_cbShowNonWorldCams') == false)) { var posWorld = uroCamCreator.indexOf('world_'); var posUSA = uroCamCreator.indexOf('usa_'); if((uroGetCBChecked('_cbShowWorldCams') == false) && (posWorld == 0)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowUSACams') == false) && (posUSA == 0)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowNonWorldCams') == false) && (posWorld != 0) && (posUSA != 0)) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbShowApprovedCams') == false) || (uroGetCBChecked('_cbShowNonApprovedCams') == false)) { if((uroGetCBChecked('_cbShowApprovedCams') == false) && (uroCamApproved == true)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowNonApprovedCams') == false) && (uroCamApproved == false)) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbShowNonApprovedCams') == true) && (uroCamApproved == false)) { if(((uroGetCBChecked('_cbShowOlderCreatedNonApproved') == true)) && (uroGetCameraAge(uroCam,1) <= uroGetElmValue('_inputCameraMinCreatedDays'))) uroCamStyle = 'hidden'; if(((uroGetCBChecked('_cbShowOlderUpdatedNonApproved') == true)) && (uroGetCameraAge(uroCam,0) <= uroGetElmValue('_inputCameraMinUpdatedDays'))) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbShowSpeedCams') == false) || (uroGetCBChecked('_cbShowRedLightCams') == false) || (uroGetCBChecked('_cbShowDummyCams') == false)) { if((uroGetCBChecked('_cbShowSpeedCams') == false) && (uroCamType == 2)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowRedLightCams') == false) && (uroCamType == 4)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowDummyCams') == false) && (uroCamType == 3)) uroCamStyle = 'hidden'; } if(uroGetCBChecked('_cbShowSpeedCams') == true) { if((uroGetCBChecked('_cbShowIfMPHSpeedSet') == false) && (uroIsCameraSpeedValid(uroCam) == 1)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowIfNoSpeedSet') == false) && (uroIsCameraSpeedValid(uroCam) == 0)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbShowIfKPHSpeedSet') == false) && (uroIsCameraSpeedValid(uroCam) == -1)) uroCamStyle = 'hidden'; } if(uroGetCBChecked('_cbHideCreatedByMe') == true) { if(uroUserID == uroCam.attributes.createdBy) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbHideCreatedByRank0') == true) && (uroCamCreatorRank == 0)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCreatedByRank1') == true) && (uroCamCreatorRank == 1)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCreatedByRank2') == true) && (uroCamCreatorRank == 2)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCreatedByRank3') == true) && (uroCamCreatorRank == 3)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCreatedByRank4') == true) && (uroCamCreatorRank == 4)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCreatedByRank5') == true) && (uroCamCreatorRank == 5)) uroCamStyle = 'hidden'; if(uroGetCBChecked('_cbHideUpdatedByMe') == true) { if(uroUserID == uroCam.attributes.updatedBy) uroCamStyle = 'hidden'; } if((uroGetCBChecked('_cbHideUpdatedByRank0') == true) && (uroCamUpdaterRank == 0)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideUpdatedByRank1') == true) && (uroCamUpdaterRank == 1)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideUpdatedByRank2') == true) && (uroCamUpdaterRank == 2)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideUpdatedByRank3') == true) && (uroCamUpdaterRank == 3)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideUpdatedByRank4') == true) && (uroCamUpdaterRank == 4)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideUpdatedByRank5') == true) && (uroCamUpdaterRank == 5)) uroCamStyle = 'hidden'; if((uroGetCBChecked('_cbHideCWLCams') == true) && (uroIsCamOnWatchList(uroCam.attributes.id) != -1)) uroCamStyle = 'hidden'; var uroCamGeometryID = uroCam.geometry.id; if(camLayer.getElementById(uroCamGeometryID) != null) { var camX = parseInt(camLayer.getElementById(uroCamGeometryID).getAttribute('x')); if(uroCamStyle == "hidden") { camLayer.getElementById(uroCamGeometryID).remove(); } } } } function uroFilterURs_onObjectsChanged() { if(uroBackfilling == false) { uroURBackfill(); uroFilterURs(); } } function uroFilterURs_onObjectsAdded() { if(uroBackfilling == false) { uroURBackfill(); uroFilterURs(); } } function uroFilterURs_onObjectsRemoved() { if(uroBackfilling == false) { uroURBackfill(); uroFilterURs(); } } function uroURBackfill_GetData(lon, lat, blockSize) { lon = parseFloat(lon); lat = parseFloat(lat); blockSize = parseFloat(blockSize); uroAddLog('Backfill square '+lon+','+lat); var xmlReq = new XMLHttpRequest(); var tURL = 'https://' + document.location.host; tURL += Waze.Config.api_base; tURL += '/Features?language=en&mapUpdateRequestFilter=0'; if(uroPracticeMode == true) tURL += '&sandbox=true'; tURL += '&bbox='+(lon)+','+(lat)+','+(lon + blockSize)+','+(lat + blockSize); xmlReq.open('GET',tURL,false); try { xmlReq.send(); uroAddLog('response '+xmlReq.status+' received'); if (xmlReq.status === 200) { var tResp = JSON.parse(xmlReq.responseText); var urCount = tResp.mapUpdateRequests.objects.length; uroAddLog(urCount+' URs loaded for backfill processing'); if(urCount == 500) { uroAddLog('WARNING - backfill data may have been pre-filtered by server'); } var backfilled = 0; for(var i=0; i<urCount; i++) { var urID = tResp.mapUpdateRequests.objects[i].id; if(W.model.mapUpdateRequests.objects[urID] == undefined) { var newUR = require('Waze/Feature/Vector/UpdateRequest'); var tUR = new newUR(tResp.mapUpdateRequests.objects[i]); var tPoint = new OpenLayers.Geometry.Point(); tPoint.x = tResp.mapUpdateRequests.objects[i].geometry.coordinates[0]; tPoint.y = tResp.mapUpdateRequests.objects[i].geometry.coordinates[1]; tPoint.transform(new OpenLayers.Projection("EPSG:4326"),new OpenLayers.Projection("EPSG:900913")); tUR.geometry = tPoint; W.model.mapUpdateRequests.put(tUR); backfilled++; } } uroAddLog(backfilled+' URs backfilled'); } else { uroAddLog('request failed (status != 200)'); } } catch(err) { uroAddLog('UR backfill request failed (exception '+err+' caught)'); } } function uroURBackfill() { if(uroGetCBChecked('_cbURBackfill') == false) { return; } var nativeURCount = Object.keys(W.model.mapUpdateRequests.objects).length; if(nativeURCount < 500) { return; } uroAddLog('exactly 500 URs loaded, possible server-side filtering requiring backfill...'); var subSize = 0.1; var vpWidth = W.map.getExtent().getWidth(); var vpHeight = W.map.getExtent().getHeight(); var vpCentre = W.map.getCenter(); var vpLL = new OpenLayers.LonLat(); var vpUR = new OpenLayers.LonLat(); vpLL.lon = vpCentre.lon - (vpWidth / 2); vpLL.lat = vpCentre.lat - (vpHeight / 2); vpUR.lon = vpCentre.lon + (vpWidth / 2); vpUR.lat = vpCentre.lat + (vpHeight / 2); vpLL = vpLL.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); vpUR = vpUR.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); vpLL.lon -= (subSize / 2); vpLL.lat -= (subSize / 2); vpUR.lon += (subSize / 2); vpUR.lat += (subSize / 2); vpLL.lon = +vpLL.lon.toFixed(1); vpLL.lat = +vpLL.lat.toFixed(1); vpUR.lon = +vpUR.lon.toFixed(1); vpUR.lat = +vpUR.lat.toFixed(1); uroBackfilling = true; for(var bfLat = vpLL.lat; bfLat <= vpUR.lat; bfLat += subSize) { for(var bfLon = vpLL.lon; bfLon <= vpUR.lon; bfLon += subSize) { uroURBackfill_GetData(bfLon, bfLat, subSize); } } uroBackfilling = false; uroFilterURs(); } function uroFilterURs() { // compatibility fix for URComments - based on code supplied by RickZabel var hasActiveURFilters = false; var urTabInputs = document.getElementById('uroCtrlURs').getElementsByTagName('input'); for(var loop = 0; loop < urTabInputs.length; loop++) { if(urTabInputs[loop].type == 'checkbox') { var ignoreCB = false; ignoreCB |= (urTabInputs[loop].id == '_cbCaseInsensitive'); ignoreCB |= (urTabInputs[loop].id == '_cbNoFilterForTaggedURs'); if((urTabInputs[loop].checked) && (ignoreCB == false)) { hasActiveURFilters = true; break; } } } sessionStorage.UROverview_hasActiveURFilters = hasActiveURFilters; if(uroFilterPreamble() == false) return; uroRefreshUpdateRequestSessions(); var selectorResolver = document.getElementById('_selectURResolverID'); var selectorCommentUser = document.getElementById('_selectURUserID'); if(uroGetCBChecked('_cbURResolverIDFilter') == false) { while(selectorResolver.options.length > 0) { selectorResolver.options.remove(0); } } if(uroGetCBChecked('_cbURUserIDFilter') == false) { while(selectorCommentUser.options.length > 0) { selectorCommentUser.options.remove(0); } } if(Object.keys(W.model.updateRequestSessions.objects).length == 0) { return; } var commenterUser = null; if(uroGetCBChecked('_cbURUserIDFilter') == true) { if(selectorCommentUser.options.length == 0) { uroUpdateUserList(); } if(selectorCommentUser.selectedOptions[0] != undefined) { commenterUser = parseInt(selectorCommentUser.selectedOptions[0].value); } } var resolverUser = null; if(uroGetCBChecked('_cbURResolverIDFilter') == true) { if(selectorResolver.options.length == 0) { uroUpdateResolverList(); } if(selectorResolver.selectedOptions[0] != undefined) { resolverUser = parseInt(selectorResolver.selectedOptions[0].value); } } uroCustomMarkerList = []; for (var urobj in W.model.mapUpdateRequests.objects) { var ureq = W.model.mapUpdateRequests.objects[urobj]; var urStyle = 'visible'; var cryosphere_link = false; var wazeauto_ur = false; var ukroadworks_ur = false; var construction_ur = false; var closure_ur = false; var event_ur = false; var note_ur = false; var hasMyComments = false; var nComments = 0; var commentDaysOld = -1; var desc = ''; if(ureq.attributes.description != null) desc = ureq.attributes.description.replace(/<\/?[^>]+(>|$)/g, ""); var ureqID = null; if(ureq.fid == null) ureqID = ureq.attributes.id; else ureqID = ureq.fid; var customType = uroGetCustomType(ureqID); if(customType == 0) ukroadworks_ur = true; else if(customType == 1) construction_ur = true; else if(customType == 2) closure_ur = true; else if(customType == 3) event_ur = true; else if(customType == 4) note_ur = true; // check UR against current session ignore list... if(uroIsOnIgnoreList(ureqID)) urStyle = 'hidden'; // check against closed/not identified filtering if enabled... if(uroGetCBChecked('_cbFilterSolved') == true) { if(ureq.attributes.resolution == 0) urStyle = 'hidden'; } if(uroGetCBChecked('_cbFilterUnidentified') == true) { if(ureq.attributes.resolution == 1) urStyle = 'hidden'; } if((ureq.attributes.resolvedOn != null) && (uroGetCBChecked('_cbFilterClosedUR') == true)) { urStyle = 'hidden'; } if((ureq.attributes.resolvedOn == null) && (uroGetCBChecked('_cbFilterOpenUR') == true)) { urStyle = 'hidden'; } if(urStyle == 'visible') { // check UR against keyword filtering if enabled... if(uroGetCBChecked('_cbURDescriptionMustBePresent') == true) { if(desc == '') urStyle = 'hidden'; } if(uroGetCBChecked('_cbURDescriptionMustBeAbsent') == true) { if(desc != '') urStyle = 'hidden'; } if(uroGetCBChecked('_cbEnableKeywordMustBePresent') == true) { if(!uroKeywordPresent(desc,uroGetElmValue('_textKeywordPresent'))) urStyle = 'hidden'; } if(uroGetCBChecked('_cbEnableKeywordMustBeAbsent') == true) { if(uroKeywordPresent(desc,uroGetElmValue('_textKeywordAbsent'))) urStyle = 'hidden'; } } if(urStyle == 'visible') { // do age-based filtering if enabled if(uroGetCBChecked('_cbEnableMinAgeFilter') == true) { if(uroGetURAge(ureq,0) < uroGetElmValue('_inputFilterMinDays')) urStyle = 'hidden'; } if(uroGetCBChecked('_cbEnableMaxAgeFilter') == true) { if(uroGetURAge(ureq,0) > uroGetElmValue('_inputFilterMaxDays')) urStyle = 'hidden'; } } if(urStyle == 'visible') { if(resolverUser != null) { if(ureq.attributes.resolvedBy != resolverUser) urStyle = 'hidden'; } } if(urStyle == 'visible') { // do comments/following filtering if(W.model.updateRequestSessions.objects[ureqID] != null) { nComments = W.model.updateRequestSessions.objects[ureqID].comments.length; var commentDaysOld = -1; if(uroGetCBChecked('_cbEnableMinCommentsFilter') == true) { if(nComments < uroGetElmValue('_inputFilterMinComments')) urStyle = 'hidden'; } if(uroGetCBChecked('_cbEnableMaxCommentsFilter') == true) { if(nComments > uroGetElmValue('_inputFilterMaxComments')) urStyle = 'hidden'; } if(nComments > 0) { var reporterIsLastCommenter = false; if(W.model.updateRequestSessions.objects[ureqID].comments[nComments-1].userID == -1) reporterIsLastCommenter = true; if(uroGetCBChecked('_cbHideIfReporterLastCommenter') == true) { if(reporterIsLastCommenter == true) urStyle = 'hidden'; } else if(uroGetCBChecked('_cbHideIfReporterNotLastCommenter') == true) { if(reporterIsLastCommenter == false) urStyle = 'hidden'; } hasMyComments = uroURHasMyComments(ureqID); if(hasMyComments == false) { if(uroGetCBChecked('_cbHideAnyComments') == true) urStyle = 'hidden'; if(uroGetCBChecked('_cbHideIfNotLastCommenter') == true) urStyle = 'hidden'; } else { if(uroGetCBChecked('_cbHideMyComments') == true) urStyle = 'hidden'; var userIsLastCommenter = false; if(W.model.updateRequestSessions.objects[ureqID].comments[nComments-1].userID == uroUserID) userIsLastCommenter = true; if(uroGetCBChecked('_cbHideIfLastCommenter') == true) { if(userIsLastCommenter == true) urStyle = 'hidden'; } else if(uroGetCBChecked('_cbHideIfNotLastCommenter') == true) { if(userIsLastCommenter == false) urStyle = 'hidden'; } } commentDaysOld = uroGetCommentAge(W.model.updateRequestSessions.objects[ureqID].comments[nComments-1]); if((uroGetCBChecked('_cbEnableCommentAgeFilter') == true) && (commentDaysOld != -1)) { if(uroGetElmValue('_inputFilterCommentDays') < commentDaysOld) urStyle = 'hidden'; } if((uroGetCBChecked('_cbEnableCommentAgeFilter2') == true) && (commentDaysOld != -1)) { if(uroGetElmValue('_inputFilterCommentDays2') > commentDaysOld) urStyle = 'hidden'; } if((commenterUser != null) && (urStyle != 'hidden')) { urStyle = 'hidden'; for(var cidx=0; cidx<nComments; cidx++) { if(W.model.updateRequestSessions.objects[ureqID].comments[cidx].userID == commenterUser) { urStyle = 'visible'; break; } } } } else { if(uroGetCBChecked('_cbURUserIDFilter') == true) { urStyle = 'hidden'; } } if(W.model.updateRequestSessions.objects[ureqID].isFollowing == true) { if(uroGetCBChecked('_cbHideMyFollowed') == true) urStyle = 'hidden'; } else { if(uroGetCBChecked('_cbHideMyUnfollowed') == true) urStyle = 'hidden'; } } } if(urStyle == 'visible') { // Test for Waze automatic URs before any others - these always (?) get inserted as General Error URs, // so we can't filter them by type... if(desc.indexOf('Waze Automatic:') != -1) { wazeauto_ur = true; } if(wazeauto_ur == true) { if(uroGetCBChecked('_cbFilterWazeAuto') == true) urStyle = 'hidden'; } else if(ukroadworks_ur == true) { if(uroGetCBChecked('_cbFilterRoadworks') == true) urStyle = 'hidden'; } else if(construction_ur == true) { if(uroGetCBChecked('_cbFilterConstruction') == true) urStyle = 'hidden'; } else if(closure_ur == true) { if(uroGetCBChecked('_cbFilterClosure') == true) urStyle = 'hidden'; } else if(event_ur == true) { if(uroGetCBChecked('_cbFilterEvent') == true) urStyle = 'hidden'; } else if(note_ur == true) { if(uroGetCBChecked('_cbFilterNote') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 6) { if(uroGetCBChecked('_cbFilterIncorrectTurn') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 7) { if (uroGetCBChecked('_cbFilterIncorrectAddress') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 8) { if(uroGetCBChecked('_cbFilterIncorrectRoute') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 9) { if(uroGetCBChecked('_cbFilterMissingRoundabout') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 10) { if(uroGetCBChecked('_cbFilterGeneralError') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 11) { if(uroGetCBChecked('_cbFilterTurnNotAllowed') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 12) { if(uroGetCBChecked('_cbFilterIncorrectJunction') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 13) { if(uroGetCBChecked('_cbFilterMissingBridgeOverpass') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 14) { if(uroGetCBChecked('_cbFilterWrongDrivingDirection') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 15) { if(uroGetCBChecked('_cbFilterMissingExit') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 16) { if(uroGetCBChecked('_cbFilterMissingRoad') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 18) { if(uroGetCBChecked('_cbFilterMissingLandmark') == true) urStyle = 'hidden'; } else if(ureq.attributes.type == 19) { if(uroGetCBChecked('_cbFilterBlockedRoad') == true) urStyle = 'hidden'; } else if(uroGetCBChecked('_cbFilterUndefined') == true) urStyle = 'hidden'; if(uroGetCBChecked('_cbInvertURFilter') == true) { if(urStyle == 'hidden') urStyle = 'visible'; else urStyle = 'hidden'; } } // filtering override for tagged URs if(uroGetCBChecked('_cbNoFilterForTaggedURs') == true) { if(ukroadworks_ur == true) { if(uroGetCBChecked('_cbFilterRoadworks') == false) urStyle = 'visible'; } else if(construction_ur == true) { if(uroGetCBChecked('_cbFilterConstruction') == false) urStyle = 'visible'; } else if(closure_ur == true) { if(uroGetCBChecked('_cbFilterClosure') == false) urStyle = 'visible'; } else if(event_ur == true) { if(uroGetCBChecked('_cbFilterEvent') == false) urStyle = 'visible'; } else if(note_ur == true) { if(uroGetCBChecked('_cbFilterNote') == false) urStyle = 'visible'; } } var urcFilteringIsActive = false; var urcCB = document.getElementById('URCommentsFilterEnabled'); if(urcCB != null) { if(urcCB.checked) { urcFilteringIsActive = true; } } // only touch marker visibility if we've got active filter settings, or if URComments is not // doing any filtering of its own if((hasActiveURFilters == true) || (urcFilteringIsActive == false)) { W.map.updateRequestLayer.markers[urobj].icon.imageDiv.style.visibility = urStyle; } if(urStyle != 'hidden') { var customMarkerType = -1; if(ukroadworks_ur == true) customMarkerType = 0; if(construction_ur == true) customMarkerType = 1; if(closure_ur == true) customMarkerType = 2; if(event_ur == true) customMarkerType = 3; if(note_ur == true) customMarkerType = 4; uroAddCustomMarkers(ureqID,customMarkerType, hasMyComments, nComments); } } uroRenderCustomMarkers(); } function uroFilterProblems() { if(uroFilterPreamble() == false) return; if((uroGetCBChecked('_cbMPNotClosedUserIDFilter') == false) && (uroGetCBChecked('_cbMPClosedUserIDFilter') == false)) { var selector = document.getElementById('_selectMPUserID'); while(selector.options.length > 0) { selector.options.remove(0); } } var solverUser = null; if((uroGetCBChecked('_cbMPNotClosedUserIDFilter') == true) || (uroGetCBChecked('_cbMPClosedUserIDFilter') == true)) { var selector = document.getElementById('_selectMPUserID'); if(selector.options.length == 0) { uroUpdateMPSolverList(); } if(selector.selectedOptions[0] != undefined) { solverUser = parseInt(selector.selectedOptions[0].value); } } for (var urobj in W.model.problems.objects) { var problem = W.model.problems.objects[urobj]; var problemStyle = 'visible'; // check problem against current session ignore list... if(uroIsOnIgnoreList(problem.attributes.id)) problemStyle = 'hidden'; // check against closed/not identified filtering if enabled... var problem_marker_img = ''; if(problem.geometry.id != null) { if(document.getElementById(problem.geometry.id) != null) { problem_marker_img = document.getElementById(problem.geometry.id).href.baseVal; if(uroGetCBChecked('_cbMPFilterSolved') == true) { if(problem_marker_img.indexOf('_solved') != -1) problemStyle = 'hidden'; } if(uroGetCBChecked('_cbMPFilterUnidentified') == true) { if(problem_marker_img.indexOf('_rejected') != -1) problemStyle = 'hidden'; } } } if(uroGetCBChecked('_cbMPFilterClosed') == true) { if(problem.attributes.open == false) { problemStyle = 'hidden'; } } if(problemStyle == 'visible') { if(solverUser != null) { if((uroGetCBChecked('_cbMPNotClosedUserIDFilter') == true) && (problem.attributes.resolvedBy == solverUser)) problemStyle = 'hidden'; if((uroGetCBChecked('_cbMPClosedUserIDFilter') == true) && (problem.attributes.resolvedBy != solverUser)) problemStyle = 'hidden'; } } if(problemStyle == 'visible') { var problemType = null; if(uroDOMHasTurnProblems) { problemType = problem.attributes.problemType; } else { problemType = problem.attributes.subType; } if(problemType == 101) { if(uroGetCBChecked('_cbMPFilterDrivingDirectionMismatch') == true) problemStyle = 'hidden'; } else if(problemType == 102) { if(uroGetCBChecked('_cbMPFilterMissingJunction') == true) problemStyle = 'hidden'; } else if(problemType == 103) { if(uroGetCBChecked('_cbMPFilterMissingRoad') == true) problemStyle = 'hidden'; } else if(problemType == 104) { if(uroGetCBChecked('_cbMPFilterCrossroadsJunctionMissing') == true) problemStyle = 'hidden'; } else if(problemType == 105) { if(uroGetCBChecked('_cbMPFilterRoadTypeMismatch') == true) problemStyle = 'hidden'; } else if(problemType == 106) { if(uroGetCBChecked('_cbMPFilterRestrictedTurn') == true) problemStyle = 'hidden'; } else if(problemType == 200) { if(uroGetCBChecked('_cbMPFilterTurnProblem') == true) problemStyle = 'hidden'; } else if(uroGetCBChecked('_cbMPFilterUnknownProblem') == true) problemStyle = 'hidden'; if(uroGetCBChecked('_cbMPFilterReopenedProblem') == true) { if((problem.attributes.open == true) && (problem.attributes.resolvedOn != null)) { problemStyle = 'hidden'; } } if(uroGetCBChecked('_cbInvertMPFilter') == true) { if(problemStyle == 'hidden') problemStyle = 'visible'; else problemStyle = 'hidden'; } if(problem.attributes.weight <= 3) { if(uroGetCBChecked('_cbMPFilterLowSeverity') == true) problemStyle = 'hidden'; } else if(problem.attributes.weight <= 7) { if(uroGetCBChecked('_cbMPFilterMediumSeverity') == true) problemStyle = 'hidden'; } else if(uroGetCBChecked('_cbMPFilterHighSeverity') == true) problemStyle = 'hidden'; } W.map.problemLayer.markers[urobj].icon.imageDiv.style.visibility = problemStyle; } if(uroDOMHasTurnProblems) { for (var urobj in W.model.turnProblems.objects) { var problem = W.model.turnProblems.objects[urobj]; var problemStyle = 'visible'; // check problem against current session ignore list... if(uroIsOnIgnoreList(problem.attributes.id)) problemStyle = 'hidden'; // check against closed/not identified filtering if enabled... var problem_marker_img = ''; if(problem.geometry.id != null) { if(document.getElementById(problem.geometry.id) != null) { problem_marker_img = document.getElementById(problem.geometry.id).href.baseVal; if(uroGetCBChecked('_cbMPFilterSolved') == true) { if(problem_marker_img.indexOf('_solved') != -1) problemStyle = 'hidden'; } if(uroGetCBChecked('_cbMPFilterUnidentified') == true) { if(problem_marker_img.indexOf('_rejected') != -1) problemStyle = 'hidden'; } } } if(uroGetCBChecked('_cbMPFilterClosed') == true) { if(problem.attributes.open == false) { problemStyle = 'hidden'; } } if(problemStyle == 'visible') { if(uroGetCBChecked('_cbMPFilterTurnProblem') == true) problemStyle = 'hidden'; if(uroGetCBChecked('_cbMPFilterReopenedProblem') == true) { if((problem.attributes.open == true) && (problem.attributes.resolvedOn != null)) { problemStyle = 'hidden'; } } if(uroGetCBChecked('_cbInvertMPFilter') == true) { if(problemStyle == 'hidden') problemStyle = 'visible'; else problemStyle = 'hidden'; } } W.map.problemLayer.markers[urobj].icon.imageDiv.style.visibility = problemStyle; } } } function uroToHex(decValue,digits) { var modifier = 1; for(var i=0; i<digits; i++) { modifier *= 16; } decValue = parseInt(decValue); decValue += modifier; var retval = decValue.toString(16); retval = retval.substr(-digits); retval = retval.toUpperCase(); return retval; } function uroFilterPreamble() { var mapviewport = document.getElementsByClassName("olMapViewport")[0]; if(mapviewport == null) { if(uroNullMapViewport == false) { uroAddLog('caught null mapviewport'); uroNullMapViewport = true; } return false; } uroNullMapViewport = false; if(uroGetCBChecked('_cbWhiteBackground')) { var customColour = '#' + uroToHex(uroGetElmValue('_inputCustomBackgroundRed'),2); customColour += uroToHex(uroGetElmValue('_inputCustomBackgroundGreen'),2); customColour += uroToHex(uroGetElmValue('_inputCustomBackgroundBlue'),2); mapviewport.style.backgroundColor = customColour; } else { mapviewport.style.backgroundColor = "#C2C2C2"; } if(uroGetCBChecked('_cbHideAMLayer')) { W.map.managedAreasLayer.setOpacity(0); } else { W.map.managedAreasLayer.setOpacity(1); } return true; } function uroFilterItems_URTabClick() { uroFilterURs(); } function uroFilterItems_MPTabClick() { uroFilterProblems(); } function uroFilterItems_PlacesTabClick() { uroFilterPlaces(); } function uroFilterItems_CamerasTabClick() { uroFilterCameras(); } function uroFilterItems_MiscTabClick() { uroFilterItems(); } function uroFilterItems() { uroFilterProblems(); uroFilterPlaces(); uroFilterCameras(); uroFilterURs(); } function uroFilterItemsOnMove() { W.map.events.unregister('mousemove',null,uroFilterItemsOnMove); uroFilterItems(); } function uroDeleteObject() { uroAddLog('delete camera ID '+uroShownFID); if(W.model.cameras.objects[uroShownFID] == null) { uroAddLog('camera object not found...'); return false; } uroRemoveCamFromWatchList(); var actionObj = require('Waze/Action/DeleteObject'); deleteAction = new actionObj(W.model.cameras.objects[uroShownFID], null); W.model.actionManager.add(deleteAction); uroExitPopup(); return false; } function uroGetUserNameAndRank(userID) { var userName; var userLevel; if(W.model.users.objects[userID] != undefined) { userName = W.model.users.objects[userID].userName; if(userName == undefined) { userName = userID; } userLevel = W.model.users.objects[userID].rank + 1; } else { userName = userID; userLevel = '?'; } return userName + ' (' + userLevel + ')'; } function uroCheckCommentsForKeyword(idSrc, keyword) { var ursObj = W.model.updateRequestSessions.objects[idSrc]; if(typeof(ursObj) == 'undefined') return false; if(ursObj.comments.length == 0) return false; for(var idx=0; idx<ursObj.comments.length; idx++) { if(ursObj.comments[idx].text.indexOf(keyword) != -1) { return true; } } return false; } function uroGetCustomMarkerIdx(customType) { if(customType == 0) return 3; if(customType == 1) return 3; if(customType == 2) return 5; if(customType == 3) return 7; if(customType == 4) return 9; return -1; } function uroGetCustomType(idSrc) { var ureq = W.model.mapUpdateRequests.objects[idSrc]; var desc = ''; if(ureq.attributes.description != null) { desc = ureq.attributes.description; if(desc.indexOf('[ROADWORKS]') != -1) return 0; if(desc.indexOf('[CONSTRUCTION]') != -1) return 1; if(desc.indexOf('[CLOSURE]') != -1) return 2; if(desc.indexOf('[EVENT]') != -1) return 3; if(desc.indexOf('[NOTE]') != -1) return 4; } if(uroCheckCommentsForKeyword(idSrc,'[ROADWORKS]')) return 0; if(uroCheckCommentsForKeyword(idSrc,'[CONSTRUCTION]')) return 1; if(uroCheckCommentsForKeyword(idSrc,'[CLOSURE]')) return 2; if(uroCheckCommentsForKeyword(idSrc,'[EVENT]')) return 3; if(uroCheckCommentsForKeyword(idSrc,'[NOTE]')) return 4; return -1; } function uroFormatRestriction(restObj) { var retval = '<tr>'; retval += '<td style="text-align:center;">'; if((restObj.days & 1) == 1) retval += 'S'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 2) == 2) retval += 'M'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 4) == 4) retval += 'T'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 8) == 8) retval += 'W'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 16) == 16) retval += 'T'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 32) == 32) retval += 'F'; else retval += '-'; retval += '</td><td style="text-align:center;">'; if((restObj.days & 64) == 64) retval += 'S'; else retval += '-'; retval += '</td><td>'; if(restObj.fromDate == null) retval += 'All dates'; else retval += restObj.fromDate+' to '+restObj.toDate; retval += '</td><td>'; if(restObj.allDay == true) retval += 'All day'; else retval += restObj.fromTime+' to '+restObj.toTime; retval += '</td><td>'; if(restObj.allVehicleTypes == restObj.vehicleTypes) retval += 'All vehicles'; else retval += 'Some vehicles'; retval += '</td><td>'; var desc = restObj.description.replace(/<\/?[^>]+(>|$)/g, ""); desc = uroClickify(desc); retval += desc; retval += '</td></tr>'; return retval; } function uroHidePopup() { uroDiv.style.visibility = 'hidden'; uroPopupShown = false; uroPopupTimer = -2; uroShownFID = -1; } function uroRecentreSessionOnUR() { W.map.updateRequestLayer.markers[uroShownFID].icon.imageDiv.click(); W.map.moveTo(W.map.updateRequestLayer.markers[uroShownFID].lonlat, 5); uroHidePopup(); return false; } function uroRecentreSessionOnMP() { W.map.problemLayer.markers[uroShownFID].icon.imageDiv.click(); W.map.moveTo(W.map.problemLayer.markers[uroShownFID].lonlat, 5); uroHidePopup(); return false; } function uroRecentreSessionOnPUR() { W.map.placeUpdatesLayer.markers[uroShownFID].icon.imageDiv.click() W.map.moveTo(W.map.placeUpdatesLayer.markers[uroShownFID].lonlat, 5); uroHidePopup(); return false; } function uroParsePxString(pxString) { return parseInt(pxString.split("px")[0]); } function uroStackListObj(fid,x,y) { this.fid = fid; this.x = uroTypeCast(x); this.y = uroTypeCast(y); } function uroRestackMarkers() { if(uroStackList.length == 0) return; if(uroStackType == 1) markerCollection = W.map.updateRequestLayer.markers; else if(uroStackType == 2) markerCollection = W.map.problemLayer.markers; else if(uroStackType == 3) markerCollection = W.map.placeUpdatesLayer.markers; for(var idx=0; idx<uroStackList.length; idx++) { var orig_x = uroStackList[idx].x + 'px'; var orig_y = uroStackList[idx].y + 'px'; var fid = uroStackList[idx].fid; if(markerCollection[fid] != undefined) { markerCollection[fid].icon.imageDiv.style.left = orig_x; markerCollection[fid].icon.imageDiv.style.top = orig_y; } } uroStackList = new Array(); uroUnstackedMasterID = null; uroStackType = null; } function uroIsIDAlreadyUnstacked(idSrc) { if(uroStackList.length == 0) return false; for(var idx=0; idx<uroStackList.length; idx++) { if(uroStackList[idx].fid == idSrc) return true; } return false; } function uroCheckStacking(stackType, masterID, unstackedX, unstackedY) { if(W.map.getZoom() < uroGetElmValue('_inputUnstackZoomLevel')) return; if(uroIsIDAlreadyUnstacked(masterID) == true) return; uroAddLog('checking for marker stack, type '+stackType+'...'); var stackList = new Array(); var threshSquared = uroGetElmValue('_inputUnstackSensitivity'); threshSquared *= threshSquared; if(stackType == 1) markerCollection = W.map.updateRequestLayer.markers; else if(stackType == 2) markerCollection = W.map.problemLayer.markers; else if(stackType == 3) markerCollection = W.map.placeUpdatesLayer.markers; for(var marker in markerCollection) { testMarkerObj = markerCollection[marker]; if(testMarkerObj.icon.imageDiv.style.visibility != 'hidden') { if(testMarkerObj.id != masterID) { var xdiff = unstackedX - uroParsePxString(markerCollection[testMarkerObj.id].icon.imageDiv.style.left); var ydiff = unstackedY - uroParsePxString(markerCollection[testMarkerObj.id].icon.imageDiv.style.top); var distSquared = ((xdiff * xdiff) + (ydiff * ydiff)); if(distSquared < threshSquared) { stackList.push(testMarkerObj.id); } } } } if(stackList.length > 0) { uroAddLog('markers are stacked!'); if(uroUnstackedMasterID != masterID) { uroAddLog('unstacked ID mismatch, relocating markers...'); uroRestackMarkers(); uroStackType = stackType; uroUnstackedMasterID = masterID; uroStackList = new Array(); // push the highlighted marker onto the stacklist so uroIsIDAlreadyUnstacked() will return true uroStackList.push(new uroStackListObj(masterID,unstackedX,unstackedY)); for(var shoveIdx=0; shoveIdx < stackList.length; shoveIdx++) { var fid = stackList[shoveIdx]; var x = uroParsePxString(markerCollection[fid].icon.imageDiv.style.left); var y = uroParsePxString(markerCollection[fid].icon.imageDiv.style.top); // store the unstacked marker positions so they can be reinstated later uroStackList.push(new uroStackListObj(fid,x,y)); unstackedX += 10; unstackedY -= 30; markerCollection[fid].icon.imageDiv.style.left = unstackedX + 'px'; markerCollection[fid].icon.imageDiv.style.top = unstackedY + 'px'; } // hide other markers to prevent confusion with the unstacked markers for(var marker in markerCollection) { var toHideID = markerCollection[marker].id; if(uroIsIDAlreadyUnstacked(toHideID) == false) { markerCollection[toHideID].icon.imageDiv.style.visibility = 'hidden'; } } } } else { uroRestackMarkers(); } } function uroNewLookHighlightedItemsCheck(e) { if((uroMouseIsDown) && (e.buttons == 0)) { uroAddLog('trapped erroneous mousedown state'); uroMouseIsDown = false; } if(uroMouseIsDown) { return; } if(document.getElementsByClassName('panel')[0] != undefined) { return; } if(W.geometryEditing.activeEditor != null) { uroHidePopup(); return; } if(OpenLayers == null) { if(uroNullOpenLayers == false) { uroAddLog('caught null OpenLayers'); uroNullOpenLayers = true; } return; } uroNullOpenLayers = false; var rc = document.getElementById(uroRootContainer); if(rc == null) { if(uroNullRootContainer == false) { uroAddLog('caught null rootContainer'); uroNullRootContainer = true } return; } uroNullRootContainer = false; if(W.map.updateRequestLayer == null) { if(uroNullURLayer == false) { uroAddLog('caught null UR layer'); uroNullURLayer = true; } return; } uroNullURLayer = false; if(W.map.problemLayer == null) { if(uroNullProblemLayer == false) { uroAddLog('caught null problem layer'); uroNullProblemLayer = true; } return; } uroNullProblemLayer = false; var mouseX = e.pageX - document.getElementById('map').getBoundingClientRect().left; var mouseY = e.pageY - document.getElementById('map').getBoundingClientRect().top; var currentItems = rc.getElementsByTagName('g'); var result = ''; var rw; var rh; var popup_loc = new OpenLayers.LonLat(0,0); var objHasIgnoreLink = false; var objHasDeleteLink = false; var popupXOffset = uroParsePxString(window.getComputedStyle(document.getElementById('sidebar')).getPropertyValue("width")); var popupYOffset = document.getElementsByClassName('waze-header')[0].clientHeight; var uroPopupX = mouseX + popupXOffset; var uroPopupY = mouseY + popupYOffset; var objHasIgnoreLink = false; var objHasDeleteLink = false; var objHasAddWatchLink = false; var objHasRemoveWatchLink = false; var objHasUpdateWatchLink = false; var objHasRecentreSessionLink = false; var newPopupType = null; // popup for segment restrictions if(uroGetCBChecked('_cbInhibitSegPopup') == false) { for(var slIdx=0; slIdx < W.map.segmentLayer.features.length; slIdx++) { if(W.map.segmentLayer.features[slIdx].renderIntent == 'highlight') { var doPopUp = false; if(W.map.segmentLayer.features[slIdx].fid == null) segObj = W.map.segmentLayer.features[slIdx].model; else segObj = W.map.segmentLayer.features[slIdx]; result += '<table cellpadding=4 border=1">'; if(segObj.attributes.fwdRestrictions.length > 0) { doPopUp = true; result += '<tr><td colspan=11><b>A-B restrictions:</b></td></tr>'; for(var idx = 0; idx < segObj.attributes.fwdRestrictions.length; idx++) { restObj = segObj.attributes.fwdRestrictions[idx]; result += uroFormatRestriction(restObj); } } if (segObj.attributes.revRestrictions.length > 0) { doPopUp = true; result += '<tr><td colspan=11><b>B-A restrictions:</b></td></tr>'; for(var idx = 0; idx < segObj.attributes.revRestrictions.length; idx++) { restObj = segObj.attributes.revRestrictions[idx]; result += uroFormatRestriction(restObj); } } result += '</table>'; if(W.map.closuresMarkerLayer.getVisibility() == true) { result += '<table cellpadding=4 border=1" width="100%">'; if(segObj.attributes.hasClosures == true) { var hasFwd = false; var hasRev = false; for(var rc in W.model.roadClosures.objects) { rcObj = W.model.roadClosures.objects[rc]; if(rcObj.segID == segObj.attributes.id) { if(rcObj.forward == true) { if(hasFwd == false) { result += '<tr><td colspan=3><b>A-B closures:</b></td></tr>'; hasFwd = true; } if(rcObj.active == true) { result += '<tr>'; } else { result += '<tr bgcolor="#C0C0C0">'; } result += '<td>' + rcObj.startDate + ' to ' + rcObj.endDate + '</td>'; result += '<td>' + rcObj.provider + '</td>'; result += '<td>' + rcObj.reason + '</td>'; result += '</td></tr>'; } else { hasRev = true; } } } if(hasRev == true) { result += '<tr><td colspan=3><b>B-A closures:</b></td></tr>'; for(var rc in W.model.roadClosures.objects) { rcObj = W.model.roadClosures.objects[rc]; if(rcObj.segID == segObj.attributes.id) { if(rcObj.forward == false) { if(rcObj.active == true) { result += '<tr>'; } else { result += '<tr bgcolor="#C0C0C0">'; } result += '<td>' + rcObj.startDate + ' to ' + rcObj.endDate + '</td>'; result += '<td>' + rcObj.provider + '</td>'; result += '<td>' + rcObj.reason + '</td>'; result += '</td></tr>'; } } } } if((hasFwd == true) || (hasRev == true)) { doPopUp = true; } } result += '</table>'; } if(doPopUp == true) { if(segObj.attributes.id == null) uroFID = segObj.id; else uroFID = segObj.attributes.id; newPopupType = 'segment_restriction'; } break; } } } // popup for restricted turns /* if(newPopupType == null) { var idSrc = null; //if(uroGetCBChecked('_cbInhibitTurnsPopup') == false) { if(W.map.layers[uroTurnsLayerIdx].markers.length > 0) { for(var marker in W.map.layers[uroTurnsLayerIdx].markers) { markerObj = W.map.layers[uroTurnsLayerIdx].markers[marker]; markerImg = window.getComputedStyle(markerObj.icon.imageDiv.childNodes[0]).getPropertyValue("background-image"); markerPos = window.getComputedStyle(markerObj.icon.imageDiv.childNodes[0]).getPropertyValue("background-position"); markerPos = markerPos.split(' '); markerPos = parseInt(markerPos[1].substr(0,markerPos[1].length-2)); var hovered = false; if(markerImg.indexOf('turns-s32af5d033c.png') != -1) { if(markerPos == -235) { hovered = true; } } if(hovered == true) { uroAddLog('hover over turn marker '+marker); break; } } } } } */ // popup for landmarks if((newPopupType == null) && (uroGetCBChecked('_cbInhibitLandmarkPopup') == false)) { uroPlaceSelected = false; for(var llFeatureIdx=0; llFeatureIdx < W.map.landmarkLayer.features.length; llFeatureIdx++) { var renderIntent = W.map.landmarkLayer.features[llFeatureIdx].renderIntent; if(renderIntent == 'highlight') { if(W.map.landmarkLayer.features[llFeatureIdx].fid == null) venueObj = W.map.landmarkLayer.features[llFeatureIdx].model; else venueObj = W.map.landmarkLayer.features[llFeatureIdx]; if(venueObj.geometry.id.indexOf('.Point_') != -1) { // override popup placement for point places var placeXY = W.map.getPixelFromLonLat(venueObj.geometry.toLonLat()); uroPopupX = placeXY.x + popupXOffset + 10; uroPopupY = placeXY.y + popupYOffset + 40; } result += '<b>'; if(venueObj.attributes.name == '') result += 'Unnamed landmark'; else result += venueObj.attributes.name; result += '</b><br>'; for(var idx = 0; idx < venueObj.attributes.categories.length; idx++) { result += I18n.translations[I18n.locale].venues.categories[venueObj.attributes.categories[idx]] + '<br>'; } if(venueObj.attributes.residential == true) { result += '<i>Private Place</i>'; } newPopupType = 'venue'; if(venueObj.attributes.id == null) uroFID = venueObj.id; else uroFID = venueObj.attributes.id; break; } else if(renderIntent == 'select') { uroPlaceSelected = true; } } } // look for URs, place updates and problems if(newPopupType == null) { var idSrc = null; var divIdx = -1; var isUR = false; var isProblem = false; var isTurnProb = false; var isPlaceUpdate = false; if(uroGetCBChecked('_cbInhibitURPopup') == false) { var hovered = false; for(var marker in W.map.updateRequestLayer.markers) { markerObj = W.map.updateRequestLayer.markers[marker]; markerImg = markerObj.icon.$div.css('background-image'); markerPos = markerObj.icon.$div.css('background-position'); markerPos = markerPos.split(' '); markerPos = parseInt(markerPos[1].substr(0,markerPos[1].length-2)); var urIDSrc = markerObj.id; if(markerImg.indexOf('problems-s8f369ca968.png') != -1) { if((markerPos == -403) || (markerPos == -483) || (markerPos == -563) || (markerPos == -643)) { hovered = true; uroAddLog('UR image type 1'); } } else if(markerImg.indexOf('problems-se224ab677e.png') != -1) { if((markerPos == -40) || (markerPos == -160) || (markerPos == -200) || (markerPos == -240)) { hovered = true; uroAddLog('UR image type 2'); } } else { if(markerPos > -200) { hovered = true; uroAddLog('UR image type 3'); } } if(hovered == true) { isUR = true; newPopupType = 'ur'; uroAddLog('hover over UR ID '+urIDSrc); var unstackedX = uroParsePxString(W.map.updateRequestLayer.markers[urIDSrc].icon.imageDiv.style.left); var unstackedY = uroParsePxString(W.map.updateRequestLayer.markers[urIDSrc].icon.imageDiv.style.top); // override popup base position uroPopupX = unstackedX + popupXOffset + 6; uroPopupY = unstackedY + popupYOffset + 46; uroPopupX -= uroParsePxString(W.map.segmentLayer.div.style.left); uroPopupY -= uroParsePxString(W.map.segmentLayer.div.style.top); // check for stacking... if(uroShownFID != idSrc) { uroCheckStacking(1,urIDSrc, unstackedX, unstackedY); } if(urIDSrc != uroCustomMarkerFID) { if(uroCustomMarkerFID != null) { var customIdx = uroGetCustomMarkerIdx(uroGetCustomType(uroCustomMarkerFID)); uroChangeCustomMarkers(uroCustomMarkerFID,false,customIdx); uroCustomMarkerFID = null; } var customIdx = uroGetCustomMarkerIdx(uroGetCustomType(urIDSrc)); if(customIdx != -1) { uroCustomMarkerFID = urIDSrc; uroChangeCustomMarkers(urIDSrc,hovered,customIdx); } } idSrc = urIDSrc; break; } } if((hovered == false) && (uroStackType == 1)) { uroRestackMarkers(); uroFilterURs(); } if((idSrc == null) && (uroCustomMarkerFID != null)) { var customIdx = uroGetCustomMarkerIdx(uroGetCustomType(uroCustomMarkerFID)); uroChangeCustomMarkers(uroCustomMarkerFID,false, customIdx); uroCustomMarkerFID = null; } } if((newPopupType == null) && (uroGetCBChecked('_cbInhibitPUPopup') == false)) { var hovered = false; for(var marker in W.map.placeUpdatesLayer.markers) { markerObj = W.map.placeUpdatesLayer.markers[marker]; markerImg = markerObj.icon.$div.css('background-image'); markerPos = markerObj.icon.$div.css('background-position'); markerPos = markerPos.split(' '); markerPos = parseInt(markerPos[1].substr(0,markerPos[1].length-2)); if(markerImg.indexOf('placeUpdates-sb30471988c.png') != -1) { // absolute offsets: 0 = new place, -120 = flagged, -240 = new photo, -360 = updated details // relative offsets: 0 = green, -40 = highlighted, -80 = default if(((markerPos + 40) % 120) == 0) { hovered = true; uroAddLog('PUR marker type 1'); } } else if(markerImg.indexOf('placeUpdates-s2e8d9c5ce4.png') != -1) { if ( (markerObj.icon.$div.css("filter") == "brightness(110%)") || (markerObj.icon.$div.css("webkit-filter") == "brightness(1.1)") ) { hovered = true; uroAddLog('PUR marker type 2'); } } if(hovered == true) { var idSrc = markerObj.id; var unstackedX = uroParsePxString(W.map.placeUpdatesLayer.markers[idSrc].icon.imageDiv.style.left); var unstackedY = uroParsePxString(W.map.placeUpdatesLayer.markers[idSrc].icon.imageDiv.style.top); // override popup base position uroPopupX = unstackedX + popupXOffset + 6; uroPopupY = unstackedY + popupYOffset + 46; uroPopupX -= uroParsePxString(W.map.segmentLayer.div.style.left); uroPopupY -= uroParsePxString(W.map.segmentLayer.div.style.top); if(uroShownFID != idSrc) { // check for stacking... uroCheckStacking(3,idSrc, unstackedX, unstackedY); } isPlaceUpdate = true; newPopupType = 'pur'; uroAddLog('hover over placeUpdate ID '+idSrc); break; } } if((hovered == false) && (uroStackType == 3)) { uroRestackMarkers(); uroFilterPlaces(); } } if((newPopupType == null) && (uroGetCBChecked('_cbInhibitMPPopup') == false)) { var hovered = false; for(var marker in W.map.problemLayer.markers) { markerObj = W.map.problemLayer.markers[marker]; markerImg = markerObj.icon.$div.css('background-image'); markerPos = markerObj.icon.$div.css('background-position'); markerPos = markerPos.split(' '); markerPos = parseInt(markerPos[1].substr(0,markerPos[1].length-2)); if(markerImg.indexOf('problems-s8f369ca968.png') != -1) { if((markerPos == -65) || (markerPos == -145) || (markerPos == -225) || (markerPos == -305)) { hovered = true; uroAddLog('Problem image type 1'); } } else if(markerImg.indexOf('problems-se224ab677e.png') != -1) { if((markerPos == -320) || (markerPos == -560) || (markerPos == -520) || (markerPos == -440)) { hovered = true; uroAddLog('Problem image type 2'); } } else { if(markerPos > -200) { hovered = true; uroAddLog('Problem image type 3'); } } if(hovered == true) { var idSrc = null; if(markerObj.model.fid == null) idSrc = markerObj.id; else idSrc = markerObj.model.fid; var unstackedX = uroParsePxString(W.map.problemLayer.markers[idSrc].icon.imageDiv.style.left); var unstackedY = uroParsePxString(W.map.problemLayer.markers[idSrc].icon.imageDiv.style.top); // override popup base position uroPopupX = unstackedX + popupXOffset + 6; uroPopupY = unstackedY + popupYOffset + 46; uroPopupX -= uroParsePxString(W.map.segmentLayer.div.style.left); uroPopupY -= uroParsePxString(W.map.segmentLayer.div.style.top); // check for stacking... if(uroShownFID != idSrc) { uroCheckStacking(2,idSrc, unstackedX, unstackedY); } isProblem = true; newPopupType = 'map_problem'; uroAddLog('hover over problem ID '+idSrc); break; } } if((hovered == false) && (uroStackType == 2)) { uroRestackMarkers(); uroFilterProblems(); } } if (idSrc != null) { var ureq = null; if(isUR) ureq = W.model.mapUpdateRequests.objects[idSrc]; else if(isProblem) { ureq = W.model.problems.objects[idSrc]; if(ureq == undefined) { if(uroDOMHasTurnProblems) { var ureq = W.model.turnProblems.objects[idSrc]; if(ureq != undefined) isTurnProb = true; } } } else if(isPlaceUpdate) ureq = W.map.placeUpdatesLayer.markers[idSrc].model; var ureqID = null; if(ureq.fid != null) ureqID = ureq.fid; else if(ureq.id != null) ureqID = ureq.id; else if(ureq.attributes.id != null) ureqID = ureq.attributes.id; uroFID = ureqID; } else { uroFID = -1; } //if((uroFID != uroShownFID) && (uroFID != -1)) if(uroFID != -1) { if(isUR) { uroAddLog('building popup for UR '+idSrc); result = '<b>Update Request ('+idSrc+'): ' + I18n.translations[I18n.locale].update_requests.types[ureq.attributes.type] + '</b><br>'; if(ureq.attributes.description != null) { var desc = ureq.attributes.description.replace(/<\/?[^>]+(>|$)/g, ""); if(desc != "null") { desc = uroClickify(desc); result += desc + '<br>'; } } var uroDaysOld = uroGetURAge(ureq,0); if(uroDaysOld != -1) { result += '<i>Submitted ' + uroParseDaysAgo(uroDaysOld) + ' '; if(ureq.attributes.guestUserName != null) { result += 'via Livemap'; if(ureq.attributes.guestUserName != '') { result += ' by '+ureq.attributes.guestUserName.replace(/<\/?[^>]+(>|$)/g, ""); } } result += '</i>'; } if(ureq.attributes.resolvedOn != null) { var uroDaysResolved = uroGetURAge(ureq,1); if(uroDaysResolved != -1) { result += '<br><i>Closed ('; if(ureq.attributes.resolution == 0) result += 'solved'; else if(ureq.attributes.resolution == 1) result += 'not identified'; else result += 'unknown'; result += ') ' + uroParseDaysAgo(uroDaysResolved) + ' '; if(ureq.attributes.resolvedBy != null) { result += ' by '+uroGetUserNameAndRank(ureq.attributes.resolvedBy); } result += '</i>'; } } if(W.model.updateRequestSessions.objects[ureqID] != null) { var hasMyComments = uroURHasMyComments(ureqID); var nComments = W.model.updateRequestSessions.objects[ureqID].comments.length; result += '<br>' + nComments + ' comment'; if(nComments != 1) result += 's'; if((hasMyComments == false) && (nComments > 0)) result += ' (none by me)'; if(nComments > 0) { var commentDaysOld = uroGetCommentAge(W.model.updateRequestSessions.objects[ureqID].comments[nComments-1]); if(commentDaysOld != -1) { result += ', last update '+uroParseDaysAgo(commentDaysOld); } } } } else if(isProblem) { uroAddLog('building popup for problem '+idSrc); if(isTurnProb) result = '<b>Turn Problem ('+idSrc+'): ' + I18n.translations[I18n.locale].problems.types["turn"].title; else { result = '<b>Map Problem ('+idSrc+'): '; var problemType = null; if(uroDOMHasTurnProblems) { problemType = ureq.attributes.problemType; } else { problemType = ureq.attributes.subType; } if(I18n.translations[I18n.locale].problems.types[problemType] == undefined) result += 'Unknown problem type ('+problemType+')'; else result += I18n.translations[I18n.locale].problems.types[problemType].title; } result += '</b><br>'; if(ureq.attributes.resolvedOn != null) { var uroDaysResolved = uroGetURAge(ureq,1); if(uroDaysResolved != -1) { result += '<br><i>Closed ' + uroParseDaysAgo(uroDaysResolved) + ' '; if(ureq.attributes.resolvedBy != null) { result += ' by '+uroGetUserNameAndRank(ureq.attributes.resolvedBy); } if((ureq.attributes.open == true) && (ureq.attributes.resolvedOn != null)) { result += '<br>Reopened by Waze'; } result += '</i>'; } } } else if(isPlaceUpdate) { uroAddLog('building popup for placeUpdate '+idSrc); result = '<b>'; if(ureq.attributes.name == '') result += 'Unnamed landmark'; else result += ureq.attributes.name; result += '</b><br>'; for(var idx = 0; idx < ureq.attributes.categories.length; idx++) { result += I18n.translations[I18n.locale].venues.categories[ureq.attributes.categories[idx]]; } if(ureq.attributes.residential == true) { result += '<br><i>Private Place</i>'; } var daysOld = uroGetPURAge(ureq); if(daysOld != -1) { result += '<br><i>Submitted '+uroParseDaysAgo(daysOld)+'</i>'; } } // add "open new WME tab" link var urPos=new OpenLayers.LonLat(); if(isPlaceUpdate) { urPos=ureq.geometry.bounds.centerLonLat.clone(); } else { urPos.lon=ureq.geometry.x; urPos.lat=ureq.geometry.y; } urPos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); var urLink = document.location.href; urLayers = '&layers='+W.map.mapState.getLayerVisibilityBitmask(); urLink = urLink.substr(0,urLink.indexOf('?zoom')); urLink += '?zoom=5&lat='+urPos.lat+'&lon='+urPos.lon+urLayers; if(isUR) urLink += '&mapUpdateRequest='+idSrc; else if(isTurnProb) urLink += '&showturn='+idSrc+'&endshow'; else if(isProblem) urLink += '&mapProblem='+idSrc; else if(isPlaceUpdate) urLink += '&showpur='+idSrc+'&endshow'; result += '<hr><ul><li><a href="'+urLink+'" target="_urTab">Open in new tab</a> - '; //result += '<a href="'+urLink+'">open in current tab</a>'; result += '<a href="#" id="_recentreSession">centre in current tab</a>'; objHasRecentreSessionLink = true; // add "open new livemap tab" link var lmLink = null; if(document.getElementsByClassName("waze-header-menu").length == 0) { uroAddLog('Livemap link in livemap element'); lmLink = document.getElementById('livemap').href; } else { uroAddLog('Livemap link in header menu, locating...'); var menuItems = document.getElementsByClassName("waze-header-menu")[0]; for(var miloop = 0; miloop<menuItems.childElementCount; miloop++) { if(menuItems.children[miloop].innerHTML.indexOf('livemap') != -1) { uroAddLog('found link in menu entry '+miloop); lmLink = menuItems.children[miloop].getElementsByTagName('a')[0].href; uroAddLog(lmLink); } } } if(lmLink != null) { var zpos = lmLink.indexOf('?'); if(zpos > -1) lmLink = lmLink.substr(0,zpos); lmLink += '?zoom=17&lat='+urPos.lat+'&lon='+urPos.lon+'&layers=BTTTT'; result += '<li><a href="'+lmLink+'" target="_lmTab">Open in new livemap tab</a>'; } if(!isPlaceUpdate) { // add "ignore for this session" link result += '<li><a href="#" id="_addtoignore">Hide for this session</a></ul>'; objHasIgnoreLink = true; } } } // look for cameras if((newPopupType == null) && (uroGetCBChecked('_cbInhibitCamPopup') == false)) { for(var clFeatureIdx = 0; clFeatureIdx < W.map.camerasLayer.features.length; clFeatureIdx++) { if(W.map.camerasLayer.features[clFeatureIdx].renderIntent == 'highlight') { if(W.map.camerasLayer.features[clFeatureIdx].fid == null) ureq = W.map.camerasLayer.features[clFeatureIdx].model; else ureq = W.map.camerasLayer.features[clFeatureIdx]; var ureqID = null; if(ureq.fid == null) ureqID = ureq.attributes.id; else ureqID = ureq.fid; // test isSelected() so that we only do overview data on cameras that are being hovered over if(ureq.isSelected() == false) { // override popup base position var markerXY = W.map.getPixelFromLonLat(ureq.geometry.toLonLat()); uroPopupX = markerXY.x + popupXOffset + 20; uroPopupY = markerXY.y + popupYOffset + 60; newPopupType = 'camera'; uroFID = ureqID; uroAddLog('generating popup for camera '+uroFID); result += '<b>Camera: ' + ureq.TYPES[ureq.attributes.type] + '</b><br>'; result += 'ID: '+uroFID+'<br>'; result += 'Created by '; if(W.model.users.get(ureq.attributes.createdBy) != null) { userID = ureq.attributes.createdBy; result += uroGetUserNameAndRank(userID); } else result += 'unknown'; result += ', '; var camAge = uroGetCameraAge(ureq,1); if(camAge != -1) { result += uroParseDaysAgo(camAge); } else result += 'unknown days ago'; result += '<br>Updated by '; if(W.model.users.get(ureq.attributes.updatedBy) != null) { userID = ureq.attributes.updatedBy; userName = W.model.users.objects[userID].userName; userLevel = W.model.users.objects[userID].rank + 1; result += userName + ' (' + userLevel + ')'; } else result += 'unknown'; result += ', '; var camAge = uroGetCameraAge(ureq,0); if(camAge != -1) { result += uroParseDaysAgo(camAge); } else result += 'unknown days ago'; result += '<br>Speed data: '; if(ureq.attributes.speed != null) { result += ureq.attributes.speed + 'km/h'; var speedInMPH = Math.round(ureq.attributes.speed / 1.609); result += ' (' + speedInMPH + 'mph'; if((speedInMPH % 10) != 0) result += ' - not valid?'; result += ')</i>'; } else result += 'unknown'; var uid = W.model.loginManager.getLoggedInUser().id; result += '<hr><ul>'; if(uroIsCamOnWatchList(uroFID) != -1) { result += '<li><a href="#" id="_updatewatchlist">Update watchlist entry</a>'; result += '<li><a href="#" id="_removefromwatchlist">Remove from watchlist</a>'; objHasUpdateWatchLink = true; objHasRemoveWatchLink = true; } else { result += '<li><a href="#" id="_addtowatchlist">Add to watchlist</a>'; objHasAddWatchLink = true; } if(ureq.attributes.permissions != 0) { result += '<li><a href="#" id="_deleteobject">Delete Camera</a>'; objHasDeleteLink = true; } result += '</ul>'; } break; } } } if(newPopupType != null) { if((uroFID != uroShownFID) || (newPopupType != uroShownPopupType)) { if(uroFID != uroShownFID) uroAddLog('FID mismatch, show popup: '+uroFID+'/'+uroShownFID); else uroAddLog('Popup type mismatch: '+newPopupType+'/'+uroShownPopupType); uroShownFID = uroFID; uroShownPopupType = newPopupType; uroPopupShown = false; } if(uroPopupShown == false) { uroAddLog('display popup at '+uroPopupX+','+uroPopupY); uroPopupShown = true; uroDiv.innerHTML = result; if((uroFID != -1) && (objHasIgnoreLink == true)) { uroAddEventListener('_addtoignore','click', uroAddToIgnoreList, true); } if(objHasDeleteLink == true) { uroAddEventListener('_deleteobject','click', uroDeleteObject, true); } if(objHasRemoveWatchLink == true) { uroAddEventListener('_removefromwatchlist','click', uroRemoveCamFromWatchList, true); } if(objHasAddWatchLink == true) { uroAddEventListener('_addtowatchlist','click', uroAddCamToWatchList, true); } if(objHasUpdateWatchLink == true) { uroAddEventListener('_updatewatchlist','click', uroUpdateCamWatchList, true); } if(objHasRecentreSessionLink == true) { if(isUR) uroAddEventListener('_recentreSession','click', uroRecentreSessionOnUR, true); else if((isProblem)||(isTurnProb)) uroAddEventListener('_recentreSession','click', uroRecentreSessionOnMP, true); else if(isPlaceUpdate) uroAddEventListener('_recentreSession','click', uroRecentreSessionOnPUR, true); } rw = parseInt(uroDiv.clientWidth); rh = parseInt(uroDiv.clientHeight); if(rw > (window.innerWidth / 2)) rw = (window.innerWidth / 2); if(rh > (window.innerHeight / 2)) rh = (window.innerHeight / 2); if((uroPopupX + rw) > window.innerWidth) { uroPopupX -= (rw + 20); if(uroPopupX < 0) uroPopupX = 0; } if((uroPopupY + rh) > window.innerHeight) { uroPopupY -= (rh + 10); if(uroPopupY < 0) uroPopupY = 0; } uroDiv.style.top = uroPopupY+'px'; uroDiv.style.left = uroPopupX+'px'; uroDiv.clientWidth = rw+'px'; uroDiv.clientHeight = rh+'px'; uroDiv.style.visibility = 'visible'; } uroPopupTimer = -1; } else { if(uroPopupTimer == -1) { uroPopupTimer = uroGetElmValue('_inputPopupEntryTimeout'); } } } function uroRestyleWMETabs() { var navTabs = document.getElementById(uroUserTabId).children[1].children; for(var loop = 0; loop<navTabs.length; loop++) { navTabs[loop].children[0].style.padding = "4px"; } setTimeout(uroRestyleWMETabs,1000); } function uroExclusiveCB() { cbChecked = uroGetCBChecked(this.id); if(cbChecked == true) { if(this.id == '_cbHideMyComments') uroGetCBChecked('_cbHideAnyComments') = false; if(this.id == '_cbHideAnyComments') uroGetCBChecked('_cbHideMyComments') = false; if(this.id == '_cbHideIfLastCommenter') uroGetCBChecked('_cbHideIfNotLastCommenter') = false; if(this.id == '_cbHideIfNotLastCommenter') uroGetCBChecked('_cbHideIfLastCommenter') = false; if(this.id == '_cbHideIfReporterLastCommenter') uroGetCBChecked('_cbHideIfReporterNotLastCommenter') = false; if(this.id == '_cbHideIfReporterNotLastCommenter') uroGetCBChecked('_cbHideIfReporterLastCommenter') = false; } } function uroGetAMs(e) { var amList = ''; if(W.map.managedAreasLayer.getVisibility() == true) { var mouseX = e.pageX - document.getElementById('map').getBoundingClientRect().left; var mouseY = e.pageY - document.getElementById('map').getBoundingClientRect().top - document.getElementById('toolbar').clientHeight; var mousePixel = new OL.Pixel(mouseX, mouseY); var mousePoint = W.map.getLonLatFromPixel(mousePixel).toPoint(); for(var amObj in W.model.managedAreas.objects) { if(W.model.managedAreas.objects[amObj].geometry.containsPoint(mousePoint)) { if(amList != '') amList += ', '; amList += uroGetUserNameAndRank(W.model.managedAreas.objects[amObj].userID); } } if(amList == '') { amList = 'none'; } amList = "<b>Area Managers:</b> "+amList; } document.getElementById("uroAMList").innerHTML = amList; } function uroMouseDown(e) { uroMouseIsDown = true; } function uroMouseUp(e) { uroMouseIsDown = false; } function uroUREvent_onObjectsChanged() { } function uroUREvent_onObjectsAdded() { if(uroGetCBChecked('_cbURResolverIDFilter') == true) { uroUpdateResolverList(); } uroFilterURs(); } function uroUREvent_onObjectsRemoved() { } function uroGetSelectedURCommentCount() { if(W.model.updateRequestSessions.objects[uroSelectedURID] != undefined) { var cachedCommentCount = W.model.updateRequestSessions.objects[uroSelectedURID].comments.length; uroAddLog(uroSelectedURID+':'+cachedCommentCount+' '+uroExpectedCommentCount); // if there aren't the same number of cached comments as there are comments in the UR dialog list, initiate // a refresh of the comment data... if(cachedCommentCount != uroExpectedCommentCount) { if(uroPendingCommentDataRefresh == true) { if(cachedCommentCount > 0) { uroCachedLastCommentID = W.model.updateRequestSessions.objects[uroSelectedURID].comments[cachedCommentCount-1].id; } else { uroCachedLastCommentID = null; } uroAddLog('updateRequestSessions refresh required for UR '+uroSelectedURID); if(uroCachedLastCommentID != null) { uroAddLog('last comment ID for this UR is '+uroCachedLastCommentID); } else { uroAddLog('first comment for this UR, no previous comment to ID'); } var idList = []; idList.push(uroSelectedURID); // need to delete the existing cache object first, as .get() is only capable of creating new objects, // it doesn't seem able to update an existing object with new data W.model.updateRequestSessions.remove(W.model.updateRequestSessions.objects[uroSelectedURID]); W.model.updateRequestSessions.get(idList); // the call to .get() initiates a XMLHttpRequest for the data, so we now need to switch modes - the // refresh process has started so we're no longer pending, but we are now waiting for the XMLHttpRequest // to return something... uroPendingCommentDataRefresh = false; uroWaitingCommentDataRefresh = true; } else { if(cachedCommentCount > 0) { currentLastCommentID = W.model.updateRequestSessions.objects[uroSelectedURID].comments[cachedCommentCount-1].id; if(currentLastCommentID == uroCachedLastCommentID) { // most recent comment loaded for this UR is the same one that was present at the start of this // refresh process, so kick back into pending mode so we can retry the .get()... uroAddLog('latest comment ID still the same, reverting to pending mode...'); uroPendingCommentDataRefresh = true; } else { // something may have gone awry here - the most recent comment loaded for this UR doesn't have the // same ID as the one present at the start of the refresh process, yet the comment counts still don't // match up, which suggests either a comment got lost along the way or someone else has commented on // the same UR at almost the same time. To get out of the loop this would create, assume that a // mismatch in the IDs means the .get() has completed successfully no matter what the new comment // count is, and take this new count to be the count we were expecting all along... uroAddLog('latest comment ID different, but expected count not correct...'); uroExpectedCommentCount = cachedCommentCount; } } else { uroAddLog('first comment on this UR not received yet, reverting to pending mode...'); uroPendingCommentDataRefresh = true; } } } else { // if the WME session is loaded with a UR already selected, such that WME has opened the UR dialog as part // of the session startup process, adding new comments to the UR cause the cached data to be updated immediately. // This prevents URO+ from switching into waiting mode in the above block of code, so we have to instead do // it here by comparing the cached count against the expected count following the Send click event. if(cachedCommentCount >= uroExpectedCommentCount) { uroPendingCommentDataRefresh = false; uroWaitingCommentDataRefresh = true; uroExpectedCommentCount = null; } // once the cached data has been updated, refilter the URs so that the new comment count is taken into account // immediately for filtering and display purposes if(uroWaitingCommentDataRefresh == true) { uroWaitingCommentDataRefresh = false; uroFilterURs(); uroAddLog('refresh complete'); } } } } function uroAddedComment() { // when the user clicks the Send button to submit a new UR comment, this event handler fires before the new comment is // posted to the server and thus also before the comment list gets updated in the UR dialog. So we take the current // comment count and, if the new comment edit box isn't empty, increment it by 1 to get the expected count. Then we // set the pending flag true to initiate a session refresh on the next 100ms tick uroExpectedCommentCount = W.map.panelRegion.currentView.conversationView.conversation.comments.length; if(document.getElementsByClassName('new-comment-text')[0].value != '') { uroExpectedCommentCount++; uroAddLog('new comment added to UR '+uroSelectedURID+', cache refresh required...'); uroPendingCommentDataRefresh = true; } else { uroPendingCommentDataRefresh = false; } } function uroTenthSecondTick() { if(uroSetupListeners) { if((loginManager.isLoggedIn()) || (uroPracticeMode == true)) { uroSetupListeners = false; if(uroPracticeMode == true) { document.getElementsByClassName("sandbox")[0].style.display = "none"; } // filter markers when the marker objects are modified (this happens whenever WME needs to load fresh marker data // due to having panned/zoomed the map beyond the extents of the previously loaded data) W.model.mapUpdateRequests.events.register("objectschanged", null, uroFilterURs_onObjectsChanged); W.model.mapUpdateRequests.events.register("objectsadded", null, uroFilterURs_onObjectsAdded); W.model.mapUpdateRequests.events.register("objectsremoved", null, uroFilterURs_onObjectsRemoved); W.model.updateRequestSessions.events.register("objectschanged", null, uroUREvent_onObjectsChanged); W.model.updateRequestSessions.events.register("objectsadded", null, uroUREvent_onObjectsAdded); W.model.updateRequestSessions.events.register("objectsremoved", null, uroUREvent_onObjectsRemoved); W.model.cameras.events.register("objectschanged", null, uroFilterCameras); W.model.cameras.events.register("objectsadded", null, uroFilterCameras); W.model.cameras.events.register("objectsremoved", null, uroFilterCameras); W.model.problems.events.register("objectschanged", null, uroFilterProblems); W.model.problems.events.register("objectsadded", null, uroFilterProblems); W.model.problems.events.register("objectsremoved", null, uroFilterProblems); W.model.venues.events.register("objectschanged", null, uroFilterPlaces); W.model.venues.events.register("objectsadded", null, uroFilterPlaces); W.model.venues.events.register("objectsremoved", null, uroFilterPlaces); var userTabs = document.getElementById(uroUserTabId); if(uroPracticeMode == false) { var navTabs = uroTimbonesGetElementsByClassName('nav-tabs', userTabs)[0]; var tabContent = uroTimbonesGetElementsByClassName('tab-content', userTabs)[0]; newtabUR = document.createElement('li'); newtabUR.innerHTML = '<a href="#sidepanel-uroverview" data-toggle="tab">URO+</a>'; navTabs.appendChild(newtabUR); } uroControls.id = "sidepanel-uroverview"; uroControls.className = "tab-pane"; if(uroPracticeMode == false) { tabContent.appendChild(uroControls); } else { userTabs.appendChild(uroControls); } uroAddEventListener('_btnUndoLastHide',"click", uroRemoveLastAddedIgnore, true); uroAddEventListener('_btnClearSessionHides',"click", uroRemoveAllIgnores, true); uroEnableIgnoreListControls(); uroAddEventListener('_btnClearCamWatchList',"click", uroClearCamWatchList, true); uroAddEventListener('_btnSettingsToText',"click", uroSettingsToText, true); uroAddEventListener('_btnTextToSettings',"click", uroTextToSettings, true); uroAddEventListener('_btnResetSettings',"click", uroDefaultSettings, true); uroAddEventListener('_btnClearSettingsText',"click", uroClearSettingsText, true); uroSetOnClick("_linkSelectUserRequests",uroShowURTab); uroSetOnClick("_linkSelectMapProblems",uroShowMPTab); uroSetOnClick("_linkSelectPlaces",uroShowPlacesTab); uroSetOnClick("_linkSelectCameras",uroShowCameraTab); uroSetOnClick("_linkSelectMisc",uroShowMiscTab); uroSetOnClick("_linkSelectOWL",uroShowOWLTab); uroSetOnClick('_cbHideMyComments',uroExclusiveCB); uroSetOnClick('_cbHideAnyComments',uroExclusiveCB); uroSetOnClick('_cbHideIfLastCommenter',uroExclusiveCB); uroSetOnClick('_cbHideIfNotLastCommenter',uroExclusiveCB); uroSetOnClick('_cbHideIfReporterLastCommenter',uroExclusiveCB); uroSetOnClick('_cbHideIfReporterNotLastCommenter',uroExclusiveCB); var dbgMode = "none"; if(uroShowDebugOutput) { dbgMode = "inline"; } document.getElementById('_uroDebugMode').style.display = dbgMode; uroAddEventListener('_uroVersion',"click", uroToggleDebug, true); uroAddLog('finalise onload'); uroLoadSettings(); uroNewLookCheckDetailsRequest(); if(uroGetCBChecked('_cbEnableDTE')) { if(dteControlsIdx != -1) { dteSetNewTabLength(); } else { uroAddLog('ERROR - archive panel not found!'); uroSetStyleDisplay(uroUserTabId,''); } } if(uroGetCBChecked('_cbEnableSRS')) { selectionManager.events.register("selectionchanged", null, srsCheckSidePanel); uroAddLog('added SRS event handler'); } // filter markers as and when the map is moved W.map.events.register("moveend", null, uroFilterItems); W.map.events.register("mousemove", null, uroGetAMs); W.map.events.register("mousemove", null, uroNewLookHighlightedItemsCheck); W.map.events.registerPriority("mousedown", null, uroMouseDown); // trap mousedown on Streetview marker drag document.getElementsByClassName('street-view-control')[0].onmousedown = uroMouseDown; W.map.events.register("mouseup", null, uroMouseUp); uroSetStyles(uroCtrlURs); uroSetStyles(uroCtrlMPs); uroSetStyles(uroCtrlPlaces); uroSetStyles(uroCtrlCameras); uroSetStyles(uroCtrlMisc); uroSetStyles(uroOWL); uroShowURTab(); uroRestyleWMETabs(); uroUserID = loginManager.getLoggedInUser().id; uroFilterItems(); } } else { var mousePos = document.getElementsByClassName('mouse-position')[0].innerHTML; if(uroPopupShown == true) { var hidePopup = false; if((mousePos == '00.00000, 00.00000') && (uroMouseInPopup == false)) { hidePopup = true; } if(document.getElementsByClassName('panel')[0] != undefined) { hidePopup = true; } if(hidePopup == true) { uroHidePopup(); } } if((uroAreaNameHoverObj != null) && (uroAreaNameHoverTime != -1) && (uroAreaNameOverlayShown == false)) { if(++uroAreaNameHoverTime > 5) { uroAreaNameOverlaySetup(); } } uroReplaceAreaNames(false); if(uroPopupTimer > 0) { if(uroMouseInPopup == false) { uroPopupTimer--; } } if(uroPopupTimer == 0) { uroHidePopup(); } // test for the opening or closing of the UR editing dialog var URDialogIsOpen = (document.getElementsByClassName('new-comment-form').length == 1); if(URDialogIsOpen) { var thisSelectedURID = W.map.panelRegion.currentView.conversationView.conversation.getID(); if(thisSelectedURID != uroSelectedURID) { // if the user selects a new UR whilst the editing dialog is still open, treat it in the // same way as if the user had selected that UR with the dialog closed uroURDialogIsOpen = false; } if(uroURDialogIsOpen == false) { // user is editing a new UR uroSelectedURID = thisSelectedURID; document.getElementsByClassName('new-comment-form')[0].getElementsByClassName('btn')[0].addEventListener("click", uroAddedComment, false); uroAddLog('user is editing UR '+uroSelectedURID); uroExpectedCommentCount = W.model.updateRequestSessions.objects[uroSelectedURID].comments.length; } } else if(uroURDialogIsOpen == true) { // dialog was open and has now been closed uroSelectedURID = null; } uroURDialogIsOpen = URDialogIsOpen; if(((uroPendingCommentDataRefresh == true) || (uroWaitingCommentDataRefresh == true)) && (uroSelectedURID != null)) { uroAddLog('check completion of comment data refresh for UR '+uroSelectedURID+' ('+uroPendingCommentDataRefresh+','+uroWaitingCommentDataRefresh+')'); uroGetSelectedURCommentCount(); } var selectedTotal = W.selectionManager.selectedItems.length; if((selectedTotal > 0) && (document.getElementById('_uroDivOWLBtns') == null)) { var selectedClass = W.selectionManager.selectedItems[0].model.CLASS_NAME; var displayAddToOWLBtn = false; var displayUpdateOWLBtn = false; var displayRemoveFromOWLBtn = false; var selectedSegments = false; var selectedLandmarks = false; // WME only seems to allow multi-object selections for segments, so testing the class of the first object in the // selection list tells us the class of any other objects in the list too... if(selectedClass == "Waze.Feature.Vector.Segment") { selectedSegments = true; for(var loop=0; loop<selectedTotal; loop++) { var fid = W.selectionManager.selectedItems[loop].model.attributes.id; var idx = uroIsSegOnWatchList(fid); if(idx == -1) { displayAddToOWLBtn = true; } else { if(uroSegDataChanged(idx)) { displayUpdateOWLBtn = true; } displayRemoveFromOWLBtn = true; } } } else if(selectedClass == "Waze.Feature.Vector.Landmark") { selectedLandmarks = true; for(var loop=0; loop<selectedTotal; loop++) { var fid = W.selectionManager.selectedItems[loop].model.attributes.id; var idx = uroIsPlaceOnWatchList(fid); if(idx == -1) { displayAddToOWLBtn = true; } else { if(uroPlaceDataChanged(idx)) { displayUpdateOWLBtn = true; } displayRemoveFromOWLBtn = true; } } } var btnHTML = '<div id="_uroDivOWLBtns">'; if((displayAddToOWLBtn == true) && (displayUpdateOWLBtn == false)) { btnHTML += '<button class="btn btn-default" id="_btnAddUpdateOWL">Add to OWL</button>'; } else if((displayUpdateOWLBtn == true) && (displayAddToOWLBtn == false)) { btnHTML += '<button class="btn btn-default" id="_btnAddUpdateOWL">Update OWL</button>'; } else if((displayAddToOWLBtn == true) && (displayUpdateOWLBtn == true)) { btnHTML += '<button class="btn btn-default" id="_btnAddUpdateOWL">Add to & Update OWL</button>'; } if(displayRemoveFromOWLBtn == true) { btnHTML += '<button class="btn btn-default" id="_btnRemoveOWL">Remove from OWL</button>'; } btnHTML += '</div>'; /* // once we get around to enabling these again, remember that altering the inner HTML of the // segment-edit-general panel when the selected segment is part of a roundabout then disables // the onclick handler for the select roundabout button... // // also remember that the current WME beta has yet another different side panel arrangement if(selectedSegments == true) { document.getElementById("segment-edit-general").innerHTML += btnHTML; } else if(selectedLandmarks == true) { document.getElementById("landmark-edit-general").innerHTML += btnHTML; } if((displayAddToOWLBtn == true)||(displayUpdateOWLBtn == true)) { if(selectedSegments == true) { uroAddEventListener('_btnAddUpdateOWL','click', uroAddUpdateSegWatchList, true); } else { uroAddEventListener('_btnAddUpdateOWL','click', uroAddUpdatePlaceWatchList, true); } } if(displayRemoveFromOWLBtn == true) { if(selectedSegments == true) { uroAddEventListener('_btnRemoveOWL','click', uroRemoveSegFromWatchList, true); } else { uroAddEventListener('_btnRemoveOWL','click', uroRemovePlaceFromWatchList, true); } } */ } } } function uroToggleURCtrls() { uroCtrlsHidden = !uroCtrlsHidden; if (!uroCtrlsHidden) { document.getElementById('_hideUCCtrl').innerHTML = "hide"; if(uroCurrentTab == 1) uroShowURTab(); else if(uroCurrentTab == 2) uroShowMPTab(); else if(uroCurrentTab == 3) uroShowPlacesTab(); else if(uroCurrentTab == 4) uroShowCameraTab(); else if(uroCurrentTab == 5) uroShowOWLTab(); else if(uroCurrentTab == 6) uroShowMiscTab(); } else { document.getElementById('_hideUCCtrl').innerHTML = "show"; uroSetStyleDisplay('uroCtrlURs','none'); uroSetStyleDisplay('uroCtrlMPs','none'); uroSetStyleDisplay('uroCtrlCameras','none'); uroSetStyleDisplay('uroCtrlMisc','none'); uroSetStyleDisplay('uroOWL','none'); } return false; } function uroActiveTab(_id) { var e = document.getElementById(_id); e.style.backgroundColor = "aliceblue"; e.style.borderTop = "1px solid"; e.style.borderLeft = "1px solid"; e.style.borderRight = "1px solid"; e.style.borderBottom = "0px solid"; } function uroInactiveTab(_id) { var e = document.getElementById(_id); e.style.backgroundColor = "white"; e.style.borderTop = "0px solid"; e.style.borderLeft = "0px solid"; e.style.borderRight = "0px solid"; e.style.borderBottom = "1px solid"; } function uroInactiveAllTabs() { uroInactiveTab("_tabSelectCameras"); uroInactiveTab("_tabSelectMapProblems"); uroInactiveTab("_tabSelectMisc"); uroInactiveTab("_tabSelectUserRequests"); uroInactiveTab("_tabSelectCWL"); uroInactiveTab("_tabSelectPlaces"); if(!uroCtrlsHidden) { uroSetStyleDisplay('uroCtrlURs','none'); uroSetStyleDisplay('uroCtrlMPs','none'); uroSetStyleDisplay('uroCtrlCameras','none'); uroSetStyleDisplay('uroCtrlMisc','none'); uroSetStyleDisplay('uroOWL','none'); uroSetStyleDisplay('uroCtrlPlaces','none'); } } function uroShowURTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectUserRequests"); uroCurrentTab = 1; if(!uroCtrlsHidden) uroSetStyleDisplay('uroCtrlURs','block'); return false; } function uroShowMPTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectMapProblems"); uroCurrentTab = 2; if(!uroCtrlsHidden) uroSetStyleDisplay('uroCtrlMPs','block'); return false; } function uroShowPlacesTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectPlaces"); uroCurrentTab = 3; if(!uroCtrlsHidden) uroSetStyleDisplay('uroCtrlPlaces','block'); return false; } function uroShowCameraTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectCameras"); uroCurrentTab = 4; if(!uroCtrlsHidden) uroSetStyleDisplay('uroCtrlCameras','block'); return false; } function uroShowOWLTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectCWL"); uroCurrentTab = 5; if(!uroCtrlsHidden) uroSetStyleDisplay('uroOWL','block'); uroOWLUpdateHTML(); return false; } function uroShowMiscTab() { uroInactiveAllTabs(); uroActiveTab("_tabSelectMisc"); uroCurrentTab = 6; if(!uroCtrlsHidden) uroSetStyleDisplay('uroCtrlMisc','block'); return false; } function uroTimbonesGetElementsByClassName(classname, node) { if(!node) node = document.getElementsByTagName("body")[0]; var a = []; var re = new RegExp('\\b' + classname + '\\b'); var els = node.getElementsByTagName("*"); for (var i=0,j=els.length; i<j; i++) if (re.test(els[i].className)) a.push(els[i]); return a; } function uroNewLookCheckDetailsRequest() { var thisurl = document.location.href; var doRetry = true; endmarkerpos = thisurl.indexOf('&endshow'); showmarkerpos = thisurl.indexOf('&showturn='); if((endmarkerpos != -1) && (showmarkerpos != -1)) { showmarkerpos += 10; uroAddLog('showturn tab opened'); var urID = thisurl.substr(showmarkerpos,endmarkerpos-showmarkerpos); uroAddLog(' turn problem ID = '+urID); try { W.map.problemLayer.markers[urID].icon.imageDiv.click(); doRetry = false; } catch(err) { uroAddLog('problems not fully loaded, retrying...'); } if(doRetry) setTimeout(uroNewLookCheckDetailsRequest,500); } else { showmarkerpos = thisurl.indexOf('&showpur='); if((endmarkerpos != -1) && (showmarkerpos != -1)) { showmarkerpos += 9; uroAddLog('showPUR tab opened'); var urID = thisurl.substr(showmarkerpos,endmarkerpos-showmarkerpos); uroAddLog(' PUR ID = '+urID); try { W.map.placeUpdatesLayer.markers[urID].icon.imageDiv.click(); doRetry = false; } catch(err) { uroAddLog('PURs not fully loaded, retrying...'); } if(doRetry) setTimeout(uroNewLookCheckDetailsRequest,500); } } } function uroUpdateMPSolverList() { if(Object.keys(W.model.problems.objects).length == 0) { return; } var resolverList = []; var selector = document.getElementById('_selectMPUserID'); var selectedUser = null; if(selector.selectedOptions[0] != undefined) { selectedUser = parseInt(selector.selectedOptions[0].value); } while(selector.options.length > 0) { selector.options.remove(0); } var selectedIdx = 0; var idx = 0; for (var mpobj in W.model.problems.objects) { var prob = W.model.problems.objects[mpobj]; if(prob.attributes.resolvedBy != null) { var userID = prob.attributes.resolvedBy; var userName = W.model.users.objects[userID].userName; if(resolverList.indexOf(userName) == -1) { resolverList.push(userName); selector.options.add(new Option(userName, userID)); if(userID == selectedUser) { selectedIdx = idx; } idx++; } } } if(selectedIdx != null) { selector.selectedIndex = selectedIdx; } } function uroUpdateResolverList() { if(Object.keys(W.model.mapUpdateRequests.objects).length == 0) { return; } var resolverList = []; var selector = document.getElementById('_selectURResolverID'); var selectedUser = null; if(selector.selectedOptions[0] != undefined) { selectedUser = parseInt(selector.selectedOptions[0].value); } while(selector.options.length > 0) { selector.options.remove(0); } var selectedIdx = 0; var idx = 0; for (var urobj in W.model.mapUpdateRequests.objects) { var ureq = W.model.mapUpdateRequests.objects[urobj]; if(ureq.attributes.resolvedBy != null) { var userID = ureq.attributes.resolvedBy; var userName = W.model.users.objects[userID].userName; if(resolverList.indexOf(userName) == -1) { resolverList.push(userName); selector.options.add(new Option(userName, userID)); if(userID == selectedUser) { selectedIdx = idx; } idx++; } } } if(selectedIdx != null) { selector.selectedIndex = selectedIdx; } } function uroUpdateUserList() { if(Object.keys(W.model.updateRequestSessions.objects).length == 0) return; var selector = document.getElementById('_selectURUserID'); var selectedUser = null; if(selector.selectedOptions[0] != undefined) { selectedUser = parseInt(selector.selectedOptions[0].value); } while(selector.options.length > 0) { selector.options.remove(0); } var selectedIdx = null; var listedIDs = []; for(var ursIdx in W.model.updateRequestSessions.objects) { var ursObj = W.model.updateRequestSessions.objects[ursIdx]; if(ursObj.comments.length > 0) { for(var cidx=0; cidx < ursObj.comments.length; cidx++) { var userID = ursObj.comments[cidx].userID; if((listedIDs.indexOf(userID) == -1) && (userID != -1)) { listedIDs.push(userID); } } } } if(listedIDs.length > 0) { var users = W.model.users.getByIds(listedIDs); for(var idx=0; idx<listedIDs.length; idx++) { selector.options.add(new Option(users[idx].userName, listedIDs[idx])); if(listedIDs[idx] == selectedUser) { selectedIdx = idx; } } } if(selectedIdx != null) { selector.selectedIndex = selectedIdx; } } function uroSetStyles(obj) { obj.style.fontSize = '12px'; obj.style.lineHeight = '100%'; obj.style.overflow = 'auto'; obj.style.height = (window.innerHeight * 0.55) + 'px'; } function uroPopulatePlacesTab() { var tHTML = ''; tHTML += '<b>Filter PURs by category/status:</b><br>'; tHTML += '<input type="checkbox" id="_cbFilterUneditablePlaceUpdates">Ones I can\'t edit</input><br>'; tHTML += '<input type="checkbox" id="_cbFilterLockRankedPlaceUpdates">Ones with non-zero lockRanks</input><br>'; tHTML += '<input type="checkbox" id="_cbFilterNewPlacePUR">Ones for new places</input><br>'; tHTML += '<input type="checkbox" id="_cbFilterUpdatedDetailsPUR">Ones for updated place details</input><br>'; tHTML += '<input type="checkbox" id="_cbFilterNewPhotoPUR">Ones for new photos</input><br>'; tHTML += '<input type="checkbox" id="_cbFilterFlaggedPUR">Ones flagged for attention</input><br>'; tHTML += '<br><input type="checkbox" id="_cbLeavePURGeos">Don\'t hide place polygons/points</input><br>'; tHTML += '<br><input type="checkbox" id="_cbInvertPURFilters">Invert PUR filters</input><br>'; tHTML += '<br><b>Filter PURs by severity:</b><br>'; tHTML += '<input type="checkbox" id="_cbPURFilterLowSeverity">Low</input> '; tHTML += '<input type="checkbox" id="_cbPURFilterMediumSeverity">Medium</input> '; tHTML += '<input type="checkbox" id="_cbPURFilterHighSeverity">High</input>'; tHTML += '<br><b>Filter PURs by age of submission:</b><br>'; tHTML += '<input type="checkbox" id="_cbEnablePURMinAgeFilter">Hide PURs less than </input>'; tHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputPURFilterMinDays"> days old<br>'; tHTML += '<input type="checkbox" id="_cbEnablePURMaxAgeFilter">Hide PURs more than </input>'; tHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputPURFilterMaxDays"> days old<br>'; tHTML += '<hr>'; tHTML += '<br><b>Filter Places by state:</b><br>'; tHTML += 'Hide if last edited<br>'; tHTML += '<input type="checkbox" id="_cbPlaceFilterEditedLessThan"> less than </input>'; tHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterPlaceEditMinDays"> days ago<br>'; tHTML += '<input type="checkbox" id="_cbPlaceFilterEditedMoreThan"> more than </input>'; tHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterPlaceEditMaxDays"> days ago<br>'; tHTML += '<br>Hide if locked at level:<br>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL0">1</input>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL1">2</input>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL2">3</input>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL3">4</input>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL4">5</input>'; tHTML += ' <input type="checkbox" id="_cbHidePlacesL5">6</input>'; tHTML += '<br><br><input type="checkbox" id="_cbHidePhotoPlaces">Hide or </input>'; tHTML += '<input type="checkbox" id="_cbHideNoPhotoPlaces">show ones with photos</input><br>'; tHTML += '<br><br><b>Filter Places by category:</b><br>'; for(var i=0; i<W.Config.venues.categories.length; i++) { parentCategory = W.Config.venues.categories[i]; localisedName = I18n.translations[I18n.locale].venues.categories[parentCategory]; tHTML += '<input type="checkbox" id="_cbPlacesFilter-'+parentCategory+'"><b>'+localisedName+'</b></input><br>'; for(var ii=0; ii<W.Config.venues.subcategories[parentCategory].length; ii++) { subCategory = W.Config.venues.subcategories[parentCategory][ii]; localisedName = I18n.translations[I18n.locale].venues.categories[subCategory]; tHTML += ' <input type="checkbox" id="_cbPlacesFilter-'+subCategory+'">'+localisedName+'</input><br>'; } } tHTML += '<input type="checkbox" id="_cbFilterPrivatePlaces"><b>Private Places</b></input><br>'; tHTML += '<br><input type="checkbox" id="_cbInvertPlacesFilter">Invert Place filters?</input>'; uroCtrlPlaces.innerHTML = tHTML; } function uroWazeBits() { // "fake" uroWazeBits() function which only performs layer scan, to stop the uroWazeBits() call in WMETB from // messing around with other stuff in the actual uroWazeBits() function (now renamed uroRealWazeBits...) that // really only ought to be called once. for(i=0;i<W.map.layers.length;i++) { if(W.map.layers[i].name == 'Spotlight') uroMaskLayer = i; if(W.map.layers[i].name.indexOf('Waze.Control.SelectHighlightFeature') != -1) uroRootContainer = W.map.layers[i].div.id; if(W.map.layers[i].name == 'Node Connections') uroTurnsLayerIdx = i; } uroPlacesRoot = W.map.landmarkLayer.id + '_vroot'; for(i=0;i<W.map.controls.length;i++) { if(W.map.controls[i].CLASS_NAME == 'Waze.View.ArchivePanel') dteControlsIdx = i; else if(W.map.controls[i].CLASS_NAME == 'Waze.Control.Archive') dteControlsIdx = i; if(W.map.controls[i].id != null) { if(W.map.controls[i].id.indexOf('UpdateRequests') != -1) uroURControlsIdx = i; if(W.map.controls[i].id.indexOf('MapProblems') != -1) uroProblemControlsIdx = i; } } uroAddLog('uroMaskLayer at idx '+uroMaskLayer); uroAddLog('Turns layer at idx '+uroTurnsLayerIdx); uroAddLog('uroRootContainer = '+uroRootContainer); uroAddLog('Places root layer = '+uroPlacesRoot); } function uroRealWazeBits() { if(document.getElementsByClassName("sandbox").length > 0) { uroPracticeMode = true; } else { uroPracticeMode = false; } uroAddLog('adding WazeBits...'+uroToHex(uroWazeBitsPresent,4)); if((uroWazeBitsPresent & 0x0001) == 0) { if(typeof unsafeWindow.W != "undefined") { if(typeof unsafeWindow.W.controller != "undefined") { if(typeof unsafeWindow.W.controller.map != "undefined") { uroAddLog(' W.map OK'); W.map = unsafeWindow.W.controller.map; uroWazeBitsPresent |= 0x0001; } } } } if((uroWazeBitsPresent & 0x0002) == 0) { if(typeof unsafeWindow.W != "undefined") { if(typeof unsafeWindow.W.controller != "undefined") { if(typeof unsafeWindow.W.controller.model != "undefined") { uroAddLog(' W.model OK'); W.model = unsafeWindow.W.controller.model; uroWazeBitsPresent |= 0x0002; } } } } if((uroWazeBitsPresent & 0x0004) == 0) { if(typeof unsafeWindow.W != "undefined") { if(typeof unsafeWindow.W.app != "undefined") { if(typeof unsafeWindow.W.app.loginManager != "undefined") { uroAddLog(' loginManager OK'); loginManager = unsafeWindow.W.app.loginManager; uroWazeBitsPresent |= 0x0004; } } } } if((uroWazeBitsPresent & 0x0008) == 0) { if(typeof unsafeWindow.W != "undefined") { if(typeof unsafeWindow.W.geometryEditing != "undefined") { if(typeof unsafeWindow.W.geometryEditing.selectionManager != "undefined") { uroAddLog(' selectionManager OK'); selectionManager = unsafeWindow.W.geometryEditing.selectionManager; uroWazeBitsPresent |= 0x0008; } } } } if((uroWazeBitsPresent & 0x0010) == 0) { if(typeof unsafeWindow.OpenLayers != "undefined") { uroAddLog(' OpenLayers OK'); OpenLayers = unsafeWindow.OpenLayers; uroWazeBitsPresent |= 0x0010; } } if((uroWazeBitsPresent & 0x0020) == 0) { if(typeof unsafeWindow.Waze != "undefined") { uroAddLog(' Waze OK'); Waze = unsafeWindow.Waze; uroWazeBitsPresent |= 0x0020; } } if((uroWazeBitsPresent & 0x0040) == 0) { if(document.getElementById('user-tabs') != null) { uroUserTabId = 'user-tabs'; uroAddLog(' user-tabs OK'); uroWazeBitsPresent |= 0x0040; } else if(document.getElementById('user-info') != null) { uroUserTabId = 'user-info'; uroAddLog(' user-info OK'); uroWazeBitsPresent |= 0x0040; } } if((uroWazeBitsPresent & 0x0080) == 0) { if(uroPracticeMode == true) { uroAddLog(' sidepanel-drives ignored in practice mode'); uroWazeBitsPresent |= 0x0080; } else { if(document.getElementById('sidepanel-drives') != null) { uroAddLog(' sidepanel-drives OK'); uroWazeBitsPresent |= 0x0080; } } } if((uroWazeBitsPresent & 0x0100) == 0) { if(typeof unsafeWindow.I18n != "undefined") { uroAddLog(' I18n OK'); uroWazeBitsPresent |= 0x0100; } } if(uroWazeBitsPresent != 0x01FF) setTimeout(uroRealWazeBits,250); else if((loginManager.isLoggedIn() == false) && (uroPracticeMode == false)) { uroAddLog('Waiting for user log-in...'); setTimeout(uroRealWazeBits,1000); } else { uroAddLog('All WazeBits present and correct...'); uroDOMHasTurnProblems = (W.model.turnProblems != undefined); uroPopulatePlacesTab(); uroControls.appendChild(uroCtrlURs); uroControls.appendChild(uroCtrlMPs); uroControls.appendChild(uroCtrlPlaces); uroControls.appendChild(uroCtrlCameras); uroControls.appendChild(uroOWL); uroControls.appendChild(uroCtrlMisc); uroControls.appendChild(uroCtrlHides); uroControls.appendChild(uroAMList); uroCtrlURs.onclick = uroFilterItems_URTabClick; uroCtrlMPs.onclick = uroFilterItems_MPTabClick; uroCtrlPlaces.onclick = uroFilterItems_PlacesTabClick; uroCtrlCameras.onclick = uroFilterItems_CamerasTabClick; uroCtrlMisc.onclick = uroFilterItems_MiscTabClick; uroWazeBits(); uroDiv.addEventListener("mouseover", uroEnterPopup, false); uroDiv.addEventListener("mouseout", uroExitPopup, false); if(sessionStorage.UROverview_FID_IgnoreList == null) sessionStorage.UROverview_FID_IgnoreList = ''; if(sessionStorage.UROverview_FID_WatchList == null) sessionStorage.UROverview_FID_WatchList = ''; if(uroConfirmIntercepted == false) uroAddInterceptor(); setInterval(uroTenthSecondTick,100); uroShowDebugOutput = false; } } function uroAddInterceptor() { uroAddLog('Adding interceptor function...'); // add interceptor function for confirm(), so that we can auto-select the "OK" option when solving URs // which have pending question... _confirm = unsafeWindow.confirm; unsafeWindow.confirm = function(msg) { if((I18n.translations[I18n.locale].update_requests.panel.confirm == msg) && (uroGetCBChecked('_cbDisablePendingQuestions') == true)) { uroAddLog('Intercepted pending comments confirmation...'); return true; } else if(typeof(msg) == 'undefined') { uroAddLog('Intercepted blank confirmation...'); return true; } else { return _confirm(msg); } }; uroConfirmIntercepted = true; } function uroEnterPopup() { uroMouseInPopup = true; } function uroExitPopup() { uroMouseInPopup = false; } function uroToggleDebug() { uroShowDebugOutput = !uroShowDebugOutput; var dbgMode = "none"; if(uroShowDebugOutput) { dbgMode = "inline"; } document.getElementById('_uroDebugMode').style.display = dbgMode; } function uroInitialise() { uroGlobals(); if(document.URL.indexOf('editor-beta') != -1) uroBetaEditor = true; // create a new div to display the UR details floaty-box uroDiv = document.createElement('div'); uroDiv.id = "uroDiv"; uroDiv.style.position = 'absolute'; uroDiv.style.visibility = 'hidden'; uroDiv.style.top = '0'; uroDiv.style.left = '0'; uroDiv.style.zIndex = 100; uroDiv.style.backgroundColor = 'aliceblue'; uroDiv.style.borderWidth = '3px'; uroDiv.style.borderStyle = 'solid'; uroDiv.style.borderRadius = '10px'; uroDiv.style.boxShadow = '5px 5px 10px Silver'; uroDiv.style.padding = '4px'; document.body.appendChild(uroDiv); uroControls = document.createElement('section'); uroControls.style.fontSize = '12px'; uroControls.id = 'uroControls'; if(navigator.userAgent.indexOf('Chrome') == -1) { var updateURL = 'https://greasyfork.org/scripts/1952-uroverview-plus-uro'; } else { var updateURL = 'https://chrome.google.com/webstore/detail/uroverview/amdamgkgchnbaopmphhjapmjcdghdphi'; } //tabbyHTML = '<input type="checkbox" id="_cbUROMasterEnable" /> '; tabbyHTML = '<b><a href="'+updateURL+'" target="_blank">UROverview Plus</a></b> <label id="_uroVersion">'+uroVersion+'</label>'; tabbyHTML += '<label id="_uroDebugMode">(dbg)</label>'; tabbyHTML += '<p><table border=0 width="100%"><tr>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectUserRequests"><a href="#" id="_linkSelectUserRequests" style="text-decoration:none;font-size:12px">URs</a></td>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectMapProblems"><a href="#" id="_linkSelectMapProblems" style="text-decoration:none;font-size:12px">MPs</a></td>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectPlaces"><a href="#" id="_linkSelectPlaces" style="text-decoration:none;font-size:12px">Places</a></td>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectCameras"><a href="#" id="_linkSelectCameras" style="text-decoration:none;font-size:12px">Cams</a></td>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectCWL"><a href="#" id="_linkSelectOWL" style="text-decoration:none;font-size:12px">OWL</a></td>'; tabbyHTML += '<td valign="center" align="center" id="_tabSelectMisc"><a href="#" id="_linkSelectMisc" style="text-decoration:none;font-size:12px">Misc</a></td>'; tabbyHTML += '</tr></table>'; uroControls.innerHTML = tabbyHTML; uroCtrlURs = document.createElement('p'); uroCtrlMPs = document.createElement('p'); uroCtrlCameras = document.createElement('p'); uroOWL = document.createElement('p'); uroCtrlMisc = document.createElement('p'); uroAMList = document.createElement('div'); uroCtrlHides = document.createElement('div'); uroCtrlPlaces = document.createElement('p'); // UR controls tab uroCtrlURs.id = "uroCtrlURs"; uroCtrlURs.innerHTML = '<br>'; uroCtrlURs.innerHTML += '<b>Hide URs by type:</b><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterWazeAuto">Waze Automatic</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterIncorrectTurn">Incorrect turn</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterIncorrectAddress">Incorrect address</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterIncorrectRoute">Incorrect route</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterMissingRoundabout">Missing roundabout</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterGeneralError">General error</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterTurnNotAllowed">Turn not allowed</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterIncorrectJunction">Incorrect junction</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterMissingBridgeOverpass">Missing bridge overpass</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterWrongDrivingDirection">Wrong driving direction</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterMissingExit">Missing exit</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterMissingRoad">Missing road</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterBlockedRoad">Blocked road</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterMissingLandmark">Missing Landmark</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterUndefined">Undefined</input><br>'; uroCtrlURs.innerHTML += ' <i>Specially tagged types</i><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbFilterRoadworks">[ROADWORKS]</input><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbFilterConstruction">[CONSTRUCTION]</input><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbFilterClosure">[CLOSURE]</input><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbFilterEvent">[EVENT]</input><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbFilterNote">[NOTE]</input><br><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbInvertURFilter">Invert operation of type filters?</input><br>'; uroCtrlURs.innerHTML += '<hr>'; uroCtrlURs.innerHTML += '<br><b>Hide by state:</b><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterOpenUR">Open</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterClosedUR">Closed</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterSolved">Solved</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbFilterUnidentified">Not identified</input><br><br>'; uroCtrlURs.innerHTML += '<br><b>Filter URs by age of submission:</b><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableMinAgeFilter">Hide URs less than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterMinDays"> days old<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableMaxAgeFilter">Hide URs more than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterMaxDays"> days old<br>'; uroCtrlURs.innerHTML += '<br><b>Filter URs by description text:</b><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbURDescriptionMustBePresent">Hide</input> or '; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbURDescriptionMustBeAbsent">show</input> URs with no description<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableKeywordMustBePresent">Hide URs not including </input>'; uroCtrlURs.innerHTML += '<input type="text" style="font-size:14px; line-height:16px; height:22px; margin-bottom:4px;" id="_textKeywordPresent"><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableKeywordMustBeAbsent">Hide URs including </input>'; uroCtrlURs.innerHTML += '<input type="text" style="font-size:14px; line-height:16px; height:22px; margin-bottom:4px;" id="_textKeywordAbsent"><br>'; uroCtrlURs.innerHTML += ' <input type="checkbox" id="_cbCaseInsensitive">Case-insensitive matches?</input><br>'; uroCtrlURs.innerHTML += '<br><b>Hide URs by comments/following:</b><br>'; uroCtrlURs.innerHTML += '<i>With comments from me?</i><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideMyComments">Yes </input>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideAnyComments">No</input><br>'; uroCtrlURs.innerHTML += '<i>If last comment made by me?</i><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideIfLastCommenter">Yes </input>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideIfNotLastCommenter">No </input><br>'; uroCtrlURs.innerHTML += '<i>If last comment made by UR reporter?</i><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideIfReporterLastCommenter">Yes </input>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideIfReporterNotLastCommenter">No</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableMinCommentsFilter">With less than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterMinComments"> comments<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableMaxCommentsFilter">With more than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="0" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterMaxComments"> comments<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideMyFollowed">Ones I am or </input>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbHideMyUnfollowed">am not following</input><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableCommentAgeFilter2">Last comment less than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterCommentDays2"> days ago<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbEnableCommentAgeFilter">Last comment more than </input>'; uroCtrlURs.innerHTML += '<input type="number" min="1" size="3" style="width:50px;line-height:14px;height:22px;margin-bottom:4px;" id="_inputFilterCommentDays"> days ago<br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbURUserIDFilter">Without comments from user</input>'; uroCtrlURs.innerHTML += '<select id="_selectURUserID" style="width:80%; height:22px;"></select><br>'; uroCtrlURs.innerHTML += '<input type="checkbox" id="_cbURResolverIDFilter">Not resolved by user</input>'; uroCtrlURs.innerHTML += '<select id="_selectURResolverID" style="width:80%; height:22px;"></select>'; uroCtrlURs.innerHTML += '<br><br><input type="checkbox" id="_cbNoFilterForTaggedURs"><b>Don\'t apply state/age filters to tagged URs</b></input><br>'; // Map problems controls tab uroCtrlMPs.id = "uroCtrlMPs"; uroCtrlMPs.innerHTML = '<br>'; uroCtrlMPs.innerHTML += '<b>Filter MPs by type:</b><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterMissingJunction">Missing junction</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterMissingRoad">Missing road</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterCrossroadsJunctionMissing">Missing crossroads</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterDrivingDirectionMismatch">Driving direction mismatch</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterRoadTypeMismatch">Road type mismatch</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterRestrictedTurn">Restricted turn might be allowed</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterUnknownProblem">Unknown problem type</input><br><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterTurnProblem">Turn Problems</input><br><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterReopenedProblem">Reopened Problems</input><br><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbInvertMPFilter">Invert operation of type filters?</input><br>'; uroCtrlMPs.innerHTML += '<br><b>Hide closed/solved/unidentified Problems:</b><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterClosed">Closed</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterSolved">Solved</input><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterUnidentified">Not identified</input><br><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPClosedUserIDFilter">Closed</input> or '; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPNotClosedUserIDFilter">Not Closed</input> by user'; uroCtrlMPs.innerHTML += '<select id="_selectMPUserID" style="width:80%; height:22px;"></select><br>'; uroCtrlMPs.innerHTML += '<br><b>Hide problems (not turn) by severity:</b><br>'; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterLowSeverity">Low</input> '; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterMediumSeverity">Medium</input> '; uroCtrlMPs.innerHTML += '<input type="checkbox" id="_cbMPFilterHighSeverity">High</input><br>'; // Places filtering tab uroCtrlPlaces.id = "uroCtrlPlaces"; uroCtrlPlaces.innerHTML = 'Places filter list being populated, please wait...'; // Camera controls tab uroCtrlCameras.id = "uroCtrlCameras"; uroCtrlCameras.innerHTML = '<br><b>Show Cameras by creator:</b><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowWorldCams" checked>world_* users</input><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowUSACams" checked>usa_* users</input><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowNonWorldCams" checked>other users</input><br>'; uroCtrlCameras.innerHTML += '<br><input type="checkbox" id="_cbShowOnlyMyCams">Show ONLY cameras created/edited by me</input><br>'; uroCtrlCameras.innerHTML += '<br><b>Show Cameras by approval status:</b><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowApprovedCams" checked>approved</input><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowNonApprovedCams" checked>non-approved</input><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbShowOlderCreatedNonApproved"> if created more than </input>'; uroCtrlCameras.innerHTML += '<input type="number" min="1" size="3" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputCameraMinCreatedDays"> days ago<br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbShowOlderUpdatedNonApproved"> if updated more than </input>'; uroCtrlCameras.innerHTML += '<input type="number" min="1" size="3" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputCameraMinUpdatedDays"> days ago<br>'; uroCtrlCameras.innerHTML += '<br><b>Show Cameras by type:</b><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowSpeedCams" checked>Speed</input><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbShowIfMPHSpeedSet" checked> with MPH speeds</input><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbShowIfKPHSpeedSet" checked> with KM/H speeds</input><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbShowIfNoSpeedSet" checked> with no speed</input><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowRedLightCams" checked>Red Light</input><br>'; uroCtrlCameras.innerHTML += '<input type="checkbox" id="_cbShowDummyCams" checked>Dummy</input><br>'; uroCtrlCameras.innerHTML += '<br><b>Hide Cameras by creator:</b><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByMe">me</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank0">L1</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank1">L2</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank2">L3</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank3">L4</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank4">L5</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideCreatedByRank5">L6</input>'; uroCtrlCameras.innerHTML += '<br><b>Hide Cameras by updater:</b><br>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByMe">me</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank0">L1</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank1">L2</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank2">L3</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank3">L4</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank4">L5</input>'; uroCtrlCameras.innerHTML += ' <input type="checkbox" id="_cbHideUpdatedByRank5">L6</input>'; uroCtrlCameras.innerHTML += '<br><br><b><input type="checkbox" id="_cbHideCWLCams">Hide cameras on watchlist</input></b><br>'; // Object watchlist tab uroOWL.id = "uroOWL"; uroOWLUpdateHTML(); // Misc controls tab uroCtrlMisc.id = "uroCtrlMisc"; uroCtrlMisc.innerHTML = '<br><b>Use default conversation markers:</b><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbNativeConvoMarkers" checked>in public WME</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbNativeBetaConvoMarkers" checked>in beta WME</input><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbCommentCount">Show comment count on UR markers</input></b><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbURBackfill">Backfill UR data</input></b><br>'; uroCtrlMisc.innerHTML += '<br><br><b>Marker Unstacking:</b><br>'; uroCtrlMisc.innerHTML += 'Distance threshold: <input type="number" min="1" max="30" value="15" size="2" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputUnstackSensitivity"><br>'; uroCtrlMisc.innerHTML += 'Disable below zoom: <input type="number" min="0" max="10" value="3" size="2" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputUnstackZoomLevel"><br>'; uroCtrlMisc.innerHTML += '<br><br><b>Use custom marker for URs tagged as:</b><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbCustomRoadworksMarkers">[ROADWORKS]</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbCustomConstructionMarkers">[CONSTRUCTION]</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbCustomClosuresMarkers">[CLOSURE]</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbCustomEventsMarkers">[EVENT]</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbCustomNotesMarkers">[NOTE]</input><br>'; uroCtrlMisc.innerHTML += '<br><br><b>Popup entry timeout:</b><br>'; uroCtrlMisc.innerHTML += '<input type="number" min="1" max="10" value="2" size="2" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputPopupEntryTimeout"> secs/10'; uroCtrlMisc.innerHTML += '<br><br><b>Disable popup for:</b><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitURPopup">URs</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitMPPopup">MPs</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitCamPopup">Cameras</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitSegPopup">Segments</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitLandmarkPopup">Landmarks</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbInhibitPUPopup">Place Updates</input><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbWhiteBackground">Use custom background colour</input></b><br>'; uroCtrlMisc.innerHTML += 'R:<input type="number" min="0" max="255" value="255" size="3" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputCustomBackgroundRed">'; uroCtrlMisc.innerHTML += 'G:<input type="number" min="0" max="255" value="255" size="3" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputCustomBackgroundGreen">'; uroCtrlMisc.innerHTML += 'B:<input type="number" min="0" max="255" value="255" size="3" style="width:50px;;line-height:14px;height:22px;margin-bottom:4px;" id="_inputCustomBackgroundBlue"><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbHideAMLayer">Hide Area Manager polygons</input></b><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbDisablePlacesFiltering">Disable Places filtering</input></b><br>'; uroCtrlMisc.innerHTML += '<br><br><b><input type="checkbox" id="_cbDisablePendingQuestions">Disable UR Pending Questions confirmation</input></b><br>'; uroCtrlMisc.innerHTML += '<br><b>Enable integrated scripts:</b><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbEnableDTE">Drive Tab Enhancement</input><br>'; uroCtrlMisc.innerHTML += '<input type="checkbox" id="_cbEnableSRS">Select Roundabout Segments</input><br>'; uroCtrlMisc.innerHTML += '<br><br><b>Settings backup/restore/reset:</b><br>'; uroCtrlMisc.innerHTML += '<input type="button" id="_btnSettingsToText" value="Backup"> '; uroCtrlMisc.innerHTML += '<input type="button" id="_btnTextToSettings" value="Restore"> | '; uroCtrlMisc.innerHTML += '<input type="button" id="_btnResetSettings" value="Reset"><br><br>'; uroCtrlMisc.innerHTML += '<textarea id="_txtSettings" value="" /><br>'; uroCtrlMisc.innerHTML += '<input type="button" id="_btnClearSettingsText" value="Clear"><br>'; // footer for tabs container uroCtrlHides.id = 'uroCtrlHides'; uroCtrlHides.innerHTML = '<input type="button" id="_btnUndoLastHide" value="Undo last hide"> '; uroCtrlHides.innerHTML += '<input type="button" id="_btnClearSessionHides" value="Undo all hides"><p>'; // footer for AM list uroAMList.id = 'uroAMList'; window.addEventListener("beforeunload", uroSaveSettings, false); uroRealWazeBits(); } function dteAddHeader() { rlcObj = document.getElementsByClassName("result-list-container"); if(typeof rlcObj == "undefined") return; if(typeof rlcObj[0].children[0] == "undefined") return; if(typeof rlcObj[0].children[0].innerHTML == "undefined") return; var thtml = rlcObj[0].children[0].innerHTML; if(thtml.indexOf('Full drive history') == -1) { thtml += '<br><br><i><small>Full drive history goes back to '+dteOldestFullDrive.toDateString()+'</small></i>'; rlcObj[0].children[0].innerHTML = thtml; } } function dteSetNewTabLength() { uroAddLog('altering ResultsPerPage parameter...'); var t = document.getElementById('sidepanel-drives'); t.style.overflow = 'auto'; t.style.height = (window.innerHeight * 0.6) + 'px'; baseloc = 'https://'+window.location.hostname+Waze.Config.api_base+'/Archive/MyList?minDistance=1000'; var a = new XMLHttpRequest(); var idxCheckFullDrive = 0; var fullDrives = 0; var foundMissingDrive = false; while(!foundMissingDrive) { uroSetStyleDisplay(uroUserTabId,'none'); var loc = baseloc+'&offset='+fullDrives+'&count=5'; uroAddLog('requesting '+loc); var retries = 0; while(retries < 3) { a.open('GET',loc,false); a.send(); if(a.responseText != "") { break; } retries++; } if(a.responseText != "") { var b = JSON.parse(a.responseText); var loadedDrives = b.archives.objects.length; uroAddLog('received '+loadedDrives+' drives'); if(loadedDrives != 5) foundMissingDrive = true; for(var loop=0; loop < loadedDrives; loop++) { if(b.archives.objects[loop].hasFullSession == false) { foundMissingDrive = true; } else { fullDrives++; dteOldestFullDrive = new Date(b.archives.objects[loop].startTime); } } } else { foundMissingDrive = true; } } uroAddLog(fullDrives+' full drives in history'); uroAddLog('oldest drives are on '+dteOldestFullDrive.toDateString()); if(fullDrives < 5) { fullDrives = 5; uroAddLog('insufficient full drives, using standard drives tab'); } else if(fullDrives > 50) { uroAddLog('too many full drives for a single tab page, splitting over multiple pages...'); fullDrives = Math.ceil(fullDrives/Math.ceil(fullDrives/50)); } uroSetStyleDisplay(uroUserTabId,''); if((dteOldestFullDrive - dteEpoch) > 0) { uroAddLog('updating drives tab...'); W.map.controls[dteControlsIdx].sidePanelView.ResultsPerPage = fullDrives; setInterval(dteAddHeader,250); setInterval(dteCheckDriveListChanges,250); } } function dteCheckDriveListChanges() { var drivesShown = document.getElementById('sidepanel-drives').getElementsByClassName('result session').length; if(drivesShown > 0) { var topID = document.getElementById('sidepanel-drives').getElementsByClassName('result session')[0].getAttribute('data-id'); if(topID != dteTopID) { dteTopID = topID; for(var loop = 0;loop < drivesShown; loop++) { var driveID = document.getElementById('sidepanel-drives').getElementsByClassName('result session')[loop].getAttribute('data-id'); var driveObj = W.model.archives.objects[driveID]; var driveDistance = driveObj.totalRoadMeters; var driveSecs = Math.floor((driveObj.endTime - driveObj.startTime) / 1000); var driveHours = Math.floor(driveSecs / 3600); driveSecs -= (driveHours * 3600); var driveMins = Math.floor(driveSecs / 60); driveSecs -= (driveMins * 60); var trueTime = (driveHours+':'+("0"+driveMins).slice(-2)+'.'+("0"+driveSecs).slice(-2)); document.getElementById('sidepanel-drives').getElementsByClassName('result')[loop].getElementsByTagName('span')[1].innerHTML = trueTime; } } } } function srsSelect() { rbtID = selectionManager.selectedItems[0].model.attributes.junctionID; uroAddLog('selecting roundabout ID '+rbtID); selectionManager.selectControl.unselectAll(); for(var slIdx=0; slIdx < W.map.segmentLayer.features.length; slIdx++) { if(W.map.segmentLayer.features[slIdx].fid == null) { junctionID = W.map.segmentLayer.features[slIdx].model.attributes.junctionID; segID = W.map.segmentLayer.features[slIdx].model.attributes.id; } else { junctionID = W.map.segmentLayer.features[slIdx].attributes.junctionID; segID = W.map.segmentLayer.features[slIdx].fid; } if(junctionID == rbtID) { uroAddLog('...adding segment '+segID); selectionManager.selectControl.select(W.map.segmentLayer.features[slIdx]); } } } function srsCheckSidePanel() { if(selectionManager.selectedItems.length == 0) return; if(document.getElementById('srsCtrl') != null) return; var junctionID = selectionManager.selectedItems[0].model.attributes.junctionID; if(junctionID == null) return; srsCtrl = document.createElement('section'); srsCtrl.id = 'srsCtrl'; srsCtrl.innerHTML = '<button id="srsButton" class="btn btn-default">Select roundabout</button>'; document.getElementById('segment-edit-general').appendChild(srsCtrl); uroSetOnClick('srsButton',srsSelect); } uroBootstrap();