mirror of https://github.com/apache/cloudstack.git
105 lines
3.3 KiB
JavaScript
105 lines
3.3 KiB
JavaScript
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// 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.
|
|
import store from '@/store'
|
|
|
|
import dayjs from 'dayjs'
|
|
import utc from 'dayjs/plugin/utc'
|
|
|
|
dayjs.extend(utc)
|
|
|
|
export function parseDayJsObject ({ value, format = true, keepMoment = true }) {
|
|
if (!value) {
|
|
return null
|
|
}
|
|
|
|
if (typeof value === 'string') {
|
|
value = dayjs(value)
|
|
}
|
|
|
|
if (!store.getters.usebrowsertimezone) {
|
|
value = value.utc(keepMoment)
|
|
}
|
|
|
|
if (!format) {
|
|
return value
|
|
}
|
|
|
|
return value.format()
|
|
}
|
|
|
|
/**
|
|
* When passing a string/dayjs to the date picker component, it converts the value to the browser timezone; therefore,
|
|
* we need to normalize the value to UTC if user is not using browser's timezone.
|
|
* @param {*} value The datetime to normalize.
|
|
* @returns A dayjs object with the datetime normalized to UTC if user is not using browser's timezone;
|
|
* otherwise, a correspondent dayjs object based on the value passed.
|
|
*/
|
|
export function parseDateToDatePicker (value) {
|
|
if (!value) {
|
|
return null
|
|
}
|
|
|
|
if (typeof value === 'string') {
|
|
value = dayjs(value)
|
|
}
|
|
|
|
if (store.getters.usebrowsertimezone) {
|
|
return value
|
|
}
|
|
|
|
return value.utc(false)
|
|
}
|
|
|
|
export function toLocalDate ({ date, timezoneoffset = store.getters.timezoneoffset, usebrowsertimezone = store.getters.usebrowsertimezone }) {
|
|
if (usebrowsertimezone) {
|
|
// Since GMT+530 is returned as -330 (minutes to GMT)
|
|
timezoneoffset = new Date().getTimezoneOffset() / -60
|
|
}
|
|
|
|
const milliseconds = Date.parse(date)
|
|
// e.g. "Tue, 08 Jun 2010 19:13:49 GMT"; "Tue, 25 May 2010 12:07:01 UTC"
|
|
return new Date(milliseconds + (timezoneoffset * 60 * 60 * 1000))
|
|
}
|
|
|
|
export function toLocaleDate ({ date, timezoneoffset = store.getters.timezoneoffset, usebrowsertimezone = store.getters.usebrowsertimezone, dateOnly = false, hourOnly = false }) {
|
|
if (!date) {
|
|
return null
|
|
}
|
|
|
|
let dateWithOffset = toLocalDate({ date, timezoneoffset, usebrowsertimezone }).toUTCString()
|
|
|
|
// e.g. "Mon, 03 Jun 2024 19:22:55 GMT" -> "03 Jun 2024 19:22:55 GMT"
|
|
dateWithOffset = dateWithOffset.substring(dateWithOffset.indexOf(', ') + 2)
|
|
|
|
// e.g. "03 Jun 2024 19:22:55 GMT" -> "03 Jun 2024 19:22:55"
|
|
dateWithOffset = dateWithOffset.substring(0, dateWithOffset.length - 4)
|
|
|
|
if (dateOnly) {
|
|
// e.g. "03 Jun 2024 19:22:55" -> "03 Jun 2024"
|
|
return dateWithOffset.substring(0, dateWithOffset.length - 9)
|
|
}
|
|
|
|
if (hourOnly) {
|
|
// e.g. "03 Jun 2024 19:22:55" -> "19:22:55"
|
|
return dateWithOffset.substring(dateWithOffset.length - 8, dateWithOffset.length)
|
|
}
|
|
|
|
return dateWithOffset
|
|
}
|
|
|
|
export { dayjs }
|