DefaultInputDatePicker.vue 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. <template>
  2. <DefaultInput
  3. v-model="treatedDate"
  4. v-model:error="error"
  5. v-bind="$attrs"
  6. :input-ref="inputRef"
  7. :label="label"
  8. :mask="inputMask"
  9. clearable
  10. >
  11. <template #append>
  12. <q-icon
  13. :name="time ? 'mdi-calendar-clock' : 'mdi-calendar'"
  14. class="cursor-pointer"
  15. >
  16. <q-popup-proxy cover transition-show="scale" transition-hide="scale">
  17. <template v-if="!time">
  18. <q-date v-model="date" mask="YYYY-MM-DD">
  19. <div class="row items-center justify-end">
  20. <q-btn v-close-popup label="OK" color="primary" flat />
  21. </div>
  22. </q-date>
  23. </template>
  24. <template v-else>
  25. <q-tab-panels
  26. v-model="activePanel"
  27. animated
  28. transition-prev="slide-right"
  29. transition-next="slide-left"
  30. class="bg-white"
  31. >
  32. <q-tab-panel name="date" class="q-pa-none">
  33. <q-date
  34. v-model="date"
  35. mask="YYYY-MM-DD HH:mm"
  36. @update:model-value="handleDateSelection"
  37. />
  38. </q-tab-panel>
  39. <q-tab-panel name="time" class="q-pa-none">
  40. <q-time v-model="date" mask="YYYY-MM-DD HH:mm" format24h />
  41. </q-tab-panel>
  42. </q-tab-panels>
  43. </template>
  44. </q-popup-proxy>
  45. </q-icon>
  46. </template>
  47. </DefaultInput>
  48. </template>
  49. <script setup>
  50. import { watch, ref, computed } from "vue";
  51. import masks from "src/helpers/masks";
  52. import DefaultInput from "./DefaultInput.vue";
  53. const { label, time } = defineProps({
  54. label: {
  55. type: String,
  56. default: "Data",
  57. },
  58. time: {
  59. type: Boolean,
  60. default: false,
  61. },
  62. });
  63. const treatedDate = defineModel({ type: [String, null] });
  64. const untreatedDate = defineModel("untreatedDate", { type: [String, null] });
  65. const error = defineModel("error", {
  66. type: [String, Object, Array, Boolean, null],
  67. });
  68. const inputRef = ref(null);
  69. const activePanel = ref("date");
  70. const date = ref();
  71. const handleDateSelection = () => {
  72. if (time) {
  73. activePanel.value = "time";
  74. }
  75. };
  76. const formatDate = (value) => {
  77. if (!value) return null;
  78. const [datePart, timePart] = value.split(" ");
  79. const formattedDate = datePart.split("-").reverse().join("/");
  80. return time && timePart ? `${formattedDate} ${timePart}` : formattedDate;
  81. };
  82. const unformatDate = (value) => {
  83. if (!value) return null;
  84. const [datePart, timePart] = value.split(" ");
  85. const formattedDate = datePart.split("/").reverse().join("-");
  86. return time && timePart ? `${formattedDate} ${timePart}` : formattedDate;
  87. };
  88. const inputMask = computed(() => {
  89. if (!inputRef.value) return "";
  90. if (time) {
  91. return masks.Brasil.datetime;
  92. }
  93. return masks.Brasil.date;
  94. });
  95. watch(date, (value) => {
  96. if (!value) return;
  97. untreatedDate.value = value;
  98. treatedDate.value = formatDate(value);
  99. });
  100. watch(treatedDate, (value) => {
  101. if (!value) {
  102. date.value = null;
  103. untreatedDate.value = null;
  104. treatedDate.value = null;
  105. activePanel.value = "date";
  106. return;
  107. }
  108. date.value = unformatDate(value);
  109. });
  110. watch(
  111. untreatedDate,
  112. (value) => {
  113. if (!value) {
  114. date.value = null;
  115. untreatedDate.value = null;
  116. treatedDate.value = null;
  117. activePanel.value = "date";
  118. return;
  119. }
  120. date.value = value;
  121. treatedDate.value = formatDate(value);
  122. },
  123. { immediate: true },
  124. );
  125. </script>