DatePicker.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <template>
  2. <main>
  3. <v-menu
  4. v-model="dateOpen"
  5. :close-on-content-click="false"
  6. :nudge-right="40"
  7. transition="scale-transition"
  8. offset-y
  9. min-width="auto"
  10. >
  11. <template v-slot:activator="{ on, attrs }">
  12. <v-text-field
  13. v-model="datesFormatted"
  14. autocomplete="off"
  15. :label="$t(label_field)"
  16. prepend-icon="mdi-calendar"
  17. :disabled="readOnly"
  18. v-bind="attrs"
  19. v-on="on"
  20. :dense="dense"
  21. :single-line="singleLine"
  22. ></v-text-field>
  23. </template>
  24. <v-date-picker
  25. v-model="datesParsed"
  26. @input="dateOpen = range && datesParsed.length < 2"
  27. locale="fr"
  28. :range="range"
  29. color="ot_green lighten-1"
  30. ></v-date-picker>
  31. </v-menu>
  32. </main>
  33. </template>
  34. <script lang="ts">
  35. import {defineComponent, watch, ref, useContext, onUnmounted, computed} from '@nuxtjs/composition-api'
  36. import DatesUtils from "~/services/utils/datesUtils";
  37. export default defineComponent({
  38. props: {
  39. field: {
  40. type: String,
  41. required: false
  42. },
  43. label: {
  44. type: String,
  45. required: false
  46. },
  47. data: {
  48. type: [String, Array],
  49. required: false
  50. },
  51. readOnly: {
  52. type: Boolean,
  53. required: false
  54. },
  55. range: {
  56. type: Boolean,
  57. required: false
  58. },
  59. dense: {
  60. type: Boolean,
  61. required: false
  62. },
  63. singleLine: {
  64. type: Boolean,
  65. required: false
  66. }
  67. },
  68. setup(props, {emit}){
  69. const {data, field, range} = props
  70. const {$moment} = useContext()
  71. const dateUtils = new DatesUtils($moment)
  72. const datesParsed = range ? ref(Array<string>()) : ref()
  73. if(range){
  74. for(const date of data as Array<string>){
  75. if(date)
  76. datesParsed.value.push($moment(date).format('YYYY-MM-DD'))
  77. }
  78. }else{
  79. datesParsed.value = $moment(data as string).format('YYYY-MM-DD')
  80. }
  81. const datesFormatted = computed(()=>{
  82. return dateUtils.formattedDate(datesParsed.value, 'DD/MM/YYYY')
  83. })
  84. const unwatch = watch(datesParsed, (newValue, oldValue) => {
  85. if(newValue === oldValue) return
  86. if(range && newValue.length < 2) return
  87. emit('update', range ? dateUtils.sortDate(newValue) : newValue, field)
  88. })
  89. onUnmounted(()=>{
  90. unwatch()
  91. })
  92. return {
  93. label_field : props.label ?? props.field,
  94. datesParsed,
  95. datesFormatted,
  96. dateOpen: ref(false)
  97. }
  98. }
  99. })
  100. </script>
  101. <style scoped>
  102. </style>