@finema/core 3.8.0 → 3.9.0

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 (43) hide show
  1. package/dist/module.json +1 -1
  2. package/dist/module.mjs +1 -1
  3. package/dist/runtime/components/FlexDeck/index.vue +79 -79
  4. package/dist/runtime/components/Form/FieldWrapper.vue +13 -13
  5. package/dist/runtime/components/Form/Fields.vue +13 -13
  6. package/dist/runtime/components/Form/InputCheckbox/index.vue +18 -18
  7. package/dist/runtime/components/Form/InputCheckboxGroup/index.vue +21 -21
  8. package/dist/runtime/components/Form/InputCurrency/index.vue +49 -49
  9. package/dist/runtime/components/Form/InputDateTime/index.vue +62 -62
  10. package/dist/runtime/components/Form/InputDateTimeRange/index.vue +56 -56
  11. package/dist/runtime/components/Form/InputNumber/index.vue +20 -20
  12. package/dist/runtime/components/Form/InputSelect/index.vue +46 -46
  13. package/dist/runtime/components/Form/InputSelectMultiple/index.vue +62 -62
  14. package/dist/runtime/components/Form/InputTags/index.vue +54 -54
  15. package/dist/runtime/components/Form/InputTextarea/index.vue +18 -18
  16. package/dist/runtime/components/Form/InputTime/index.vue +38 -38
  17. package/dist/runtime/components/Form/InputToggle/index.vue +17 -17
  18. package/dist/runtime/components/Form/InputUploadDropzone/index.vue +40 -34
  19. package/dist/runtime/components/Form/InputUploadDropzoneAuto/index.vue +50 -50
  20. package/dist/runtime/components/Form/InputUploadDropzoneAutoMultiple/index.vue +50 -50
  21. package/dist/runtime/components/Form/InputUploadImageAuto/index.vue +50 -50
  22. package/dist/runtime/components/Form/InputWYSIWYG/EditorImagePasteExtension.d.ts +16 -0
  23. package/dist/runtime/components/Form/InputWYSIWYG/EditorImagePasteExtension.js +106 -0
  24. package/dist/runtime/components/Form/InputWYSIWYG/EditorImageUploadNode.vue +18 -18
  25. package/dist/runtime/components/Form/InputWYSIWYG/EditorLinkPopover.vue +65 -65
  26. package/dist/runtime/components/Form/InputWYSIWYG/README.md +96 -0
  27. package/dist/runtime/components/Form/InputWYSIWYG/index.vue +3 -2
  28. package/dist/runtime/components/Form/fileState/EmptyState.vue +21 -21
  29. package/dist/runtime/components/Form/fileState/FailedState.vue +33 -33
  30. package/dist/runtime/components/Form/fileState/LoadingState.vue +24 -24
  31. package/dist/runtime/components/Form/fileState/MultipleFilesState.vue +75 -75
  32. package/dist/runtime/components/Form/fileState/PreviewModal.vue +23 -23
  33. package/dist/runtime/components/Form/index.vue +5 -5
  34. package/dist/runtime/components/Image.vue +28 -28
  35. package/dist/runtime/components/Log/index.vue +17 -17
  36. package/dist/runtime/components/Table/ColumnDate.vue +1 -1
  37. package/dist/runtime/components/Table/ColumnDateTime.vue +1 -1
  38. package/dist/runtime/components/Table/ColumnImage.vue +4 -4
  39. package/dist/runtime/components/Table/ColumnText.vue +1 -1
  40. package/dist/runtime/components/Table/Pagination.vue +46 -46
  41. package/dist/runtime/components/Table/Simple.vue +16 -16
  42. package/dist/runtime/server/tsconfig.json +3 -3
  43. package/package.json +1 -1
package/dist/module.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@finema/core",
3
- "version": "3.8.0",
3
+ "version": "3.9.0",
4
4
  "configKey": "core",
