egroupware/api/js/etemplate/Et2Date/Et2DateTimeToday.ts
2022-02-03 14:58:56 -07:00

52 lines
1.5 KiB
TypeScript

/**
* EGroupware eTemplate2 - Readonly date-time_today WebComponent
*
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package api
* @link https://www.egroupware.org
* @author Nathan Gray
*/
import {formatDate, formatDateTime, formatTime, parseDateTime} from "./Et2Date";
import {Et2DateReadonly} from "./Et2DateReadonly";
/**
* Widget displays date/time with different formatting relative to today
* If the date is today, we show just the time. Otherwise, full date + time.
*/
export class Et2DateTimeToday extends Et2DateReadonly
{
constructor()
{
super();
this.parser = parseDateTime;
this.formatter = this.formatDateTime;
}
/**
* Format date+time relative to "now"
* If the date is today, we show just the time. Otherwise, the date and time.
*
* @param {Date} date
* @param {import('@lion/localize/types/LocalizeMixinTypes').FormatDateOptions} [options] Intl options are available
* @returns {string}
*/
formatDateTime(date : Date, options = {dateFormat: "", timeFormat: ""}) : string
{
let display = "";
// Today - just the time
if(formatDate(date, {dateFormat: 'Y-m-d'}) == formatDate(new Date(), {dateFormat: 'Y-m-d'}))
{
display = formatTime(date);
}
// Before today - date and time
else
{
display = formatDateTime(date);
}
return display;
}
}
// @ts-ignore TypeScript is not recognizing that this is a LitElement
customElements.define("et2-date-time_today", Et2DateTimeToday);