Skip to content

Commit

Permalink
2019.09.18.01
Browse files Browse the repository at this point in the history
  • Loading branch information
dBsooner committed Sep 18, 2019
1 parent 58b8c9b commit 6e7ac63
Showing 1 changed file with 36 additions and 29 deletions.
65 changes: 36 additions & 29 deletions WME-URComments-Enhanced.js
Original file line number Diff line number Diff line change
@@ -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
Expand Down Expand Up @@ -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 = ['<b>CHANGE:</b> Changed restrictions applied to be a warning icon in settings and comment list.',
'<b>BUGFIX:</b> Another fix for the restrictions alert.',
'<b>PREVIOUS RELEASES - 2019.08.27.01 2019.08.28.01 - BELOW</b>',
'<b>CHANGE:</b> Shortcuts in UR are now collapsible, with state retained in settings.',
'<b>BUGFIX:</b> Shortcuts not correctly initiating other events.',
'<b>BUGFIX:</b> Country and state being re-added multiple times by WME. (workaround)',
'<b>NEW:</b> New comment box will have a peachish background color if append mode is enabled.',
'<b>CHANGE:</b> Major overhaul of output text to limit number of jQuery operations. BIG speed increase.',
'<b>CHANGE:</b> Removed automated custom sheet creation / conversion.',
'<b>CHANGE:</b> Added manual custom sheet creation / conversion (conversion will still work).',
'<b>CHANGE:</b> Alert box completely removed in favor of WazeWrap alerts (missed one or two).',
'<b>CHANGE:</b> Ability to translate intersection / segment naming to locales.',
'<b>CHANGE:</b> Catch if row 25 is not set to "GROUP TITLE" and report gracefully.',
'<b>CHANGE:</b> Queue auto-sent reminders info box and display after completion of routine.',
'<b>CHANGE:</b> Better handle carriage returns during shortcut insertion.',
'<b>BUGFIX:</b> Restoring settings would inadvertantly get overwritten by WazeWrap backups.',
'<b>BUGFIX:</b> Better handling of errors in processing so mask boxes get removed.',
'<b>BUGFIX:</b> Improper handling of mouse events in some browsers.'
SCRIPT_VERSION_CHANGES = ['<b>NEW:</b> Remember collapsed state of <i>More Information</i> box in UR Panel.',
'<b>NEW:</b> Unknown venue name (no name on venue / place) is now translatable to locale(s).',
'<b>NEW:</b> Unknown road name (no name on road / segment) is now translatable to locale(s).',
'<b>BUGFIX:</b> Translations not loading correctly in certain situations.'
],
DOUBLE_CLICK_ICON = '',
DEBUG = true,
Expand Down Expand Up @@ -257,6 +243,7 @@ async function loadSettingsFromStorage(restoreSettings, proceedWithRestore) {
lastSaved: 0,
lastVersion: undefined,
wmeUserId: undefined,
expandMoreInfo: false,
expandShortcuts: true,
// Comment List
commentList: 0,
Expand Down Expand Up @@ -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);
}

Expand Down Expand Up @@ -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;
Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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'));
Expand Down Expand Up @@ -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' }));
Expand Down Expand Up @@ -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',
Expand Down Expand Up @@ -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)
Expand Down

0 comments on commit 6e7ac63

Please sign in to comment.