WME URCom

This script is for replying to user requests the goal is to speed up and simplify the process. Thanks to Chat Jumper and URO+!

Installer ce script?
Script suggéré par l'auteur

Vous aimerez aussi WME Send to Slack.

Installer ce script
// ==UserScript==
// @name           WME URCom
// @description    This script is for replying to user requests the goal is to speed up and simplify the process. Thanks to Chat Jumper and URO+!
// @namespace      https://gitlab.com/WMEScripts
// @grant          none
// @grant          GM_info
// @version        2024.05.29.01
// @match          https://editor-beta.waze.com/*editor*
// @match          https://beta.waze.com/*editor*
// @match          https://www.waze.com/*editor*
// @author         tunisiano187 based on Rick Zabel '2014, maintained by GyllieGyllie
// @license        MIT/BSD/X11
// @compatible     chrome firefox
// @require         https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
// @supportURL      mailto:incoming+WMEScripts/URComments-French@incoming.gitlab.com
// @contributionURL https://ko-fi.com/tunisiano
// @icon			

// ==/UserScript==
const ScriptName = GM_info.script.name;
const URCommentVersion = GM_info.script.version;//var URCommentVersion = "1.5.4"; //branched from 0.9.3
const URCommentUpdateMessage = "yes"; // yes alert the user, no has a silent update.

/* Changelog
1.9.2 - Sizing Signature field
1.9.3 - Details about the Signature and the refresh need
1.9.4 - Relocate Signature settings
1.9.5 - Auto email errors
1.9.6 - Pictures in pills
1.9.7 - Pills corrections
1.9.8 - Title and pills updates
1.9.9 - Credits et corrections
1.9.10 - Bug closure text correction
1.9.11 - Design and some corrections
1.9.12 - icons before comments in the comments tab
1.9.13 - Don't complete comments, disable textarea and hide send button id the UR is locked (Out of editing area) or closed
1.9.14 - Adding Francais Belgique à la liste
2018.07.18.01 - New versionning numbers to ease the checks for last update
2018.08.04.01 - Adding the NL version
2018.08.08.01 - Signature even if no predefined answer found
2018.08.12.01 - Local version update
2018.08.15.01 - Adding the ability to add Titles in the comments part
2018.08.15.02 - Translator's name
2018.08.15.03 - Removing the open database option for now
2018.08.15.04 - Bad comment break the script
2018.08.15.05 - Title spaces
2018.08.15.06 - Test text moved
2018.08.16.01-03 - Design changes
2018.08.16.04 - Bug correction
2018.08.17.01 - Handling the ending dot on comments title that breaks the autocomplete
2018.08.18.01-03 - Change URCom logo + Design
2018.08.21.01
2018.09.02.01 - undefined mask
2019.05.19.01 - Adapt timeout to avoid useless messages
2019.08.15.01 - Adapt to the new WME version
2019.11.24.01 - Yellow Background if message from the user
2020.01.18.01 - Support of unknown reports
2020.01.18.02 - remove alert
2020.01.13.01 - Solving signature's return problem
2020.02.15.01 - Error version number
2020.04.12.01 - Add user's message in the (..) answer
2020.08.07.01 - Remove the line that hide the textarea
2023.06.04.01 - New design based on current WME styling
2023.06.16.01 - Major code overhaul & bug fixing
2023.06.16.02 - Fix migration logic being broken
2023.06.18.01 - Filter cleanup, small fixes, new features
2023.07.03.01 - Add feature to create custom responses
2023.08.03.01 - Fixes after new WME Update
2023.08.03.02 - Fixes after WME update rollback
2023.08.15.01 - Change how custom list data is stored to fix all browser support
2023.08.16.01 - Small fix to changes from yesterday
2023.08.21.01 - Small fix in migration logic being broken if you use script first time
2024.03.22.01 - Fix auto response no longer working
2024.05.29.01 - Fix some issues after WME update
*/

//here is my todo; remove ur count, instruction link in new window

let URCommentVersionUpdateNotes = "UR Comments has been updated to " + URCommentVersion + "<br />";
URCommentVersionUpdateNotes = URCommentVersionUpdateNotes + "<br />" + "- Fix issue where the script no longer worked after a recent WME update";
//URCommentVersionUpdateNotes = URCommentVersionUpdateNotes + "<br /><br />" + "Known issue:";
//URCommentVersionUpdateNotes = URCommentVersionUpdateNotes + "<br />" + "UR Pills showing amount days & comments no longer works due to how WME now renders the UR Icons. We are trying to find a fix but it may not be possible to fix this.";

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////
////// Define items that need to be at the root level so they can be used inside functions
//////
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////

let migrate = false;
const options = loadOptions();

// If we need to migrate, do the migration now
if (migrate) {
	migrateOptions();
}

// Now validate the options are ok
validateOptions(options);

// Use this for counting how many times we waited for waze to finish a task..
// currently used to write to the console so the code is easier to debug
// in the future we might do actions if we waited to long
let PauseCount = 1;

let DB;

// These are the names of the comments lists built into the script and will show up in the comment list drop down
const BoilerPlateCreatorsArray = [
	"URComDefault",
	"Custom",
	"Luxembourg",
//  "FRNL_Belgique", // Bilingue FR/NL maintainer Acidoxy
	"Francais_Belgique", //maintained tiniebongoetc https://greasyfork.org/fr/scripts/370207-wme-urcom-francais-belgique
	"Nederlands", //maintainer WimVandierendonck
];

// Get the SelectedBoilerPlateCreator
let SelectedBoilerPlateCreator = options.BoilerPlateCreators;

// If the comment list hasn't been chosen default to the URComDefault's list
if (SelectedBoilerPlateCreator === "" || SelectedBoilerPlateCreator === null || SelectedBoilerPlateCreator === "rickzabel") {
    SelectedBoilerPlateCreator = "URComDefault";
    options.BoilerPlateCreators = SelectedBoilerPlateCreator;
    saveOptions(options);
}

let CustomLists = [];
let CustomListText = [];
let InitReady = false;

let ShowTextEditFields = false;
let ShowTextOptionButtons = true;
let TextEditIndex = undefined;
let DeleteTextMode = false;

// Array that holds the comments
let URCommentsArray = [];

// These are the holders for the position in the comments list that the reminder and close messages are at
let ReminderPosition = "";
let CloseNotIdentifiedPosition = "";

const def_names = []; // Default waze message array
const URC_Text = []; // URC text
const URC_URL = []; // URC URL
const URC_Text_tooltip = []; // URC tool-tip text
const URC_USER_PROMPT = []; // URC Alerts, Confirmations, and orange box messages
let TranslatorsName = "";

// Waze swaps out the close button on the UR window after you click send. we use this to grab the close and compare to the new one
let CloseButtonHolder = "";
// Since we are scanning for open UR I need to keep track of the current urID so the comments can be overridden
let UrCommentLasturID = "";

// This is used to hold the info about the previous tab, before we auto switched tabs
let PreviousTab = null;
let PreviousTabPosition = null;

// Used to track if we are switching languages
let ChangeLanguage = false;

// Return to zoom instead of zoom 0
let ReturnToCurrentZoom = "";

//var UrCommentsIcon = '';
const UrCommentsIcon = '';
const UrCommentsTextPic = '<img alt="" style="margin-bottom: 1px; height: 12px;" src="\" />'; // Picture of the number of comments
const UrCommentsTimePic = '<img alt="" style=\"margin-bottom: 1px; height: 12px;" src=\"\" />'; // Delay picture
const URC_img_waze_editor = '<img alt="" style="height: 15px; margin-right: 5px;" src="" />';
const MagnifyingIcon = '<img alt="" style="margin-bottom: 1px; height: 12px;" src="" />';
const RefreshIcon = '<img alt="" style="margin-bottom: 1px; height: 12px;" src="\n" />';

// Keep references to our html elements
let scriptContentPane;

let nConfirm;

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////
////// bootstrap
//////
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////