5
5
  "builder": {
6
6
  "@nuxt/module-builder": "1.0.2",
package/dist/module.mjs CHANGED
@@ -4,7 +4,7 @@ import * as lodash from 'lodash-es';
4
4
  import * as theme from '../dist/runtime/theme/index.js';
5
5
 
6
6
  const name = "@finema/core";
7
- const version = "3.8.0";
7
+ const version = "3.9.0";
8
8
 
9
9
  const nuxtAppOptions = {
10
10
  head: {
@@ -1,83 +1,83 @@
1
1
  <template>
2
- <div>
3
- <div
4
- v-if="options.isEnabledSearch"
5
- class="mb-4 flex justify-end"
6
- >
7
- <Input
8
- v-model="q"
9
- icon="i-heroicons-magnifying-glass"
10
- :placeholder="options.searchPlaceholder || '\u0E04\u0E49\u0E19\u0E2B\u0E32...'"
11
- />
12
- </div>
13
-
14
- <div
15
- v-if="options.pageOptions && options.isEnableInfiniteScroll"
16
- class="mb-4 flex items-center justify-end"
17
- >
18
- <p class="text-xs text-gray-500">
19
- {{ totalInnerRawData }} รายการ จากทั้งหมด {{ totalCountWithComma }} รายการ
20
- </p>
21
- </div>
22
-
23
- <slot
24
- v-if="options.status.isSuccess && options.rawData.length === 0"
25
- name="empty-state"
26
- >
27
- <Empty />
28
- </slot>
29
-
30
- <slot
31
- v-else-if="options.status.isLoading"
32
- name="loading-state"
33
- >
34
- <Loader
35
- :loading="true"
36
- />
37
- </slot>
38
- <slot
39
- v-else-if="options.status.isError"
40
- name="error-state"
41
- >
42
- <div
43
- class="
44
- text-error-400 flex h-[200px] items-center justify-center text-2xl
45
- "
46
- >
47
- {{ StringHelper.getError(options.status.errorData) }}
48
- </div>
49
- </slot>
50
-
51
- <div
52
- v-else
53
- :class="containerClass"
54
- >
55
- <slot
56
- v-for="(row, index) in displayData"
57
- :key="index"
58
- :row="row"
59
- />
60
- <div ref="bottomEdgeElement" />
61
- </div>
62
-
63
- <div
64
- v-if="options.pageOptions && !options.isEnableInfiniteScroll && !options.isHidePagination"
65
- class="mt-4 flex justify-between px-3"
66
- >
67
- <p class="text-xs text-gray-500">
68
- {{ pageBetween }} {{ appConfig.core?.locale === "th" ? "\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23 \u0E08\u0E32\u0E01\u0E17\u0E31\u0E49\u0E07\u0E2B\u0E21\u0E14" : "items of total" }}
69
- {{ totalCountWithComma }} {{ appConfig.core?.locale === "th" ? "\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23" : "items" }}
70
- </p>
71
- <Pagination
72
- v-if="options.pageOptions.totalPage > 1"
73
- :to="options.isRouteChange ? to : void 0"
74
- :default-page="options.pageOptions?.currentPage || 1"
75
- :items-per-page="options.pageOptions.limit"
76
- :total="options.pageOptions.totalCount"
77
- @update:page="onPageChange"
78
- />
79
- </div>
80
- </div>
2
+ <div>
3
+ <div
4
+ v-if="options.isEnabledSearch"
5
+ class="mb-4 flex justify-end"
6
+ >
7
+ <Input
8
+ v-model="q"
9
+ icon="i-heroicons-magnifying-glass"
10
+ :placeholder="options.searchPlaceholder || '\u0E04\u0E49\u0E19\u0E2B\u0E32...'"
11
+ />
12
+ </div>
13
+
14
+ <div
15
+ v-if="options.pageOptions && options.isEnableInfiniteScroll"
16
+ class="mb-4 flex items-center justify-end"
17
+ >
18
+ <p class="text-xs text-gray-500">
19
+ {{ totalInnerRawData }} รายการ จากทั้งหมด {{ totalCountWithComma }} รายการ
20
+ </p>
21
+ </div>
22
+
23
+ <slot
24
+ v-if="options.status.isSuccess && options.rawData.length === 0"
25
+ name="empty-state"
26
+ >
27
+ <Empty />
28
+ </slot>
29
+
30
+ <slot
31
+ v-else-if="options.status.isLoading"
32
+ name="loading-state"
33
+ >
34
+ <Loader
35
+ :loading="true"
36
+ />
37
+ </slot>
38
+ <slot
39
+ v-else-if="options.status.isError"
40
+ name="error-state"
41
+ >
42
+ <div
43
+ class="
44
+ text-error-400 flex h-[200px] items-center justify-center text-2xl
45
+ "
46
+ >
47
+ {{ StringHelper.getError(options.status.errorData) }}
48
+ </div>
49
+ </slot>
50
+
51
+ <div
52
+ v-else
53
+ :class="containerClass"
54
+ >
55
+ <slot
56
+ v-for="(row, index) in displayData"
57
+ :key="index"
58
+ :row="row"
59
+ />
60
+ <div ref="bottomEdgeElement" />
61
+ </div>
62
+
63
+ <div
64
+ v-if="options.pageOptions && !options.isEnableInfiniteScroll && !options.isHidePagination"
65
+ class="mt-4 flex justify-between px-3"
66
+ >
67
+ <p class="text-xs text-gray-500">
68
+ {{ pageBetween }} {{ appConfig.core?.locale === "th" ? "\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23 \u0E08\u0E32\u0E01\u0E17\u0E31\u0E49\u0E07\u0E2B\u0E21\u0E14" : "items of total" }}
69
+ {{ totalCountWithComma }} {{ appConfig.core?.locale === "th" ? "\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23" : "items" }}
70
+ </p>
71
+ <Pagination
72
+ v-if="options.pageOptions.totalPage > 1"
73
+ :to="options.isRouteChange ? to : void 0"
74
+ :default-page="options.pageOptions?.currentPage || 1"
75
+ :items-per-page="options.pageOptions.limit"
76
+ :total="options.pageOptions.totalCount"
77
+ @update:page="onPageChange"
78
+ />
79
+ </div>
80
+ </div>
81
81
  </template>
82
82
 
83
83
  <script setup>
@@ -1,17 +1,17 @@
1
1
  <template>
2
- <FormField
3
- :label="label"
4
- :name="name"
5
- :description="description"
6
- :hint="hint"
7
- :data-testid="name"
8
- :help="help"
9
- :error="errorMessage"
10
- :required="!!required"
11
- :ui="containerUi"
12
- >
13
- <slot />
14
- </FormField>
2
+ <FormField
3
+ :label="label"
4
+ :name="name"
5
+ :description="description"
6
+ :hint="hint"
7
+ :data-testid="name"
8
+ :help="help"
9
+ :error="errorMessage"
10
+ :required="!!required"
11
+ :ui="containerUi"
12
+ >
13
+ <slot />
14
+ </FormField>
15
15
  </template>
16
16
 
17
17
  <script setup>
@@ -1,22 +1,22 @@
1
1
  <template>
2
- <div
2
+ <div
3
3
  :class="[theme.base({
4
4
  class: [$props.class, ui?.base]
5
- })]"
6
- >
7
- <component
8
- :is="componentMap[option.type]?.component"
9
- v-for="option in options.filter((item) => !item.isHide)"
10
- :key="option.props.name"
11
- :class="option.class"
12
- :form="form"
5
+ })]"
6
+ >
7
+ <component
8
+ :is="componentMap[option.type]?.component"
9
+ v-for="option in options.filter((item) => !item.isHide)"
10
+ :key="option.props.name"
11
+ :class="option.class"
12
+ :form="form"
13
13
  v-bind="{
14
14
  ...getFieldBinding(option),
15
15
  ...componentMap[option.type]?.props
16
- }"
17
- v-on="option.on ?? {}"
18
- />
19
- </div>
16
+ }"
17
+ v-on="option.on ?? {}"
18
+ />
19
+ </div>
20
20
  </template>
21
21
 
22
22
  <script setup>
@@ -1,22 +1,22 @@
1
1
  <template>
2
- <FieldWrapper
3
- v-bind="wrapperProps"
4
- label=""
5
- description=""
6
- >
7
- <Checkbox
8
- :model-value="value"
9
- :disabled="wrapperProps.disabled"
10
- :name="name"
11
- :label="label"
12
- :description="description"
13
- :required="required"
14
- :variant="variant"
15
- :indicator="indicator"
16
- :ui="ui"
17
- @update:modelValue="onChange"
18
- />
19
- </FieldWrapper>
2
+ <FieldWrapper
3
+ v-bind="wrapperProps"
4
+ label=""
5
+ description=""
6
+ >
7
+ <Checkbox
8
+ :model-value="value"
9
+ :disabled="wrapperProps.disabled"
10
+ :name="name"
11
+ :label="label"
12
+ :description="description"
13
+ :required="required"
14
+ :variant="variant"
15
+ :indicator="indicator"
16
+ :ui="ui"
17
+ @update:modelValue="onChange"
18
+ />
19
+ </FieldWrapper>
20
20
  </template>
21
21
 
22
22
  <script setup>
@@ -1,25 +1,25 @@
1
1
  <template>
2
- <FieldWrapper
3
- v-bind="wrapperProps"
4
- label=""
5
- description=""
6
- >
7
- <CheckboxGroup
8
- :model-value="value"
9
- :disabled="wrapperProps.disabled"
10
- :name="name"
11
- :label="label"
12
- :items="options"
13
- :description="description"
14
- :required="required"
15
- :variant="variant"
16
- :indicator="indicator"
17
- :value-key="valueKey"
18
- :orientation="orientation"
19
- :ui="ui"
20
- @update:model-value="onChange"
21
- />
22
- </FieldWrapper>
2
+ <FieldWrapper
3
+ v-bind="wrapperProps"
4
+ label=""
5
+ description=""
6
+ >
7
+ <CheckboxGroup
8
+ :model-value="value"
9
+ :disabled="wrapperProps.disabled"
10
+ :name="name"
11
+ :label="label"
12
+ :items="options"
13
+ :description="description"
14
+ :required="required"
15
+ :variant="variant"
16
+ :indicator="indicator"
17
+ :value-key="valueKey"
18
+ :orientation="orientation"
19
+ :ui="ui"
20
+ @update:model-value="onChange"
21
+ />
22
+ </FieldWrapper>
23
23
  </template>
24
24
 
25
25
  <script setup>
@@ -1,56 +1,56 @@
1
1
  <template>
2
- <FieldWrapper
3
- v-bind="wrapperProps"
4
- :error-message="undefined"
5
- >
6
- <div
2
+ <FieldWrapper
3
+ v-bind="wrapperProps"
4
+ :error-message="undefined"
5
+ >
6
+ <div
7
7
  :class="['inline-flex w-full items-center -space-x-px rounded-lg ring-1', {
8
8
  'ring-error': wrapperProps.errorMessage,
9
9
  'ring-gray-300': !wrapperProps.errorMessage
