Date range picker
Shows a date range picker component.
Examples
Basic date range picker
Code
vue
<template>
<DateRangePicker v-model="value" />
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { DateRangePicker } from '@/components/ui/date-range-picker'
import type { DateRange } from 'reka-ui'
const value = ref<DateRange>({
start: undefined,
end: undefined
})
</script>
With presets
Code
vue
<template>
<DateRangePicker v-model="value" :presets="presets" :max-value="now(getLocalTimeZone())" />
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { DateRangePicker } from '@/components/ui/date-range-picker'
import type { DateRange } from 'reka-ui'
import { now, getLocalTimeZone } from '@internationalized/date'
const value = ref<DateRange>({
start: undefined,
end: undefined
})
const presets = [
{
label: '24 hours',
value: { start: now(getLocalTimeZone()).subtract({ hours: 24 }), end: now(getLocalTimeZone()) }
},
{
label: 'Last week',
value: { start: now(getLocalTimeZone()).subtract({ days: 7 }), end: now(getLocalTimeZone()) }
},
{
label: 'Last month',
value: { start: now(getLocalTimeZone()).subtract({ days: 31 }), end: now(getLocalTimeZone()) }
},
{
label: 'Last quarter',
value: { start: now(getLocalTimeZone()).subtract({ months: 4 }), end: now(getLocalTimeZone()) }
},
{
label: 'Last year',
value: { start: now(getLocalTimeZone()).subtract({ years: 1 }), end: now(getLocalTimeZone()) }
}
]
</script>