// Now we use this to load the arrays, but we wait till the me tab & loads, this gives the custom comments file a chance to also load
async function URComments_bootstrap() {

	await initDatabase();

	/////////////////////////////////////////////////////////////////////////////////////////////////////////////
	// these is the array used to store the ur comments
	// comment arrays should follow the format
	// "Title",     * is what will show up in the ur comment tab
	// "comment",   * is the comment that will be sent to the user currently
	// "URStatus"   * this is action to take when the option "Auto Click Open, Solved, Not Identified" is on.
	//					after clicking send it will click one of those choices. usage is. "Open", or "Solved",or "NotIdentified",
	/////////////////////////////////////////////////////////////////////////////////////////////////////////////

	if (options.BoilerPlateCreators === "URComDefault") {

		URCommentsArray = [
			"No further communication",
			"No further information was received and the request is being closed. As you travel, please feel welcome to report any map issues you encounter. Thanks!",
			"Solved", //t0cableguy 12/8/14 //rickzabel 12/8/14 , karlcr9911 12/8/14

			"Fixed",
			"Thanks to your report we have found and fixed a problem with the map. The fix should reach mobile devices within a few days. On rare occasions it can take closer to a week.", //GizmoGuy 4/13/15
			"Solved",

			"Address Adjustments",
			"Thanks! The address has been adjusted. This should reach mobile devices within a few days. On rare occasions it can take closer to a week.", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"Solved",

			"Address in correct spot",
			"The live map is currently showing your address in the correct spot. Please remove any instance of this address from your history and favorites by tapping the 'i' within the blue circle and then 'remove from history'. Then search for the address. If you don't remove the old results from your navigation or favorites, you will continue to be routed to the old coordinates. Please submit another report if this does not resolve your issue. Thanks!",
			"Solved", //karlcr9911 rickzabel 4/3/2015

			"The road has been closed",
			"Volunteer responding - Thank you for your report. The road has been closed.", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"Solved", //requested by SkiDooGuy //changed to NotIdentified by karlcr9911 4/3/2015 //7/22/2015 changed to Solved by karlcr9911

			"Fixed Speed Limit",
			"The missing/incorrect speed limit you reported has been updated. Thank you!",
			"Solved", //karlcr9911 rickzabel

			"Address fishing",
			"Waze does not tell us your starting or ending destinations. Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel i use this one after i sent a message with Volunteer responding 1
			"Open",

			"Errors with no text",
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/8/14
			"Open",

			"Reminder message", //do not change (rickzabel)
			"Just a reminder: We have not received a response on your report. If we don't hear back from you soon, we will infer everything is okay and close the report. Thanks!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"Open",

			"No reply close message",
			"The problem was unclear and volunteers didn't receive a response, so we are closing this report. As you travel, please feel welcome to report any map issues you encounter. Thanks!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"Speed Limit Already Set",
			"Volunteer responding; The speed limit here is already set correctly. In the future, please submit speed limit requests near the point where the speed limit changes. If the speed limit change is temporary due to construction, please advise and provide additional details. If you would like to see speed limits at all times while using the app, please go to Settings > Speedometer > Show speed limit.  Thank you!",
			"NotIdentified", //rickzabel karlcr9911 8/31/2016

			"App Bug",
			"Unfortunately, In this situation, there is nothing wrong with the map that we can adjust to prevent issues with the app. Please report this to https://support.google.com/waze/answer/6276841",
			"NotIdentified", //twintiggrz, t0cableguy, rickzabel 12/27/2015

			"Bad GPS",
			"Volunteer responding - It appears that your device was having GPS trouble. GPS signals do not travel through vehicles or tall buildings. Please make sure your device is somewhere with a clear view of the sky.", //rickzabel 12/18/2014
			"NotIdentified",

			"Valid Route",
			"Volunteer responding - We reviewed the issue and did not find any map errors. It looks like Waze provided you with a valid route. Try the Waze suggested route a few times, as it may turn out to actually be faster. If not you'll be teaching Waze that that route is slower, and the faster route will become preferred.", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"Valid Left turns",
			"Volunteer responding - If you wait and complete the left turn, it may actually be faster than the alternative. If it’s not faster, your wait time will contribute to Waze’s database, thus helping to discourage the routing server from suggesting left turns at that intersection. We also suggest if you do not feel comfortable making such left turns, you can always go another route and let Waze recalculate.", //karlcr9911 4/4/15 //rickzabel 4/5/15
			"NotIdentified",

			"Valid Left turns 2",
			"Volunteer responding – We cannot disable legal turns only because they are difficult. If you wait and complete the left turn, it may actually be faster than the alternative. If it’s not faster, your wait time will contribute to Waze’s database, thus helping to discourage the routing server from suggesting left turns at that intersection. We also suggest if you do not feel comfortable making such left turns, you can always go another route and let Waze recalculate.", //karlcr9911 4/4/15 //rickzabel 4/5/15
			"NotIdentified",

			"Valid but Difficult Route",
			"Volunteer responding – We cannot disable legal routes only because they are difficult. If you wait and complete the route, it may actually be faster than the alternative. If it’s not faster, your wait time will contribute to Waze’s database, thus helping to discourage the routing server from suggesting the route. We also suggest if you do not feel comfortable, you can always go another route and let Waze recalculate.", //karlcr9911 4/4/15 //rickzabel 4/5/15
			"NotIdentified",

			"Missing place",
			"Volunteer responding - Thank you for reporting a missing place.  Anytime you find a a place that is missing from the waze app you can add it from the app by tapping the Pin icon > Place. After taking a picture of the place please add as many details as you can. Thanks!",
			"NotIdentified",

			"California double yellow",
			"Volunteer responding, In California it is perfectly legal to make a left turn across one double yellow line. Turning across two double yellow lines, spaced apart 2 feet or more, is considered a barrier, and is illegal to cross. Thanks!", //rz 2/26/15 //karlcr9911 4/4/15
			"NotIdentified",

			"Detours / Odd-Routing",
			"Volunteer responding - We can't find anything on the map to explain the route Waze gave you. Waze will route complex detours to save a few seconds. We are very sorry to say that map editors cannot be helpful in this situation. Thanks!", //rickzabel 4/18/20115
			"NotIdentified",

			"Overall Waze complaint",
			"Volunteer responding - You can help make Waze better by reporting problems as you find them. Please include as many details as possible? Thanks!",
			"NotIdentified", //rickzabel Pesach 12/22/14

			"Report to local municipality",
			"Volunteer responding - We are only able to help with map issues. This should be reported to the local municipality. Please feel welcome to report any map issues you encounter. Thanks!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"No user transponder (avoid tolls)",
			"Volunteer responding -  While Waze attempts to route you to your destination efficiently, it does not know if you have a toll transponder. To avoid tolls, there is an option under Settings > Navigation or after clicking GO tap Routes and select one without the toll icon. Thanks!", //rickzabel 11/24/2016
			"NotIdentified",

			"No user transponder",
			"Volunteer responding - While Waze attempts to route you to your destination efficiently, it does not know if you have a toll transponder.  We are very sorry to say that the volunteer map editors cannot be much help here. As you travel, please feel welcome to report any map issues you encounter. Thanks!", //rickzabel karlcr9911 4/18/2015
			"NotIdentified",

			"Not Using HOV",
			"Waze does not have the ability to know you meet the HOV criteria. Driving into the HOV lane should force Waze to recalculate your route. Afterwards you should be allowed to stay in the HOV lane. Thanks!", //rickzabel 12/14/14
			"NotIdentified",

			"U-turns",
			"Volunteer responding - Currently Waze will not tell you to make a \"U-turn\". It will route you in several left/right turns to effectively create a U-turn. This is a programming issue that cannot be changed by the volunteer map editors. We understand that Waze is working on a fix. Thanks!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"Traffic - Stale Information",
			"Map editors are unable to remove traffic jams. You can help clear traffic reports by tapping \"not there\" when prompted or by traveling through the intersection at normal speed.", // rickzabel 7/22/2015 //t0cableguy 7/22/2015
			"NotIdentified",

			"Traffic - Jams",
			"To report a traffic jams please use the Waze app by clicking the pin in the lower right and then clicking Traffic Jam. Traffic Jam reports can help route you and other Wazers around traffic problems in real-time. Thanks!", // reworded - rickzabel 12/7/2014, karlcr9911 12/8/14
			"NotIdentified",

			"Signal Avoidance Bug",
			"There are no issues with the intersection’s turn restrictions. Waze's developers are working on a fix for this issue. We do not have an ETA. Please feel free to use the turn until the issue is resolved. Thanks!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"Already included restrictions",
			"This restriction is already included in the map, Waze should not route through this illegal turn. If Waze ever gives you a route through a restricted turn, please send another Map Issue report at that time. Thanks!",
			"NotIdentified", //rickzabel Pesach 12/27/14

			"1000 mile limit",
			"The search and navigation capabilities of Waze are limited to 1000 miles. When driving further than that distance you will need to select a destination less than 1000 miles as your temporary destination.", //karlcr9911 4/5/15 //rickzabel 4/5/15
			"NotIdentified",

			"Temporary road blockage",
			"Volunteer responding - If the road is completely blocked, use the Report > Closure feature for you and others to be rerouted around it. Otherwise please use Report > Traffic. At a minimum Waze is learning that that route is slower, and a faster route will become preferred.", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"NotIdentified",

			"Temporary Road Closure",
			"Volunteer responding - For closures that last only a few days, the volunteer map editors cannot be much help. It takes at least that long for our edits to make it to the live map! When you encounter road closures in the future, please use the Report > Closure feature built into the Waze app. Thanks!",
			"NotIdentified",

			"Temporary Road Closure",
			"Do you know how long the road is going to be closed? For closures that last only a few days, the volunteer map editors cannot be much help. It takes at least that long for our edits to make it to the live map! When you encounter short-term road closures in the future, please use the Report > Closure feature built into the Waze app. If this is a long-term closure please respond and let us know as much as you can. Thanks!", // reworded - rickzabel 12/7/2014, karlcr9911 12/8/14
			"Open",

			"Closure clean-up",
			"Due to daily changing closures we are closing out the old requests to concentrate on the newest ones. For closures that last only a few days, the volunteer map editors cannot be much help. It takes at least that long for our edits to make it to the live map! When you encounter short-term road closures in the future, please use the Report > Closure feature built into the Waze app. Thanks!", //rickzabel 12/28/14
			"NotIdentified",

			"Thanks for the reply",
			"Thank you for the reply! This request will be closed. As you travel, please feel welcome to report any map issues you encounter.",
			"NotIdentified", //rickzabel 12/27/14

			"No further communication",
			"No further information was received and the request is being closed. As you travel, please feel welcome to report any map issues you encounter. Thanks!", //t0cableguy 12/8/14 //rickzabel 12/8/14 , karlcr9911 12/8/14
			"NotIdentified", // same comment different action based off UR status rickzabel 12/7/14, karlcr9911 12/7/14 // one sentence? rickzabel 12/7/14 t0cableguy 12/8/14

			"water non-editable",
			"This particular water feature is not editable by the volunteer editors, feel free to report this to support at https://support.google.com/waze/",
			"NotIdentified",

			"Clear TTS Cache",
			"Please clear your Text-to-Speech cache. In the navigate search box type cc@tts in the search field and press search. You will get a message that the TTS file has been cleared. Your TTS cache will be re-populated as you use routing.. Thanks!", //GizmoGuy411  t0cableguy rickzabel 2015-04-04
			"NotIdentified", //t0cableguy This should be a last chance option for fixing the issue.04-04-2015  //rickzabel 04-04-2015

			"<br>",
			"",
			"",

			"Problem appears corrected",
			"Just a reminder: The problem appears to be corrected. Please let us know if you are continuing to have the issue. If we do not hear from you in a few days we will close this report. Thanks!",
			"Open", //karlcr9911 12/7/14 t0cableguy 12/8/14 //rickzabel 12/8/14

			"Clears comment & sets UR status to Open",
			"",
			"Open",

			"Include Users Description",
			"Volunteer responding - You reported \"$URD\" and Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!",
			"Open",

			// selected segments requires the use of https://greasyfork.org/en/scripts/9232-wme-panel-swap
			"Include selected segments names",
			"Volunteer responding - You reported a problem near $SELSEGS, Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!",
			"Open",

			"Wrong Street Name",
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know which street name you think is wrong and what it should be? Thanks",
			"Open", //rickzabel Pesach 12/22/14

			"<br>",
			"",
			"",

			// Default URs  6 through 22 are all the different types of UR that a user can submit do not change them thanks
			"Incorrect turn", //6
			"Volunteer responding - Would you please let us know what turn you are having a problem with? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Incorrect address", //7
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you tell us your destination as you entered it into Waze? What is the problem you are having with this address? Thanks!", //rickzabel 12/8/14
			"Open",

			"Incorrect route", //8
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Missing roundabout", //9
			"Volunteer responding - Would you tell us as much as possible about the roundabout you believe is missing? Thanks!",
			"Open",

			"General error", //10
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know what went wrong? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Turn not allowed", //11
			"Volunteer responding - Would you please let us know which turn was or should not be allowed and why? Please specify the street names at the intersection. Thanks!", //rickzabel 2/26/15
			"Open",

			"Incorrect junction", //12
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Missing bridge overpass", //13
			"Volunteer responding - Would you please let us know what overpass you believe is missing? When moving at highway speeds, Waze deliberately chooses not to display some nearby features to avoid cluttering the screen. Would you tell us as much as possible about the missing overpass. Thanks!", //rickzabel 12/9/14
			"Open",

			"Wrong driving direction", //14
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Missing Exit", //15
			"Volunteer responding - Waze did not send us enough information to fix your request. Would you please let us know as much as possible about the missing exit? Thanks!", //rickzabel 12/9/14
			"Open",

			"Missing Road", //16
			"Volunteer responding - Would you tell us as much as possible about the road you believe is missing? Thanks!", //rickzabel 12/9/14
			"Open",


			"Missing Landmark", //18
			"Volunteer responding - Would you tell us as much as possible about the landmark you believe is missing? Thanks!",
			"Open",

			/*
			"Blocked Road", //19
			"Volunteer responding -",
			"Open",

			"Missing Street Name", //21
			"Volunteer responding -",
			"Open",

			"Incorrect Street Prefix or Suffix", ///22
			"Volunteer responding -",
			"Open",
			*/

			"Speed Limit", //23
			"Waze did not send us enough information to fix your request. Would you please tell us as much as possible about the issue regarding the speed limit? In the future please submit requests near the point where the speed limit changes. If the speed limit change is temporary due to construction, please advise and provide additional details. If you would like to see speed limits at all times while using the app, please go to Settings > Speedometer > Show speed limit. Thanks!",
			"Open", //rickzabel

			"<br>",
			"",
			"",
			// End of Default URs

			"User Followed Waze's route",
			"Volunteer responding - It appears that you followed the route Waze suggested. Would you please let us know what went wrong with the route Waze gave you? Would you tell us your destination as you entered it into Waze? Thanks!", //reworded rickzabel 12/7/2014
			"Open",

			"Alley Interference",
			"Volunteer responding - Waze does not let the us know where you were going, although it was probably adjacent to the alley. Would you tell us your destination as you entered it into Waze? Thanks!", //rickzabel 12/9/14
			"Open",

			"Road Closed",
			"Volunteer responding - Would you please let us know the following; What road is closed?; between which intersections is this road closed; Do you know how long this road is scheduled to be closed? Thanks!", //rickzabel 12/9/14
			"Open",

			"Area Entrances",
			"We have had problems with Google pins being placed in the center of large landmarks. Delete your previous search and do a new search for the location. Go to the bottom of the auto fill list to see more results and make sure you pick the Waze search engine.",
			"Open",

			"48 Hour Reply",
			//"Please allow 48 hours for changes to be reflected in the live map.",
			"We made some changes to the map, please allow up to 48 hours for the changes to be reflected on the live map.", //rickzabel 12/7/14 //t0cableguy 12/8/14, karlcr9911 12/8/14
			"Open",

			"Clear Saved Locations",
			"To get an updated result, remove the location from your navigation history and then search for the location again.", //t0cableguy 12/8/14, karlcr9911 12/8/14
			"Open",

			"Address - Incorrect Position",
			"Can you tell us the address or if you can revisit visit the location, please show us the correct position by using the Report > Places feature. Before you save move as close as possible to the entrance. Please do not submit pictures containing faces, license plates, or personal details. Thanks!", //rickzabel t0cableguy 04-04-2015
			"Open",

			"Address - Missing from Map",
			"Volunteer responding - Would you let us know the address that is missing? The available resources do not have the address available for your location. You can use the Report > Places feature in Waze to mark the location. Before you save move close as possible to the entrance. Do not submit pictures containing faces, license plates, or personal details. Thanks!", //rickzabel 4/5/2015 //t0cableguy 4/5/2015
			"Open",

			"Address - Bad Results",
			"Search results in Waze are retrieved from numerous sources. After tapping search, Scroll to the bottom and you will see options for other search engines. Please try a different option as another search engine might have the address you are looking for", //rickzabel 12/9/14
			"Open",

			"House Number Adjustment",
			"I've forced Waze to re-register the house number for your destination. I believe this should correct your issue. Please allow up to 48 hours for changes to be reflected in the live map. If you have the location in your saved searches or favorites, please remove them and re-add the destination. Please let me know if you continue to experience this problem by submitting another error report. Thanks!", //rickzabel 12/7/14 //karlcr9911 12/8/14
			"Open",

			"Missing Bridges or Roads",
			"The roads for this area are thoroughly mapped and the volunteer editors cannot find anything missing from the map. When you are moving, Waze deliberately chooses not to display some nearby features to avoid cluttering the screen. If you are certain a feature is missing from the map, please reply and tell us as much as possible about it. Thanks!", //rickzabel karlcr9911 4/18/2015
			"Open",

			"Manual Refresh",
			"Please try doing these options. Tap the Search Icon > Settings gear icon > Display & Map > Data Transfer > Refresh map of my area. Secondly, you can try clearing Waze's app cache in your phone’s app manager. The final option is to reset the app by going to the navigation screen and type ##@resetapp in search field and hit search.", // rickzabel 11/24/16
			"Open",

			"Pave Road",
			"Volunteer responding - You can pave the road from the app by tapping the Pin icon > Map Issue > Pave Road tab. After leaving the paved road, tap Start paving. Once done, tap the Steamroller > Stop paving. You can provide information about the new road such as its name by tapping on the Pin icon > Map Issue > Missing Road. Thanks!", //karlcr9911 4/5/15 //rickzabel 4/5/15 removed single quotes
			"Open",

			"Unlock request",
			"I have started the process to get this issue fixed. Thanks for your report!", //GizmoGuy, t0cableguy, rickzabel 1/14/2015
			"Open"
		];

		// Auto insertion config:
		// The position in the list that the reminder message is at. (counting titles, comments, and ur status)
		ReminderPosition = 24;

		// The position of the close as Not Identified message that you have in the list (the first comment is the list is 0)
		CloseNotIdentifiedPosition = 27;

		// Waze's default URs number to name conversion array
		// Thanks to SuperMedic

		def_names[6] = "Incorrect turn";
		def_names[7] = "Incorrect address";
		def_names[8] = "Incorrect route";
		def_names[9] = "Missing roundabout";
		def_names[10] = "General error";
		def_names[11] = "Turn not allowed";
		def_names[12] = "Incorrect junction";
		def_names[13] = "Missing bridge overpass";
		def_names[14] = "Wrong driving direction";
		def_names[15] = "Missing Exit";
		def_names[16] = "Missing Road";
		def_names[18] = "Missing Landmark";
		def_names[19] = "Blocked Road";
		def_names[21] = "Missing Street Name";
		def_names[22] = "Incorrect Street Prefix or Suffix";
		def_names[23] = "Speed Limit";  //speed limit ur type is number 23

		// Zoom out links
		URC_Text[0] = "Zoom Out 0 & Close UR";
		URC_Text_tooltip[0] = "Zooms all the way out and closes the UR window";

		URC_Text[1] = "Zoom Out 2 & Close UR";
		URC_Text_tooltip[1] = "Zooms out to level 2 and closes the UR window (this is where I found most of the toolbox highlighting works)";

		URC_Text[2] = "Zoom Out 3 & Close UR";
		URC_Text_tooltip[2] = "Zooms out to level 3 and closes the UR window (this is where I found most of the toolbox highlighting works)";

		URC_Text_tooltip[3] = "Reload the map";

		URC_Text[4] = "UR count : ";
		URC_Text_tooltip[4] = "Number of URs Shown on screen";

		// Tab names
		URC_Text[5] = "Comments";
		URC_Text[6] = "UR Filtering";
		URC_Text[7] = "Settings";

		//UR Filtering Tab
		URC_Text[8] = "Click here for Instructions";
		URC_Text_tooltip[8] = "Instructions for UR filtering";
		URC_URL[8] = "https://docs.google.com/presentation/d/1zwdKAejRbnkUll5YBfFNrlI2I3Owmb5XDIbRAf47TVU/";

		URC_Text[9] = "Enable URComments UR filtering";
		URC_Text_tooltip[9] = "Enable or disable URComments filtering";

		URC_Text[10] = "Enable UR pill counts";
		URC_Text_tooltip[10] = "Enable or disable the pill with UR counts";

		URC_Text[12] = "Hide Waiting";
		URC_Text_tooltip[12] = "Only show URs that need work (hide in-between states)";

		URC_Text[13] = "Only show my URs";
		//URC_Text_tooltip[13] = "Hide UR where there are zero comments from the logged in editor";
		URC_Text_tooltip[13] = "Hide URs where you have no comments";

		URC_Text[14] = "Show others URs past reminder + close";
		URC_Text_tooltip[14] = "Show URs that other commented on that have gone past the reminder and close day settings added together";

		URC_Text[15] = "Hide URs Reminder needed";
		URC_Text_tooltip[15] = "Hide URs where reminders are needed";

		URC_Text[16] = "Hide URs user replies";
		URC_Text_tooltip[16] = "Hide UR with user replies";

		URC_Text[17] = "Hide URs close needed";
		URC_Text_tooltip[17] = "Hide URs that need closing";

		URC_Text[18] = "Hide URs no comments";
		URC_Text_tooltip[18] = "Hide URs that have zero comments";

		URC_Text[19] = "hide 0 comments without descriptions";
		URC_Text_tooltip[19] = "Hide URs that do not have descriptions or comments";

		URC_Text[20] = "hide 0 comments with descriptions";
		URC_Text_tooltip[20] = "Hide URs that have descriptions and zero comments";

		URC_Text[21] = "Hide Closed URs";
		URC_Text_tooltip[21] = "Hide closed URs";

		URC_Text[22] = "[URO+] Hide Tagged URs";
		URC_Text_tooltip[22] = "Hide URs that are tagged with URO+ style tags ex. [NOTE]";

		URC_Text[23] = "Reminder days: ";
		//URC_Text_tooltip[23] = "";

		URC_Text[24] = "Close days: ";
		//URC_Text_tooltip[] = "";

		//settings tab
		URC_Text[25] = "Auto set new UR comment";
		URC_Text_tooltip[25] = "Auto set the UR comment on new URs that do not already have comments";

		URC_Text[26] = "Auto set reminder UR comment";
		URC_Text_tooltip[26] = "Auto set the UR reminder comment for URs that are older than reminder days setting and have only one comment";

		URC_Text[27] = "Auto zoom in on new UR";
		URC_Text_tooltip[27] = "Auto zoom in when opening URs with no comments and when sending UR reminders";

		URC_Text[28] = "Auto center on UR";
		URC_Text_tooltip[28] = "Auto Center the map at the current map zoom when UR has comments and the zoom is less than 3";

		URC_Text[29] = "Auto click open, solved, not identified";
		URC_Text_tooltip[29] = "Suppress the message about recent pending questions to the reporter and then depending on the choice set for that comment Clicks Open, Solved, Not Identified";

		URC_Text[30] = "Auto save after a solved or not identified comment";
		URC_Text_tooltip[30] = "If Auto Click Open, Solved, Not Identified is also checked, this option will click the save button after clicking on a UR-Comment and then the send button";

		URC_Text[31] = "Auto close comment window";
		URC_Text_tooltip[31] = "For the user requests that do not require saving this will close the user request after clicking on a UR-Comment and then the send button";

		URC_Text[32] = "Auto reload map after comment";
		URC_Text_tooltip[32] = "Reloads the map after clicking on a UR-Comment and then send button. This does not apply to any messages that needs to be saved, since saving automatically reloads the map. Currently this is not needed but I am leaving it in encase Waze makes changes";

		URC_Text[33] = "Auto zoom out after comment";
		URC_Text_tooltip[33] = "After clicking on a UR-Comment in the list and clicking send on the UR the map zoom will be set back to your previous zoom";

		URC_Text[34] = "Auto switch to the UrComments tab";
		URC_Text_tooltip[34] = "Auto switch to the URComments tab when opening a UR, when the UR window is closed you will be switched to your previous tab";

		URC_Text[35] = "Close message - double click link (auto send)";
		URC_Text_tooltip[35] = "Add an extra link to the close comment when double clicked will auto send the comment to the UR windows and click send, and then will launch all of the other options that are enabled";

		URC_Text[36] = "All comments - double click link (auto send)";
		URC_Text_tooltip[36] = "Add an extra link to each comment in the list that when double clicked will auto send the comment to the UR windows and click send, and then will launch all of the other options that are enabled";

		URC_Text[37] = "Comment List";
		URC_Text_tooltip[37] = "This shows the selected comment list. There is support for a custom list. If you would like your comment list built into this script or have suggestions on the Comments team’s list, please contact me at rickzabel @waze or @gmail";

		URC_Text[38] = "Disable done / next buttons";
		URC_Text_tooltip[38] = "Disable the done / next buttons at the bottom of the new UR window";

		URC_Text[39] = "Unfollow UR after send";
		URC_Text_tooltip[39] = "Unfollow UR after sending comment";

		URC_Text[40] = "Auto send reminders";
		URC_Text_tooltip[40] = "Auto send reminders to my UR as they are on screen";

		URC_Text[41] = "Replace tag name with editor name";
		URC_Text_tooltip[41] = "When a UR has the logged in editors name in the description or any of the comments of the UR (not the name Waze automatically adds when commenting) replace the tag type with the editors name";

		URC_Text[42] = "(Double Click)"; //double click to close links
		URC_Text_tooltip[42] = "Double click here to auto send - ";

		URC_Text[43] = "[URO+] Dont show tag name on pill";
		URC_Text_tooltip[43] = "Dont show tag name on pill where there is a URO+ tag";

		URC_Text[44] = "Your signature";
		URC_Text_tooltip[44] = "Here you can set your signature, after making a change, please refresh your page to update the texts";

		URC_Text[45] = "c"; // Comment initial
		URC_Text_tooltip[45] = "Comments";

		URC_Text[46] = "d"; // Day initial
		URC_Text_tooltip[46] = "Days";

		URC_Text[47] = "Credits";
		URC_Text_tooltip[47] = "Credits/Contacts";

		URC_Text[48] = "Developper";
		URC_Text_tooltip[48] = "Developper's nickname";

		URC_Text[49] = "Translations & Comments";
		URC_Text_tooltip[49] = "Translator's nickname";

		URC_Text[50] = "Include the PS";
		URC_Text_tooltip[50] = "Include the PS in the text";

		URC_Text[51] = "Post scriptum";
		URC_Text_tooltip[51] = "Post scriptum";

		URC_Text[52] = "These options are still in test";

		URC_Text[53] = "Maintainer";
		URC_Text_tooltip[53] = "Script maintained by";

		URC_Text[54] = "Greeting";
		URC_Text_tooltip[54] = "Set a custom greeting, this will be put before the configured response";

		URC_Text[55] = "Hide AndroidAuto description";
		URC_Text_tooltip[55] = "Hides the 'Reported from AAOS' description";

		URC_Text[56] = "+ Create New";

		URC_Text[57] = "Response List";
		URC_Text_tooltip[57] = "Use a custom created response list";

		URC_Text[58] = "Responses";

		URC_Text[59] = "Edit custom response";
		URC_Text[60] = "Add custom response";

		URC_Text[61] = "Title";
		URC_Text_tooltip[61] = "Enter the title of the option, for auto fill this should match ur type";

		URC_Text[62] = "Response";
		URC_Text_tooltip[62] = "Enter the message to reply to the UR";

		URC_Text[63] = "UR Status";
		URC_Text_tooltip[63] = "Select the status to apply when clicking this option";

		URC_Text[64] = "Signature";
		URC_Text_tooltip[64] = "Add your signature to the response";

		URC_Text[65] = "Save";
		URC_Text[66] = "Cancel";

		URC_Text[67] = "Custom List Options";
		URC_Text[68] = "Add text option";
		URC_Text[69] = "Edit a text option";
		URC_Text[70] = "Edit name of the list";
		URC_Text[71] = "DANGER ZONE";
		URC_Text[72] = "Delete this list";
		URC_Text[73] = "Cancel delete";
		URC_Text[74] = "Delete a text option";

		URC_USER_PROMPT[0] = "URCom - You either have a older version of the custom comments file or a syntax error either will keep the custom list from loading. Missing: ";

		URC_USER_PROMPT[1] = "URCom - You are missing the following items from your custom comment list: ";

		URC_USER_PROMPT[2] = "List can not be found. You can find the list and instructions at https://wiki.waze.com/wiki/User:Rickzabel/UrComments/";

		URC_USER_PROMPT[3] = "URComments you can not set close days to zero";

		URC_USER_PROMPT[4] = "URCom - To use the double click links you must have the Auto click open, solved, not identified option enabled";

		URC_USER_PROMPT[5] = "URCom - Aborting FilterURs2 because both filtering, counts, and auto reminders are disabled";

		URC_USER_PROMPT[6] = "URCom - Loading UR data has timed out, retrying."; //this message is shown across the top of the map in a orange box, length must be kept short

		URC_USER_PROMPT[7] = "URCom - Adding reminder message to UR: "; //this message is shown across the top of the map in a orange box, length must be kept short

		URC_USER_PROMPT[8] = "URComment's UR Filtering has been disabled because URO+\'s UR filters are active."; //this message is shown across the top of the map in a orange box, length must be kept short

		URC_USER_PROMPT[9] = "UrComments has detected that you have unsaved edits!\n\nWith the Auto Save option enabled and with unsaved edits you cannot send comments that would require the script to save. Please save your edits and then re-click the comment you wish to send.";

		URC_USER_PROMPT[10] = "URCom - Can not find the comment box! In order for this script to work you need to have a UR open."; //this message is shown across the top of the map in a orange box, length must be kept short

		URC_USER_PROMPT[11] = "URCom - This will send reminders at the reminder days setting. This only happens when they are visible on your screen. NOTE: when using this feature you should not leave any UR open unless you had a question that needed an answer from the wazer as this script will send those reminders."; //conformation message/ question

		URC_USER_PROMPT[12] = "URCom - Your configured custom list doesn't exist anymore!";

		URC_USER_PROMPT[13] = "This name already exists!";

		URC_USER_PROMPT[14] = "Successfully added new list";

		URC_USER_PROMPT[15] = "Failed to add new list!";

		URC_USER_PROMPT[16] = "Enter new name for the list";

		URC_USER_PROMPT[16] = "Successfully updated name";

		URC_USER_PROMPT[17] = "Failed to update list!";

		URC_USER_PROMPT[18] = "Not all required fields are set!";

		URC_USER_PROMPT[19] = "Failed to save custom text!";

		URC_USER_PROMPT[20] = "Are you sure you want to delete this list?";

		URC_USER_PROMPT[21] = "Failed to delete list!";

		URC_USER_PROMPT[22] = "Click the text option to delete";

		URC_USER_PROMPT[23] = "Failed to delete item!";

		URC_USER_PROMPT[24] = "Click the text option to edit";

		TranslatorsName = "@tunisiano187";

		// End URComDefault's list
	} else {

		// Custom other languages lists from external list
		try {

			// Custom list
			URCommentsArray = eval("window.Urcomments" + options.BoilerPlateCreators + "Array2");

			// The position in the list that the reminder message is at. (starting at 0 counting titles, comments, and ur status)
			ReminderPosition = eval("window.Urcomments" + options.BoilerPlateCreators + "ReminderPosistion");

			// The position of the close as Not Identified message (starting at 0 counting titles, comments, and ur status)
			// Yes the name is spelled wrong, but we need to leave that since external scripts for translations set it like that
			CloseNotIdentifiedPosition = eval("window.Urcomments" + options.BoilerPlateCreators + "CloseNotIdentifiedPosistion");

			// Copy the waze default titles into the active?
			// Waze's default URs number to name conversion array
			// Thanks to SuperMedic

			def_names[6] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[6]"); //"Incorrect turn";
			def_names[7] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[7]"); //"Incorrect address";
			def_names[8] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[8]"); //"Incorrect route";
			def_names[9] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[9]"); //"Missing roundabout";
			def_names[10] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[10]"); //"General error";
			def_names[11] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[11]"); //"Turn not allowed";
			def_names[12] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[12]"); //"Incorrect junction";
			def_names[13] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[13]"); //"Missing bridge overpass";
			def_names[14] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[14]"); //"Wrong driving direction";
			def_names[15] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[15]"); //"Missing Exit";
			def_names[16] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[16]"); //"Missing Road";
			def_names[18] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[18]"); //"Missing Landmark";
			def_names[19] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[19]"); //"Blocked Road";
			def_names[21] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[21]"); //"Missing Street Name";
			def_names[22] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[22]"); //"Incorrect Street Prefix or Suffix";
			def_names[23] = eval("window.Urcomments" + options.BoilerPlateCreators + "def_names[23]"); //"Speed limits";

			URC_Text[0] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[0]");
			URC_Text_tooltip[0] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[0]");

			URC_Text[1] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[1]");
			URC_Text_tooltip[1] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[1]");

			URC_Text[2] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[2]");
			URC_Text_tooltip[2] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[2]");

			URC_Text[3] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[3]");
			URC_Text_tooltip[3] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[3]");

			URC_Text[4] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[4]");
			URC_Text_tooltip[4] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[4]");

			URC_Text[5] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[5]");
			URC_Text_tooltip[5] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[5]");

			URC_Text[6] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[6]");
			URC_Text_tooltip[6] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[6]");

			URC_Text[7] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[7]");
			URC_Text_tooltip[7] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[7]");

			URC_Text[8] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[8]");
			URC_Text_tooltip[8] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[8]");
			URC_URL[8] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_URL[8]");

			URC_Text[9] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[9]");
			URC_Text_tooltip[9] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[9]");

			URC_Text[10] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[10]");
			URC_Text_tooltip[10] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[10]");

			URC_Text[11] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[11]");
			URC_Text_tooltip[11] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[11]");

			URC_Text[12] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[12]");
			URC_Text_tooltip[12] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[12]");

			URC_Text[13] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[13]");
			URC_Text_tooltip[13] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[13]");

			URC_Text[14] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[14]");
			URC_Text_tooltip[14] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[14]");

			URC_Text[15] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[15]");
			URC_Text_tooltip[15] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[15]");

			URC_Text[16] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[16]");
			URC_Text_tooltip[16] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[16]");

			URC_Text[17] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[17]");
			URC_Text_tooltip[17] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[17]");

			URC_Text[18] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[18]");
			URC_Text_tooltip[18] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[18]");

			URC_Text[19] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[19]");
			URC_Text_tooltip[19] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[19]");

			URC_Text[20] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[20]");
			URC_Text_tooltip[20] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[20]");

			URC_Text[21] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[21]");
			URC_Text_tooltip[21] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[21]");

			URC_Text[22] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[22]");
			URC_Text_tooltip[22] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[22]");

			URC_Text[23] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[23]");
			URC_Text_tooltip[23] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[23]");

			URC_Text[24] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[24]");
			URC_Text_tooltip[24] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[24]");

			URC_Text[25] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[25]");
			URC_Text_tooltip[25] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[25]");

			URC_Text[26] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[26]");
			URC_Text_tooltip[26] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[26]");

			URC_Text[27] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[27]");
			URC_Text_tooltip[27] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[27]");

			URC_Text[28] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[28]");
			URC_Text_tooltip[28] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[28]");

			URC_Text[29] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[29]");
			URC_Text_tooltip[29] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[29]");

			URC_Text[30] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[30]");
			URC_Text_tooltip[30] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[30]");

			URC_Text[31] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[31]");
			URC_Text_tooltip[31] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[31]");

			URC_Text[32] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[32]");
			URC_Text_tooltip[32] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[32]");

			URC_Text[33] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[33]");
			URC_Text_tooltip[33] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[33]");

			URC_Text[34] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[34]");
			URC_Text_tooltip[34] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[34]");

			URC_Text[35] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[35]");
			URC_Text_tooltip[35] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[35]");

			URC_Text[36] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[36]");
			URC_Text_tooltip[36] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[36]");

			URC_Text[37] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[37]");
			URC_Text_tooltip[37] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[37]");

			URC_Text[38] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[38]");
			URC_Text_tooltip[38] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[38]");

			URC_Text[39] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[39]");
			URC_Text_tooltip[39] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[39]");

			URC_Text[40] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[40]");
			URC_Text_tooltip[40] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[40]");

			URC_Text[41] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[41]");
			URC_Text_tooltip[41] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[41]");

			URC_Text[42] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[42]");
			URC_Text_tooltip[42] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[42]");

			URC_Text[43] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[43]");
			URC_Text_tooltip[43] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[43]");

			URC_Text[44] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[44]");
			URC_Text_tooltip[44] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[44]");

			URC_Text[45] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[45]");
			URC_Text_tooltip[45] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[45]");

			URC_Text[46] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[46]");
			URC_Text_tooltip[46] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[46]");

			URC_Text[47] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[47]");
			URC_Text_tooltip[47] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[47]");

			URC_Text[48] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[48]");
			URC_Text_tooltip[48] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[48]");

			URC_Text[49] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[49]");
			URC_Text_tooltip[49] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[49]");

			URC_Text[50] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[50]");
			URC_Text_tooltip[50] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[50]");

			URC_Text[51] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[51]");
			URC_Text_tooltip[51] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[51]");

			URC_Text[52] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[52]");

			URC_Text[53] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[53]");
			URC_Text_tooltip[53] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[53]");

			URC_Text[54] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[54]");
			URC_Text_tooltip[54] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[54]");

			URC_Text[55] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[55]");
			URC_Text_tooltip[55] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[55]");

			URC_Text[56] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[56]");

			URC_Text[57] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[57]");
			URC_Text_tooltip[57] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[57]");

			URC_Text[58] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[58]");

			URC_Text[59] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[59]");
			URC_Text[60] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[60]");

			URC_Text[61] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[61]");
			URC_Text_tooltip[61] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[61]");

			URC_Text[62] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[62]");
			URC_Text_tooltip[62] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[62]");

			URC_Text[63] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[63]");
			URC_Text_tooltip[63] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[63]");

			URC_Text[64] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[64]");
			URC_Text_tooltip[64] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text_tooltip[64]");

			URC_Text[65] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[65]");
			URC_Text[66] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[66]");

			URC_Text[67] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[67]");
			URC_Text[68] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[68]");
			URC_Text[69] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[69]");
			URC_Text[70] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[70]");
			URC_Text[71] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[71]");
			URC_Text[72] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[72]");
			URC_Text[73] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[73]");
			URC_Text[74] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_Text[74]");

			URC_USER_PROMPT[0] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[0]");
			URC_USER_PROMPT[1] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[1]");
			URC_USER_PROMPT[2] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[2]");
			URC_USER_PROMPT[3] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[3]");
			URC_USER_PROMPT[4] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[4]");
			URC_USER_PROMPT[5] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[5]");
			URC_USER_PROMPT[6] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[6]");
			URC_USER_PROMPT[7] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[7]");
			URC_USER_PROMPT[8] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[8]");
			URC_USER_PROMPT[9] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[9]");
			URC_USER_PROMPT[10] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[10]");
			URC_USER_PROMPT[11] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[11]");
			URC_USER_PROMPT[12] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[12]");
			URC_USER_PROMPT[13] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[13]");
			URC_USER_PROMPT[14] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[14]");
			URC_USER_PROMPT[15] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[15]");
			URC_USER_PROMPT[16] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[16]");
			URC_USER_PROMPT[17] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[17]");
			URC_USER_PROMPT[18] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[18]");
			URC_USER_PROMPT[19] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[19]");
			URC_USER_PROMPT[20] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[20]");
			URC_USER_PROMPT[21] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[21]");
			URC_USER_PROMPT[22] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[22]");
			URC_USER_PROMPT[23] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[23]");
			URC_USER_PROMPT[24] = eval("window.Urcomments" + options.BoilerPlateCreators + "URC_USER_PROMPT[24]");

			TranslatorsName = eval("window.Urcomments" + options.BoilerPlateCreators + "TranslatorsName");

		} catch (err) {
			alert("URC: All of the text in URC is now configurable within the custom comments file. Your comments file " + options.BoilerPlateCreators + " is outdated, has errors, or your language file is not installed please back up your comments. Then force update the comments file from greasyfork and paste your comments back into the custom comments file. Since there is an error the comments team's list will be chosen.");
			parent.location='mailto:incoming+WMEScripts/URComments-French@incoming.gitlab.com?subject=BEFR%20error&body=' + options.BoilerPlateCreators + " err : " + err;

			options.BoilerPlateCreators = 'URComDefault';
			saveOptions(options);

			refreshUI();
			return false;
		}
	}

	const request = DB
		.transaction("custom_lists")
		.objectStore("custom_lists")
		.getAll();

	request.onsuccess = (event) => {
		if (event.target.result) {

			const results = [...event.target.result];

			results.sort((a, b) => {
				return a.order - b.order
			});

			CustomLists = [];
			CustomLists.push("Default");

			results.forEach(list => {
				CustomLists.push(list.name);
			})

			CustomLists.push(URC_Text[56]);

			loadCustomText(() => {
				InitReady = true;
			});

		}
	};

	startCode();
	displayChangelog();
}

