mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
Merge pull request #1570 from Camc314/migrate-to-ES6-23
Migration of datetime, alert and activitylog to ES6 modules
This commit is contained in:
commit
649fca3c3a
12 changed files with 102 additions and 80 deletions
|
@ -92,6 +92,8 @@
|
||||||
"test": [
|
"test": [
|
||||||
"src/components/accessSchedule/accessSchedule.js",
|
"src/components/accessSchedule/accessSchedule.js",
|
||||||
"src/components/actionSheet/actionSheet.js",
|
"src/components/actionSheet/actionSheet.js",
|
||||||
|
"src/components/activitylog.js",
|
||||||
|
"src/components/alert.js",
|
||||||
"src/components/alphaPicker/alphaPicker.js",
|
"src/components/alphaPicker/alphaPicker.js",
|
||||||
"src/components/appFooter/appFooter.js",
|
"src/components/appFooter/appFooter.js",
|
||||||
"src/components/autoFocuser.js",
|
"src/components/autoFocuser.js",
|
||||||
|
@ -205,6 +207,7 @@
|
||||||
"src/plugins/bookPlayer/plugin.js",
|
"src/plugins/bookPlayer/plugin.js",
|
||||||
"src/plugins/bookPlayer/tableOfContents.js",
|
"src/plugins/bookPlayer/tableOfContents.js",
|
||||||
"src/plugins/photoPlayer/plugin.js",
|
"src/plugins/photoPlayer/plugin.js",
|
||||||
|
"src/scripts/datetime.js",
|
||||||
"src/scripts/deleteHelper.js",
|
"src/scripts/deleteHelper.js",
|
||||||
"src/scripts/dfnshelper.js",
|
"src/scripts/dfnshelper.js",
|
||||||
"src/scripts/dom.js",
|
"src/scripts/dom.js",
|
||||||
|
|
|
@ -1,11 +1,21 @@
|
||||||
define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings', 'serverNotifications', 'connectionManager', 'emby-button', 'listViewStyle'], function (events, globalize, dom, datefns, dfnshelper, userSettings, serverNotifications, connectionManager) {
|
import events from 'events';
|
||||||
'use strict';
|
import globalize from 'globalize';
|
||||||
|
import dom from 'dom';
|
||||||
|
import * as datefns from 'date-fns';
|
||||||
|
import dfnshelper from 'dfnshelper';
|
||||||
|
import userSettings from 'userSettings';
|
||||||
|
import serverNotifications from 'serverNotifications';
|
||||||
|
import connectionManager from 'connectionManager';
|
||||||
|
import 'emby-button';
|
||||||
|
import 'listViewStyle';
|
||||||
|
|
||||||
|
/* eslint-disable indent */
|
||||||
|
|
||||||
function getEntryHtml(entry, apiClient) {
|
function getEntryHtml(entry, apiClient) {
|
||||||
var html = '';
|
let html = '';
|
||||||
html += '<div class="listItem listItem-border">';
|
html += '<div class="listItem listItem-border">';
|
||||||
var color = '#00a4dc';
|
let color = '#00a4dc';
|
||||||
var icon = 'notifications';
|
let icon = 'notifications';
|
||||||
|
|
||||||
if ('Error' == entry.Severity || 'Fatal' == entry.Severity || 'Warn' == entry.Severity) {
|
if ('Error' == entry.Severity || 'Fatal' == entry.Severity || 'Warn' == entry.Severity) {
|
||||||
color = '#cc0000';
|
color = '#cc0000';
|
||||||
|
@ -56,8 +66,8 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
}
|
}
|
||||||
|
|
||||||
limit = limit || parseInt(elem.getAttribute('data-activitylimit') || '7');
|
limit = limit || parseInt(elem.getAttribute('data-activitylimit') || '7');
|
||||||
var minDate = new Date();
|
const minDate = new Date();
|
||||||
var hasUserId = 'false' !== elem.getAttribute('data-useractivity');
|
const hasUserId = 'false' !== elem.getAttribute('data-useractivity');
|
||||||
|
|
||||||
if (hasUserId) {
|
if (hasUserId) {
|
||||||
minDate.setTime(minDate.getTime() - 24 * 60 * 60 * 1000); // one day back
|
minDate.setTime(minDate.getTime() - 24 * 60 * 60 * 1000); // one day back
|
||||||
|
@ -74,7 +84,7 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
elem.setAttribute('data-activitystartindex', startIndex);
|
elem.setAttribute('data-activitystartindex', startIndex);
|
||||||
elem.setAttribute('data-activitylimit', limit);
|
elem.setAttribute('data-activitylimit', limit);
|
||||||
if (!startIndex) {
|
if (!startIndex) {
|
||||||
var activityContainer = dom.parentWithClass(elem, 'activityContainer');
|
const activityContainer = dom.parentWithClass(elem, 'activityContainer');
|
||||||
|
|
||||||
if (activityContainer) {
|
if (activityContainer) {
|
||||||
if (result.Items.length) {
|
if (result.Items.length) {
|
||||||
|
@ -91,7 +101,7 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
}
|
}
|
||||||
|
|
||||||
function onActivityLogUpdate(e, apiClient, data) {
|
function onActivityLogUpdate(e, apiClient, data) {
|
||||||
var options = this.options;
|
const options = this.options;
|
||||||
|
|
||||||
if (options && options.serverId === apiClient.serverId()) {
|
if (options && options.serverId === apiClient.serverId()) {
|
||||||
reloadData(this, options.element, apiClient);
|
reloadData(this, options.element, apiClient);
|
||||||
|
@ -99,14 +109,14 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
}
|
}
|
||||||
|
|
||||||
function onListClick(e) {
|
function onListClick(e) {
|
||||||
var btnEntryInfo = dom.parentWithClass(e.target, 'btnEntryInfo');
|
const btnEntryInfo = dom.parentWithClass(e.target, 'btnEntryInfo');
|
||||||
|
|
||||||
if (btnEntryInfo) {
|
if (btnEntryInfo) {
|
||||||
var id = btnEntryInfo.getAttribute('data-id');
|
const id = btnEntryInfo.getAttribute('data-id');
|
||||||
var items = this.items;
|
const items = this.items;
|
||||||
|
|
||||||
if (items) {
|
if (items) {
|
||||||
var item = items.filter(function (i) {
|
const item = items.filter(function (i) {
|
||||||
return i.Id.toString() === id;
|
return i.Id.toString() === id;
|
||||||
})[0];
|
})[0];
|
||||||
|
|
||||||
|
@ -118,35 +128,35 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
}
|
}
|
||||||
|
|
||||||
function showItemOverview(item) {
|
function showItemOverview(item) {
|
||||||
require(['alert'], function (alert) {
|
import('alert').then(({default: alert}) => {
|
||||||
alert({
|
alert({
|
||||||
text: item.Overview
|
text: item.Overview
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function ActivityLog(options) {
|
class ActivityLog {
|
||||||
|
constructor(options) {
|
||||||
this.options = options;
|
this.options = options;
|
||||||
var element = options.element;
|
const element = options.element;
|
||||||
element.classList.add('activityLogListWidget');
|
element.classList.add('activityLogListWidget');
|
||||||
element.addEventListener('click', onListClick.bind(this));
|
element.addEventListener('click', onListClick.bind(this));
|
||||||
var apiClient = connectionManager.getApiClient(options.serverId);
|
const apiClient = connectionManager.getApiClient(options.serverId);
|
||||||
reloadData(this, element, apiClient);
|
reloadData(this, element, apiClient);
|
||||||
var onUpdate = onActivityLogUpdate.bind(this);
|
const onUpdate = onActivityLogUpdate.bind(this);
|
||||||
this.updateFn = onUpdate;
|
this.updateFn = onUpdate;
|
||||||
events.on(serverNotifications, 'ActivityLogEntry', onUpdate);
|
events.on(serverNotifications, 'ActivityLogEntry', onUpdate);
|
||||||
apiClient.sendMessage('ActivityLogEntryStart', '0,1500');
|
apiClient.sendMessage('ActivityLogEntryStart', '0,1500');
|
||||||
}
|
}
|
||||||
|
destroy() {
|
||||||
ActivityLog.prototype.destroy = function () {
|
const options = this.options;
|
||||||
var options = this.options;
|
|
||||||
|
|
||||||
if (options) {
|
if (options) {
|
||||||
options.element.classList.remove('activityLogListWidget');
|
options.element.classList.remove('activityLogListWidget');
|
||||||
connectionManager.getApiClient(options.serverId).sendMessage('ActivityLogEntryStop', '0,1500');
|
connectionManager.getApiClient(options.serverId).sendMessage('ActivityLogEntryStop', '0,1500');
|
||||||
}
|
}
|
||||||
|
|
||||||
var onUpdate = this.updateFn;
|
const onUpdate = this.updateFn;
|
||||||
|
|
||||||
if (onUpdate) {
|
if (onUpdate) {
|
||||||
events.off(serverNotifications, 'ActivityLogEntry', onUpdate);
|
events.off(serverNotifications, 'ActivityLogEntry', onUpdate);
|
||||||
|
@ -154,7 +164,9 @@ define(['events', 'globalize', 'dom', 'date-fns', 'dfnshelper', 'userSettings',
|
||||||
|
|
||||||
this.items = null;
|
this.items = null;
|
||||||
this.options = null;
|
this.options = null;
|
||||||
};
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return ActivityLog;
|
export default ActivityLog;
|
||||||
});
|
|
||||||
|
/* eslint-enable indent */
|
||||||
|
|
|
@ -1,14 +1,17 @@
|
||||||
define(['browser', 'dialog', 'globalize'], function (browser, dialog, globalize) {
|
import browser from 'browser';
|
||||||
'use strict';
|
import dialog from 'dialog';
|
||||||
|
import globalize from 'globalize';
|
||||||
|
|
||||||
|
/* eslint-disable indent */
|
||||||
|
|
||||||
function replaceAll(originalString, strReplace, strWith) {
|
function replaceAll(originalString, strReplace, strWith) {
|
||||||
var reg = new RegExp(strReplace, 'ig');
|
const reg = new RegExp(strReplace, 'ig');
|
||||||
return originalString.replace(reg, strWith);
|
return originalString.replace(reg, strWith);
|
||||||
}
|
}
|
||||||
|
|
||||||
return function (text, title) {
|
export default function (text, title) {
|
||||||
|
|
||||||
var options;
|
let options;
|
||||||
if (typeof text === 'string') {
|
if (typeof text === 'string') {
|
||||||
options = {
|
options = {
|
||||||
title: title,
|
title: title,
|
||||||
|
@ -21,7 +24,7 @@ define(['browser', 'dialog', 'globalize'], function (browser, dialog, globalize)
|
||||||
if (browser.tv && window.alert) {
|
if (browser.tv && window.alert) {
|
||||||
alert(replaceAll(options.text || '', '<br/>', '\n'));
|
alert(replaceAll(options.text || '', '<br/>', '\n'));
|
||||||
} else {
|
} else {
|
||||||
var items = [];
|
const items = [];
|
||||||
|
|
||||||
items.push({
|
items.push({
|
||||||
name: globalize.translate('ButtonGotIt'),
|
name: globalize.translate('ButtonGotIt'),
|
||||||
|
@ -41,5 +44,6 @@ define(['browser', 'dialog', 'globalize'], function (browser, dialog, globalize)
|
||||||
}
|
}
|
||||||
|
|
||||||
return Promise.resolve();
|
return Promise.resolve();
|
||||||
};
|
}
|
||||||
});
|
|
||||||
|
/* eslint-enable indent */
|
||||||
|
|
|
@ -53,7 +53,7 @@ define(['loading', 'globalize', 'events', 'viewManager', 'skinManager', 'backdro
|
||||||
break;
|
break;
|
||||||
case 'ServerUpdateNeeded':
|
case 'ServerUpdateNeeded':
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({
|
alert.default({
|
||||||
text: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin'),
|
text: globalize.translate('ServerUpdateNeeded', 'https://github.com/jellyfin/jellyfin'),
|
||||||
html: globalize.translate('ServerUpdateNeeded', '<a href="https://github.com/jellyfin/jellyfin">https://github.com/jellyfin/jellyfin</a>')
|
html: globalize.translate('ServerUpdateNeeded', '<a href="https://github.com/jellyfin/jellyfin">https://github.com/jellyfin/jellyfin</a>')
|
||||||
}).then(function () {
|
}).then(function () {
|
||||||
|
|
|
@ -346,6 +346,7 @@ import 'css!./multiSelect';
|
||||||
|
|
||||||
import('alert').then(({default: alert}) => {
|
import('alert').then(({default: alert}) => {
|
||||||
alert({
|
alert({
|
||||||
|
|
||||||
text: globalize.translate('PleaseSelectTwoItems')
|
text: globalize.translate('PleaseSelectTwoItems')
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -709,7 +709,7 @@ define(['events', 'datetime', 'appSettings', 'itemHelper', 'pluginManager', 'pla
|
||||||
function showPlaybackInfoErrorMessage(instance, errorCode, playNextTrack) {
|
function showPlaybackInfoErrorMessage(instance, errorCode, playNextTrack) {
|
||||||
|
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({
|
alert.default({
|
||||||
text: globalize.translate('PlaybackError' + errorCode),
|
text: globalize.translate('PlaybackError' + errorCode),
|
||||||
title: globalize.translate('HeaderPlaybackError')
|
title: globalize.translate('HeaderPlaybackError')
|
||||||
}).then(function () {
|
}).then(function () {
|
||||||
|
|
|
@ -16,7 +16,7 @@ import globalize from 'globalize';
|
||||||
|
|
||||||
view.addEventListener('viewshow', function () {
|
view.addEventListener('viewshow', function () {
|
||||||
if (!activityLog) {
|
if (!activityLog) {
|
||||||
activityLog = new ActivityLog({
|
activityLog = new ActivityLog.default({
|
||||||
serverId: ApiClient.serverId(),
|
serverId: ApiClient.serverId(),
|
||||||
element: view.querySelector('.activityItems')
|
element: view.querySelector('.activityItems')
|
||||||
});
|
});
|
||||||
|
|
|
@ -1787,7 +1787,7 @@ define(['loading', 'appRouter', 'layoutManager', 'connectionManager', 'userSetti
|
||||||
imageLoader.lazyChildren(collectionItems);
|
imageLoader.lazyChildren(collectionItems);
|
||||||
collectionItems.querySelector('.btnAddToCollection').addEventListener('click', function () {
|
collectionItems.querySelector('.btnAddToCollection').addEventListener('click', function () {
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({
|
alert.default({
|
||||||
text: globalize.translate('AddItemToCollectionHelp'),
|
text: globalize.translate('AddItemToCollectionHelp'),
|
||||||
html: globalize.translate('AddItemToCollectionHelp') + '<br/><br/><a is="emby-linkbutton" class="button-link" target="_blank" href="https://web.archive.org/web/20181216120305/https://github.com/MediaBrowser/Wiki/wiki/Collections">' + globalize.translate('ButtonLearnMore') + '</a>'
|
html: globalize.translate('AddItemToCollectionHelp') + '<br/><br/><a is="emby-linkbutton" class="button-link" target="_blank" href="https://web.archive.org/web/20181216120305/https://github.com/MediaBrowser/Wiki/wiki/Collections">' + globalize.translate('ButtonLearnMore') + '</a>'
|
||||||
});
|
});
|
||||||
|
|
|
@ -150,7 +150,7 @@ define(['appSettings', 'userSettings', 'playbackManager', 'connectionManager', '
|
||||||
|
|
||||||
function alertText(text, title) {
|
function alertText(text, title) {
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({
|
alert.default({
|
||||||
text: text,
|
text: text,
|
||||||
title: title
|
title: title
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,15 +1,16 @@
|
||||||
define(['globalize'], function (globalize) {
|
import globalize from 'globalize';
|
||||||
'use strict';
|
|
||||||
|
|
||||||
function parseISO8601Date(s, toLocal) {
|
/* eslint-disable indent */
|
||||||
|
|
||||||
|
export function parseISO8601Date(s, toLocal) {
|
||||||
|
|
||||||
// parenthese matches:
|
// parenthese matches:
|
||||||
// year month day hours minutes seconds
|
// year month day hours minutes seconds
|
||||||
// dotmilliseconds
|
// dotmilliseconds
|
||||||
// tzstring plusminus hours minutes
|
// tzstring plusminus hours minutes
|
||||||
var re = /(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(\.\d+)?(Z|([+-])(\d{2}):(\d{2}))?/;
|
const re = /(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(\.\d+)?(Z|([+-])(\d{2}):(\d{2}))?/;
|
||||||
|
|
||||||
var d = s.match(re);
|
const d = s.match(re);
|
||||||
|
|
||||||
// "2010-12-07T11:00:00.000-09:00" parses to:
|
// "2010-12-07T11:00:00.000-09:00" parses to:
|
||||||
// ["2010-12-07T11:00:00.000-09:00", "2010", "12", "07", "11",
|
// ["2010-12-07T11:00:00.000-09:00", "2010", "12", "07", "11",
|
||||||
|
@ -24,8 +25,8 @@ define(['globalize'], function (globalize) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse strings, leading zeros into proper ints
|
// parse strings, leading zeros into proper ints
|
||||||
var a = [1, 2, 3, 4, 5, 6, 10, 11];
|
const a = [1, 2, 3, 4, 5, 6, 10, 11];
|
||||||
for (var i in a) {
|
for (let i in a) {
|
||||||
d[a[i]] = parseInt(d[a[i]], 10);
|
d[a[i]] = parseInt(d[a[i]], 10);
|
||||||
}
|
}
|
||||||
d[7] = parseFloat(d[7]);
|
d[7] = parseFloat(d[7]);
|
||||||
|
@ -33,7 +34,7 @@ define(['globalize'], function (globalize) {
|
||||||
// Date.UTC(year, month[, date[, hrs[, min[, sec[, ms]]]]])
|
// Date.UTC(year, month[, date[, hrs[, min[, sec[, ms]]]]])
|
||||||
// note that month is 0-11, not 1-12
|
// note that month is 0-11, not 1-12
|
||||||
// see https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Date/UTC
|
// see https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Date/UTC
|
||||||
var ms = Date.UTC(d[1], d[2] - 1, d[3], d[4], d[5], d[6]);
|
let ms = Date.UTC(d[1], d[2] - 1, d[3], d[4], d[5], d[6]);
|
||||||
|
|
||||||
// if there are milliseconds, add them
|
// if there are milliseconds, add them
|
||||||
if (d[7] > 0) {
|
if (d[7] > 0) {
|
||||||
|
@ -42,7 +43,7 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
// if there's a timezone, calculate it
|
// if there's a timezone, calculate it
|
||||||
if (d[8] !== 'Z' && d[10]) {
|
if (d[8] !== 'Z' && d[10]) {
|
||||||
var offset = d[10] * 60 * 60 * 1000;
|
let offset = d[10] * 60 * 60 * 1000;
|
||||||
if (d[11]) {
|
if (d[11]) {
|
||||||
offset += d[11] * 60 * 1000;
|
offset += d[11] * 60 * 1000;
|
||||||
}
|
}
|
||||||
|
@ -58,14 +59,14 @@ define(['globalize'], function (globalize) {
|
||||||
return new Date(ms);
|
return new Date(ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
function getDisplayRunningTime(ticks) {
|
export function getDisplayRunningTime(ticks) {
|
||||||
var ticksPerHour = 36000000000;
|
const ticksPerHour = 36000000000;
|
||||||
var ticksPerMinute = 600000000;
|
const ticksPerMinute = 600000000;
|
||||||
var ticksPerSecond = 10000000;
|
const ticksPerSecond = 10000000;
|
||||||
|
|
||||||
var parts = [];
|
const parts = [];
|
||||||
|
|
||||||
var hours = ticks / ticksPerHour;
|
let hours = ticks / ticksPerHour;
|
||||||
hours = Math.floor(hours);
|
hours = Math.floor(hours);
|
||||||
|
|
||||||
if (hours) {
|
if (hours) {
|
||||||
|
@ -74,7 +75,7 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
ticks -= (hours * ticksPerHour);
|
ticks -= (hours * ticksPerHour);
|
||||||
|
|
||||||
var minutes = ticks / ticksPerMinute;
|
let minutes = ticks / ticksPerMinute;
|
||||||
minutes = Math.floor(minutes);
|
minutes = Math.floor(minutes);
|
||||||
|
|
||||||
ticks -= (minutes * ticksPerMinute);
|
ticks -= (minutes * ticksPerMinute);
|
||||||
|
@ -84,7 +85,7 @@ define(['globalize'], function (globalize) {
|
||||||
}
|
}
|
||||||
parts.push(minutes);
|
parts.push(minutes);
|
||||||
|
|
||||||
var seconds = ticks / ticksPerSecond;
|
let seconds = ticks / ticksPerSecond;
|
||||||
seconds = Math.floor(seconds);
|
seconds = Math.floor(seconds);
|
||||||
|
|
||||||
if (seconds < 10) {
|
if (seconds < 10) {
|
||||||
|
@ -95,7 +96,7 @@ define(['globalize'], function (globalize) {
|
||||||
return parts.join(':');
|
return parts.join(':');
|
||||||
}
|
}
|
||||||
|
|
||||||
var toLocaleTimeStringSupportsLocales = function () {
|
const toLocaleTimeStringSupportsLocales = function () {
|
||||||
try {
|
try {
|
||||||
new Date().toLocaleTimeString('i');
|
new Date().toLocaleTimeString('i');
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -106,9 +107,9 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
function getOptionList(options) {
|
function getOptionList(options) {
|
||||||
|
|
||||||
var list = [];
|
const list = [];
|
||||||
|
|
||||||
for (var i in options) {
|
for (const i in options) {
|
||||||
list.push({
|
list.push({
|
||||||
name: i,
|
name: i,
|
||||||
value: options[i]
|
value: options[i]
|
||||||
|
@ -118,7 +119,7 @@ define(['globalize'], function (globalize) {
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
function toLocaleString(date, options) {
|
export function toLocaleString(date, options) {
|
||||||
|
|
||||||
if (!date) {
|
if (!date) {
|
||||||
throw new Error('date cannot be null');
|
throw new Error('date cannot be null');
|
||||||
|
@ -128,7 +129,7 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
if (toLocaleTimeStringSupportsLocales) {
|
if (toLocaleTimeStringSupportsLocales) {
|
||||||
|
|
||||||
var currentLocale = globalize.getCurrentDateTimeLocale();
|
const currentLocale = globalize.getCurrentDateTimeLocale();
|
||||||
|
|
||||||
if (currentLocale) {
|
if (currentLocale) {
|
||||||
return date.toLocaleString(currentLocale, options);
|
return date.toLocaleString(currentLocale, options);
|
||||||
|
@ -138,7 +139,7 @@ define(['globalize'], function (globalize) {
|
||||||
return date.toLocaleString();
|
return date.toLocaleString();
|
||||||
}
|
}
|
||||||
|
|
||||||
function toLocaleDateString(date, options) {
|
export function toLocaleDateString(date, options) {
|
||||||
|
|
||||||
if (!date) {
|
if (!date) {
|
||||||
throw new Error('date cannot be null');
|
throw new Error('date cannot be null');
|
||||||
|
@ -148,7 +149,7 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
if (toLocaleTimeStringSupportsLocales) {
|
if (toLocaleTimeStringSupportsLocales) {
|
||||||
|
|
||||||
var currentLocale = globalize.getCurrentDateTimeLocale();
|
const currentLocale = globalize.getCurrentDateTimeLocale();
|
||||||
|
|
||||||
if (currentLocale) {
|
if (currentLocale) {
|
||||||
return date.toLocaleDateString(currentLocale, options);
|
return date.toLocaleDateString(currentLocale, options);
|
||||||
|
@ -156,9 +157,9 @@ define(['globalize'], function (globalize) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is essentially a hard-coded polyfill
|
// This is essentially a hard-coded polyfill
|
||||||
var optionList = getOptionList(options);
|
const optionList = getOptionList(options);
|
||||||
if (optionList.length === 1 && optionList[0].name === 'weekday') {
|
if (optionList.length === 1 && optionList[0].name === 'weekday') {
|
||||||
var weekday = [];
|
const weekday = [];
|
||||||
weekday[0] = 'Sun';
|
weekday[0] = 'Sun';
|
||||||
weekday[1] = 'Mon';
|
weekday[1] = 'Mon';
|
||||||
weekday[2] = 'Tue';
|
weekday[2] = 'Tue';
|
||||||
|
@ -172,7 +173,7 @@ define(['globalize'], function (globalize) {
|
||||||
return date.toLocaleDateString();
|
return date.toLocaleDateString();
|
||||||
}
|
}
|
||||||
|
|
||||||
function toLocaleTimeString(date, options) {
|
export function toLocaleTimeString(date, options) {
|
||||||
|
|
||||||
if (!date) {
|
if (!date) {
|
||||||
throw new Error('date cannot be null');
|
throw new Error('date cannot be null');
|
||||||
|
@ -182,7 +183,7 @@ define(['globalize'], function (globalize) {
|
||||||
|
|
||||||
if (toLocaleTimeStringSupportsLocales) {
|
if (toLocaleTimeStringSupportsLocales) {
|
||||||
|
|
||||||
var currentLocale = globalize.getCurrentDateTimeLocale();
|
const currentLocale = globalize.getCurrentDateTimeLocale();
|
||||||
|
|
||||||
if (currentLocale) {
|
if (currentLocale) {
|
||||||
return date.toLocaleTimeString(currentLocale, options);
|
return date.toLocaleTimeString(currentLocale, options);
|
||||||
|
@ -192,7 +193,7 @@ define(['globalize'], function (globalize) {
|
||||||
return date.toLocaleTimeString();
|
return date.toLocaleTimeString();
|
||||||
}
|
}
|
||||||
|
|
||||||
function getDisplayTime(date) {
|
export function getDisplayTime(date) {
|
||||||
|
|
||||||
if (!date) {
|
if (!date) {
|
||||||
throw new Error('date cannot be null');
|
throw new Error('date cannot be null');
|
||||||
|
@ -217,19 +218,19 @@ define(['globalize'], function (globalize) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var time = toLocaleTimeString(date);
|
let time = toLocaleTimeString(date);
|
||||||
|
|
||||||
var timeLower = time.toLowerCase();
|
const timeLower = time.toLowerCase();
|
||||||
|
|
||||||
if (timeLower.indexOf('am') !== -1 || timeLower.indexOf('pm') !== -1) {
|
if (timeLower.indexOf('am') !== -1 || timeLower.indexOf('pm') !== -1) {
|
||||||
|
|
||||||
time = timeLower;
|
time = timeLower;
|
||||||
var hour = date.getHours() % 12;
|
let hour = date.getHours() % 12;
|
||||||
var suffix = date.getHours() > 11 ? 'pm' : 'am';
|
const suffix = date.getHours() > 11 ? 'pm' : 'am';
|
||||||
if (!hour) {
|
if (!hour) {
|
||||||
hour = 12;
|
hour = 12;
|
||||||
}
|
}
|
||||||
var minutes = date.getMinutes();
|
let minutes = date.getMinutes();
|
||||||
|
|
||||||
if (minutes < 10) {
|
if (minutes < 10) {
|
||||||
minutes = '0' + minutes;
|
minutes = '0' + minutes;
|
||||||
|
@ -239,7 +240,7 @@ define(['globalize'], function (globalize) {
|
||||||
time = hour + minutes + suffix;
|
time = hour + minutes + suffix;
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
var timeParts = time.split(':');
|
const timeParts = time.split(':');
|
||||||
|
|
||||||
// Trim off seconds
|
// Trim off seconds
|
||||||
if (timeParts.length > 2) {
|
if (timeParts.length > 2) {
|
||||||
|
@ -253,21 +254,21 @@ define(['globalize'], function (globalize) {
|
||||||
return time;
|
return time;
|
||||||
}
|
}
|
||||||
|
|
||||||
function isRelativeDay(date, offsetInDays) {
|
export function isRelativeDay(date, offsetInDays) {
|
||||||
|
|
||||||
if (!date) {
|
if (!date) {
|
||||||
throw new Error('date cannot be null');
|
throw new Error('date cannot be null');
|
||||||
}
|
}
|
||||||
|
|
||||||
var yesterday = new Date();
|
const yesterday = new Date();
|
||||||
var day = yesterday.getDate() + offsetInDays;
|
const day = yesterday.getDate() + offsetInDays;
|
||||||
|
|
||||||
yesterday.setDate(day); // automatically adjusts month/year appropriately
|
yesterday.setDate(day); // automatically adjusts month/year appropriately
|
||||||
|
|
||||||
return date.getFullYear() === yesterday.getFullYear() && date.getMonth() === yesterday.getMonth() && date.getDate() === day;
|
return date.getFullYear() === yesterday.getFullYear() && date.getMonth() === yesterday.getMonth() && date.getDate() === day;
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
export default {
|
||||||
parseISO8601Date: parseISO8601Date,
|
parseISO8601Date: parseISO8601Date,
|
||||||
getDisplayRunningTime: getDisplayRunningTime,
|
getDisplayRunningTime: getDisplayRunningTime,
|
||||||
toLocaleDateString: toLocaleDateString,
|
toLocaleDateString: toLocaleDateString,
|
||||||
|
@ -279,4 +280,5 @@ define(['globalize'], function (globalize) {
|
||||||
return toLocaleTimeStringSupportsLocales;
|
return toLocaleTimeStringSupportsLocales;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
});
|
|
||||||
|
/* eslint-enable indent */
|
||||||
|
|
|
@ -15,7 +15,7 @@ define(['connectionManager', 'playbackManager', 'syncPlayManager', 'events', 'in
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({ title: args.Header, text: args.Text });
|
alert.default({ title: args.Header, text: args.Text });
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -187,7 +187,7 @@ var Dashboard = {
|
||||||
}
|
}
|
||||||
|
|
||||||
require(['alert'], function (alert) {
|
require(['alert'], function (alert) {
|
||||||
alert({
|
alert.default({
|
||||||
title: options.title || Globalize.translate('HeaderAlert'),
|
title: options.title || Globalize.translate('HeaderAlert'),
|
||||||
text: options.message
|
text: options.message
|
||||||
}).then(options.callback || function () {});
|
}).then(options.callback || function () {});
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue