@finema/core 1.4.152 → 1.4.154

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (168) hide show
  1. package/README.md +60 -60
  2. package/dist/module.json +1 -5
  3. package/dist/module.mjs +10 -2
  4. package/dist/runtime/components/Alert.vue +48 -48
  5. package/dist/runtime/components/Avatar.vue +27 -27
  6. package/dist/runtime/components/Badge.vue +11 -11
  7. package/dist/runtime/components/Breadcrumb.vue +44 -44
  8. package/dist/runtime/components/Button/Group.vue +37 -37
  9. package/dist/runtime/components/Button/index.vue +75 -75
  10. package/dist/runtime/components/Card.vue +38 -38
  11. package/dist/runtime/components/Core.vue +37 -37
  12. package/dist/runtime/components/Dialog/index.vue +108 -108
  13. package/dist/runtime/components/Dropdown/index.vue +70 -70
  14. package/dist/runtime/components/FlexDeck/Base.vue +143 -143
  15. package/dist/runtime/components/FlexDeck/index.vue +68 -68
  16. package/dist/runtime/components/Form/FieldWrapper.vue +23 -23
  17. package/dist/runtime/components/Form/Fields.vue +230 -230
  18. package/dist/runtime/components/Form/InputCheckbox/index.vue +28 -28
  19. package/dist/runtime/components/Form/InputDateTime/index.vue +60 -60
  20. package/dist/runtime/components/Form/InputDateTimeRange/date_range_time_field.types.d.ts +1 -1
  21. package/dist/runtime/components/Form/InputDateTimeRange/index.vue +83 -83
  22. package/dist/runtime/components/Form/InputNumber/index.vue +27 -27
  23. package/dist/runtime/components/Form/InputRadio/index.vue +27 -27
  24. package/dist/runtime/components/Form/InputSelect/index.vue +45 -45
  25. package/dist/runtime/components/Form/InputSelectMultiple/index.vue +54 -54
  26. package/dist/runtime/components/Form/InputStatic/index.vue +16 -16
  27. package/dist/runtime/components/Form/InputTags/index.vue +145 -145
  28. package/dist/runtime/components/Form/InputText/index.vue +67 -67
  29. package/dist/runtime/components/Form/InputTextarea/index.vue +25 -25
  30. package/dist/runtime/components/Form/InputToggle/index.vue +14 -14
  31. package/dist/runtime/components/Form/InputUploadDropzone/index.vue +206 -206
  32. package/dist/runtime/components/Form/InputUploadDropzone/types.d.ts +1 -1
  33. package/dist/runtime/components/Form/InputUploadDropzoneAuto/index.vue +342 -342
  34. package/dist/runtime/components/Form/InputUploadDropzoneAuto/types.d.ts +1 -1
  35. package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/ItemUpload.vue +241 -241
  36. package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/ItemView.vue +89 -89
  37. package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/index.vue +164 -164
  38. package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/types.d.ts +1 -1
  39. package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/ItemUpload.vue +161 -161
  40. package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/ItemView.vue +64 -64
  41. package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/index.vue +172 -172
  42. package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/types.d.ts +1 -1
  43. package/dist/runtime/components/Form/InputUploadFileClassic/index.vue +95 -95
  44. package/dist/runtime/components/Form/InputUploadFileClassicAuto/index.vue +151 -151
  45. package/dist/runtime/components/Form/InputUploadFileClassicAuto/types.d.ts +1 -1
  46. package/dist/runtime/components/Form/InputUploadImageAuto/index.vue +219 -219
  47. package/dist/runtime/components/Form/InputUploadImageAuto/types.d.ts +1 -1
  48. package/dist/runtime/components/Form/InputWYSIWYG/index.vue +53 -53
  49. package/dist/runtime/components/Form/index.vue +6 -6
  50. package/dist/runtime/components/Icon.vue +23 -23
  51. package/dist/runtime/components/Image.vue +36 -36
  52. package/dist/runtime/components/Loader.vue +27 -27
  53. package/dist/runtime/components/Modal/index.vue +146 -146
  54. package/dist/runtime/components/QRCode.vue +22 -22
  55. package/dist/runtime/components/SimplePagination.vue +96 -96
  56. package/dist/runtime/components/Slideover/index.vue +110 -110
  57. package/dist/runtime/components/Table/Base.vue +139 -139
  58. package/dist/runtime/components/Table/ColumnDate.vue +16 -16
  59. package/dist/runtime/components/Table/ColumnDateTime.vue +18 -18
  60. package/dist/runtime/components/Table/ColumnImage.vue +15 -15
  61. package/dist/runtime/components/Table/ColumnNumber.vue +14 -14
  62. package/dist/runtime/components/Table/ColumnText.vue +25 -25
  63. package/dist/runtime/components/Table/Simple.vue +69 -69
  64. package/dist/runtime/components/Table/index.vue +65 -65
  65. package/dist/runtime/components/Tabs/index.vue +64 -64
  66. package/dist/runtime/components/TeleportSafe.vue +40 -40
  67. package/dist/runtime/composables/loaderList.d.ts +2 -2
  68. package/dist/runtime/composables/{loaderList.js → loaderList.mjs} +2 -2
  69. package/dist/runtime/composables/loaderObject.d.ts +1 -1
  70. package/dist/runtime/composables/{loaderObject.js → loaderObject.mjs} +2 -2
  71. package/dist/runtime/composables/loaderPage.d.ts +1 -1
  72. package/dist/runtime/composables/{loaderPage.js → loaderPage.mjs} +3 -3
  73. package/dist/runtime/composables/useConfig.d.ts +1 -1
  74. package/dist/runtime/composables/useForm.d.ts +1 -1
  75. package/dist/runtime/composables/useTable.d.ts +2 -2
  76. package/dist/runtime/composables/{useTable.js → useTable.mjs} +1 -1
  77. package/dist/runtime/composables/{useUpload.js → useUpload.mjs} +1 -1
  78. package/dist/runtime/helpers/{apiListHelper.js → apiListHelper.mjs} +1 -1
  79. package/dist/runtime/helpers/{apiObjectHelper.js → apiObjectHelper.mjs} +1 -1
  80. package/dist/runtime/helpers/apiPageHelper.d.ts +1 -1
  81. package/dist/runtime/helpers/{apiPageHelper.js → apiPageHelper.mjs} +4 -4
  82. package/dist/runtime/ui.config/index.d.ts +16 -16
  83. package/dist/runtime/ui.config/index.mjs +16 -0
  84. package/dist/runtime/ui.config/{uploadDropzoneImage.js → uploadDropzoneImage.mjs} +1 -1
  85. package/dist/runtime/utils/ArrayHelper.d.ts +1 -1
  86. package/dist/runtime/utils/{ArrayHelper.spec.js → ArrayHelper.spec.mjs} +1 -1
  87. package/dist/runtime/utils/{FileHelper.spec.js → FileHelper.spec.mjs} +1 -1
  88. package/dist/runtime/utils/ObjectHelper.d.ts +2 -2
  89. package/dist/runtime/utils/{ObjectHelper.js → ObjectHelper.mjs} +2 -2
  90. package/dist/runtime/utils/{ObjectHelper.spec.js → ObjectHelper.spec.mjs} +1 -1
  91. package/dist/runtime/utils/ParamHelper.d.ts +1 -1
  92. package/dist/runtime/utils/{ParamHelper.spec.js → ParamHelper.spec.mjs} +1 -1
  93. package/dist/runtime/utils/{StringHelper.spec.js → StringHelper.spec.mjs} +1 -1
  94. package/dist/runtime/utils/{TimeHelper.spec.js → TimeHelper.spec.mjs} +1 -1
  95. package/dist/runtime/utils/{TimeHelper.thai.spec.js → TimeHelper.thai.spec.mjs} +1 -1
  96. package/dist/types.d.mts +16 -1
  97. package/dist/types.d.ts +16 -1
  98. package/package.json +92 -93
  99. package/dist/runtime/ui.config/index.js +0 -16
  100. /package/dist/runtime/components/Dropdown/{types.js → types.mjs} +0 -0
  101. /package/dist/runtime/components/FlexDeck/{types.js → types.mjs} +0 -0
  102. /package/dist/runtime/components/Form/InputCheckbox/{types.js → types.mjs} +0 -0
  103. /package/dist/runtime/components/Form/InputDateTime/{date_time_field.types.js → date_time_field.types.mjs} +0 -0
  104. /package/dist/runtime/components/Form/InputDateTimeRange/{date_range_time_field.types.js → date_range_time_field.types.mjs} +0 -0
  105. /package/dist/runtime/components/Form/InputNumber/{types.js → types.mjs} +0 -0
  106. /package/dist/runtime/components/Form/InputRadio/{types.js → types.mjs} +0 -0
  107. /package/dist/runtime/components/Form/InputSelect/{types.js → types.mjs} +0 -0
  108. /package/dist/runtime/components/Form/InputSelectMultiple/{types.js → types.mjs} +0 -0
  109. /package/dist/runtime/components/Form/InputStatic/{types.js → types.mjs} +0 -0
  110. /package/dist/runtime/components/Form/InputTags/{types.js → types.mjs} +0 -0
  111. /package/dist/runtime/components/Form/InputText/{types.js → types.mjs} +0 -0
  112. /package/dist/runtime/components/Form/InputTextarea/{types.js → types.mjs} +0 -0
  113. /package/dist/runtime/components/Form/InputToggle/{types.js → types.mjs} +0 -0
  114. /package/dist/runtime/components/Form/InputUploadDropzone/{types.js → types.mjs} +0 -0
  115. /package/dist/runtime/components/Form/InputUploadDropzoneAuto/{types.js → types.mjs} +0 -0
  116. /package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/{types.js → types.mjs} +0 -0
  117. /package/dist/runtime/components/Form/InputUploadDropzoneImageAutoMultiple/{types.js → types.mjs} +0 -0
  118. /package/dist/runtime/components/Form/InputUploadFileClassic/{types.js → types.mjs} +0 -0
  119. /package/dist/runtime/components/Form/InputUploadFileClassicAuto/{types.js → types.mjs} +0 -0
  120. /package/dist/runtime/components/Form/InputUploadImageAuto/{types.js → types.mjs} +0 -0
  121. /package/dist/runtime/components/Form/InputWYSIWYG/{types.js → types.mjs} +0 -0
  122. /package/dist/runtime/components/Form/{types.js → types.mjs} +0 -0
  123. /package/dist/runtime/components/Table/{types.js → types.mjs} +0 -0
  124. /package/dist/runtime/composables/{useApp.js → useApp.mjs} +0 -0
  125. /package/dist/runtime/composables/{useConfig.js → useConfig.mjs} +0 -0
  126. /package/dist/runtime/composables/{useDialog.js → useDialog.mjs} +0 -0
  127. /package/dist/runtime/composables/{useFlexDeck.js → useFlexDeck.mjs} +0 -0
  128. /package/dist/runtime/composables/{useForm.js → useForm.mjs} +0 -0
  129. /package/dist/runtime/composables/{useNotification.js → useNotification.mjs} +0 -0
  130. /package/dist/runtime/composables/{useWatch.js → useWatch.mjs} +0 -0
  131. /package/dist/runtime/{core.config.js → core.config.mjs} +0 -0
  132. /package/dist/runtime/helpers/{componentHelper.js → componentHelper.mjs} +0 -0
  133. /package/dist/runtime/lib/{Requester.js → Requester.mjs} +0 -0
  134. /package/dist/runtime/{plugin.js → plugin.mjs} +0 -0
  135. /package/dist/runtime/{quill.plugin.js → quill.plugin.mjs} +0 -0
  136. /package/dist/runtime/types/{common.js → common.mjs} +0 -0
  137. /package/dist/runtime/types/{config.js → config.mjs} +0 -0
  138. /package/dist/runtime/types/{lib.js → lib.mjs} +0 -0
  139. /package/dist/runtime/ui.config/{alert.js → alert.mjs} +0 -0
  140. /package/dist/runtime/ui.config/{badge.js → badge.mjs} +0 -0
  141. /package/dist/runtime/ui.config/{breadcrumb.js → breadcrumb.mjs} +0 -0
  142. /package/dist/runtime/ui.config/{button.js → button.mjs} +0 -0
  143. /package/dist/runtime/ui.config/{buttonGroup.js → buttonGroup.mjs} +0 -0
  144. /package/dist/runtime/ui.config/{card.js → card.mjs} +0 -0
  145. /package/dist/runtime/ui.config/{checkbox.js → checkbox.mjs} +0 -0
  146. /package/dist/runtime/ui.config/{formGroup.js → formGroup.mjs} +0 -0
  147. /package/dist/runtime/ui.config/{icon.js → icon.mjs} +0 -0
  148. /package/dist/runtime/ui.config/{input.js → input.mjs} +0 -0
  149. /package/dist/runtime/ui.config/{modal.js → modal.mjs} +0 -0
  150. /package/dist/runtime/ui.config/{notification.js → notification.mjs} +0 -0
  151. /package/dist/runtime/ui.config/{pagination.js → pagination.mjs} +0 -0
  152. /package/dist/runtime/ui.config/{select.js → select.mjs} +0 -0
  153. /package/dist/runtime/ui.config/{selectMenu.js → selectMenu.mjs} +0 -0
  154. /package/dist/runtime/ui.config/{slideover.js → slideover.mjs} +0 -0
  155. /package/dist/runtime/ui.config/{table.js → table.mjs} +0 -0
  156. /package/dist/runtime/ui.config/{tabs.js → tabs.mjs} +0 -0
  157. /package/dist/runtime/ui.config/{tags.js → tags.mjs} +0 -0
  158. /package/dist/runtime/ui.config/{textarea.js → textarea.mjs} +0 -0
  159. /package/dist/runtime/ui.config/{toggle.js → toggle.mjs} +0 -0
  160. /package/dist/runtime/ui.config/{uploadFileDropzone.js → uploadFileDropzone.mjs} +0 -0
  161. /package/dist/runtime/ui.config/{uploadFileInputClassicAuto.js → uploadFileInputClassicAuto.mjs} +0 -0
  162. /package/dist/runtime/ui.config/{uploadImage.js → uploadImage.mjs} +0 -0
  163. /package/dist/runtime/utils/{ArrayHelper.js → ArrayHelper.mjs} +0 -0
  164. /package/dist/runtime/utils/{FileHelper.js → FileHelper.mjs} +0 -0
  165. /package/dist/runtime/utils/{ParamHelper.js → ParamHelper.mjs} +0 -0
  166. /package/dist/runtime/utils/{StringHelper.js → StringHelper.mjs} +0 -0
  167. /package/dist/runtime/utils/{TimeHelper.js → TimeHelper.mjs} +0 -0
  168. /package/dist/runtime/utils/{lodash.js → lodash.mjs} +0 -0