10
- }]"
11
- >
12
- <p class="pl-3 text-lg">
13
- {{ currencySymbol }}
14
- </p>
15
- <InputNumber
16
- :model-value="value.value"
17
- :disabled="wrapperProps.disabled"
18
- :name="name"
19
- :placeholder="wrapperProps.placeholder"
20
- :autofocus="!!autoFocus"
21
- :readonly="readonly"
22
- :min="min"
23
- :max="max"
24
- :step="step"
25
- :format-options="formatOptions"
26
- :increment="false"
27
- :decrement="false"
28
- variant="none"
29
- @update:model-value="onAmountChange"
30
- />
31
- <Select
32
- :model-value="value.currency"
33
- :items="options"
34
- :disabled="wrapperProps.disabled"
35
- value-key="value"
36
- label-key="label"
37
- variant="none"
38
- size="xl"
39
- class="cursor-pointer"
40
- @update:model-value="onCurrencyChange"
41
- >
42
- <template #default="{ modelValue }">
43
- {{ options.find((item) => item.value === modelValue)?.label || modelValue }}
44
- </template>
45
- </Select>
46
- </div>
47
- <p
48
- v-if="wrapperProps.errorMessage"
49
- class="text-error mt-2"
50
- >
51
- {{ wrapperProps.errorMessage }}
52
- </p>
53
- </FieldWrapper>
10
+ }]"
11
+ >
12
+ <p class="pl-3 text-lg">
13
+ {{ currencySymbol }}
14
+ </p>
15
+ <InputNumber
16
+ :model-value="value.value"
17
+ :disabled="wrapperProps.disabled"
18
+ :name="name"
19
+ :placeholder="wrapperProps.placeholder"
20
+ :autofocus="!!autoFocus"
21
+ :readonly="readonly"
22
+ :min="min"
23
+ :max="max"
24
+ :step="step"
25
+ :format-options="formatOptions"
26
+ :increment="false"
27
+ :decrement="false"
28
+ variant="none"
29
+ @update:model-value="onAmountChange"
30
+ />
31
+ <Select
32
+ :model-value="value.currency"
33
+ :items="options"
34
+ :disabled="wrapperProps.disabled"
35
+ value-key="value"
36
+ label-key="label"
37
+ variant="none"
38
+ size="xl"
39
+ class="cursor-pointer"
40
+ @update:model-value="onCurrencyChange"
41
+ >
42
+ <template #default="{ modelValue }">
43
+ {{ options.find((item) => item.value === modelValue)?.label || modelValue }}
44
+ </template>
45
+ </Select>
46
+ </div>
47
+ <p
48
+ v-if="wrapperProps.errorMessage"
49
+ class="text-error mt-2"
50
+ >
51
+ {{ wrapperProps.errorMessage }}
52
+ </p>
53
+ </FieldWrapper>
54
54
  </template>
55
55
 
56
56
  <script setup>
@@ -1,71 +1,71 @@
1
1
  <template>