function loadCustomText(callback) {

	if (options.CustomTextList && options.CustomTextList !== "Default") {

		CustomListText = [];

		// Verify it still exists
		if (CustomLists.indexOf(options.CustomTextList) === -1) {

			alert(URC_USER_PROMPT[12]);
			options.CustomTextList = "";
			saveOptions(options);

		} else {

			console.log("[URCom] Loading custom text: " + options.CustomTextList);

			const request = DB
				.transaction("custom_lists")
				.objectStore("custom_lists")
				.get(options.CustomTextList);

			request.onsuccess = (event) => {

				if (event.target.result) {

					const results = [...event.target.result.responses];

					for (let i = 0; i < results.length; i++) {
						const result = results[i];

						CustomListText.push({
							sorting: result.sorting,
							name: result.name,
							text: result.text,
							status: result.status,
							signature: result.signature
						});
					}

					CustomListText.sort((a, b) => {
						return a.sorting - b.sorting
					});

				}

				callback();

			};

		}
	} else {
		callback();
	}

}

function displayChangelog() {

	if (!WazeWrap.Interface) {
		setTimeout(displayChangelog, 1000);
		return;
	}

	if (URCommentUpdateMessage === "yes") {
		// Alert the user in URComment version updates
		if (localStorage.getItem('URComVersion') === URCommentVersion) {
			console.log("[URCom] Version - " + URCommentVersion);
		} else {
			WazeWrap.Interface.ShowScriptUpdate(ScriptName, URCommentVersion, URCommentVersionUpdateNotes + "<br />", "https://gitlab.com/WMEScripts/URComments-French");

			const updateName = "#wmeurcom" + URCommentVersion.replaceAll(".", "");
			$(updateName + " .WWSUFooter a").text("Gitlab")

			localStorage.setItem('URComVersion', URCommentVersion);
		}
	}

}

