valaxy/packages/valaxy-theme-press/components/PressDocFooterLastUpdated.vue

46 lines
1.1 KiB
Vue

<script setup lang="ts">
import { computed, onMounted, ref, watchEffect } from 'vue'
import { useData } from 'valaxy'
import { useI18n } from 'vue-i18n'
const data = useData()
const date = computed(() => new Date(data.lastUpdated!))
const isoDatetime = computed(() => date.value.toISOString())
const datetime = ref('')
// set time on mounted hook because the locale string might be different
// based on end user and will lead to potential hydration mismatch if
// calculated at build time
onMounted(() => {
watchEffect(() => {
datetime.value = date.value.toLocaleString(window.navigator.language)
})
})
const { t } = useI18n()
</script>
<template>
<p class="press-lastUpdated text-right">
{{ t('tooltip.last_updated') }}:
<time :datetime="isoDatetime">{{ datetime }}</time>
</p>
</template>
<style scoped>
.press-lastUpdated {
line-height: 24px;
font-size: 14px;
font-weight: 500;
color: var(--va-c-text-light);
}
@media (min-width: 640px) {
.press-lastUpdated {
line-height: 32px;
font-size: 14px;
font-weight: 500;
}
}
</style>