it-tools/src/tools/date-time-converter/date-time-converter.vue

129 lines
3.3 KiB
Vue
Raw Normal View History

2022-04-12 01:43:49 +02:00
<template>
2022-04-15 23:10:47 +02:00
<div>
<n-card>
<n-space justify="center">
2022-04-22 23:31:40 +02:00
<n-form-item label="Use current date-time ?" label-placement="left" :show-feedback="false">
2022-04-15 23:10:47 +02:00
<n-switch v-model:value="useCurrentDate" />
</n-form-item>
</n-space>
<n-form-item
:feedback="inputInvalid ? 'Invalid date for the current format' : ''"
:validation-status="inputInvalid ? 'error' : undefined"
>
2022-04-22 23:31:40 +02:00
<n-input-group style="flex-grow: 1">
2022-04-15 23:10:47 +02:00
<n-select
v-model:value="inputFormat"
2022-04-22 23:31:40 +02:00
style="width: 200px"
2022-04-15 23:10:47 +02:00
:options="formats.map(({ name }, i) => ({ label: name, value: i }))"
:disabled="useCurrentDate"
/>
2022-04-12 01:43:49 +02:00
2022-04-15 23:10:47 +02:00
<n-input
v-model:value="inputDate"
:on-input="onDateInputChanged"
:disabled="useCurrentDate"
placeholder="Your date string..."
/>
</n-input-group>
</n-form-item>
2022-04-22 23:31:40 +02:00
<n-divider style="margin-top: 0" />
<div v-for="{ name, fromDate } in formats" :key="name" style="margin: 5px 0">
2022-04-15 23:10:47 +02:00
<n-input-group>
2022-04-22 23:31:40 +02:00
<n-input-group-label style="flex: 0 0 170px"> {{ name }}: </n-input-group-label>
2022-04-16 21:00:14 +02:00
<input-copyable :value="fromDate(baseDate)" />
2022-04-15 23:10:47 +02:00
</n-input-group>
</div>
</n-card>
</div>
2022-04-12 01:43:49 +02:00
</template>
<script setup lang="ts">
import { useRafFn } from '@vueuse/core';
2022-04-22 23:31:40 +02:00
import {
formatISO,
formatISO9075,
formatRFC3339,
formatRFC7231,
fromUnixTime,
getTime,
getUnixTime,
isDate,
parseISO,
parseJSON,
} from 'date-fns';
import { ref } from 'vue';
import InputCopyable from '../../components/InputCopyable.vue';
2022-04-12 01:43:49 +02:00
2022-04-22 23:31:40 +02:00
const useCurrentDate = ref(true);
const inputDate = ref('');
const inputFormat = ref(6);
const inputInvalid = ref(false);
const baseDate = ref(new Date());
2022-04-12 01:43:49 +02:00
useRafFn(() => {
2022-04-22 23:31:40 +02:00
if (useCurrentDate.value) {
baseDate.value = new Date();
}
});
2022-04-12 01:43:49 +02:00
function onDateInputChanged(value: string) {
2022-04-22 23:31:40 +02:00
const { toDate } = formats[inputFormat.value];
inputInvalid.value = false;
2022-04-12 01:43:49 +02:00
2022-04-22 23:31:40 +02:00
try {
const formatted: Date | string = toDate(value);
2022-04-12 01:43:49 +02:00
2022-04-22 23:31:40 +02:00
if (!isDate(formatted) || isNaN(formatted.getTime())) {
throw new Error('Invalid date');
2022-04-12 01:43:49 +02:00
}
2022-04-22 23:31:40 +02:00
baseDate.value = formatted;
} catch (_) {
inputInvalid.value = true;
}
2022-04-12 01:43:49 +02:00
}
const formats = [
2022-04-22 23:31:40 +02:00
{
name: 'JS locale date string',
fromDate: (date: Date) => date.toString(),
toDate: (date: string) => new Date(date),
},
{
name: 'ISO 8601',
fromDate: (date: Date) => formatISO(date),
toDate: (date: string) => parseISO(date),
},
{
name: 'ISO 9075',
fromDate: (date: Date) => formatISO9075(date),
toDate: (date: string) => parseISO(date),
},
{
name: 'RFC 3339',
fromDate: (date: Date) => formatRFC3339(date),
toDate: (date: string) => new Date(date),
},
{
name: 'RFC 7231',
fromDate: (date: Date) => formatRFC7231(date),
toDate: (date: string) => new Date(date),
},
{
name: 'Timestamp',
fromDate: (date: Date) => String(getTime(date)),
toDate: (ms: string) => parseJSON(+ms),
},
{
name: 'Unix timestamp',
fromDate: (date: Date) => String(getUnixTime(date)),
toDate: (sec: string) => fromUnixTime(+sec),
},
{
name: 'UTC format',
fromDate: (date: Date) => date.toUTCString(),
toDate: (date: string) => new Date(date),
},
];
2022-04-12 01:43:49 +02:00
</script>