function refreshUI() {
	// Clear the html from the tabs
	$("#sidepanel-Comments").html('');

	// Reload the content
	ChangeLanguage = true;
	URComments_bootstrap();
}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////
////// init
//////
////////////////////////////////////////////////////////////////////////////////////////////////////////////
function applyCss() {
	// CSS
	// Expand the UR textarea so we can verfiy what comment we clicked on. special thanks to SeekingSerenity
	let g = '.ur-comment-list .comment-list { bottom: 200px !important; } .ur-comment-list .new-comment-form textarea { height: 140px !important; } .ur-comment-list .new-comment-form { height: 200px !important; }';

	const wazeHeight = $('.view-area').height();
	if (wazeHeight > 500) {
		// beta-editor comment textarea
		g = g + ' .new-comment-form .new-comment-text { height: 140px !important; }';
	}

	// css for items in my tab that are in a label (uro presets)
	g = g + '#sidepanel-Comments label { cursor:pointer; margin:0px 0px 0px; vertical-align: middle;font-size: 10px;}';

	// css for checkboxes
	g = g + ' #sidepanel-Comments .URCommentsCheckbox { text-decoration:none; cursor:pointer; color: #000000; margin:0px 0px 0px; vertical-align: middle; font-size: 12px;}';

	// css for our comments,
	g = g + ' #sidepanel-Comments .URComments { text-decoration:none; cursor:pointer; color: #000000; font-size: 12px;}'; // margin-top: 5px;

	// css for our uro presets,
	g = g + ' #sidepanel-Comments .URCommentsPresets { text-decoration:none; cursor:pointer; color: #000000; font-size: 10px;}';

	// css for our nav tabs,
	g = g + ' #comments-tab22 ul { font-size: 12px; padding: 0px;}';

	// css for our nav tabs links,
	g = g + ' #comments-tab22 a { padding: 3px !important ; margin-right: 0px !important;}';

	// keep the padding on our nav tabs
	g = g + ' #comments-tab22 nav-tabs { padding: 0px !important;}';

	// css for non selected UR opacity
	g = g + " .olMap.problem-selected .map-problem:not(.selected) { opacity: .5 !important;}";

	// css to fix the beta editors UR window
	g = g + ' .problem-edit .section .title { line-height: 15px !important;  }';

	g = g + ' .problem-edit .header { line-height: 15px !important; padding: 0px 15px!important; }';
	g = g + ' .problem-edit .section .content { padding: 5px !important;}';

	// css to undo some of the changes from maximizer
	if ($("#sidebar").width() < 300) {
		//g = g + '#sidebar { max-width: 290px !important;}';
		g = g + ' .show-sidebar .row-fluid .fluid-fixed {margin-left: 290px !important;}';
	}

	// move description up a div
	g = g + ' .problem-edit .description { background-color: white; overflow-x: hidden;  overflow-y: auto;  max-height: 80px; border-bottom: 2px solid #e9e9e9;}';

	// Make some spacing between checkboxes in settings
	g = g + '  .urcom-option { margin-top: 10px; }';

	// Our button style
	g = g + '  .urcom-button { margin: 5px 0; border: 1px solid rgba(27, 31, 35, 0.15); border-radius: 6px; box-shadow: rgba(27, 31, 35, 0.04) 0 1px 0, rgba(255, 255, 255, 0.25) 0 1px 0 inset; background-color: #FAFBFC; cursor: pointer; font-size: 14px; font-weight: 500; line-height: 20px; list-style: none; padding: 3px 10px; position: relative; transition: background-color 0.2s cubic-bezier(0.3, 0, 0.5, 1); }'

	// Append our css to the head
	$("head").append($('<style id="URCOM-CSS" type="text/css">' + g + '</style>'));
}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
////
//// Option Methods
////
////////////////////////////////////////////////////////////////////////////////////////////////////////////
function addCommentTexts(container) {

	if (!ShowTextEditFields) {

		// Custom Text
		addDropdownSettings(container, URC_Text_tooltip[57], URC_Text[57], 'CustomTextList', CustomLists, changeCustomTextList);

		const header = $('<h5 style="margin-top: 20px;">' + URC_Text[58] + '</h5>');
		container.append(header);
	}

	// Start generating the comment list and mouse click handlers

	if (options.CustomTextList && options.CustomTextList !== "Default") {

		if (ShowTextEditFields) {

			let headerText;

			if (TextEditIndex !== undefined && TextEditIndex !== -1) {
				headerText = URC_Text[59];
			} else {
				headerText = URC_Text[61];
			}

			// Add options to setup custom text
			const header = $('<h5 style="margin-top: 20px;">' + headerText + '</h5>');
			container.append(header);

			const titleInput = $('<wz-text-input id="customTextTitle"></wz-text-input>');
			const titleWrapper = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[61] + '">' + URC_Text[61] + '</span></div>').append(titleInput);

			container.append(titleWrapper);

			const textInput = $('<wz-textarea id="customTextText" style="height: 130px; width: 270px;"></wz-textarea>');
			const textWrapper = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[62] + '">' + URC_Text[62] + '</span></div>').append(textInput);

			container.append(textWrapper);

			const selectWrapper = $('<div class="urcom-option" title="' + URC_Text_tooltip[63] + '"></div>');
			selectWrapper.append('<span>' + URC_Text[63] + '</span>');
			selectWrapper.append('<br />');

			const select = $('<select name="customTextStatus" id="customTextStatus" style="width: 100%;"></select>');
			select.append('<option value="open">open</option>');
			select.append('<option value="open">closed</option>');
			select.append('<option value="open">notidentified</option>');
			selectWrapper.append(select);
			container.append(selectWrapper);

			const signature = $('<wz-checkbox id="customTextSignature" Title="' + URC_Text_tooltip[64] + '" name="types" disabled="false" checked="true">' + URC_Text[64] + '</wz-checkbox>');
			const signatureWrapper = $('<div class="urcom-option"></div>').append(signature);

			container.append(signatureWrapper);

			const saveButton = $('<wz-button size="sm" style="width: 100%; margin-top: 10px;">' + URC_Text[65] + '</wz-button>');
			saveButton.on('click', saveCustomText);
			container.append(saveButton);

			const cancelButton = $('<wz-button size="sm" style="width: 100%; margin-top: 10px;">' + URC_Text[66] + '</wz-button>');
			cancelButton.on('click', cancelTextEdit);
			container.append(cancelButton);

		} else {

			// Go over the array and generate comment divs
			for (let i = 0; i < CustomListText.length; i++) {
				const text = CustomListText[i];
				let reply = text.text;

				if (text.signature) {
					reply += '$SIGNATURE';
				}

				addComments(container, i, text.name, text.status, reply);

			}

			if (ShowTextOptionButtons) {
				const options = $('<h5 style="margin-top: 20px;">' + URC_Text[67] + '</h5>');
				container.append(options);

				const addItem = $('<div style="width: 100%; margin-top: 20px; color: green" class="urcom-button">' + URC_Text[68] + '</div>');
				addItem.on('click', addNewItem);
				container.append(addItem);

				const editButton = $('<div style="width: 100%; margin-top: 10px; color: orange" class="urcom-button">' + URC_Text[69] + '</div>');
				editButton.on('click', editItem);
				container.append(editButton);

				const editList = $('<div style="width: 100%; margin-top: 10px; color: orange" class="urcom-button">' + URC_Text[70] + '</div>');
				editList.on('click', renameList);
				container.append(editList);

				const dangerZone = $('<h5 style="margin-top: 20px; color:darkred">' + URC_Text[71] + '</h5>');
				container.append(dangerZone);

				const deleteButton = $('<div style="width: 100%; margin-top: 10px; color: orangered" class="urcom-button">' + URC_Text[72] + '</div>');
				deleteButton.on('click', deleteCustomList);
				container.append(deleteButton);

				let text;

				if (DeleteTextMode) {
					text = URC_Text[73];
				} else {
					text = URC_Text[74];
				}

				const deleteTextButton = $('<div style="width: 100%; margin-top: 10px; color: orangered" class="urcom-button">' + text + '</div>');
				deleteTextButton.on('click', deleteTextItem);
				container.append(deleteTextButton);
			}

		}

	} else {

		// CurrentIndex is used to keep count of total arrays pairs which is used on the div's id tags
		let CurrentIndex = 1;

		// Go over the array and generate comment divs
		// We jump per 3 since each comment has 3 fields
		for (let i = 0; i < URCommentsArray.length; i = i + 3) {

			addComments(container, CurrentIndex, URCommentsArray[i], URCommentsArray[i + 2].toLowerCase(), URCommentsArray[i + 1])

			// inc the CurrentIndex
			CurrentIndex++;

		}

	}

	// Add 2 br to the end of the list for lower resolution monitors
	container.append('<br /><br />');
}

function addComments(container, CurrentIndex, title, URStatus, text) {

	// Setup the comment color var
	let textColor;

	if (URStatus === "open") {
		// Black
		textColor = "#000000";
	} else if (URStatus === "solved") {
		// Green
		textColor = "#008F00";
	} else if (URStatus === "notidentified") {
		// Orange
		textColor = "#E68A00";
	} else {
		// Red - not defined and that is a problem
		textColor = "#CC0000";
	}

	// Escaping titles and comments with escapeHtml(comment) so we can display items with special char as html;
	let comment = escapeHtml(text);
	let addClicks = false;

	// normal comment link
	let commentWrapper;
	let clickText;
	let doubleClickText;

	if (title !== "<br>" && comment !== "#Title") {

		// This is a real button
		commentWrapper = $('<div id="URComments-comment' + CurrentIndex + '" style="margin: 5px 0; border: 1px solid rgba(27, 31, 35, 0.15); border-radius: 6px; box-shadow: rgba(27, 31, 35, 0.04) 0 1px 0, rgba(255, 255, 255, 0.25) 0 1px 0 inset; background-color: #FAFBFC; cursor: pointer; font-size: 14px; font-weight: 500; line-height: 20px; list-style: none; padding: 3px 10px; position: relative; transition: background-color 0.2s cubic-bezier(0.3, 0, 0.5, 1);">');

		if (DeleteTextMode) {
			commentWrapper.css("border-color", "darkred");
			commentWrapper.css("background-color", "orangered");
		} else if (TextEditIndex === -1) {
			commentWrapper.css("background-color", "yellow");
		}

		addClicks = true;

	} else {

		// These are titles/empty lines
		commentWrapper = $('<div id="URComments-comment' + CurrentIndex + '"></div>')

	}

	if (comment === "#Title") {

		const titleHeader = $('<h5 style="color:' + textColor + '; text-decoration: underline; margin-top:15px;" title="title: ' + title + ' Action: ' + URStatus + '; comment: ' + comment + ' ">' + title + '</h5>');
		commentWrapper.append(titleHeader);

	} else {

		clickText = $('<a class="URComments" style="color:' + textColor + '" title="title: ' + title + ' Action: ' + URStatus + '; comment: ' + comment + ' ">' + title + '</a>');
		commentWrapper.append(clickText);

		if (title !== "<br>") {
			if (title === URCommentsArray[CloseNotIdentifiedPosition] && options.DBLClk7DCAutoSend || options.DBLClkAll) {

				doubleClickText = $('<a id="URComments-commentDBLCLK' + CurrentIndex + '" class="URComments" style="color:' + textColor + '" title="' + URC_Text_tooltip[42] + title + '"> ' + URC_Text[42] + '</a>');
				commentWrapper.append('<br />').append(doubleClickText);

			}
		}

	}

	// Add comment to list
	container.append(commentWrapper);

	if (addClicks) {

		if (DeleteTextMode) {

			commentWrapper.on('click', executeDeleteTextItem(CurrentIndex));

		} else if (TextEditIndex === -1) {

			commentWrapper.on('click', selectEditItem(CurrentIndex));

		} else if (!TextEditIndex) {

			// Set urID to zero so we don't freak out the functions expecting a UR ID
			let urID = 0;

			// Create the click function for each comment
			commentWrapper.on('click', autoZoomIN(title, text, URStatus, urID));

			// Create the double click function for each comment
			if (doubleClickText) {

				// Use this to click send automatically
				doubleClickText.on('dblclick', autoZoomIN(title, text, URStatus, urID, "AutoSendComment"));

			}

		}

	}

}

function addOptions(container) {

	// Language select
	addDropdownSettings(container, URC_Text_tooltip[37], URC_Text[37], 'BoilerPlateCreators', BoilerPlateCreatorsArray, BoilerPlateCreatorsFunction);

	const settings = $('<h4 style="margin-top: 20px;">' + URC_Text[7] + '</h4>');
	container.append(settings);

	// Auto Reply
	addBooleanSettings(container, URC_Text_tooltip[25], URC_Text[25], 'AutoSetNewComment');

	// Automated Reminder / Closure
	addBooleanSettings(container, URC_Text_tooltip[26], URC_Text[26], 'UrCommentAutoSet4dayComment');

	// Zoom in on open
	addBooleanSettings(container, URC_Text_tooltip[27], URC_Text[27], 'NewZoomIn');

	// Center on open
	addBooleanSettings(container, URC_Text_tooltip[28], URC_Text[28], 'WithCommentRecenter');

	// Auto Change State
	addBooleanSettingsCallback(container, URC_Text_tooltip[29], URC_Text[29], 'AutoClickURStatus', (event) => {
		toggleBoolean(event);

		if (!options.AutoClickURStatus && options.SaveAfterComment) {
			options.SaveAfterComment = false;
		}

		if (options.DBLClk7DCAutoSend || options.DBLClkAll) {
			alert(URC_USER_PROMPT[4]); //"URComments to use the double click links you must have the autoset UR status option enabled"

			options.AutoClickURStatus = true;
		}

		saveOptions(options);
		refreshUI();
	});

	// Auto Save On Close
	addBooleanSettingsCallback(container, URC_Text_tooltip[30], URC_Text[30], 'SaveAfterComment', (event) => {
		toggleBoolean(event);

		if (options.SaveAfterComment && !options.AutoClickURStatus) {

			// This is required!
			options.AutoClickURStatus = true;
			saveOptions(options);

			refreshUI();
		}
	});

	// Auto Close UR Screen
	addBooleanSettings(container, URC_Text_tooltip[31], URC_Text[31], 'UrCommentAutoCloseComment');

	// Zoom after close
	addBooleanSettings(container, URC_Text_tooltip[33], URC_Text[33], 'ZoomOutAfterComment');

	// Switch to comment tab auto
	addBooleanSettings(container, URC_Text_tooltip[34], URC_Text[34], 'AutoSwitchToURCommentsTab');

	// Double clicking the 7 day close comment will auto send the 7 day close comment
	addBooleanSettingsCallback(container, URC_Text_tooltip[35], URC_Text[35], 'DBLClk7DCAutoSend', (event) => {
		toggleBoolean(event);

		if (options.DBLClk7DCAutoSend) {

			// This is required!
			options.AutoClickURStatus = true;
			saveOptions(options);

			refreshUI();

		}
	});

	// Double clicking comments will auto send comments
	addBooleanSettingsCallback(container, URC_Text_tooltip[36], URC_Text[36], 'DBLClkAll', (event) => {
		toggleBoolean(event);

		if (options.DBLClkAll) {

			// This is required!
			options.AutoClickURStatus = true;
			saveOptions(options);

			refreshUI();
		}

	});

	// Disable Next Button
	addBooleanSettings(container, URC_Text_tooltip[38], URC_Text[38], 'UrCommentDisableURDoneBtn');

	// Do not follow conversation
	addBooleanSettings(container, URC_Text_tooltip[39], URC_Text[39], 'URCommentURUnfollow');

	// Auto send reminders for UR on screen
	addBooleanSettingsCallback(container, URC_Text_tooltip[40], URC_Text[40], 'URCommentsAutoSendMyReminders', (event) => {

		if (event.target.checked) {

			// "URComments This will send reminders at the reminder days setting. This only happens when they are in your visible area. NOTE: when using this feature you should not leave any UR open unless you had a question that needed an answer from the wazer as this script will send those reminders. "
			const r = confirm(URC_USER_PROMPT[11]);

			// this is where we reuse the r var this makes the nested ifs much more simple
			if (r === true) {
				FilterURs();
				toggleBoolean(event);
			} else {
				event.preventDefault();
				event.target.checked = false;
			}

		} else {
			toggleBoolean(event);
		}

	});

	// Enable or disable ur pill counts
	addBooleanSettingsCallback(container, URC_Text_tooltip[10], URC_Text[10], 'URCommentsPillEnabled', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Replace tag with editor name
	addBooleanSettingsCallback(container, URC_Text_tooltip[41], URC_Text[41], 'URCommentsReplaceTagWithEditorName', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Don't show tagged text
	addBooleanSettingsCallback(container, URC_Text_tooltip[43], URC_Text[43], 'URCommentsDontShowTaggedText', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide the AA description
	addBooleanSettings(container, URC_Text_tooltip[55], URC_Text[55], 'HideAADescription');

	// Days used to filter UR (reminder days / close days)
	addTextNumberSettings(container, URC_Text_tooltip[23], URC_Text[23], "ReminderDays");
	addTextNumberSettings(container, URC_Text_tooltip[24], URC_Text[24], "CloseDays");

	// Greeting
	addTextAreaSettings(container, URC_Text_tooltip[54], URC_Text[54], 'Greeting');

	// Signature
	addTextAreaSettings(container, URC_Text_tooltip[44], URC_Text[44], 'Signature');

	// Include PS
	//addBooleanSettings(container, URC_Text_tooltip[50], URC_Text[50], 'URComShowPS');

	// PS
	//addTextAreaSettings(container, "", "", 'URCommentsPS');

	const contactLabel = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[47] + '" style="padding-bottom: 10px; line-height: 15px; font-weight: bold;"><br>' + URC_Text[47] + ' :</span></div>');
	container.append(contactLabel);

	const developer = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[48] + '" style="line-height: 15px;">' + URC_img_waze_editor + URC_Text[48] + ': <a href="mailto:incoming+WMEScripts/WME-language-forcer@incoming.gitlab.com" target="_blank">@tunisiano187</a></span></div>'); // Dev
	container.append(developer);

	const maintainer = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[53] + '" style="line-height: 15px;">' + URC_img_waze_editor + URC_Text[53] + ': @GyllieGyllie</span></div>'); // Maintainer
	container.append(maintainer);

	const translator = $('<div class="urcom-option"><span Title="' + URC_Text_tooltip[49] + '" style="line-height: 15px;">' + URC_img_waze_editor + URC_Text[49] + ': ' + TranslatorsName + '</span></div>'); // Translator
	container.append(translator);
}

