diff --git a/WME-URComments-Enhanced.js b/WME-URComments-Enhanced.js
index 7d38051..25de46a 100644
--- a/WME-URComments-Enhanced.js
+++ b/WME-URComments-Enhanced.js
@@ -1,7 +1,7 @@
// ==UserScript==
// @name WME URComments-Enhanced (beta)
// @namespace https://greasyfork.org/users/166843
-// @version 2019.08.30.01
+// @version 2019.09.18.01
// eslint-disable-next-line max-len
// @description URComments-Enhanced (URC-E) allows Waze editors to handle WME update requests more quickly and efficiently. Also adds many UR filtering options, ability to change the markers, plus much, much, more!
// @grant none
@@ -38,24 +38,10 @@ const SCRIPT_NAME = GM_info.script.name.replace('(beta)', 'β'),
SETTINGS_STORE_NAME = 'WME_URC-E',
ALERT_UPDATE = true,
SCRIPT_VERSION = GM_info.script.version,
- SCRIPT_VERSION_CHANGES = ['CHANGE: Changed restrictions applied to be a warning icon in settings and comment list.',
- 'BUGFIX: Another fix for the restrictions alert.',
- 'PREVIOUS RELEASES - 2019.08.27.01 2019.08.28.01 - BELOW',
- 'CHANGE: Shortcuts in UR are now collapsible, with state retained in settings.',
- 'BUGFIX: Shortcuts not correctly initiating other events.',
- 'BUGFIX: Country and state being re-added multiple times by WME. (workaround)',
- 'NEW: New comment box will have a peachish background color if append mode is enabled.',
- 'CHANGE: Major overhaul of output text to limit number of jQuery operations. BIG speed increase.',
- 'CHANGE: Removed automated custom sheet creation / conversion.',
- 'CHANGE: Added manual custom sheet creation / conversion (conversion will still work).',
- 'CHANGE: Alert box completely removed in favor of WazeWrap alerts (missed one or two).',
- 'CHANGE: Ability to translate intersection / segment naming to locales.',
- 'CHANGE: Catch if row 25 is not set to "GROUP TITLE" and report gracefully.',
- 'CHANGE: Queue auto-sent reminders info box and display after completion of routine.',
- 'CHANGE: Better handle carriage returns during shortcut insertion.',
- 'BUGFIX: Restoring settings would inadvertantly get overwritten by WazeWrap backups.',
- 'BUGFIX: Better handling of errors in processing so mask boxes get removed.',
- 'BUGFIX: Improper handling of mouse events in some browsers.'
+ SCRIPT_VERSION_CHANGES = ['NEW: Remember collapsed state of More Information box in UR Panel.',
+ 'NEW: Unknown venue name (no name on venue / place) is now translatable to locale(s).',
+ 'NEW: Unknown road name (no name on road / segment) is now translatable to locale(s).',
+ 'BUGFIX: Translations not loading correctly in certain situations.'
],
DOUBLE_CLICK_ICON = '',
DEBUG = true,
@@ -257,6 +243,7 @@ async function loadSettingsFromStorage(restoreSettings, proceedWithRestore) {
lastSaved: 0,
lastVersion: undefined,
wmeUserId: undefined,
+ expandMoreInfo: false,
expandShortcuts: true,
// Comment List
commentList: 0,
@@ -447,11 +434,11 @@ async function loadSettingsFromStorage(restoreSettings, proceedWithRestore) {
I18n.t('urce.common.No'));
}
const loadedSettings = (restoreSettings === 'resetSettings') ? undefined : restoreSettings || $.parseJSON(localStorage.getItem(SETTINGS_STORE_NAME));
- _settings = $.extend({}, defaultSettings, loadedSettings);
+ _settings = $.extend(true, {}, defaultSettings, loadedSettings);
const serverSettings = await WazeWrap.Remote.RetrieveSettings(SETTINGS_STORE_NAME);
if (!restoreSettings && serverSettings && (serverSettings.lastSaved > _settings.lastSaved)) {
- $.extend(_settings, serverSettings);
+ $.extend(true, _settings, serverSettings);
_timeouts.saveSettingsToStorage = window.setTimeout(saveSettingsToStorage, 5000);
}
@@ -874,6 +861,15 @@ async function handleUpdateRequestContainer(urId, caller) {
$('i[id|="urceShortcuts"]').off().on('click', function () {
handleClickedShortcut(this.id.substr(14));
});
+ if (_settings.expandMoreInfo && $('#panel-container .mapUpdateRequest .top-section .body .more-info').hasClass('collapsed'))
+ $('#panel-container .mapUpdateRequest .top-section .body .more-info .title').click();
+ $('#panel-container .mapUpdateRequest .top-section .body .more-info .title').on('click', function () {
+ if (this.parentElement.classList.contains('collapsed'))
+ _settings.expandMoreInfo = true;
+ else
+ _settings.expandMoreInfo = false;
+ saveSettingsToStorage();
+ });
$('#urceShortcutsExpand').off().on('click', function () {
if ($($(this).find('i')[0]).hasClass('fa-chevron-down'))
_settings.expandShortcuts = false;
@@ -1073,11 +1069,11 @@ function formatText(text, replaceVars, shortcutClicked) {
if (selFeatures.length > 1) {
const streetObj = W.model.streets.getObjectById(selFeatures[idx].model.attributes.primaryStreetID);
if (idx === 0) {
- street1Name = (streetObj.name && (streetObj.name.length > 0)) ? streetObj.name : 'NO NAME';
+ street1Name = (streetObj.name && (streetObj.name.length > 0)) ? streetObj.name : I18n.t('urce.tools.UnknownRoadName');
firstCityId = streetObj.cityID;
}
else {
- street2Name = (streetObj.name && (streetObj.name.length > 0)) ? streetObj.name : 'NO NAME';
+ street2Name = (streetObj.name && (streetObj.name.length > 0)) ? streetObj.name : I18n.t('urce.tools.UnknownRoadName');
if ((firstCityId !== 999940) && (text.indexOf('$SELSEGS_WITH_CITY$') > -1)) {
if ((firstCityId === streetObj.cityID) || (streetObj.cityID === 999940)) {
const cityObj = W.model.cities.getObjectById(firstCityId);
@@ -1283,10 +1279,8 @@ function formatText(text, replaceVars, shortcutClicked) {
if (placeObj && (placeObj.model.type === 'venue')) {
if (placeObj.model.attributes.residential === true)
text = text.replace('$PLACE_NAME$', I18n.t('objects.venue.fields.residential'));
- else if (placeObj.model.attributes.name.length > 0)
- text = text.replace('$PLACE_NAME$', placeObj.model.attributes.name);
else
- WazeWrap.Alerts.error(SCRIPT_NAME, I18n.t('urce.prompts.PlaceNameInsertError'));
+ text = text.replace('$PLACE_NAME$', ((placeObj.model.attributes.name.length > 0) ? placeObj.model.attributes.name : I18n.t('urce.tools.UnknownVenueName')));
}
else {
WazeWrap.Alerts.error(SCRIPT_NAME, I18n.t('urce.prompts.PlaceNameInsertError'));
@@ -2844,7 +2838,7 @@ function createCommentListCSV(section) {
urstatus = entry.urstatus.toUpperCase();
else
urstatus = '';
- return [`${entry.title}|${entry.comment}|${urstatus}`];
+ return [`"${entry.title.replace(/"/gmi, '\\"')}"|"${entry.comment.replace(/"/gmi, '\\"')}"|${urstatus}`];
});
const a = document.createElement('a');
a.href = URL.createObjectURL(new Blob([commentsArr.join('\n')], { type: 'text/csv' }));
@@ -5058,7 +5052,9 @@ function loadTranslations() {
RestoreSettingsSelectFileTitle: 'Select the JSON file created by the URC-E "Backup" settings button.',
RestoreSettingsTitle: 'Restore a backup copy of your URC-E settings from the JSON backup file created with the backup settings button.\n\nNote: Please do not modify the JSON '
+ 'file in any way. The format is crucial to proper restoral of settings.',
- SegmentWithCity: '$SEG1NAME$ in $SEGCITY$'
+ SegmentWithCity: '$SEG1NAME$ in $SEGCITY$',
+ UnknownRoadName: 'unnamed road',
+ UnknownVenueName: 'unnamed venue'
},
urPanel: {
CurrentDate: 'Current date',
@@ -5177,7 +5173,18 @@ function loadTranslations() {
};
translations['en-US'] = { ...translations.en };
const locale = I18n.currentLocale();
- I18n.translations[locale].urce = $.extend({}, translations.en, translations[locale]);
+ Object.keys(translations[locale]).forEach(obj1 => {
+ if (typeof translations[locale][obj1] === 'object') {
+ Object.keys(translations[locale][obj1]).forEach(obj2 => {
+ if (translations[locale][obj1][obj2].length === 0)
+ delete (translations[locale][obj1][obj2]);
+ });
+ }
+ else if ((typeof translations[locale][obj1] === 'string') && (translations[locale][obj1].length === 0)) {
+ delete (translations[locale][obj1]);
+ }
+ });
+ I18n.translations[locale].urce = $.extend(true, {}, translations.en, translations[locale]);
if (Object.keys(translations).indexOf(locale) === -1)
_needTranslation = true;
if (errorText)