// ==UserScript== // @name WME Junction Angle Info (development version) // @namespace https://github.com/milkboy/WME-ja // @description Show the angle between two selected (and connected) segments // @include /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor.*$/ // @updateURL https://github.com/milkboy/WME-ja/raw/master/wme_junctionangle.user.js // @version 1.15.0 // @grant none // @copyright 2019 Michael Wikberg // @license CC-BY-NC-SA // @icon  // @nocompat // ==/UserScript== /** * Copyright 2019 Michael Wikberg * WME Junction Angle Info extension is licensed under a Creative Commons * Attribution-NonCommercial-ShareAlike 3.0 Unported License. * * Contributions by: * 2014 Paweł Pyrczak "tkr85" * 2014 "AlanOfTheBerg" * 2014 "berestovskyy" * 2015 "FZ69617" * 2015 "wlodek76" * 2016 Sergey Kuznetsov "WazeRus" (Russian translation) * 2016 "MajkiiTelini" Czech translation */ /*jshint eqnull:true, nonew:true, nomen:true, curly:true, latedef:false, unused:strict, noarg:true, loopfunc:true */ /*jshint trailing:true, forin:true, noempty:true, maxparams:7, maxerr:100, eqeqeq:true, strict:true, undef:true */ /*jshint bitwise:true, newcap:true, immed:true, onevar:true, browser:true, nonbsp:true, freeze:true */ /*global I18n, console, $*/ function run_ja() { "use strict"; /* * First some variable and enumeration definitions */ var ja_version = "1.15.0"; var ja_debug = 1; //0: no output, 1: basic info, 2: debug 3: verbose debug, 4: insane debug var ja_last_restart = 0, ja_roundabout_points = [], ja_options = {}, ja_mapLayer; var ja_TURN_ANGLE = 45.04; //Turn vs. keep angle specified in Wiki. var ja_U_TURN_ANGLE = 168.24; //U-Turn angle based on map experiments. var ja_GRAY_ZONE = 0.5; //Gray zone angle intended to prevent from irregularities observed on map. var ja_OVERLAPPING_ANGLE = 0.666; //Experimentally measured overlapping angle. var ja_routing_type = { BC: "junction_none", KEEP: "junction_keep", KEEP_LEFT: "junction_keep_left", KEEP_RIGHT: "junction_keep_right", TURN: "junction_turn", EXIT: "junction_exit", EXIT_LEFT: "junction_exit_left", EXIT_RIGHT: "junction_exit_right", U_TURN: "junction_u_turn", PROBLEM: "junction_problem", NO_TURN: "junction_no_turn", NO_U_TURN: "junction_no_u_turn", ROUNDABOUT: "junction_roundabout", ROUNDABOUT_EXIT: "junction_roundabout_exit" }; var ja_road_type = { //Streets STREET: 1, PRIMARY_STREET: 2, //Highways RAMP: 4, FREEWAY: 3, MAJOR_HIGHWAY: 6, MINOR_HIGHWAY: 7, //Other drivable DIRT_ROAD: 8, FERRY: 14, PRIVATE_ROAD: 17, PARKING_LOT_ROAD: 20, //Non-drivable WALKING_TRAIL: 5, PEDESTRIAN_BOARDWALK: 10, STAIRWAY: 16, RAILROAD: 18, RUNWAY: 19 }; var ja_vehicle_types = { TRUCK: 1, PUBLIC: 2, TAXI: 4, BUS: 8, HOV2: 16, HOV3: 32, RV: 64, TOWING: 128, MOTORBIKE: 256, PRIVATE: 512, HAZ: 1024 }; var ja_settings = { defaultOn: { elementType: "checkbox", elementId: "_jaCbShowLayer", defaultValue: true }, angleMode: { elementType: "select", elementId: "_jaSelAngleMode", defaultValue: "aDeparture", options: ["aAbsolute", "aDeparture"]}, angleDisplay: { elementType: "select", elementId: "_jaSelAngleDisplay", defaultValue: "displayFancy", options: ["displayFancy", "displaySimple"]}, angleDisplayArrows: { elementType: "select", elementId: "_jaSelAngleDisplayArrows", defaultValue: "<>", options: ["<>", "⇦⇨", "⇐⇒", "←→", "⇐⇒⇖⇗", "←→↖↗"]}, guess: { elementType: "checkbox", elementId: "_jaCbGuessRouting", defaultValue: true }, noInstructionColor: { elementType: "color", elementId: "_jaTbNoInstructionColor", defaultValue: "#ffffff", group: "guess"}, keepInstructionColor: { elementType: "color", elementId: "_jaTbKeepInstructionColor", defaultValue: "#cbff84", group: "guess"}, exitInstructionColor: { elementType: "color", elementId: "_jaTbExitInstructionColor", defaultValue: "#6cb5ff", group: "guess"}, turnInstructionColor: { elementType: "color", elementId: "_jaTbTurnInstructionColor", defaultValue: "#4cc600", group: "guess"}, uTurnInstructionColor: { elementType: "color", elementId: "_jaTbUTurnInstructionColor", defaultValue: "#b66cff", group: "guess"}, noTurnColor: { elementType: "color", elementId: "_jaTbNoTurnColor", defaultValue: "#a0a0a0", group: "guess"}, problemColor: { elementType: "color", elementId: "_jaTbProblemColor", defaultValue: "#feed40", group: "guess"}, roundaboutOverlayDisplay: { elementType: "select", elementId: "_jaSelRoundaboutOverlayDisplay", defaultValue: "rOverNever", options: ["rOverNever","rOverSelected","rOverAlways"]}, roundaboutOverlayColor: { elementType: "color", elementId: "_jaTbRoundaboutOverlayColor", defaultValue: "#aa0000", group: "roundaboutOverlayDisplay"}, roundaboutColor: { elementType: "color", elementId: "_jaTbRoundaboutColor", defaultValue: "#ff8000", group: "roundaboutOverlayDisplay"}, decimals: { elementType: "number", elementId: "_jaTbDecimals", defaultValue: 0, min: 0, max: 2}, pointSize: { elementType: "number", elementId: "_jaTbPointSize", defaultValue: 12, min: 6, max: 20} }; var ja_arrow = { get: function(at) { var arrows = ja_getOption("angleDisplayArrows"); return arrows[at % arrows.length]; }, left: function() { return this.get(0); }, right: function() { return this.get(1); }, left_up: function() { return this.get(2); }, right_up: function() { return this.get(3); } }; function getWaze() { if(window.wrappedJSObject) { return window.wrappedJSOnject.W; } return window.W; } /* * Main logic functions */ function junctionangle_init() { var i, ja_select_option, navTabs, tabContent; var ja_settings_dom = document.createElement("div"); var ja_settings_dom_panel = document.createElement("div"); var ja_settings_dom_content = document.createElement("div"); var ja_settings_header = document.createElement('h4'); var style = document.createElement('style'); var form = document.createElement('form'); var section = document.createElement('div'); var ja_reset_button = document.createElement('button'); var userTabs = document.getElementById('user-info'); var ja_info = document.createElement('ul'); var ja_version_elem = document.createElement('li'); var jatab = document.createElement('li'); //Listen for selected nodes change event getWaze().selectionManager.events.register("selectionchanged", null, ja_calculate); //Temporary workaround. Beta editor changed the event listener logic, but live is still using the old version //if-else should be removed once not needed anymore if("events" in getWaze().model.segments) { //Live getWaze().model.segments.events.on({ "objectschanged": ja_calculate, "objectsremoved": ja_calculate }); getWaze().model.nodes.events.on({ "objectschanged": ja_calculate, "objectsremoved": ja_calculate }); } else if("_events" in getWaze().model.segments) { //Beta editor getWaze().model.segments.on({ "objectschanged": ja_calculate, "objectsremoved": ja_calculate }); getWaze().model.nodes.on({ "objectschanged": ja_calculate, "objectsremoved": ja_calculate }); } //Recalculate on zoom end also getWaze().map.events.register("zoomend", null, ja_calculate); ja_load(); ja_loadTranslations(); /** * Add JAI tab configuration options */ ja_settings_dom_panel.className = "side-panel-section"; ja_settings_dom_content.className = "tab-content"; ja_settings_header.appendChild(document.createTextNode(ja_getMessage("settingsTitle"))); ja_settings_dom_content.appendChild(ja_settings_header); style.appendChild(document.createTextNode(function () {/* #jaOptions > *:first-child { margin-top: 1em; } #jaOptions * { vertical-align: middle; } #jaOptions label { display: inline; } #jaOptions input, select { display: inline; margin-right: 7px; box-sizing: border-box; border: 1px solid #cccccc; border-radius: 5px; padding: 3px; } #jaOptions input[type="number"] { width: 4em; padding: 6px; } #jaOptions input[type="color"] { width: 15%; height: 2em; padding: 4px; } @supports (-webkit-appearance:none) { #jaOptions input[type="color"] { padding: 0px 2px 0px 2px; } } #jaOptions .disabled { position: relative; } #jaOptions .disabled:after { content: " "; z-index: 10; display: block; position: absolute; height: 100%; top: 0; left: 0; right: 0; background: rgba(255, 255, 255, 0.666); } */}.toString().match(/[^]*\/\*([^]*)\*\/\}$/)[1])); section.className = "form-group"; form.className = "attributes-form side-panel-section"; section.id = "jaOptions"; ja_log("---------- Creating settings HTML ----------", 2); Object.getOwnPropertyNames(ja_settings).forEach(function (a) { var setting = ja_settings[a]; var ja_controls_container = document.createElement('div'); var ja_input = document.createElement('input'); var ja_label = document.createElement('label'); ja_controls_container.className = "controls-container"; ja_input.type = setting.elementType; switch (setting.elementType) { case 'color': ja_input.id = setting.elementId; ja_controls_container.appendChild(ja_input); break; case 'number': ja_input.id = setting.elementId; ja_input.setAttribute("min", setting.min); ja_input.setAttribute("max", setting.max); ja_controls_container.appendChild(ja_input); break; /* case 'text': ja_input.id = setting.elementId; ja_input.size = (setting.max ? setting.max : 8); ja_input.maxlength = (setting.max ? setting.max : 7); ja_controls_container.appendChild(ja_input); break; */ case 'checkbox': ja_input.id = setting.elementId; ja_controls_container.appendChild(ja_input); break; case 'select': ja_input = document.createElement('select'); //Override with