2
- <FieldWrapper v-bind="wrapperProps">
3
- <Datepicker
4
- :model-value="innerValue"
5
- :disabled="wrapperProps.disabled"
6
- :cancel-text="appConfig.core?.locale === 'th' ? '\u0E22\u0E01\u0E40\u0E25\u0E34\u0E01' : 'Cancel'"
7
- :select-text="appConfig.core?.locale === 'th' ? '\u0E15\u0E01\u0E25\u0E07' : 'Select'"
8
- :locale="appConfig.core?.locale"
9
- :enable-time-picker="!disabledTime"
10
- :placeholder="wrapperProps.placeholder"
11
- :format="format"
12
- :min-date="minDate"
13
- :max-date="maxDate"
14
- :min-time="minTime"
15
- :max-time="maxTime"
16
- :six-weeks="true"
17
- :start-time="startTime"
18
- :teleport="teleport"
19
- :required="required"
20
- :flow="['calendar', 'time']"
21
- @update:model-value="onInput"
22
- >
23
- <template
24
- v-if="appConfig.core?.locale === 'th' && appConfig.core?.is_thai_year"
25
- #year="{ value }"
26
- >
27
- {{ value + 543 }}
28
- </template>
29
- <template
30
- v-if="appConfig.core?.locale === 'th' && appConfig.core?.is_thai_year"
31
- #year-overlay-value="{ value }"
32
- >
33
- {{ value + 543 }}
34
- </template>
35
- <template #dp-input="{ value: innerValue }">
36
- <Input
37
- v-if="!readMode"
38
- :trailing-icon="innerValue ? void 0 : 'i-heroicons-calendar-days'"
39
- type="text"
40
- :disabled="wrapperProps.disabled"
41
- :model-value="innerValue"
42
- :placeholder="wrapperProps.placeholder"
43
- :readonly="true"
2
+ <FieldWrapper v-bind="wrapperProps">
3
+ <Datepicker
4
+ :model-value="innerValue"
5
+ :disabled="wrapperProps.disabled"
6
+ :cancel-text="appConfig.core?.locale === 'th' ? '\u0E22\u0E01\u0E40\u0E25\u0E34\u0E01' : 'Cancel'"
7
+ :select-text="appConfig.core?.locale === 'th' ? '\u0E15\u0E01\u0E25\u0E07' : 'Select'"
8
+ :locale="appConfig.core?.locale"
9
+ :enable-time-picker="!disabledTime"
10
+ :placeholder="wrapperProps.placeholder"
11
+ :format="format"
12
+ :min-date="minDate"
13
+ :max-date="maxDate"
14
+ :min-time="minTime"
15
+ :max-time="maxTime"
16
+ :six-weeks="true"
17
+ :start-time="startTime"
18
+ :teleport="teleport"
19
+ :required="required"
20
+ :flow="['calendar', 'time']"
21
+ @update:model-value="onInput"
22
+ >
23
+ <template
24
+ v-if="appConfig.core?.locale === 'th' && appConfig.core?.is_thai_year"
25
+ #year="{ value }"
26
+ >
27
+ {{ value + 543 }}
28
+ </template>
29
+ <template
30
+ v-if="appConfig.core?.locale === 'th' && appConfig.core?.is_thai_year"
31
+ #year-overlay-value="{ value }"
32
+ >
33
+ {{ value + 543 }}
34
+ </template>
35
+ <template #dp-input="{ value: innerValue }">
36
+ <Input
37
+ v-if="!readMode"
38
+ :trailing-icon="innerValue ? void 0 : 'i-heroicons-calendar-days'"
39
+ type="text"
40
+ :disabled="wrapperProps.disabled"
41
+ :model-value="innerValue"
42
+ :placeholder="wrapperProps.placeholder"
43
+ :readonly="true"
44
44
  :ui="{
45
45
  base: 'cursor-pointer select-none',
46
46
  trailingIcon: 'cursor-pointer'
47
- }"
48
- />
49
- <div
50
- v-else
51
- class="cursor-pointer p-1 hover:bg-gray-100"
52
- :class="classReadMode"
53
- >
54
- {{ innerValue || "none" }}
55
- </div>
56
- </template>
57
- <template #clear-icon="{ clear }">
58
- <Icon
59
- v-if="clearable"
60
- :name="clearIcon"
47
+ }"
48
+ />
49
+ <div
50
+ v-else
51
+ class="cursor-pointer p-1 hover:bg-gray-100"
52
+ :class="classReadMode"
53
+ >
54
+ {{ innerValue || "none" }}
55
+ </div>
56
+ </template>
57
+ <template #clear-icon="{ clear }">
58
+ <Icon
59
+ v-if="clearable"
60
+ :name="clearIcon"
61
61
  :class="theme.clearIcon({
62
62
  class: [ui?.clearIcon]
63
- })"
64
- @click.stop="clear"
65
- />
66
- </template>
67
- </Datepicker>
68
- </FieldWrapper>
63
+ })"
64
+ @click.stop="clear"
65
+ />
66
+ </template>
67
+ </Datepicker>
68
+ </FieldWrapper>
69
69
  </template>
70
70
 
71
71
  <script setup>