2015-11-30 18:11:04 +00:00
|
|
|
/*
|
2016-01-07 04:06:39 +00:00
|
|
|
Copyright 2015, 2016 OpenMarket Ltd
|
2017-05-25 17:26:42 +00:00
|
|
|
Copyright 2017 Vector Creations Ltd
|
2015-11-30 18:11:04 +00:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2017-05-25 10:39:08 +00:00
|
|
|
import { _t } from './languageHandler';
|
2015-11-30 18:11:04 +00:00
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
function getDaysArray(): string[] {
|
2017-05-25 17:26:42 +00:00
|
|
|
return [
|
|
|
|
_t('Sun'),
|
|
|
|
_t('Mon'),
|
|
|
|
_t('Tue'),
|
|
|
|
_t('Wed'),
|
|
|
|
_t('Thu'),
|
|
|
|
_t('Fri'),
|
|
|
|
_t('Sat'),
|
|
|
|
];
|
2017-05-23 14:16:31 +00:00
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
function getMonthsArray(): string[] {
|
2017-05-25 17:26:42 +00:00
|
|
|
return [
|
|
|
|
_t('Jan'),
|
|
|
|
_t('Feb'),
|
|
|
|
_t('Mar'),
|
|
|
|
_t('Apr'),
|
|
|
|
_t('May'),
|
|
|
|
_t('Jun'),
|
|
|
|
_t('Jul'),
|
|
|
|
_t('Aug'),
|
|
|
|
_t('Sep'),
|
|
|
|
_t('Oct'),
|
|
|
|
_t('Nov'),
|
|
|
|
_t('Dec'),
|
|
|
|
];
|
2017-05-23 14:16:31 +00:00
|
|
|
}
|
2015-11-30 18:11:04 +00:00
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
function pad(n: number): string {
|
2017-05-14 23:25:12 +00:00
|
|
|
return (n < 10 ? '0' : '') + n;
|
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
function twelveHourTime(date: Date, showSeconds = false): string {
|
2017-05-19 20:31:24 +00:00
|
|
|
let hours = date.getHours() % 12;
|
2017-05-19 21:26:24 +00:00
|
|
|
const minutes = pad(date.getMinutes());
|
2017-07-03 15:25:03 +00:00
|
|
|
const ampm = date.getHours() >= 12 ? _t('PM') : _t('AM');
|
2017-06-30 15:29:40 +00:00
|
|
|
hours = hours ? hours : 12; // convert 0 -> 12
|
2018-02-08 15:58:53 +00:00
|
|
|
if (showSeconds) {
|
|
|
|
const seconds = pad(date.getSeconds());
|
|
|
|
return `${hours}:${minutes}:${seconds}${ampm}`;
|
|
|
|
}
|
2017-05-30 15:31:16 +00:00
|
|
|
return `${hours}:${minutes}${ampm}`;
|
2017-05-18 21:00:44 +00:00
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
export function formatDate(date: Date, showTwelveHour = false): string {
|
2018-01-10 12:00:11 +00:00
|
|
|
const now = new Date();
|
|
|
|
const days = getDaysArray();
|
|
|
|
const months = getMonthsArray();
|
|
|
|
if (date.toDateString() === now.toDateString()) {
|
|
|
|
return formatTime(date, showTwelveHour);
|
|
|
|
} else if (now.getTime() - date.getTime() < 6 * 24 * 60 * 60 * 1000) {
|
|
|
|
// TODO: use standard date localize function provided in counterpart
|
|
|
|
return _t('%(weekDayName)s %(time)s', {
|
|
|
|
weekDayName: days[date.getDay()],
|
|
|
|
time: formatTime(date, showTwelveHour),
|
|
|
|
});
|
|
|
|
} else if (now.getFullYear() === date.getFullYear()) {
|
|
|
|
// TODO: use standard date localize function provided in counterpart
|
|
|
|
return _t('%(weekDayName)s, %(monthName)s %(day)s %(time)s', {
|
2017-05-26 16:30:02 +00:00
|
|
|
weekDayName: days[date.getDay()],
|
|
|
|
monthName: months[date.getMonth()],
|
|
|
|
day: date.getDate(),
|
2018-01-10 12:00:11 +00:00
|
|
|
time: formatTime(date, showTwelveHour),
|
2017-05-26 16:30:02 +00:00
|
|
|
});
|
2018-01-10 12:00:11 +00:00
|
|
|
}
|
|
|
|
return formatFullDate(date, showTwelveHour);
|
|
|
|
}
|
2016-08-16 14:01:01 +00:00
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
export function formatFullDateNoTime(date: Date): string {
|
2018-01-14 18:32:17 +00:00
|
|
|
const days = getDaysArray();
|
|
|
|
const months = getMonthsArray();
|
|
|
|
return _t('%(weekDayName)s, %(monthName)s %(day)s %(fullYear)s', {
|
|
|
|
weekDayName: days[date.getDay()],
|
|
|
|
monthName: months[date.getMonth()],
|
|
|
|
day: date.getDate(),
|
|
|
|
fullYear: date.getFullYear(),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-04-02 07:25:21 +00:00
|
|
|
export function formatFullDate(date: Date, showTwelveHour = false, showSeconds = true): string {
|
2018-01-10 12:00:11 +00:00
|
|
|
const days = getDaysArray();
|
|
|
|
const months = getMonthsArray();
|
|
|
|
return _t('%(weekDayName)s, %(monthName)s %(day)s %(fullYear)s %(time)s', {
|
|
|
|
weekDayName: days[date.getDay()],
|
|
|
|
monthName: months[date.getMonth()],
|
|
|
|
day: date.getDate(),
|
|
|
|
fullYear: date.getFullYear(),
|
2021-04-02 07:25:21 +00:00
|
|
|
time: showSeconds ? formatFullTime(date, showTwelveHour) : formatTime(date, showTwelveHour),
|
2018-01-10 12:00:11 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
export function formatFullTime(date: Date, showTwelveHour = false): string {
|
2018-02-08 15:58:53 +00:00
|
|
|
if (showTwelveHour) {
|
|
|
|
return twelveHourTime(date, true);
|
|
|
|
}
|
|
|
|
return pad(date.getHours()) + ':' + pad(date.getMinutes()) + ':' + pad(date.getSeconds());
|
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
export function formatTime(date: Date, showTwelveHour = false): string {
|
2018-01-10 12:00:11 +00:00
|
|
|
if (showTwelveHour) {
|
|
|
|
return twelveHourTime(date);
|
|
|
|
}
|
|
|
|
return pad(date.getHours()) + ':' + pad(date.getMinutes());
|
|
|
|
}
|
2018-01-10 12:06:24 +00:00
|
|
|
|
2021-08-06 12:24:14 +00:00
|
|
|
export function formatCallTime(delta: Date): string {
|
|
|
|
const hours = delta.getUTCHours();
|
|
|
|
const minutes = delta.getUTCMinutes();
|
|
|
|
const seconds = delta.getUTCSeconds();
|
2021-08-06 11:57:27 +00:00
|
|
|
|
|
|
|
let output = "";
|
|
|
|
if (hours) output += `${hours}h `;
|
|
|
|
if (minutes || output) output += `${minutes}m `;
|
|
|
|
if (seconds || output) output += `${seconds}s`;
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2021-08-27 14:19:59 +00:00
|
|
|
export function formatSeconds(inSeconds: number): string {
|
|
|
|
const hours = Math.floor(inSeconds / (60 * 60)).toFixed(0).padStart(2, '0');
|
|
|
|
const minutes = Math.floor((inSeconds % (60 * 60)) / 60).toFixed(0).padStart(2, '0');
|
|
|
|
const seconds = Math.floor(((inSeconds % (60 * 60)) % 60)).toFixed(0).padStart(2, '0');
|
|
|
|
|
|
|
|
let output = "";
|
|
|
|
if (hours !== "00") output += `${hours}:`;
|
|
|
|
output += `${minutes}:${seconds}`;
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2018-01-10 12:06:24 +00:00
|
|
|
const MILLIS_IN_DAY = 86400000;
|
2021-11-03 10:16:50 +00:00
|
|
|
function withinPast24Hours(prevDate: Date, nextDate: Date): boolean {
|
|
|
|
return Math.abs(prevDate.getTime() - nextDate.getTime()) <= MILLIS_IN_DAY;
|
|
|
|
}
|
|
|
|
|
|
|
|
function withinCurrentYear(prevDate: Date, nextDate: Date): boolean {
|
|
|
|
return prevDate.getFullYear() === nextDate.getFullYear();
|
|
|
|
}
|
|
|
|
|
2020-10-13 16:39:58 +00:00
|
|
|
export function wantsDateSeparator(prevEventDate: Date, nextEventDate: Date): boolean {
|
2018-01-10 12:06:24 +00:00
|
|
|
if (!nextEventDate || !prevEventDate) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// Return early for events that are > 24h apart
|
2021-11-03 10:16:50 +00:00
|
|
|
if (!withinPast24Hours(prevEventDate, nextEventDate)) {
|
2018-01-10 12:06:24 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Compare weekdays
|
|
|
|
return prevEventDate.getDay() !== nextEventDate.getDay();
|
|
|
|
}
|
2021-06-01 07:10:03 +00:00
|
|
|
|
2021-06-01 16:22:04 +00:00
|
|
|
export function formatFullDateNoDay(date: Date) {
|
2021-06-09 11:10:52 +00:00
|
|
|
return _t("%(date)s at %(time)s", {
|
|
|
|
date: date.toLocaleDateString().replace(/\//g, '-'),
|
|
|
|
time: date.toLocaleTimeString().replace(/:/g, '-'),
|
2021-06-09 10:42:57 +00:00
|
|
|
});
|
2021-06-01 07:10:03 +00:00
|
|
|
}
|
2021-06-03 07:10:00 +00:00
|
|
|
|
|
|
|
export function formatFullDateNoDayNoTime(date: Date) {
|
|
|
|
return (
|
|
|
|
date.getFullYear() +
|
|
|
|
"/" +
|
|
|
|
pad(date.getMonth() + 1) +
|
|
|
|
"/" +
|
|
|
|
pad(date.getDate())
|
|
|
|
);
|
|
|
|
}
|
2021-11-03 10:16:50 +00:00
|
|
|
|
|
|
|
export function formatRelativeTime(date: Date, showTwelveHour = false): string {
|
|
|
|
const now = new Date(Date.now());
|
|
|
|
if (withinPast24Hours(date, now)) {
|
|
|
|
return formatTime(date, showTwelveHour);
|
|
|
|
} else {
|
|
|
|
const months = getMonthsArray();
|
|
|
|
let relativeDate = `${months[date.getMonth()]} ${date.getDate()}`;
|
|
|
|
|
|
|
|
if (!withinCurrentYear(date, now)) {
|
|
|
|
relativeDate += `, ${date.getFullYear()}`;
|
|
|
|
}
|
|
|
|
return relativeDate;
|
|
|
|
}
|
|
|
|
}
|