function addFilters(container) {

	const instructionLabel = $('<a target="_blank" Title="' + URC_Text_tooltip[8] + '" href="' + URC_URL[8] + '">' + URC_Text[8] + '</a><br><br>');
	container.append(instructionLabel);

	// Enable or disable urc filtering URCommentsFilterEnabled
	addBooleanSettingsCallback(container, URC_Text_tooltip[9], URC_Text[9], 'URCommentsFilterEnabled', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide UR that are not "mine"
	addBooleanSettingsCallback(container, URC_Text_tooltip[13], URC_Text[13], 'URCommentsHideNotMyUR', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Show UR that have gone past the close day setting
	addBooleanSettingsCallback(container, URC_Text_tooltip[14], URC_Text[14], 'URCommentsShowPastClose', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide inbetween ur
	addBooleanSettingsCallback(container, URC_Text_tooltip[12], URC_Text[12], 'URCommentsHideInbetween', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide reminders
	addBooleanSettingsCallback(container, URC_Text_tooltip[15], URC_Text[15], 'URCommentsHideReminderNeeded', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide replies
	addBooleanSettingsCallback(container, URC_Text_tooltip[16], URC_Text[16], 'URCommentsHideReplies', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide older than 7 day
	addBooleanSettingsCallback(container, URC_Text_tooltip[17], URC_Text[17], 'URCommentsHideCloseNeeded', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide initial (zero comments)
	addBooleanSettingsCallback(container, URC_Text_tooltip[18], URC_Text[18], 'URCommentsHideInital', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide UR that do not have descriptions
	addBooleanSettingsCallback(container, URC_Text_tooltip[19], URC_Text[19], 'URCommentsHideWithoutDescript', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide UR that have descriptions
	addBooleanSettingsCallback(container, URC_Text_tooltip[20], URC_Text[20], 'URCommentsHideWithDescript', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

	// Hide notes
	addBooleanSettingsCallback(container, URC_Text_tooltip[22], URC_Text[22], 'URCommentsHideNotes', (event) => {
		toggleBoolean(event);
		FilterURs();
	});

}

// Save what comment list is selected
function BoilerPlateCreatorsFunction(event) {

	const selected = event.target.value;

	if (selected !== "") {
		options.BoilerPlateCreators = selected;
		saveOptions(options);

		refreshUI();
	}

}

// Save what custom comment list is selected
function changeCustomTextList(event) {
	const selected = event.target.value;

	if (selected === URC_Text[56]) {
		addCustomList();
	} else if (selected !== "") {
		options.CustomTextList = selected;
		saveOptions(options);

		loadCustomText(() => {
			refreshUI();
		})
	}

}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
////
//// Option Logic
////
////////////////////////////////////////////////////////////////////////////////////////////////////////////
function getDefaultOptions() {
	return {
		AutoSetNewComment: true,
		UrCommentAutoSet4dayComment: true,
		NewZoomIn: true,
		WithCommentRecenter: true,
		AutoClickURStatus: true,
		SaveAfterComment: true,
		UrCommentAutoCloseComment: true,
		ZoomOutAfterComment: true,
		AutoSwitchToURCommentsTab: true,
		DBLClk7DCAutoSend: false,
		DBLClkAll: false,
		UrCommentDisableURDoneBtn: true,
		URCommentURUnfollow: false,
		URCommentsAutoSendMyReminders: false,
		URCommentsReplaceTagWithEditorName: false,
		URCommentsDontShowTaggedText: false,
		HideAADescription: true,
		Signature: "",
		Greeting: "",
		URComShowPS: false,
		URCommentsPS: "",
		BoilerPlateCreators: "URComDefault",
		URCommentsFilterEnabled: true,
		URCommentsPillEnabled: true,
		URCommentsHideNotMyUR: true,
		URCommentsShowPastClose: true,
		URCommentsHideInbetween: true,
		URCommentsHideReminderNeeded: false,
		URCommentsHideReplies: false,
		URCommentsHideCloseNeeded: false,
		URCommentsHideInital: false,
		URCommentsHideWithoutDescript: false,
		URCommentsHideWithDescript: false,
		URCommentsHideClosed: true,
		URCommentsHideNotes: false,
		ReminderDays: 4,
		CloseDays: 3,
		CustomTextList: '',
	}
}

function loadOptions() {
	let text = localStorage.getItem("URCom-Options");
	let options;

	if (text) {
		options = JSON.parse(text);
	} else {
		options = getDefaultOptions();
		migrate = true;
	}

	return options;
}

function validateOptions(options) {
	const defaultOptions = getDefaultOptions();

	// Add missing options
	for (let key in defaultOptions) {
		if (!(key in options)) {
			options[key] = defaultOptions[key]
		}
	}

	if (options.DBLClkAll) {
		options.AutoClickURStatus = true;
	}

	if (options.DBLClk7DCAutoSend) {
		options.AutoClickURStatus = true;
	}

	if (isNaN(options.ReminderDays) || options.ReminderDays < 0) {
		options.ReminderDays = 0;
	}

	if (isNaN(options.CloseDays) || options.CloseDays < 0) {
		options.CloseDays = 0;
	}

	if (options.CustomTextList === "None") {
		options.CustomTextList = "Default";
	}
}

function saveOptions(options) {
	const optionsJson = JSON.stringify(options);
	localStorage.setItem("URCom-Options", optionsJson);
}

function toggleBoolean(event) {
	options[event.target.id] = event.target.checked;
	saveOptions(options);
}

function changeText(event) {
	options[event.target.id] = event.target.value;
	saveOptions(options);
}

function migrateOptions() {
	migrateTextOption('BoilerPlateCreators', 'BoilerPlateCreators');

	migrateBooleanOptions('AutoSetNewComment', 'AutoSetNewComment');
	migrateBooleanOptions('UrCommentAutoSet4dayComment', 'UrCommentAutoSet4dayComment');
	migrateBooleanOptions('UrCommentAutoCloseComment', 'UrCommentAutoCloseComment');
	migrateBooleanOptions('NewZoomIn', 'NewZoomIn');
	migrateBooleanOptions('WithCommentRecenter', 'WithCommentRecenter');
	migrateBooleanOptions('AutoClickURStatus', 'AutoClickURStatus');
	migrateBooleanOptions('SaveAfterComment', 'SaveAfterComment');
	migrateBooleanOptions('ZoomOutAfterComment', 'ZoomOutAfterComment');
	migrateBooleanOptions('AutoSwitchToURCommentsTab', 'AutoSwitchToURCommentsTab');
	migrateBooleanOptions('DBLClk7DCAutoSend', 'DBLClk7DCAutoSend');
	migrateBooleanOptions('DBLClkAll', 'DBLClkAll');
	migrateBooleanOptions('UrCommentDisableURDoneBtn', 'UrCommentDisableURDoneBtn');
	migrateBooleanOptions('URCommentURUnfollow', 'URCommentURUnfollow');
	migrateBooleanOptions('URCommentsAutoSendMyReminders', 'URCommentsAutoSendMyReminders');
	migrateBooleanOptions('URCommentsReplaceTagWithEditorName', 'URCommentsReplaceTagWithEditorName');
	migrateBooleanOptions('URCommentsDontShowTaggedText', 'URCommentsDontShowTaggedText');
	migrateTextOption('Signature', 'Signature');
	migrateBooleanOptions('URComShowPS', 'URComShowPS');
	migrateTextOption('URCommentsPS', 'URCommentsPS');

	migrateBooleanOptions('URCommentsFilterEnabled', 'URCommentsFilterEnabled');
	migrateBooleanOptions('URCommentsPillEnabled', 'URCommentsPillEnabled');
	migrateBooleanOptions('URCommentsHideNotMyUR', 'URCommentsHideNotMyUR');
	migrateBooleanOptions('URCommentsShowPastClose', 'URCommentsShowPastClose');
	migrateBooleanOptions('URCommentsHideInbetween', 'URCommentsHideInbetween');
	migrateBooleanOptions('URCommentsHideReminderNeeded', 'URCommentsHideReminderNeeded');
	migrateBooleanOptions('URCommentsHideReplies', 'URCommentsHideReplies');
	migrateBooleanOptions('URCommentsHideCloseNeeded', 'URCommentsHideCloseNeeded');
	migrateBooleanOptions('URCommentsHideInital', 'URCommentsHideInital');
	migrateBooleanOptions('URCommentsHideWithoutDescript', 'URCommentsHideWithoutDescript');
	migrateBooleanOptions('URCommentsHideWithDescript', 'URCommentsHideWithDescript');
	migrateBooleanOptions('URCommentsHideClosed', 'URCommentsHideClosed');
	migrateBooleanOptions('URCommentsHideNotes', 'URCommentsHideNotes');
	migrateNumericOption('ReminderDays', 'ReminderDays');
	migrateNumericOption('CloseDays', 'CloseDays');

	saveOptions(options);
}

function migrateBooleanOptions(oldOption, newOption) {
	const value = localStorage.getItem(oldOption);

	if (value !== null && value !== undefined) {
		options[newOption] = value === "yes";
	}
}

function migrateNumericOption(oldOption, newOption) {
	const value = localStorage.getItem(oldOption);

	if (value !== null && value !== undefined) {
		const number = Number(value);

		if (!isNaN(number)) {
			options[newOption] = number;
		}
	}
}

function migrateTextOption(oldOption, newOption) {
	const value = localStorage.getItem(oldOption);

	if (value !== null && value !== undefined) {
		options[newOption] = value;
	}
}

function addDropdownSettings(container, title, label, name, values, callback) {
	const currentValue = options[name];

	const wrapper = $('<div class="urcom-option" title="' + title + '"></div>');
	wrapper.append('<span>' + label + '</span>');
	wrapper.append('<br />');

	const select = $('<select name="' + name + '" id="' + name + '" style="width: 100%;"></select>');

	for (let i = 0; i < values.length; i++) {
		select.append('<option value="' + values[i] + '" ' + (currentValue === values[i] ? 'selected="selected"' : '') + '>' + values[i] + '</option>');
	}

	// Create call back for the select
	select.on('change', callback);
	wrapper.append(select);

	container.append(wrapper);
}

function addBooleanSettings(container, title, label, name) {
	addBooleanSettingsCallback(container, title, label, name, toggleBoolean);
}

function addBooleanSettingsCallback(container, title, label, name, clickHandler) {
	const currentValue = options[name];

	const checkbox = $('<wz-checkbox id="' + name + '" Title="' + title + '" name="types" disabled="false" checked="' + currentValue + '">' + label + '</wz-checkbox>');
	const optionHtml = $('<div class="urcom-option"></div>').append(checkbox);

	container.append(optionHtml);

	checkbox.on('click', clickHandler);
}

function addTextNumberSettings(container, title, label, name) {
	const currentValue = options[name];

	const textInput = $('<wz-text-input type="number" min="0" max="999" id="' + name + '" value="' + currentValue + '"></wz-text-input>');
	const optionHtml = $('<div class="urcom-option"><span Title="' + title + '">' + label + '</span></div>').append(textInput);

	container.append(optionHtml);

	textInput.on('change', changeText);
}

function addTextAreaSettings(container, title, label, name) {
	const currentValue = options[name];

	const textArea = $('<wz-textarea id="' + name + '" style="height: 130px; width: 270px;" value="' + currentValue + '"></wz-textarea>');
	const optionHtml = $('<div class="urcom-option"><span Title="' + title + '">' + label + '</span></div>').append(textArea);

	container.append(optionHtml);

	textArea.on('change', changeText);
}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
////
//// UR Comment functions
////
////////////////////////////////////////////////////////////////////////////////////////////////////////////
function addCustomList() {
	let name = prompt("Enter the name for your list");

	if (!name) {
		refreshUI();
		return;
	}

	// Make sure it doesn't exist
	if (CustomLists.indexOf(name) >= 0) {
		alert(URC_USER_PROMPT[13]);
		return;
	}

	// Insert into the DB
	const objectStore = DB
		.transaction("custom_lists", "readwrite")
		.objectStore("custom_lists");

	objectStore.add({
		name: name,
		order: CustomLists.length - 2,
		responses: []
	});

	CustomLists.splice(CustomLists.length - 1, 1);
	CustomLists.push(name);
	CustomLists.push(URC_Text[56]);

	options.CustomTextList = name;
	saveOptions(options);

	CustomListText = [];

	refreshUI();

	alert(URC_USER_PROMPT[14]);
}

function renameList() {
	let name = prompt(URC_USER_PROMPT[16], options.CustomTextList);

	if (!name) {
		return;
	}

	// Make sure it doesn't exist
	if (CustomLists.indexOf(name) >= 0) {
		alert(URC_USER_PROMPT[13]);
		return;
	}

	const objectStore = DB
		.transaction("custom_lists", "readwrite")
		.objectStore("custom_lists");

	const request = objectStore.get(options.CustomTextList);

	request.onerror = (event) => {
		alert(URC_USER_PROMPT[18]);
	};

	request.onsuccess = (event) => {
		const data = event.target.result;

		data.name = name;

		const requestUpdate = objectStore.add(data);

		requestUpdate.onerror = (event) => {
			alert(URC_USER_PROMPT[18]);
		};

		requestUpdate.onsuccess = (event) => {
			objectStore.delete(options.CustomTextList);

			const index = CustomLists.indexOf(options.CustomTextList);
			CustomLists[index] = name;

			options.CustomTextList = name;
			saveOptions(options);

			refreshUI();

			alert(URC_USER_PROMPT[17]);

		}
	}
}

function cancelTextEdit() {
	ShowTextEditFields = false;
	TextEditIndex = undefined;

	refreshUI();
}

function saveCustomText() {

	const titleInput = $("#customTextTitle")[0];
	const textInput = $("#customTextText")[0];
	const statusSelect = $("#customTextStatus")[0];
	const signatureCheckbox = $("#customTextSignature")[0];

	const title = titleInput.value;
	const text = textInput.value;
	const statusIndex = statusSelect.selectedIndex;
	const signature = signatureCheckbox.checked;

	let status;

	switch (statusIndex) {
		case 0:
		default:
			status = "open";
			break;
		case 1:
			status = "closed";
			break;
		case 2:
			status = "notidentified";
			break;
	}

	if (!title || !text || !status) {
		alert(URC_USER_PROMPT[18]);
		return;
	}

	const objectStore = DB
		.transaction("custom_lists", "readwrite")
		.objectStore("custom_lists");

	const request = objectStore.get(options.CustomTextList);

	request.onerror = (event) => {
		alert(URC_USER_PROMPT[19]);
	};

	request.onsuccess = (event) => {
		const data = event.target.result;

		if (TextEditIndex !== undefined && TextEditIndex !== -1) {

			// Update text
			data.responses.forEach(response => {
				if (response.sorting === TextEditIndex) {
					response.name = title;
					response.text = text;
					response.status = status;
					response.signature = signature;
				}
			})

		} else {

			data.responses.push({
				sorting: CustomListText.length,
				name: title,
				text: text,
				status: status,
				signature: signature
			})

		}

		const requestUpdate = objectStore.put(data);

		requestUpdate.onerror = (event) => {
			alert(URC_USER_PROMPT[19]);
		};

		requestUpdate.onsuccess = (event) => {
			ShowTextEditFields = false;
			TextEditIndex = undefined;

			loadCustomText(() => {
				refreshUI();
			});
		}
	}

}

function deleteCustomList() {

	const result = confirm(URC_USER_PROMPT[20]);

	if (!result) {
		return;
	}

	const objectStore = DB
		.transaction("custom_lists", "readwrite")
		.objectStore("custom_lists");

	const request = objectStore.delete(options.CustomTextList);

	request.onerror = (event) => {
		alert(URC_USER_PROMPT[21]);
	};

	request.onsuccess = (event) => {

		// Fall back to default list
		CustomLists = CustomLists.filter(name => name !== options.CustomTextList);
		CustomListText = [];
		options.CustomTextList = "Default";

		refreshUI();

	}

}

function deleteTextItem() {
	DeleteTextMode = !DeleteTextMode;
	refreshUI();

	if (DeleteTextMode) {
		showWMEMessage(URC_USER_PROMPT[22], 5000);
	}
}

function executeDeleteTextItem(index) {

	return function() {
		const text = CustomListText[index];

		const objectStore = DB
			.transaction("custom_lists", "readwrite")
			.objectStore("custom_lists");

		const request = objectStore.get(options.CustomTextList);

		request.onerror = (event) => {
			alert(URC_USER_PROMPT[19]);
		};

		request.onsuccess = (event) => {
			const data = event.target.result;

			// Remove the one we don't need
			data.responses = data.responses.filter(response => response.name !== text.name || response.text !== text.text || response.status !== text.status);

			// Update sorting
			for (let i = 0; i < data.responses.length; i++) {
				data.responses[i].sorting = i;
			}

			const requestUpdate = objectStore.put(data);

			requestUpdate.onerror = (event) => {
				alert(URC_USER_PROMPT[23]);
			};

			requestUpdate.onsuccess = (event) => {
				DeleteTextMode = false;

				loadCustomText(() => {
					refreshUI();
				});
			}
		}
	}

}

function migrateDb(oldDb) {
	return new Promise(async resolve => {

		let migrating = true;

		oldDb.transaction(async (tx) => {

			await tx.executeSql('SELECT * FROM custom_comments', [], async function (tx, results) {

				const len = results.rows.length;

				console.log("[URCom] Migration found " + len + " existing lists");

				for (let i = 0; i < len; i++) {

					let migratingList = true;

					const name = results.rows.item(i).name;
					const responses = [];

					await tx.executeSql('SELECT * FROM custom_comments_text WHERE list = ? ORDER BY sorting', [name], function (tx, results) {
						const len = results.rows.length;

						for (let j = 0; j < len; j++) {
							const result = results.rows.item(j);

							responses.push({
								sorting: result.sorting,
								name: result.name,
								text: result.text,
								status: result.status,
								signature: result.signature
							});
						}

						const objectStore = DB
							.transaction("custom_lists", "readwrite")
							.objectStore("custom_lists");

						objectStore.add({
							name: name,
							order: i,
							responses: responses
						});

						migratingList = false;

					});

					while (migratingList) {
						await sleep(1);
					}
				}

				migrating = false;

			});

		}, (error) => {
			// Ignore since prolly table doesn't exist
			migrating = false;
		});

		while (migrating) {
			await sleep(1);
		}

		oldDb.transaction((tx) => {
			tx.executeSql('DELETE FROM custom_comments', []);
		});

		resolve();
	});
}

function addNewItem() {
	ShowTextEditFields = true;
	refreshUI()
}

function editItem() {
	ShowTextOptionButtons = false;

	TextEditIndex = -1;
	refreshUI();

	showWMEMessage(URC_USER_PROMPT[24], 5000);
}

function selectEditItem(index) {

	return function() {

		const text = CustomListText[index];

		if (!text) {
			TextEditIndex = undefined;
			return;
		}

		ShowTextEditFields = true;
		ShowTextOptionButtons = true;
		TextEditIndex = index;

		// Refresh first
		refreshUI();

		// Then update the settings
		const titleInput = $("#customTextTitle")[0];
		const textInput = $("#customTextText")[0];
		const statusSelect = $("#customTextStatus")[0];
		const signatureCheckbox = $("#customTextSignature")[0];

		titleInput.value = text.name;
		textInput.value = text.text;
		signatureCheckbox.checked = text.signature;

		switch (text.status) {
			case "open":
				statusSelect.selectedIndex = 0;
				break;
			case "closed":
				statusSelect.selectedIndex = 1;
				break;
			case "notidentified":
				statusSelect.selectedIndex = 2;
				break;
		}
	}
}

function escapeHtml(a) {
	a = a.replace(/&/g, "&amp;");
	a = a.replace(/</g, "&lt;");
	a = a.replace(/>/g, "&gt;");
	a = a.replace(/"/g, "&quot;");
	a = a.replace(/'/g, "&#039;");
	return a;
}

function autoZoomIN(Title, Comment, URStatus, urID, AutoSendComment) {
	return function() {

		let URCommentsUnsavedDetected = false;
		const URCommentsUnsavedCount = Number($("#save-button .counter").html());

		// Detect unsaved changed if there are and the auto save option is on abort adding comments to the UR
		if (!isNaN(URCommentsUnsavedCount) && URCommentsUnsavedCount > 0 && options.SaveAfterComment && URStatus.toLowerCase() !== "open") {
			URCommentsUnsavedDetected = true;
			alert(URC_USER_PROMPT[9]); //"UrComments has detected that you have unsaved changes!\n\nWith the Auto Save option enabled and with unsaved changes you cannot send comments that would require the script to save. Please save your changes and then re-click the comment you wish to send."
		}

		// Get urID for manually clicked comments
		if (urID === 0 || urID === "" || urID === undefined) {
			urID = $(".map-problem.marker-selected").data("id");
		}

		// Check to see if the auto zoom in option is enabled, if it is start the zooming in process
		// having OneOrTheOther first is a hack to make the logic work
		let OneOrTheOther = false;

		if (options.NewZoomIn && Title !== URCommentsArray[ReminderPosition] && Title !== URCommentsArray[CloseNotIdentifiedPosition] && AutoSendComment !== "AutoSendComment") {
			OneOrTheOther = true;
		}

		if (OneOrTheOther && URCommentsUnsavedDetected === false) {

			// Predefined zoom threshold for auto zoom
			const zoom = 15;

			// Do not zoom back out if we are already zoomed in and just happen to be re-clicking on a UR.
			// or we have the map set good for a 4-day reminder
			const WazeCurrentZoom = getWazeMapZoomLevel();

			if (WazeCurrentZoom < zoom) {
				goToURById(urID, zoom);
			}

			setTimeout(postURComment(Title, Comment, URStatus, AutoSendComment, urID), 1);

		} else if (URCommentsUnsavedDetected === false) {

			// auto zoom in is disabled jump to postURComment
			// we have to use set timeout here because we need the  return function() in PostURComment
			// for when we are zooming in and out for the reminder
			// since we are not zooming here jump rigth to PostURComment
			setTimeout(postURComment(Title, Comment, URStatus, AutoSendComment, urID), 1);
		}

	};
}

function getWazeMapZoomLevel() {
	return W.map.mapState.mapLocation.zoom;
}

function goToURById(urID, zoom) {

	// save zoom so we can return this the current zoom level
	ReturnToCurrentZoom = getWazeMapZoomLevel();

	const geo = getUrById(urID).attributes.geometry;
	W.map.getOLMap().moveTo([geo.x, geo.y], zoom);

}

function postURComment(title, comment, urStatus, autoSendComment, urID) {

	// The user clicked on a comment link
	return function() {
		// Swap out special text
		comment = stringSwap(comment, urID);

		$('.new-comment-form .send-button').on('click', urCommentZoomOutCheck(title, urStatus));

		// Check if the comment text area is present if not alert the user to open a UR
		const commentArea = $($(".new-comment-text")[0]);

		if (commentArea) {
			commentArea.val(comment).change();

			commentArea.keyup();

			if(!$('.no-comments')) {
				commentArea.css("backgroundColor","Yellow");
			}

			// Click the UR status
			setTimeout(checkIfClickStatus(urStatus, autoSendComment), 100);
		} else {
			// We were unable to find an open UR
			showWMEMessage(URC_USER_PROMPT[10], 5000); //"URComments: Can not find the comment box! In order for this script to work you need to have a user request open."
		}
	};

}

function urCommentZoomOutCheck(Title, URStatus) {
	return function() {
		// This is the new place for zooming out and will still be happening while the comment is sending
		if (options.ZoomOutAfterComment) {
			setTimeout(setZoomCloseUR(ReturnToCurrentZoom, "LeaveOpen"), 0);
		}

		setTimeout(urCommentSendBtnClicked(Title, URStatus), 20);
	}
}

function setZoomCloseUR(zoom, b) {
	// This sets the map zoom; 0 is all the way out; 10 is all the way in but next to useless (the map and sat views disappear);
	// the closest zoom that shows the sat and map is zoom 9
	return function() {
		W.map.getOLMap().moveTo(W.map.getCenter(), zoom);

		// Close ur if zooming out to
		if (b === "CloseUR") {
			W?.map?.panelRegion?.currentView?.destroy();
		}
	};
}

function stringSwap(string, urID) {
	if (urID > 0) {
		const ur = getUrById(urID);

		string = string.replace("$URD", ur.attributes.typeText + ' : ' + ur.attributes.description);
		string = string.replace(/          /g, "");
		string = string.replace(/        /g, "");
		//string = string.replace(/(\r\n|\n)/gm, "");
	} else if ($(".description .content").length > 0) {
		string = string.replace("$URD", $(".description .content").html());
		string = string.replace(/          /g, "");
		string = string.replace(/        /g, "");
		//string = string.replace(/(\r\n|\n)/gm, "");
		string = string.replace("$USERNAME", W.loginManager.user.getUsername());
	} else if (string.indexOf("$URD") >= 0) {
		string = string.replace(" \"$URD\"", "");
	}

	const greeting = options.Greeting;
	if (greeting && greeting !== "" && greeting !== null && greeting !== "undefined") {
		string = greeting + "\r\n" + string;
	}

	const signature = options.Signature;
	if (signature && signature !== "" && signature !== null && signature !== "undefined") {
		string = string.replace('$SIGNATURE', "\r\n" + signature);
	}

	// Selected segments
	let streetName = "";

	if (W.selectionManager.getSelectedFeatures().length >= 1 && W.selectionManager.getSelectedFeatures().length <= 2) {
		for (let i = 0; i < W.selectionManager.getSelectedFeatures().length; i++) {
			if (W.selectionManager.getSelectedFeatures()[i].model.CLASS_NAME === "W.Feature.Vector.Segment") {
				const primaryStreetID = W.selectionManager.getSelectedFeatures()[i].model.attributes.primaryStreetID;
				if (i === 0) {
					streetName = W.model.streets.objects[primaryStreetID].name;
				} else {
					streetName = "the intersection of " + streetName + " and " + W.model.streets.objects[primaryStreetID].name;
				}
			}
		}

		string = string.replace("$SELSEGS", streetName);
	}

	return string;
}

function urCommentSendBtnClicked(title, urStatus) {

	// Waze is weird and after clicking send button the close button had to be refound, which takes a few seconds for the new close button to be drawn
	// so we wait 1500 milliseconds before looking for the close button
	// since we are passing vars to the next function we have to pass this to handler function so it doesn't happen on click

	// The above is still true but what i have found is that it sometimes takes a while from clicking send to the comment actually posting.
	// There was time when i closed the comment before it actually posted and it would have to be redone. So added a check and a timeout and recheck if the textarea isn't empty.
	// Afterwards we can re-grab and click the close button
	return function() {

		// Grab the close button to compare to later
		CloseButtonHolder = $(".problem-panel-navigation button.close-button");

		// Check to see if the comments went through before saving or closing the comment
		const textArea = $(".new-comment-text");
		if (textArea.val() !== "" && textArea.val() !== undefined) {

			PauseCount++;
			setTimeout(urCommentSendBtnClicked(title, urStatus), 20);

		} else {

			PauseCount = 1;

			// Check if we want to unfollow
			const followCheckbox = $('.new-comment-form wz-checkbox')[0];

			if (options.URCommentURUnfollow && followCheckbox.checked) {
				followCheckbox.checked = false;

				const urID = $(".map-problem.marker-selected").data("id");

				setTimeout(toggleFollowConversation(urID), 500);
			}

			// Delay this command for uro not to freak out on refreshing uro bubble ur count
			setTimeout(closeDelayHack2(title, urStatus), 100);

		}
	};
}

function toggleFollowConversation(urID) {
	return function() {
		W.controller.descartesClient.followUpdateRequest({ follow: false, mapUpdateRequestID: urID });
		W.model.updateRequestSessions.getObjectById(urID).setAttribute('isFollowing', false);
	};
}

function closeDelayHack2(title, urStatus) {
	return function() {

		PauseCount = 1;

		if (urStatus.toLowerCase() === "solved" || urStatus.toLowerCase() === "notidentified") {

			// This clicks the waze save btn
			if (options.AutoClickURStatus && options.SaveAfterComment) {

				// Click save
				$('.toolbar #save-button').trigger('click');

			} else if (options.UrCommentAutoCloseComment) {

				W?.map?.panelRegion?.currentView?.destroy();

			}

		} else {

			// When not saving you have to click close.
			if (options.UrCommentAutoCloseComment) {

				W?.map?.panelRegion?.currentView?.destroy();

			}
		}

		//this is the new place for zooming out and will still be happening while the comment is sending
		//zoom out option - if the user option is set to reload map after posting a comment reply
		if (options.ZoomOutAfterComment) {
			//urcToConsole("zoom out closeDelayHack2");
			setTimeout(setZoomCloseUR(ReturnToCurrentZoom, "LeaveOpen"), 0);
		}

		setTimeout(urcUREvent_onObjectsAdded('URCommentsReload'), 0);

	};
}

function urcUREvent_onObjectsAdded(a) {

	return function() {

		// Check if filtering or the pill count are enabled otherwise abort this function
		if (!options.URCommentsFilterEnabled && !options.URCommentsPillEnabled && !options.URCommentsAutoSendMyReminders) {
			return
		}

		if (a === "timedout" && window.HideUR === "running") {
			window.HideUR = "stopped";
			a = "timedout";
		}

		if (window.HideUR === "stopped" && a !== "timedout") {
			clearTimeout(window.buffertedtimeout);
			clearTimeout(window.buffertedtimeout2);

			// Certain events need to be launched a bit later then others
			if (a === "moveend" || a === "zoomend") {
				window.buffertedtimeout = setTimeout(FilterURs, 2000);
			} else {
				window.buffertedtimeout = setTimeout(FilterURs, 500);
			}

			window.HideUR = "running";
			window.BufferFillterURCommand = false;
			window.buffertedtimeout2 = setTimeout(urcUREvent_onObjectsAdded("timedout"), 30000);
		}

	};
}

function FilterURs() {

	const allUrs = W.model.mapUpdateRequests.objects;
	const allUrIDs = Object.keys(allUrs);

	// Abort filtering URs if the list is empty
	if (allUrIDs.length === 0) {
		window.HideUR = "stopped";
		setTimeout(urcUREvent_onObjectsAdded("list is empty retry"), 5000);
		return;
	}

	// This seems to trigger loading info from the UR but may not be needed
	/*
	// Check that all visible urs are loaded
	let idList = [];
	let PushNeededCount = 0;

	for (let urID of allUrIDs) {

		if (getUrById(urID) == null) {
			idList.push(urID);
			PushNeededCount = PushNeededCount + 1;
		}

		// Batch per 500
		if (PushNeededCount > 500) {
			//W.model.updateRequestSessions.get(idList);
			idList = [];
			PushNeededCount = 0;
		}
	}

	if (idList.length > 0) {
		//W.model.updateRequestSessions.get(idList);
	}
	 */

	let totalVisibleUrs = 0;

	let allID = '';
	let countInCurrentList = 0;

	let delay = 0;

	for (let urID of allUrIDs) {

		totalVisibleUrs++;

		// Make sure we can see the UR
		if (onScreen(allUrs[urID])) {

			if (allID !== '') {
				allID += ",";
			}

			allID = allID + urID;
			countInCurrentList = countInCurrentList + 1;
		}

		// Batch the current list
		if (countInCurrentList >= 500) {

			// Send this batch in a timeout
			setTimeout(FilterURs2(allID), delay);

			countInCurrentList = 0;
			allID = "";
			delay = delay + 1000;
		}
	}

	// Update the count in the script tab
	$("#URCount").html(`${totalVisibleUrs}`);

	setTimeout(FilterURs2(allID), delay);
}

function FilterURs2(allID) {

	return function() {

		const CloseDays = options.CloseDays;
		const ReminderDays = options.ReminderDays;
		const ClosePlusReminderDays = CloseDays + ReminderDays;

		const EditorID = W.loginManager.user.getID(); // Editor's id number
		const LoggedInEditor = W.loginManager.user.getUsername();

		if (allID !== "") {

			// This is the link that works but I think it is grabbing a cached version of the page
			//https://www.waze.com/row-Descartes/app/MapProblems/UpdateRequests?ids=20006756

			const urSessionURL = 'https://' + window.location.host + W.Config.api_base + '/MapProblems/UpdateRequests?ids=' + allID + '&time=' + (new Date()).getTime();

			//urcToConsole("urSessionURL: " + urSessionURL);

			// https://www.waze.com/Descartes-live/app/MapProblems/UpdateRequests?ids=3678676
			let LastCommenterUserID = '0';

			// Send a request to load the UR data
			$.ajax({
				dataType: "json",
				url: urSessionURL,

				success: function(json) {

					try {

						const urs = json.updateRequestSessions.objects;
						const layer = W.map.layers.find((layer) => layer.name === "update_requests");

						for (let jsnObj = 0; jsnObj < urs.length; jsnObj++) {

							const urDetail = urs[jsnObj];
							const id = urDetail.id;
							const ur = W.model.mapUpdateRequests.objects[id];

							const urDescription = ur.attributes.description;

							let skip = false;
							let urStyle = 'shown';
							let Marked = '';
							let UrcURType = '';
							let lastCommentDateTime = 0;

							const numberOfComments = urDetail.comments.length;
							let CountsBGColor = '#FFFF99'; // Light yellow

							const urBubble = $('image#' + id);

							if (numberOfComments > 0) {

								let reporterResponded = false;
								let LastComment = '';

								for (let comment of urDetail.comments) {

									if (comment.userID === -1) {
										reporterResponded = true;
									}

									const commentText = comment.text;

									lastCommentDateTime = comment.createdOn;
									LastCommenterUserID = comment.userID;
									LastComment = commentText;

									// Only white if logged in editor has the last editor comment
									if (LastCommenterUserID > 1) {
										if (LastCommenterUserID === EditorID) {
											CountsBGColor = "white";
										} else {
											CountsBGColor = "#FFFF99"; //light yellow
										}
									}

									// NOTE, ROADWORKS, CONSTRUCTION, CLOSURE, EVENT,
									if (commentText.indexOf("NOTE]") >= 0 || commentText.indexOf("ROADWORKS]") >= 0 || commentText.indexOf("CONSTRUCTION]") >= 0 || commentText.indexOf("CLOSURE]") >= 0 || commentText.indexOf("EVENT]") >= 0 || commentText.indexOf(LoggedInEditor) >= 0) {
										skip = true;
									}

									if (commentText.indexOf(LoggedInEditor) >= 0 && options.URCommentsReplaceTagWithEditorName) {
										Marked = LoggedInEditor;
									} else if (commentText.indexOf("NOTE]") >= 0) {
										Marked = "Note";
									} else if (commentText.indexOf("ROADWORKS]") >= 0) {
										Marked = "Roadworks";
									} else if (commentText.indexOf("CONSTRUCTION]") >= 0) {
										Marked = "Construction";
									} else if (commentText.indexOf("CLOSURE]") >= 0) {
										Marked = "Closure";
									} else if (commentText.indexOf("EVENT]") >= 0) {
										Marked = "Event";
									}

									if (options.URCommentsDontShowTaggedText && Marked !== "") {
										Marked = "DontShowTaggedText";
									}

								}

							}

							let lastCommentAge = uroDateToDays(lastCommentDateTime);

							if (urDescription) {

								// Skip tagged URs
								if (urDescription.indexOf("NOTE]") >= 0 || urDescription.indexOf("ROADWORKS]") >= 0 || urDescription.indexOf("CONSTRUCTION]") >= 0 || urDescription.indexOf("CLOSURE]") >= 0 || urDescription.indexOf("EVENT]") >= 0 || urDescription.indexOf(LoggedInEditor) >= 0) {
									//urcToConsole("skipped2 URO+ tagged in description urid: " + id + "with comment text " + urDescription);
									skip = true;
								}

								if (urDescription.indexOf(LoggedInEditor) >= 0 && options.URCommentsReplaceTagWithEditorName) {
									Marked = LoggedInEditor;
								} else if (urDescription.indexOf("NOTE]") >= 0) {
									Marked = "Note";
								} else if (urDescription.indexOf("ROADWORKS]") >= 0) {
									Marked = "Roadworks";
								} else if (urDescription.indexOf("CONSTRUCTION]") >= 0) {
									Marked = "Construction";
								} else if (urDescription.indexOf("CLOSURE]") >= 0) {
									Marked = "Closure";
								} else if (urDescription.indexOf("EVENT]") >= 0) {
									Marked = "Event";
								} else if (urDescription.indexOf("WSLM]") >= 0) {
									Marked = "WSLM";
								}


								if (options.URCommentsDontShowTaggedText && Marked !== ""){
									Marked = "DontShowTaggedText";
								}

								if (options.URCommentsHideWithDescript && numberOfComments <= 0) {
									UrcURType = UrcURType + " WithDescription";
								}

							} else {
								if (options.URCommentsHideWithoutDescript && numberOfComments <= 0) {
									UrcURType = UrcURType + " WithoutDescription";
								}
							}

							if (ur.attributes.open === false) {
								skip = true;
							}

							if (skip === false && ur.type === "mapUpdateRequest") {

								if (numberOfComments > 0) {

									// 4 day UR if there is only one comment, if the comment is less or equal to the editors setting, and if the last comment was not made by the driver
									if (numberOfComments === 1 && ReminderDays > 0 && lastCommentAge >= ReminderDays && LastCommenterUserID > 1) {

										if (options.URCommentsHideReminderNeeded) {
											UrcURType = UrcURType + " NeedsReminder";
										}

										if (LastCommenterUserID === EditorID && options.URCommentsAutoSendMyReminders && urBubble.hasClass('ReminderSent') === false && EditorID > 0) {

											showWMEMessage(URC_USER_PROMPT[7] + id, 2500); //"URComments: Adding reminder message to UR: "

											let comment = URCommentsArray[ReminderPosition + 1];
											comment = stringSwap(comment, id);

											W.model.updateRequestSessions.objects[id].addComment(comment);

											// ToggleFollowConversation false
											if (options.URCommentURUnfollow) {
												setTimeout(toggleFollowConversation(id), 0);
											}

											// Attempting to stop double reminders from being sent by adding a class that we can check for before sending the reminder
											urBubble.addClass('ReminderSent');

											// Set to hide if hide in between states is checked
											if (options.URCommentsHideInbetween) {
												UrcURType = UrcURType + " InBetweenStates";
											}

										}

										// 7 day if the number of comments are greater than or equal to 1, days past are more than 7, the last comment was not from the driver, and number of comments are less than 2
									} else if ((numberOfComments >= 2 && lastCommentAge >= CloseDays && LastCommenterUserID > 1) || (numberOfComments >= 1 && ReminderDays === 0 && lastCommentAge >= CloseDays && LastCommenterUserID > 1)) {

										// Hide or show UR that need closing
										if (options.URCommentsHideCloseNeeded && UrcURType === "") {
											UrcURType = UrcURType + " NeedsClose";
										}

									} else if (LastCommenterUserID > 0) {

										// In between states waiting for replies or time to elapse
										if (options.URCommentsHideInbetween) {
											UrcURType = UrcURType + " InBetweenStates";
										}

									}

									// Last comment was a user reply; change the pin color to blue or peach
									if (LastCommenterUserID < 1) {
										if (CountsBGColor === "white") {
											CountsBGColor = "#79B5C7"; // Light blue
										} else {
											CountsBGColor = "#FFCC99"; // Peach
										}

										if (options.URCommentsHideReplies) {
											UrcURType = UrcURType + " HasUserReplies";
										}

									} else if (lastCommentAge > ClosePlusReminderDays && CountsBGColor !== "white") {
										CountsBGColor = "#FF8B8B"; // Light red
									}

									if (CountsBGColor === "#FFFF99" && numberOfComments >= 1 && lastCommentAge >= ClosePlusReminderDays && LastCommenterUserID > 1) {
										CountsBGColor = "#FF8B8B"; // Light red
									}

								}

							}

							if (lastCommentAge === undefined) {
								lastCommentAge = "?";
							}

							let Message = '';

							if (Marked === "DontShowTaggedText" ){
								Message = numberOfComments + UrCommentsTextPic + " " + lastCommentAge + UrCommentsTimePic;
								CountsBGColor = "#CCCCCC"; //light grey
							} else if (Marked !== "") {
								Message = Marked + " " + numberOfComments + UrCommentsTextPic;
								CountsBGColor = "#CCCCCC"; //light grey
							} else {
								Message = numberOfComments + UrCommentsTextPic + " " + lastCommentAge + UrCommentsTimePic;
							}

							// If the ur is tagged or has more than 0 comments reorder the ur stacking
							if (Marked !== "" || numberOfComments > 0) {

								let MessageOffset = Message.length;
								MessageOffset = MessageOffset - (UrCommentsTextPic.length - 3)
								MessageOffset = MessageOffset - (UrCommentsTimePic.length - 4)

								if (MessageOffset < 10) {
									MessageOffset = MessageOffset * 1.4;
								} else {
									MessageOffset = MessageOffset * 2.3;
								}

								MessageOffset = "-" + MessageOffset + "px";

								if (CountsBGColor === "#CCCCCC") { // Light grey
									urBubble.css({
										'z-index': '999'
									});
								} else if (CountsBGColor === "white" || CountsBGColor === "#79B5C7") {
									urBubble.css({
										'z-index': '998'
									});
									//).style.visibility
								} else if (CountsBGColor === "#FF8B8B") { // Light red
									urBubble.css({
										'z-index': '997'
									});
								}

								/*

								CountsBGColor = "#FFFF99"; //light yellow = UR that are waiting for the last editor but still has time before the Close days setting ex 7 days
								CountsBGColor = "#CCCCCC"; //light grey = URO styled notes ex [NOTE]
								CountsBGColor = "#FFCC99"; //peach = another editor before the close days has gone by has user reply
								CountsBGColor = "#FF8B8B"; //light red = past the close days setting and is now able to be taken over by another editor
								CountsBGColor = "white"; = UR that "belong to the editor logged in that need work
								CountsBGColor = "#79B5C7"; //light blue = UR that "belong to the editor logged in that have user replies

								White = The editor logged in has comments on the UR and the UR needs work
								light blue = The editor logged in has comments on the UR and the UR's last comment was a user reply
								light red = past the close days setting and is now able to be taken over by another editor

								light yellow = UR that are waiting for the another editor to send a reminder or to be closed but still has time before the Close days setting (ex 7 days)
								peach = UR that another editor had commented on but the last comment is a user reply

								light grey = URO styled notes ex [NOTE]

								*/

								if (options.URCommentsPillEnabled) {

									const featureId = layer.features.find((feature) => feature.attributes.wazeFeature.id === id).geometry.id;
									const urCountBubble = $('image#' + featureId);

									// Add URC bubble
									if (urCountBubble.hasClass('URCounts') === false) {

										urBubble.append($("<div>").css("clear", "both")
											.css("margin-bottom", "10px")

											.append($("<div>").html(Message)
												.css("color", "black")
												.css("background", CountsBGColor)
												.css("position", "absolute")
												.css("top", "30px")
												.css("height", "18px")
												.css("right", MessageOffset)

												.css("display", "block")
												.css("width", "auto")
												.css("white-space", "nowrap")
												.css("padding-left", "5px")
												.css("padding-right", "5px")

												.css("border", "1px solid")
												.css("border-radius", "25px")

												.addClass('URCounts')
											)
										);

									} else {
										urCountBubble.html(Message);
										urCountBubble.css("background", CountsBGColor);
										urCountBubble.css("right", MessageOffset);
									}

									// End of URC bubble

								}
							}

							// URC UR Filtering

							let uroURFiltersActive = false; // var used to keep track if we actually need to show / hide the UR pins

							if (sessionStorage.UROverview_hasActiveURFilters === undefined) {

								// These are all of the tags that URO uses to filter URs. If any of the settings are enabled set a var to let URO do the filterenabled
								if ($("#_cbFilterWazeAuto").is(":checked")
									|| $("#_cbFilterIncorrectTurn").is(":checked")
									|| $("#_cbFilterIncorrectAddress").is(":checked")
									|| $("#_cbFilterIncorrectRoute").is(":checked")
									|| $("#_cbFilterMissingRoundabout").is(":checked")
									|| $("#_cbFilterGeneralError").is(":checked")
									|| $("#_cbFilterTurnNotAllowed").is(":checked")
									|| $("#_cbFilterIncorrectJunction").is(":checked")
									|| $("#_cbFilterMissingBridgeOverpass").is(":checked")
									|| $("#_cbFilterWrongDrivingDirection").is(":checked")
									|| $("#_cbFilterMissingExit").is(":checked")
									|| $("#_cbFilterMissingRoad").is(":checked")
									|| $("#_cbFilterBlockedRoad").is(":checked")
									|| $("#_cbFilterMissingLandmark").is(":checked")
									|| $("#_cbFilterUndefined").is(":checked")
									|| $("#_cbFilterRoadworks").is(":checked")
									|| $("#_cbFilterConstruction").is(":checked")
									|| $("#_cbFilterClosure").is(":checked")
									|| $("#_cbFilterEvent").is(":checked")
									|| $("#_cbFilterNote").is(":checked")
									|| $("#_cbInvertURFilter").is(":checked")
									|| $("#_cbFilterOpenUR").is(":checked")
									|| $("#_cbFilterClosedUR").is(":checked")
									|| $("#_cbFilterSolved").is(":checked")
									|| $("#_cbFilterUnidentified").is(":checked")
									|| $("#_cbEnableMinAgeFilter").is(":checked")
									|| $("#_cbEnableMaxAgeFilter").is(":checked")
									|| $("#_cbURDescriptionMustBePresent").is(":checked")
									|| $("#_cbURDescriptionMustBeAbsent").is(":checked")
									|| $("#_cbEnableKeywordMustBePresent").is(":checked")
									|| $("#_cbEnableKeywordMustBeAbsent").is(":checked")
									|| $("#_cbCaseInsensitive").is(":checked")
									|| $("#_cbHideMyComments").is(":checked")
									|| $("#_cbHideAnyComments").is(":checked")
									|| $("#_cbHideIfLastCommenter").is(":checked")
									|| $("#_cbHideIfNotLastCommenter").is(":checked")
									|| $("#_cbHideIfReporterLastCommenter").is(":checked")
									|| $("#_cbHideIfReporterNotLastCommenter").is(":checked")
									|| $("#_cbEnableMinCommentsFilter").is(":checked")
									|| $("#_cbEnableMaxCommentsFilter").is(":checked")
									|| $("#_cbHideMyFollowed").is(":checked")
									|| $("#_cbHideMyUnfollowed").is(":checked")
									|| $("#_cbEnableCommentAgeFilter2").is(":checked")
									|| $("#_cbEnableCommentAgeFilter").is(":checked")
									|| $("#_cbURUserIDFilter").is(":checked")
									|| $("#_cbURResolverIDFilter").is(":checked")
								) {

									uroURFiltersActive = true; // At least one of URO's UR checkboxes were enabledPlugin

								}

							} else if (sessionStorage.UROverview_hasActiveURFilters === "true") {
								uroURFiltersActive = true; // Twisters URO active filter bit is set to true
							}

							if (uroURFiltersActive === true && options.URCommentsFilterEnabled) {
								showWMEMessage(URC_USER_PROMPT[8], 5000); // "URComment's UR Filtering has been disabled because URO\'s UR filters are active."

								$('#URCommentsFilterEnabled').prop('checked', false);

								options.URCommentsFilterEnabled = false;
								saveOptions(options);

							}

							if (options.URCommentsFilterEnabled && uroURFiltersActive === false) {
								// Check if we should hide URO stype tagged UR

								if (options.URCommentsHideNotes && Marked !== "") {
									UrcURType = UrcURType + " IsTagged";
								} else if (Marked !== "" && UrcURType !== "IsClosed") {
									UrcURType = UrcURType + " 1";
								}

								// check if not "my" ur
								if (options.URCommentsHideNotMyUR && numberOfComments > 0) {
									// Light red, Peach, Light yellow
									if (CountsBGColor === "#FFCC99" || CountsBGColor === "#FFFF99" || CountsBGColor === "#FF8B8B") {
										UrcURType = UrcURType + " NotMyUR";
									}
								}

								// URCommentsShowPastClose
								if (options.URCommentsShowPastClose && numberOfComments > 0 && lastCommentAge > ClosePlusReminderDays) {

									// Light red, Peach, Light yellow
									if (CountsBGColor === "#FFCC99" || CountsBGColor === "#FFFF99" || CountsBGColor === "#FF8B8B") {
										if (UrcURType.indexOf("HasUserReplies") < 0) {
											UrcURType = " ShowPastClose";
										}
									}
								}

								// Initial UR no comments
								if (urDetail.comments.length === 0 && options.URCommentsHideInital) {
									UrcURType = UrcURType + " initial";
								}

								if (UrcURType.indexOf("IsTagged") > 0) {
									urStyle = 'hidden';
								} else if (UrcURType.indexOf("InBetweenStates") > 0
									|| UrcURType.indexOf("NeedsReminder") > 0
									|| UrcURType.indexOf("NeedsClose") > 0
									|| UrcURType.indexOf("initial") > 0
									|| UrcURType.indexOf("HasUserReplies") > 0
									|| UrcURType.indexOf("IsClosed") > 0
									|| UrcURType.indexOf("NotMyUR") > 0
									|| UrcURType.indexOf("WithoutDescription") > 0
									|| UrcURType.indexOf("WithDescription") > 0
								) {
									urStyle = 'hidden';
								} else {
									urStyle = 'visible';
								}

								urBubble.css("visibility", urStyle);

								// when filtering is disable and URO filters are disabled reshow all the UR
							} else if (!options.URCommentsFilterEnabled && uroURFiltersActive === false) {
								urStyle = 'visible';
								urBubble.css("visibility", urStyle);
							}

						}
						window.HideUR = "stopped";

					} catch (e) {

						console.log(e);

						setTimeout(FilterURs, 1000);

					}
				}
			});

		} else {
			window.HideUR = "stopped";
		}

	};
}

function onScreen(obj) {

	// Geometry was removed from W.model.mapUpdateRequests.objects[id]
	// but can be found in W.model.mapUpdateRequests.objects[id].geometry
	const geo = obj.getOLGeometry();
	if (geo) {
		return W.map.getExtent().intersectsBounds(geo.getBounds());
	}

	return false;
}

function uroDateToDays(dateToConvert) {
	const dateNow = new Date();
	const elapsedSinceEpoch = dateNow.getTime();
	const elapsedSinceEvent = elapsedSinceEpoch - dateToConvert;

	dateNow.setHours(0);
	dateNow.setMinutes(0);
	dateNow.setSeconds(0);
	dateNow.setMilliseconds(0);

	const 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 uroGetCommentAge(commentObj) {
	if (commentObj.createdOn === null) {
		return -1;
	}

	return uroDateToDays(commentObj.createdOn);
}

function showWMEMessage(message, delay) {

	const dateNow = new Date();
	let TrickRemove = dateNow.getTime();

	const width = message.length * 10;

	// Message holder div
	const c = '<div id="URCMessage" style="width: 100%; font-size: 15px; font-weight: bold; margin-left: auto; margin-right: auto; position: absolute; top: 0; left: 10px; z-index: 1000;"></div>';
	$("#map").append(c);

	// Message div
	const d = '<div id="URCMapNote' + TrickRemove + '" style="width: ' + width + 'px; font-size: 15px; font-weight: bold; margin-left: auto; margin-right: auto; background-color: orange;"><center><b>' + message + '</b></center></div>';
	$("#URCMessage").append(d);

	// Remove messages after the duration has passed
	$("#URCMapNote" + TrickRemove).show().delay(delay).queue(function(n) {
		$(this).remove();
		n();
	});

}

function checkIfClickStatus(URStatus, AutoSendComment) {
	return function() {

		if (options.AutoClickURStatus) {

			// Bypass the confirm function so other site messages do not come up!
			confirmToConsole();

			const openInput = $("input[value='open']");

			// Click the ur status options (Not identified solved, open)
			if (openInput) {

				if (URStatus.toLowerCase() === "notidentified") {

					// Click Not identified
					$("input[value='not-identified']").trigger('click');

				} else if (URStatus.toLowerCase() === "solved") {

					// Click solved

					$("input[value='solved']").trigger('click');
				} else {

					// Click back on open just encase the wrong reply was clicked previously
					openInput.trigger('click');

				}
			}

			// Restores confirm function so other site messages come up!
			restoreConfirmToConfirm();
		}

		if (AutoSendComment === "AutoSendComment") {
			setTimeout(uRVerifyStatusSet(URStatus, AutoSendComment), 1);
		}
	};
}

function confirmToConsole() {
	// Override the default action of the standard confirm by writing confirm to a new function nconfirm, making a 'fake' confirm and then restoring confirm by copying the nconfirm back over confirm!
	nConfirm = confirm;

	confirm = function(msg) {
		// if ((I18n.translations[I18n.locale].update_requests.panel.confirm == msg) && (uroGetCBChecked('_cbDisablePendingQuestions') == true)) {
		// urcToConsole('URComment confirm redirected to console: ' + msg);
		return true;
	};
}

function restoreConfirmToConfirm() {
	// Restore the normal action of confirm by writing nconfirm to back over confirm, so the site is able to send user messages outside of my script!
	confirm = nConfirm;
}

function uRVerifyStatusSet(URStatus, AutoSendComment) {
	return function() {

		let URStatusOk = true;

		if (options.AutoClickURStatus) {

			if (URStatus.toLowerCase() === "notidentified") {

				// Click Not identified
				if ($("input[value='not-identified']").is(":checked") === false) {
					URStatusOk = false;
				}

			} else if (URStatus.toLowerCase() === "solved") {

				// Click solved
				if ($("input[value='solved']").is(":checked") === false) {
					URStatusOk = false;
				}

			} else {

				// Click back on open just encase the wrong reply was clicked previously
				if ($("input[value='open']").is(":checked") === false) {
					URStatusOk = false;
				}

			}

		}

		if (URStatusOk) {
			setTimeout(autoClickSend(URStatus, AutoSendComment), 10);
		} else {
			setTimeout(uRVerifyStatusSet(URStatus, AutoSendComment), 150);
		}

	};
}

function autoClickSend(URStatus, AutoSendComment) {
	return function() {
		if (AutoSendComment === "AutoSendComment") {
			$('.new-comment-form .send-button').trigger('click');
		}
	};
}

function autoReloadMapOnComment() {
	// Click the reload button for the map
	$("#overlay-buttons .reload-button").trigger('click');
}

// This is the small crosshair in the UR window
function crossHairsClicked(urID, zoom) {
	return function() {
		setTimeout(() => goToURById(urID, zoom), 100);
	};
}

function getUrById(id) {

	/*
	const urs = W.model.mapUpdateRequests.getObjectArray();

	for (let i = 0; i < urs.length; i++) {
		if (urs[i].attributes?.id === id) {
			return urs[i];
		}
	}

	return null;
	 */

	return W.model.mapUpdateRequests.objects[id];
}

function sleep(ms) {
	return new Promise(resolve => setTimeout(resolve, ms));
}

///////////////////////////////////////////////////////////////////////////////////
//////
////// Background task(s)
//////
///////////////////////////////////////////////////////////////////////////////////

// Look for the UR window to be open
function lookForOpenedUR() {

	// Relaunch checking for open ur - moved this up here so the script would keep trying if I had an error
	setTimeout(lookForOpenedUR, 500);

	let urID = W.map.getLayerByName('update_requests').features.filter((feature) => feature.attributes.wazeFeature.isSelected)[0]?.attributes?.wazeFeature?.id;

	if (typeof urID !== 'undefined' && urID > 0) {

		// New or same ur (re)open(ed) so now we can do stuff; this prevents this function to continuously applying settings to a ur
		if (UrCommentLasturID !== urID && $(".new-comment-text").length !== 0) {

			// grab the current UR ID for next time
			UrCommentLasturID = urID;

			// Auto expand ur comments list and text area
			const conversation = $("#panel-container .problem-edit .conversation");
			if (conversation.length !== 0) {
				conversation.removeClass('collapsed');
			}

			// Auto expand ur comments description
			const description = $("#panel-container .problem-edit .description");
			if (description.length !== 0) {
				description.removeClass('collapsed');

				if (options.HideAADescription) {
					const content = $("#panel-container .problem-edit .description .content");
					if (content.length !== 0) {
						let contentText = content.text();

						// Does the AA tag exist?
						if (contentText.indexOf("Reported from AAOS") >= 0) {
							if (contentText === "Reported from AAOS") {
								// Full description so just hide it
								description.css("display", "none");
							} else {
								// Subtract if from the content
								content.text(contentText.replace("Reported from AAOS", ""));
							}
						}
					}

				}
			}

			// Disable the stupid buttons at the bottom of the UR window done / next
			const nextButton = $("#panel-container .content .navigation");
			if (nextButton.length > 0 && options.UrCommentDisableURDoneBtn) {
				nextButton.css('display', 'none');
			}

			// Jump to bottom in full UR section
			const topSection = $('.problem-data').parent();
			topSection.scrollTop(topSection[0].scrollHeight);

			// Jump to bottom in conversation section
			const conversationSection = $('.conversation-view .comment-list');
			conversationSection.scrollTop(conversationSection[0].scrollHeight);

			// Attach an even listener to the UR center button to take us to the UR
			$('#panel-container .header .panel-header-actions .focus').on('click', crossHairsClicked(urID, 15));

			// Autofill in comment
			// Check what type of message to insert into the ur
			const UR = getUrById(urID);
			let comments;

			if (W.model.updateRequestSessions.objects[urID].hasOwnProperty('comments')) {
				comments = W.model.updateRequestSessions.objects[urID].comments;
			} else {
				comments = W.model.updateRequestSessions.objects[urID].attributes.comments;
			}

			const commentCount = comments.length;

			// If number of comment is zero assume this is a new ur
			if (!UR.attributes.hasComments) {

				const noPermissionAlert = $(".no-permissions-alert").length > 0;

				// Initial, zero comments
				if (options.AutoSetNewComment && !noPermissionAlert) {

					// This will be on of the types of UR that a user can choose from when submitting a UR
					const urType = UR.attributes.type;

					if (options.CustomTextList && options.CustomTextList !== "Default") {
						for (let i = 0; i < CustomListText.length; i++) {

							let text = CustomListText[i];

							if (text.name.toLowerCase().replace('.', '') === def_names[urType].toLowerCase()) {

								let reply = text.text;

								if (text.signature) {
									reply += '$SIGNATURE';
								}

								setTimeout(autoZoomIN(text.name, reply, text.status, urID), 0);
								break;
							}
						}
					} else {
						// Loop through the comment array for a comment that matches the request type.
						for (let i = 0; i < URCommentsArray.length; i = i + 3) {
							if (URCommentsArray[i].toLowerCase().replace('.', '') === def_names[urType].toLowerCase()) {
								setTimeout(autoZoomIN(URCommentsArray[i], URCommentsArray[i + 1], URCommentsArray[i + 2], urID), 0);
								break;
							}
						}
					}

					//var inmyzone = 1;
				} else if (noPermissionAlert){
					//$(".new-comment-text").prop('disabled', true);
					//$(".send-button").hide();
					//var inmyzone = 0;
				}

				/*
        var db = openDatabase("URCom" // actual database name.  Opens existing or creates.
                  , "1" // version number.  *Must* be correct.
                  , "Database to collect URs and call them back later" //
                  , 10 * 1024*1024);
            db.transaction(function(tx){
                var timetocheck=0;
                var ReminderDays = $('#ReminderDays').val();
                if(getUrById(urID).comments[0])
                {
                    timetocheck = uroGetCommentAge(getUrById(urID).comments[0]);
                } else {
                    timetocheck = 0;
                }
                timetocheck = timetocheck - ReminderDays;
                if (timetocheck <1) {
    timetocheck = 1;
  }
                var today = new Date();
  var dd = today.getDate();
  dd=dd+timetocheck;
  var mm = today.getMonth()+1;
  var yyyy = today.getFullYear();
  var datum = new Date(Date.UTC(yyyy,mm,dd,0,0,0));
  W.map.center.transform(W.map.projection, W.map.displayProjection); // The map is in 900913 projection, converting to EPSG:4326 to get "normal" GPS coordinates
  var URlink = "https://www.waze.com/fr/editor/?env=row&lon=" + W.map.center.lon + "&lat=" + W.map.center.lat +"&mapUpdateRequest="+urID;
  tx.executeSql("INSERT INTO `UR_List` (id, timetocheck, inmyzone, link) VALUES (?,?,?,?)", [urID, timetocheck, inmyzone, URlink]);
            });*/

			} else {

				// Reminder & close section
				const LastCommenterUserID = comments[comments.length - 1].userID;

				// uro days old
				let commentDaysOld = uroGetCommentAge(comments[commentCount - 1]);

				// Do we want to auto set reminders
				if (options.UrCommentAutoSet4dayComment) {

					// -- REMINDER SECTION -- \\
					const ReminderDays = options.ReminderDays;

					// Only 1 comment has been added, reminder days is higher than 0, reminder days has passed, and comment isn't from reporter (aka userid != -1)
					if (commentCount === 1 && ReminderDays > 0 && commentDaysOld >= ReminderDays && LastCommenterUserID > 1) {
						setTimeout(autoZoomIN(URCommentsArray[ReminderPosition], URCommentsArray[ReminderPosition + 1], URCommentsArray[ReminderPosition + 2], urID), 0);
					}

					// -- CLOSE SECTION -- \\
					const CloseDays = options.CloseDays;

					if (commentCount > 1 && CloseDays > 0 && commentDaysOld >= CloseDays && LastCommenterUserID > 1) {
						setTimeout(autoZoomIN(URCommentsArray[CloseNotIdentifiedPosition], URCommentsArray[CloseNotIdentifiedPosition + 1], URCommentsArray[CloseNotIdentifiedPosition + 2], urID), 0);
					}

				}

				// Don't allow auto filling of the close message because it clicks the not identified option and causes trouble when the Ur window is shut/closed the next save will mark it as not identified, without a comment.

			}

			/*if ($(".no-permissions-alert")[0] || $(".close-details")[0]){
          $(".new-comment-text").prop('disabled', true);
          $(".new-comment-text").hide();
          $(".send-button").hide();
      }*/
			/*if($(".new-comment-text").val()==="" && URComSignature.trim()!=="")
      {
          $(".new-comment-text").val("\n\n" + URComSignature);
      }*/

			const WazeCurrentZoom = getWazeMapZoomLevel();

			// Predefined zoom threshold for auto zoom
			const zoom = 15;

			if (commentCount === 0 && options.NewZoomIn) {
				// Zoom in new

				// Do not zoom back out if we are already zoomed in and just happen to be re-clicking on a UR.
				if (WazeCurrentZoom < zoom) {
					goToURById(urID, zoom);
				}
			} else if (options.WithCommentRecenter) {

				// Re-center on urs that are not zoom in
				if (WazeCurrentZoom < zoom) {
					goToURById(urID, WazeCurrentZoom);
				}

			}

			// Auto switch to ur comments tab
			if (options.AutoSwitchToURCommentsTab) {
				// Grab the active tab
				PreviousTab = $("#user-tabs > ul > li.active > a");
				// Grab the active tabs scroll position
				PreviousTabPosition = $('#sidebar').scrollTop();
				$('#sidebar').scrollTop( 0 ); //set scoll pos

				// Open the scripts tab
				if (!$("[data-for=userscript_tab]")[0].selected) {
					$(".w-icon.w-icon-script").trigger('click');
				}

				//Make UR Comments tab active
				$('#CommentsTab').trigger('click');
			}
		}


	} else {

		// Reset the id if a ur is not open so we can set the tab for the same ur
		UrCommentLasturID = "";

		// Switch tab back
		if (options.AutoSwitchToURCommentsTab) {

			// Verify that we had found a tab
			if (PreviousTab !== null) {

				// Click back on the previous tab
				$(PreviousTab).trigger('click');
				$('#sidebar').scrollTop( PreviousTabPosition ); // Set scoll pos
				// Clear out the previous tab holder
				PreviousTab = null;
				PreviousTabPosition = null;

			}

		}
	}

}

function URCLoadUpdateRequestsEvents() {
	window.HideUR = "stopped";

	//from Cardyin 5/26/2016
	W.model.mapUpdateRequests.on("objectschanged", urcUREvent_onObjectsAdded('mapUpdateRequests objectschanged')); // needed
	W.model.updateRequestSessions.on("objectsadded", urcUREvent_onObjectsAdded('updateRequestSessions objectsadded')); // needed

	W.map.events.register("moveend", null, urcUREvent_onObjectsAdded('moveend')); //needed
	W.map.events.register("zoomend", null, urcUREvent_onObjectsAdded('zoomend')); //needed

	setTimeout(urcUREvent_onObjectsAdded('pageload'), 500);
}

function init() {

	// if we are changing the language do not redraw the tab
	if (ChangeLanguage === false) {

		applyCss();

		// -- Setup the tab for the script
		const scriptTab = $('<li><a href="#sidepanel-Comments" data-toggle="tab" id="CommentsTab"><img src="' + UrCommentsIcon + '" height="16px" title="URCom" alt="URCom"/> URCom</li>');

		// I had to switch to first() because someone was reusing the nav tabs in another
		// script and this would cause my tab to go inside theirs!
		$("#user-tabs ul.nav-tabs").first().append(scriptTab);

		// -- Setup the pane for our content
		scriptContentPane = $('<div class="tab-pane" id="sidepanel-Comments"></div>');
		$("#user-info div.tab-content").first().append(scriptContentPane);

	}

	// Reset the var to change the language
	ChangeLanguage = false;

	// Add the content to the comments tab
	// Comment tab header and zoom out button
	const topSection = $('<div class="URComments"></div>")');
	scriptContentPane.append(topSection);

	const topOptions = $('<div id="options" style="display: flex; justify-content: space-between; width: 97%; text-align: center"></div>');

	// Map Reload
	const reload = $('<div id="URCWazeReloadMap" style="width: 30%;" class="urcom-button" title="' + URC_Text_tooltip[3] + '">' + RefreshIcon + '</div>');
	reload.on('click', autoReloadMapOnComment);

	// Close UR and zoom
	const closeAndZoom = $('<div id="CloseAndZoom" style="width: 30%;" class="urcom-button" title="' + URC_Text_tooltip[0] + '">' + MagnifyingIcon + '</div>');
	closeAndZoom.on('click', setZoomCloseUR(15, "CloseUR"))

	// Shows UR count
	const urCount = $('<div id="URCountWrapper" style="width: 30%;" class="urcom-button" Title="' + URC_Text_tooltip[4] + '"><img src="' + UrCommentsIcon + '" height="16px" style="margin-right: 5px;"/><span id="URCount"></span></div>');

	topOptions.append(reload).append(closeAndZoom).append(urCount);
	topSection.append(topOptions);

	const tabs = $('<wz-tabs fixed="true"></wz-tabs>');

	const textTab = $('<wz-tab is-active label="' + URC_Text[5] + '" tooltip="' + URC_Text[5] + '"></wz-tab>');
	const textTabContent = $('<div id="sidepanel-URComments-list"></div>')
	textTab.append(textTabContent);

	const filterTab = $('<wz-tab label="' + URC_Text[6] + '" tooltip="' + URC_Text[6] + '"></wz-tab>');
	const filterTabContent = $('<div id="sidepanel-URComments-URO-Presets"></div>')
	filterTab.append(filterTabContent);

	const settingsTab = $('<wz-tab label="' + URC_Text[7] + '" tooltip="' + URC_Text[7] + '"></wz-tab>');
	const settingsTabContent = $('<div id="sidepanel-URComments-settings"></div>')
	settingsTab.append(settingsTabContent);

	tabs.append(textTab).append(filterTab).append(settingsTab);
	scriptContentPane.append(tabs);

	// Overwrite the padding for the tabs to show more text
	setTimeout(() => {
		$($('#sidepanel-Comments wz-tabs')[0].shadowRoot).find('.wz-tab-label').css('padding', 5);
	}, 1000);

	////////////////////////////////////////////////////////////////////////////////////////////////////////////
	//////
	////// Draw Options
	//////
	////////////////////////////////////////////////////////////////////////////////////////////////////////////

	addCommentTexts(textTabContent);

	addOptions(settingsTabContent);

	addFilters(filterTabContent);


	////////////////////////////////////////////////////////////////////////////////////////////////////////////
	//////
	////// Launch background task(s)
	//////
	////////////////////////////////////////////////////////////////////////////////////////////////////////////

	// Start looking for opened UR's window
	setTimeout(lookForOpenedUR, 1000);

	setTimeout(URCLoadUpdateRequestsEvents, 0);

}

function startCode() {

	if ($("#user-tabs").length && InitReady) {
		init();
	} else {
		setTimeout(startCode, 2000);
	}

}

async function initDatabase() {
	const request = window.indexedDB.open("URCom", 1);

	request.onerror = (event) => {
		console.error("[URCom] Why didn't you allow my web app to use IndexedDB?!");
	};

	request.onupgradeneeded = (event) => {
		const db = event.target.result;
		const objectStore = db.createObjectStore("custom_lists", { keyPath: "name" });

		objectStore.transaction.oncomplete = (event) => {
			console.log("[URCom] Created store");
		}
	}

	request.onsuccess = (event) => {
		console.log("[URCom] DB ready");
		DB = event.target.result;
	};

	while (!DB) {
		await sleep(10);
	}

	if ("openDatabase" in window) {
		try {

			let created = false;

			const oldDb = openDatabase(
				"URCom", // actual database name.  Opens existing or creates.
				"1", // version number.  *Must* be correct.
				"Database to store custom URCom data", //
				10 * 1024 * 1024, // Size of the DB
				() => {
					created = true;
				}
			);

			if (!created) {

				console.log("[URCom] Migrating");
				await migrateDb(oldDb);
				console.log("[URCom] Migration over");

			}

		} catch (e) {}
	}

}

setTimeout(URComments_bootstrap, 3000);