homemanager-fe/src/components/form/fields/FormDateField.vue

55 lines
1.3 KiB
Vue
Raw Normal View History

2023-01-27 16:27:14 +00:00
<template>
<FormField
:name="name"
:label="label"
:disabled="disabled"
2023-01-27 18:11:20 +00:00
:required="required"
2023-01-27 16:27:14 +00:00
for-id-prefix="dp-input"
>
2023-01-27 18:11:20 +00:00
<template #input="{ invalid, fieldFQN, value, setValue }">
2023-01-27 16:27:14 +00:00
<Datepicker
2023-05-22 18:01:41 +00:00
v-bind="props"
2023-01-27 16:27:14 +00:00
:class="[invalid ? 'dp__invalid' : '']"
2023-01-27 18:11:20 +00:00
:uid="fieldFQN"
2023-01-27 16:27:14 +00:00
:placeholder="placeholder"
2023-05-22 18:01:41 +00:00
:state="undefined"
:format="format"
2023-01-27 16:27:14 +00:00
:model-value="(value as string)"
@update:model-value="setValue"
/>
</template>
<template #default><slot /></template>
</FormField>
</template>
<script setup lang="ts">
import FormField from '../FormField.vue';
2023-05-22 18:01:41 +00:00
import Datepicker, { VueDatePickerProps } from '@vuepic/vue-datepicker';
import '@vuepic/vue-datepicker/dist/main.css';
import { Omit } from 'lodash';
import { computed } from 'vue';
2023-01-27 16:27:14 +00:00
2023-05-22 18:01:41 +00:00
interface DatePickerProps extends VueDatePickerProps {
2023-01-27 16:27:14 +00:00
label: string;
name: string;
disabled?: boolean;
2023-01-27 18:11:20 +00:00
required?: boolean;
2023-01-27 16:27:14 +00:00
clearable?: boolean;
placeholder?: string;
}
// https://vue3datepicker.com/
const props = withDefaults(defineProps<DatePickerProps>(), {
disabled: false,
2023-05-22 18:01:41 +00:00
textInput: true,
arrowNavigation: true,
enableTimePicker: true,
autoPosition: true,
is24: true,
2023-01-27 16:27:14 +00:00
});
2023-05-22 18:01:41 +00:00
const format = computed(() =>
props.format ?? props.enableTimePicker ? `dd/MM/yyyy, HH:mm` : 'dd/MM/yyyy'
);
2023-01-27 16:27:14 +00:00
</script>