From a40bc1e92b5a6880a36cc3a4e5a7ac55ebe7ccd9 Mon Sep 17 00:00:00 2001 From: Joffrey JAFFEUX Date: Fri, 22 Nov 2019 17:14:27 +0100 Subject: [PATCH] FIX: prevents timezone to show duplicated zones in preview It could happen if you have Etc/UTC in default settings, and timezone="UTC" on date, the equality check is now more strict. --- .../discourse-local-dates.js.no-module.es6 | 40 ++++++++++--------- 1 file changed, 22 insertions(+), 18 deletions(-) diff --git a/plugins/discourse-local-dates/assets/javascripts/discourse-local-dates.js.no-module.es6 b/plugins/discourse-local-dates/assets/javascripts/discourse-local-dates.js.no-module.es6 index 3be2593ce2e..d9c9f138e05 100644 --- a/plugins/discourse-local-dates/assets/javascripts/discourse-local-dates.js.no-module.es6 +++ b/plugins/discourse-local-dates/assets/javascripts/discourse-local-dates.js.no-module.es6 @@ -125,6 +125,10 @@ } function _isEqualZones(timezoneA, timezoneB) { + if (timezoneA.includes(timezoneB) || timezoneB.includes(timezoneA)) { + return true; + } + return ( moment.tz(timezoneA).utcOffset() === moment.tz(timezoneB).utcOffset() ); @@ -222,7 +226,9 @@ const previewedTimezones = []; const watchingUserTimezone = moment.tz.guess(); const timezones = options.timezones.filter( - timezone => timezone !== watchingUserTimezone + timezone => + !_isEqualZones(timezone, watchingUserTimezone) && + !_isEqualZones(timezone, options.timezone) ); previewedTimezones.push({ @@ -244,26 +250,24 @@ timezones.unshift(options.timezone); } - timezones - .filter(z => z) - .forEach(timezone => { - if (_isEqualZones(timezone, displayedTimezone)) { - return; - } + timezones.filter(Boolean).forEach(timezone => { + if (_isEqualZones(timezone, displayedTimezone)) { + return; + } - if (_isEqualZones(timezone, watchingUserTimezone)) { - timezone = watchingUserTimezone; - } + if (_isEqualZones(timezone, watchingUserTimezone)) { + timezone = watchingUserTimezone; + } - previewedTimezones.push({ - timezone, - dateTime: options.time - ? moment(dateTime) - .tz(timezone) - .format("LLL") - : _createDateTimeRange(dateTime, timezone) - }); + previewedTimezones.push({ + timezone, + dateTime: options.time + ? moment(dateTime) + .tz(timezone) + .format("LLL") + : _createDateTimeRange(dateTime, timezone) }); + }); if (!previewedTimezones.length) { previewedTimezones.push({