UNPKG

adaptive-expressions

Version:
103 lines 4.19 kB
"use strict"; /** * @module adaptive-expressions */ /** * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. */ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ConvertToUTC = void 0; const dayjs_1 = __importDefault(require("dayjs")); const timezone_1 = __importDefault(require("dayjs/plugin/timezone")); dayjs_1.default.extend(timezone_1.default); const expressionEvaluator_1 = require("../expressionEvaluator"); const expressionType_1 = require("../expressionType"); const functionUtils_1 = require("../functionUtils"); const returnType_1 = require("../returnType"); const timeZoneConverter_1 = require("../timeZoneConverter"); /** * Convert a timestamp to Universal Time Coordinated (UTC) from the source time zone. */ class ConvertToUTC extends expressionEvaluator_1.ExpressionEvaluator { /** * Initializes a new instance of the [ConvertToUTC](xref:adaptive-expressions.ConvertToUTC) class. */ constructor() { super(expressionType_1.ExpressionType.ConvertToUTC, ConvertToUTC.evaluator, returnType_1.ReturnType.String, ConvertToUTC.validator); } /** * @private */ static evaluator(expression, state, options) { let value; let locale = options.locale ? options.locale : Intl.DateTimeFormat().resolvedOptions().locale; let format = functionUtils_1.FunctionUtils.DefaultDateTimeFormat; const { args, error: childrenError } = functionUtils_1.FunctionUtils.evaluateChildren(expression, state, options); let error = childrenError; if (!error) { ({ format, locale } = functionUtils_1.FunctionUtils.determineFormatAndLocale(args, 4, format, locale)); if (typeof args[0] === 'string' && typeof args[1] === 'string') { ({ value, error } = ConvertToUTC.evalConvertToUTC(args[0], args[1], format, locale)); } else { error = `${expression} should contain an ISO format timestamp, a destination time zone string and an optional output format string.`; } } return { value, error }; } /** * @private */ static verifyTimeStamp(timeStamp) { const parsed = (0, dayjs_1.default)(timeStamp); if (parsed.toString() === 'Invalid Date') { return `${timeStamp} is a invalid datetime`; } return undefined; } /** * @private */ static evalConvertToUTC(timeStamp, sourceTimezone, format, locale) { let result; let error; let formattedSourceTime; const timeZone = timeZoneConverter_1.TimeZoneConverter.windowsToIana(sourceTimezone); if (!timeZoneConverter_1.TimeZoneConverter.verifyTimeZoneStr(timeZone)) { error = `${sourceTimezone} is not a valid timezone`; } if (!error) { error = this.verifyTimeStamp(timeStamp); if (!error) { try { const sourceTime = dayjs_1.default.tz(timeStamp, timeZone); formattedSourceTime = sourceTime.format(); } catch (_a) { error = `${timeStamp} with ${timeZone} is not a valid timestamp with specified timeZone:`; } if (!error) { try { result = (0, dayjs_1.default)(formattedSourceTime).locale(locale).tz('Etc/UTC').format(format); } catch (_b) { error = `${format} is not a valid timestamp format`; } } } } return { value: result, error }; } /** * @private */ static validator(expr) { functionUtils_1.FunctionUtils.validateOrder(expr, [returnType_1.ReturnType.String, returnType_1.ReturnType.String], returnType_1.ReturnType.String, returnType_1.ReturnType.String); } } exports.ConvertToUTC = ConvertToUTC; //# sourceMappingURL=convertToUTC.js.map