@@ -1,83 +1,83 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <Datepicker
4
- v-model="innerValueRef"
5
- :disabled="wrapperProps.isDisabled"
6
- cancel-text="ยกเลิก"
7
- select-text="เลือก"
8
- locale="th"
9
- :format="format"
10
- :enable-time-picker="!disabledTime"
11
- :placeholder="wrapperProps.placeholder"
12
- :min-date="minDate"
13
- :max-date="maxDate"
14
- :min-time="minTime"
15
- :max-time="maxTime"
16
- :start-time="startTime"
17
- :multi-calendars="!isDisabledMultiCalendar"
18
- :required="isRequired"
19
- time-picker-inline
20
- range
21
- @update:model-value="onInput"
22
- >
23
- <template #dp-input="{ value: innerValue }">
24
- <UInput
25
- :trailing-icon="innerValue ? undefined : 'i-heroicons-calendar-days'"
26
- type="text"
27
- :value="innerValue"
28
- :placeholder="wrapperProps.placeholder"
29
- :readonly="true"
30
- input-class="cursor-pointer select-none"
31
- />
32
- </template>
33
- </Datepicker>
34
- </FieldWrapper>
35
- </template>
36
- <script lang="ts" setup>
37
- import Datepicker from '@vuepic/vue-datepicker'
38
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
39
- import { TimeHelper, ref, useFieldHOC } from '#imports'
40
- import '@vuepic/vue-datepicker/dist/main.css'
41
- import type {
42
- IDateTimeRangeFieldProps,
43
- IDateTimeRangeResponse,
44
- } from './date_range_time_field.types'
45
-
46
- const props = withDefaults(defineProps<IDateTimeRangeFieldProps>(), {})
47
-
48
- const { value, wrapperProps } = useFieldHOC<IDateTimeRangeResponse | null>(props)
49
-
50
- const innerValueRef = ref<Date[]>([])
51
-
52
- const format = (date: Date[]) => {
53
- if (props.disabledTime) {
54
- return date.length > 0
55
- ? TimeHelper.displayDate(date[0]) + ' - ' + TimeHelper.displayDate(date[1] ?? '')
56
- : ''
57
- }
58
-
59
- return date.length > 0
60
- ? TimeHelper.displayDateTime(date[0]) + ' - ' + TimeHelper.displayDateTime(date[1] ?? '')
61
- : ''
62
- }
63
-
64
- const onInput = (_value: Date[]) => {
65
- if (_value === null) {
66
- value.value = null
67
-
68
- return
69
- }
70
-
71
- if (props.disabledTime && !props.isReturnISO) {
72
- value.value = <IDateTimeRangeResponse>{
73
- start: TimeHelper.getDateFormTime(_value[0]),
74
- end: TimeHelper.getDateFormTime(_value[1]),
75
- }
76
- } else {
77
- value.value = <IDateTimeRangeResponse>{
78
- start: _value[0],
79
- end: _value[1],
80
- }
81
- }
82
- }
83
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <Datepicker
4
+ v-model="innerValueRef"
5
+ :disabled="wrapperProps.isDisabled"
6
+ cancel-text="ยกเลิก"
7
+ select-text="เลือก"
8
+ locale="th"
9
+ :format="format"
10
+ :enable-time-picker="!disabledTime"
11
+ :placeholder="wrapperProps.placeholder"
12
+ :min-date="minDate"
13
+ :max-date="maxDate"
14
+ :min-time="minTime"
15
+ :max-time="maxTime"
16
+ :start-time="startTime"
17
+ :multi-calendars="!isDisabledMultiCalendar"
18
+ :required="isRequired"
19
+ time-picker-inline
20
+ range
21
+ @update:model-value="onInput"
22
+ >
23
+ <template #dp-input="{ value: innerValue }">
24
+ <UInput
25
+ :trailing-icon="innerValue ? undefined : 'i-heroicons-calendar-days'"
26
+ type="text"
27
+ :value="innerValue"
28
+ :placeholder="wrapperProps.placeholder"
29
+ :readonly="true"
30
+ input-class="cursor-pointer select-none"
31
+ />
32
+ </template>
33
+ </Datepicker>
34
+ </FieldWrapper>
35
+ </template>
36
+ <script lang="ts" setup>
37
+ import Datepicker from '@vuepic/vue-datepicker'
38
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
39
+ import { TimeHelper, ref, useFieldHOC } from '#imports'
40
+ import '@vuepic/vue-datepicker/dist/main.css'
41
+ import type {
42
+ IDateTimeRangeFieldProps,
43
+ IDateTimeRangeResponse,
44
+ } from './date_range_time_field.types'
45
+
46
+ const props = withDefaults(defineProps<IDateTimeRangeFieldProps>(), {})
47
+
48
+ const { value, wrapperProps } = useFieldHOC<IDateTimeRangeResponse | null>(props)
49
+
50
+ const innerValueRef = ref<Date[]>([])
51
+
52
+ const format = (date: Date[]) => {
53
+ if (props.disabledTime) {
54
+ return date.length > 0
55
+ ? TimeHelper.displayDate(date[0]) + ' - ' + TimeHelper.displayDate(date[1] ?? '')
56
+ : ''
57
+ }
58
+
59
+ return date.length > 0
60
+ ? TimeHelper.displayDateTime(date[0]) + ' - ' + TimeHelper.displayDateTime(date[1] ?? '')
61
+ : ''
62
+ }
63
+
64
+ const onInput = (_value: Date[]) => {
65
+ if (_value === null) {
66
+ value.value = null
67
+
68
+ return
69
+ }
70
+
71
+ if (props.disabledTime && !props.isReturnISO) {
72
+ value.value = <IDateTimeRangeResponse>{
73
+ start: TimeHelper.getDateFormTime(_value[0]),
74
+ end: TimeHelper.getDateFormTime(_value[1]),
75
+ }
76
+ } else {
77
+ value.value = <IDateTimeRangeResponse>{
78
+ start: _value[0],
79
+ end: _value[1],
80
+ }
81
+ }
82
+ }
83
+ </script>
@@ -1,27 +1,27 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <UInput
4
- v-model.number="value"
5
- type="number"
6
- :disabled="wrapperProps.isDisabled"
7
- :leading-icon="leadingIcon"
8
- :trailing-icon="trailingIcon"
9
- :name="name"
10
- :placeholder="wrapperProps.placeholder"
11
- :autofocus="!!autoFocus"
12
- :icon="icon"
13
- :readonly="isReadonly"
14
- :ui="_deepMerge({}, ui, { icon: { trailing: { pointer: '' } } })"
15
- />
16
- </FieldWrapper>
17
- </template>
18
- <script lang="ts" setup>
19
- import { _deepMerge } from '#imports'
20
- import { useFieldHOC } from '#core/composables/useForm'
21
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
22
- import type { INumberFieldProps } from '#core/components/Form/InputNumber/types'
23
-
24
- const props = withDefaults(defineProps<INumberFieldProps>(), {})
25
-
26
- const { value, wrapperProps } = useFieldHOC<number>(props)
27
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <UInput
4
+ v-model.number="value"
5
+ type="number"
6
+ :disabled="wrapperProps.isDisabled"
7
+ :leading-icon="leadingIcon"
8
+ :trailing-icon="trailingIcon"
9
+ :name="name"
10
+ :placeholder="wrapperProps.placeholder"
11
+ :autofocus="!!autoFocus"
12
+ :icon="icon"
13
+ :readonly="isReadonly"
14
+ :ui="_deepMerge({}, ui, { icon: { trailing: { pointer: '' } } })"
15
+ />
16
+ </FieldWrapper>
17
+ </template>
18
+ <script lang="ts" setup>
19
+ import { _deepMerge } from '#imports'
20
+ import { useFieldHOC } from '#core/composables/useForm'
21
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
22
+ import type { INumberFieldProps } from '#core/components/Form/InputNumber/types'
23
+
24
+ const props = withDefaults(defineProps<INumberFieldProps>(), {})
25
+
26
+ const { value, wrapperProps } = useFieldHOC<number>(props)
27
+ </script>
@@ -1,27 +1,27 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <URadioGroup
4
- v-model="value"
5
- :options="options"
6
- :disabled="wrapperProps.isDisabled"
7
- :required="isRequired"
8
- value-attribute="value"
9
- option-attribute="label"
10
- :icon="icon"
11
- :color="color"
12
- :size="size"
13
- :ui="ui"
14
- :ui-menu="uiMenu"
15
- />
16
- </FieldWrapper>
17
- </template>
18
-
19
- <script lang="ts" setup>
20
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
21
- import { useFieldHOC } from '#core/composables/useForm'
22
- import { type ISelectFieldProps } from '#core/components/Form/InputSelect/types'
23
-
24
- const props = withDefaults(defineProps<ISelectFieldProps>(), {})
25
-
26
- const { value, wrapperProps } = useFieldHOC<any>(props)
27
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <URadioGroup
4
+ v-model="value"
5
+ :options="options"
6
+ :disabled="wrapperProps.isDisabled"
7
+ :required="isRequired"
8
+ value-attribute="value"
9
+ option-attribute="label"
10
+ :icon="icon"
11
+ :color="color"
12
+ :size="size"
13
+ :ui="ui"
14
+ :ui-menu="uiMenu"
15
+ />
16
+ </FieldWrapper>
17
+ </template>
18
+
19
+ <script lang="ts" setup>
20
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
21
+ import { useFieldHOC } from '#core/composables/useForm'
22
+ import { type ISelectFieldProps } from '#core/components/Form/InputSelect/types'
23
+
24
+ const props = withDefaults(defineProps<ISelectFieldProps>(), {})
25
+
26
+ const { value, wrapperProps } = useFieldHOC<any>(props)
27
+ </script>
@@ -1,45 +1,45 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <USelectMenu
4
- :model-value="value"
5
- searchable
6
- :options="options"
7
- :placeholder="placeholder || label"
8
- :disabled="wrapperProps.isDisabled"
9
- :loading="loading"
10
- :searchable-placeholder="searchablePlaceholder"
11
- value-attribute="value"
12
- option-attribute="label"
13
- :icon="icon"
14
- :color="color"
15
- :size="size"
16
- :ui="ui"
17
- :ui-menu="uiMenu"
18
- @update:modelValue="onChange"
19
- >
20
- <template #label>
21
- <span v-if="value" class="truncate">
22
- {{ options.find((item) => item.value === value)?.label || value }}
23
- </span>
24
- </template>
25
- </USelectMenu>
26
- </FieldWrapper>
27
- </template>
28
-
29
- <script lang="ts" setup>
30
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
31
- import { useFieldHOC } from '#core/composables/useForm'
32
- import { type ISelectFieldProps } from '#core/components/Form/InputSelect/types'
33
-
34
- const emits = defineEmits(['change'])
35
- const props = withDefaults(defineProps<ISelectFieldProps>(), {
36
- searchablePlaceholder: 'ค้นหา...',
37
- })
38
-
39
- const { value, wrapperProps, handleChange } = useFieldHOC<any>(props)
40
-
41
- const onChange = (value: any) => {
42
- handleChange(value)
43
- emits('change', value)
44
- }
45
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <USelectMenu
4
+ :model-value="value"
5
+ searchable
6
+ :options="options"
7
+ :placeholder="placeholder || label"
8
+ :disabled="wrapperProps.isDisabled"
9
+ :loading="loading"
10
+ :searchable-placeholder="searchablePlaceholder"
11
+ value-attribute="value"
12
+ option-attribute="label"
13
+ :icon="icon"
14
+ :color="color"
15
+ :size="size"
16
+ :ui="ui"
17
+ :ui-menu="uiMenu"
18
+ @update:modelValue="onChange"
19
+ >
20
+ <template #label>
21
+ <span v-if="value" class="truncate">
22
+ {{ options.find((item) => item.value === value)?.label || value }}
23
+ </span>
24
+ </template>
25
+ </USelectMenu>
26
+ </FieldWrapper>
27
+ </template>
28
+
29
+ <script lang="ts" setup>
30
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
31
+ import { useFieldHOC } from '#core/composables/useForm'
32
+ import { type ISelectFieldProps } from '#core/components/Form/InputSelect/types'
33
+
34
+ const emits = defineEmits(['change'])
35
+ const props = withDefaults(defineProps<ISelectFieldProps>(), {
36
+ searchablePlaceholder: 'ค้นหา...',
37
+ })
38
+
39
+ const { value, wrapperProps, handleChange } = useFieldHOC<any>(props)
40
+
41
+ const onChange = (value: any) => {
42
+ handleChange(value)
43
+ emits('change', value)
44
+ }
45
+ </script>
@@ -1,54 +1,54 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <USelectMenu
4
- :model-value="value || []"
5
- searchable
6
- multiple
7
- :options="options"
8
- :placeholder="placeholder || label"
9
- :disabled="wrapperProps.isDisabled"
10
- :loading="loading"
11
- :searchable-placeholder="searchablePlaceholder"
12
- value-attribute="value"
13
- option-attribute="label"
14
- :icon="icon"
15
- :color="color"
16
- :size="size"
17
- :ui="ui"
18
- :ui-menu="uiMenu"
19
- @update:model-value="value = $event"
20
- >
21
- <template #label>
22
- <div v-if="ArrayHelper.toArray(value).length > 0" class="flex flex-wrap gap-x-2 gap-y-1">
23
- <Badge v-for="_value in ArrayHelper.toArray(value)" :key="_value">
24
- <div class="flex items-center gap-x-1">
25
- {{ options.find((item) => item.value === _value)?.label || _value }}
26
- <Icon
27
- name="i-heroicons:x-circle-20-solid"
28
- class="size-4 cursor-pointer hover:text-gray-200"
29
- @click.prevent="handleDelete(_value)"
30
- />
31
- </div>
32
- </Badge>
33
- </div>
34
- </template>
35
- </USelectMenu>
36
- </FieldWrapper>
37
- </template>
38
-
39
- <script lang="ts" setup>
40
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
41
- import { useFieldHOC } from '#core/composables/useForm'
42
- import type { ISelectMultipleFieldProps } from '#core/components/Form/InputSelectMultiple/types'
43
- import { ArrayHelper } from '#core/utils/ArrayHelper'
44
-
45
- const props = withDefaults(defineProps<ISelectMultipleFieldProps>(), {
46
- searchablePlaceholder: 'ค้นหา...',
47
- })
48
-
49
- const { value, wrapperProps } = useFieldHOC<any[]>(props)
50
-
51
- const handleDelete = (_value: any) => {
52
- value.value = ArrayHelper.toArray(value.value).filter((item: any) => item !== _value)
53
- }
54
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <USelectMenu
4
+ :model-value="value || []"
5
+ searchable
6
+ multiple
7
+ :options="options"
8
+ :placeholder="placeholder || label"
9
+ :disabled="wrapperProps.isDisabled"
10
+ :loading="loading"
11
+ :searchable-placeholder="searchablePlaceholder"
12
+ value-attribute="value"
13
+ option-attribute="label"
14
+ :icon="icon"
15
+ :color="color"
16
+ :size="size"
17
+ :ui="ui"
18
+ :ui-menu="uiMenu"
19
+ @update:model-value="value = $event"
20
+ >
21
+ <template #label>
22
+ <div v-if="ArrayHelper.toArray(value).length > 0" class="flex flex-wrap gap-x-2 gap-y-1">
23
+ <Badge v-for="_value in ArrayHelper.toArray(value)" :key="_value">
24
+ <div class="flex items-center gap-x-1">
25
+ {{ options.find((item) => item.value === _value)?.label || _value }}
26
+ <Icon
27
+ name="i-heroicons:x-circle-20-solid"
28
+ class="size-4 cursor-pointer hover:text-gray-200"
29
+ @click.prevent="handleDelete(_value)"
30
+ />
31
+ </div>
32
+ </Badge>
33
+ </div>
34
+ </template>
35
+ </USelectMenu>
36
+ </FieldWrapper>
37
+ </template>
38
+
39
+ <script lang="ts" setup>
40
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
41
+ import { useFieldHOC } from '#core/composables/useForm'
42
+ import type { ISelectMultipleFieldProps } from '#core/components/Form/InputSelectMultiple/types'
43
+ import { ArrayHelper } from '#core/utils/ArrayHelper'
44
+
45
+ const props = withDefaults(defineProps<ISelectMultipleFieldProps>(), {
46
+ searchablePlaceholder: 'ค้นหา...',
47
+ })
48
+
49
+ const { value, wrapperProps } = useFieldHOC<any[]>(props)
50
+
51
+ const handleDelete = (_value: any) => {
52
+ value.value = ArrayHelper.toArray(value.value).filter((item: any) => item !== _value)
53
+ }
54
+ </script>
@@ -1,16 +1,16 @@
1
- <template>
2
- <FieldWrapper v-bind="wrapperProps" :is-required="false">
3
- <p class="form-control-static">
4
- {{ !value || value.length === 0 ? '-' : value }}
5
- </p>
6
- </FieldWrapper>
7
- </template>
8
- <script lang="ts" setup>
9
- import { type IStaticFieldProps } from '#core/components/Form/InputStatic/types'
10
- import { useFieldHOC } from '#core/composables/useForm'
11
- import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
12
-
13
- const props = withDefaults(defineProps<IStaticFieldProps>(), {})
14
-
15
- const { value, wrapperProps } = useFieldHOC<string>(props)
16
- </script>
1
+ <template>
2
+ <FieldWrapper v-bind="wrapperProps" :is-required="false">
3
+ <p class="form-control-static">
4
+ {{ !value || value.length === 0 ? '-' : value }}
5
+ </p>
6
+ </FieldWrapper>
7
+ </template>
8
+ <script lang="ts" setup>
9
+ import { type IStaticFieldProps } from '#core/components/Form/InputStatic/types'
10
+ import { useFieldHOC } from '#core/composables/useForm'
11
+ import FieldWrapper from '#core/components/Form/FieldWrapper.vue'
12
+
13
+ const props = withDefaults(defineProps<IStaticFieldProps>(), {})
14
+
15
+ const { value, wrapperProps } = useFieldHOC<string>(props)
16
+ </script>