@jari-ace/element-plus-component 0.0.2 → 0.1.1

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 (128) hide show
  1. package/README.md +18 -18
  2. package/dist/components/rolePicker/RoleEditor.vue.js +2 -2
  3. package/dist/components/rolePicker/RoleEditor.vue.js.map +1 -1
  4. package/dist/components/tip/index.d.ts +1 -35
  5. package/dist/components/tip/index.d.ts.map +1 -1
  6. package/dist/components/upload/index.d.ts +1 -1
  7. package/dist/components/upload/index.d.ts.map +1 -1
  8. package/dist/hooks/useBridage.d.ts +3 -3
  9. package/dist/hooks/useBridage.d.ts.map +1 -1
  10. package/dist/hooks/useBridage.js +29 -22
  11. package/dist/hooks/useBridage.js.map +1 -1
  12. package/dist/hooks/useUserRefQuery.d.ts +2 -2
  13. package/lib/index.css +1 -1
  14. package/lib/index.js +148 -141
  15. package/lib/index.umd.cjs +2 -2
  16. package/package.json +61 -61
  17. package/packages/components/autoComplete/JaAutoComplete.vue +47 -47
  18. package/packages/components/autoComplete/index.ts +5 -5
  19. package/packages/components/avatar/JaAvatar.vue +126 -126
  20. package/packages/components/avatar/avatarToken.ts +11 -11
  21. package/packages/components/avatar/defaultImg.ts +14 -14
  22. package/packages/components/avatar/index.ts +7 -7
  23. package/packages/components/button/JaButton.vue +51 -51
  24. package/packages/components/button/index.ts +4 -4
  25. package/packages/components/channelPicker/index.ts +7 -7
  26. package/packages/components/channelPicker/src/ChannelPicker.vue +43 -43
  27. package/packages/components/channelPicker/src/JaChannelPicker.vue +42 -42
  28. package/packages/components/checkbox/JaCheckbox.vue +73 -73
  29. package/packages/components/checkbox/index.ts +4 -4
  30. package/packages/components/checkboxGroup/JaCheckboxGroup.vue +45 -45
  31. package/packages/components/checkboxGroup/index.ts +4 -4
  32. package/packages/components/customGroupTree/index.ts +10 -10
  33. package/packages/components/customGroupTree/src/customGroupTree.vue +91 -91
  34. package/packages/components/datePicker/JaDatePicker.vue +52 -52
  35. package/packages/components/datePicker/index.ts +4 -4
  36. package/packages/components/departmentPicker/index.ts +4 -4
  37. package/packages/components/departmentPicker/src/DepartmentPicker.vue +107 -107
  38. package/packages/components/departmentPicker/src/consts.ts +2 -2
  39. package/packages/components/departmentTree/index.ts +10 -10
  40. package/packages/components/departmentTree/src/departmentTree.vue +135 -135
  41. package/packages/components/dropdownButton/JaDropdownButton.vue +59 -59
  42. package/packages/components/dropdownButton/index.ts +4 -4
  43. package/packages/components/enumList/EnumListInput.vue +107 -107
  44. package/packages/components/enumList/JaEnumList.vue +39 -39
  45. package/packages/components/enumList/index.ts +7 -7
  46. package/packages/components/form/JaForm.vue +126 -126
  47. package/packages/components/form/index.ts +5 -5
  48. package/packages/components/form/types.ts +4 -4
  49. package/packages/components/formItem/JaFormItem.vue +68 -68
  50. package/packages/components/formItem/index.ts +4 -4
  51. package/packages/components/index.ts +33 -33
  52. package/packages/components/input/JaInput.vue +143 -143
  53. package/packages/components/input/index.ts +4 -4
  54. package/packages/components/inputI18n/I18nBundleEditor.vue +76 -76
  55. package/packages/components/inputI18n/InputI18n.vue +142 -142
  56. package/packages/components/inputI18n/JaInputI18n.vue +50 -50
  57. package/packages/components/inputI18n/index.ts +8 -8
  58. package/packages/components/inputNumber/JaInputNumber.vue +98 -98
  59. package/packages/components/inputNumber/index.ts +4 -4
  60. package/packages/components/mapItemList/JaMapItemList.vue +35 -35
  61. package/packages/components/mapItemList/MapItemListInput.vue +191 -191
  62. package/packages/components/mapItemList/index.ts +7 -7
  63. package/packages/components/numberList/JaNumberList.vue +36 -36
  64. package/packages/components/numberList/NumberListInput.vue +111 -111
  65. package/packages/components/numberList/index.ts +7 -7
  66. package/packages/components/properyPicker/JaPropertyPicker.vue +38 -38
  67. package/packages/components/properyPicker/PropertyPicker.vue +314 -314
  68. package/packages/components/properyPicker/index.ts +7 -7
  69. package/packages/components/radioGroup/JaRadioGroup.vue +50 -50
  70. package/packages/components/radioGroup/index.ts +4 -4
  71. package/packages/components/rolePicker/RoleEditor.vue +129 -129
  72. package/packages/components/rolePicker/RolePicker.vue +44 -44
  73. package/packages/components/rolePicker/RolePickerRaw.vue +56 -56
  74. package/packages/components/rolePicker/baseRolePicker.vue +86 -86
  75. package/packages/components/rolePicker/index.ts +10 -10
  76. package/packages/components/scrollbar/Scrollbar.vue +89 -89
  77. package/packages/components/scrollbar/index.ts +5 -5
  78. package/packages/components/scrollbar/utils.ts +17 -17
  79. package/packages/components/select/JaSelect.vue +48 -48
  80. package/packages/components/select/index.ts +4 -4
  81. package/packages/components/stringList/JaStringList.vue +36 -36
  82. package/packages/components/stringList/StringListInput.vue +96 -96
  83. package/packages/components/stringList/index.ts +7 -7
  84. package/packages/components/switch/JaSwitch.vue +50 -50
  85. package/packages/components/switch/index.ts +4 -4
  86. package/packages/components/timePicker/JaTimePicker.vue +52 -52
  87. package/packages/components/timePicker/index.ts +5 -5
  88. package/packages/components/tip/index.ts +4 -4
  89. package/packages/components/tip/src/AceTip.vue +43 -43
  90. package/packages/components/upload/index.ts +6 -6
  91. package/packages/components/upload/src/Upload.vue +25 -25
  92. package/packages/components/upload/src/type.ts +3 -3
  93. package/packages/components/userGroupPicker/index.ts +4 -4
  94. package/packages/components/userGroupPicker/src/UserGroupPicker.vue +94 -94
  95. package/packages/components/userGroupTree/index.ts +10 -10
  96. package/packages/components/userGroupTree/src/userGroupTree.vue +149 -149
  97. package/packages/components/userPicker/index.ts +10 -10
  98. package/packages/components/userPicker/src/CustomGroupManager.vue +189 -189
  99. package/packages/components/userPicker/src/JaUserList.vue +283 -283
  100. package/packages/components/userPicker/src/JaUserPicker.vue +37 -37
  101. package/packages/components/userPicker/src/UserPicker.vue +366 -366
  102. package/packages/components/userSelectDialog/index.ts +6 -6
  103. package/packages/components/userSelectDialog/src/userSelectDialog.vue +447 -447
  104. package/packages/components/userTag/UserInfoTag.vue +397 -397
  105. package/packages/components/userTag/index.ts +6 -6
  106. package/packages/components/userTag/sharedAxios.ts +8 -8
  107. package/packages/directives/auth/index.ts +41 -41
  108. package/packages/directives/autofocus/index.ts +29 -29
  109. package/packages/directives/index.ts +10 -10
  110. package/packages/directives/shortcut/index.ts +192 -192
  111. package/packages/hooks/useAppInstances.ts +34 -34
  112. package/packages/hooks/useBackendValidations.ts +55 -55
  113. package/packages/hooks/useBridage.ts +157 -148
  114. package/packages/hooks/useDateTimeShortCuts.ts +65 -65
  115. package/packages/hooks/useTreeData.ts +45 -45
  116. package/packages/hooks/useUserRefQuery.ts +222 -222
  117. package/packages/index.ts +21 -21
  118. package/packages/list.json +7 -7
  119. package/packages/types/custom.d.ts +13 -13
  120. package/packages/types/window.d.ts +16 -16
  121. package/packages/utils/install.ts +43 -43
  122. package/packages/utils/objectUtils.ts +31 -31
  123. package/theme-style/fonts/iconfont.json +5196 -5196
  124. package/theme-style/index.scss +10 -10
  125. package/theme-style/styles/element-plus-var.scss +1419 -1419
  126. package/theme-style/styles/iconfont.css +2979 -2979
  127. package/theme-style/styles/theme-var.scss +72 -72
  128. package/theme-style/styles/transition.scss +122 -122
@@ -1,35 +1,35 @@
1
- <script setup lang="ts">
2
- import {inject, watch, ref} from "vue";
3
- import {getValue, setValue} from "../../utils/objectUtils";
4
- import type {ValidationInstance} from "../../hooks/useBackendValidations";
5
- import MapItemListInput from "./MapItemListInput.vue";
6
-
7
- type ValueType = string | number | boolean | undefined;
8
- const model = inject('aceFormModel') as Record<string, never>
9
- const prop = inject('aceFormItemProp') as string
10
- const validator = inject('aceFormValidator') as ValidationInstance
11
- const emit = defineEmits<{
12
- change: [value: Record<string, ValueType>]
13
- }>()
14
-
15
- function onChange(value: Record<string, string>) {
16
- validator.removeFieldError(prop)
17
- setValue(model.formData, prop, mv.value);
18
- emit('change', value)
19
- }
20
-
21
- const mv = ref(getValue(model.formData, prop) as Record<string, ValueType> ?? {"": ""});
22
- watch(() => model.formData, () => {
23
- mv.value = getValue(model.formData, prop) as Record<string, ValueType> ?? {"": ""};
24
- })
25
- </script>
26
-
27
- <template>
28
- <map-item-list-input v-model="mv"
29
- @change="onChange"
30
- v-bind="$attrs"/>
31
- </template>
32
-
33
- <style scoped lang="scss">
34
-
35
- </style>
1
+ <script setup lang="ts">
2
+ import {inject, watch, ref} from "vue";
3
+ import {getValue, setValue} from "../../utils/objectUtils";
4
+ import type {ValidationInstance} from "../../hooks/useBackendValidations";
5
+ import MapItemListInput from "./MapItemListInput.vue";
6
+
7
+ type ValueType = string | number | boolean | undefined;
8
+ const model = inject('aceFormModel') as Record<string, never>
9
+ const prop = inject('aceFormItemProp') as string
10
+ const validator = inject('aceFormValidator') as ValidationInstance
11
+ const emit = defineEmits<{
12
+ change: [value: Record<string, ValueType>]
13
+ }>()
14
+
15
+ function onChange(value: Record<string, string>) {
16
+ validator.removeFieldError(prop)
17
+ setValue(model.formData, prop, mv.value);
18
+ emit('change', value)
19
+ }
20
+
21
+ const mv = ref(getValue(model.formData, prop) as Record<string, ValueType> ?? {"": ""});
22
+ watch(() => model.formData, () => {
23
+ mv.value = getValue(model.formData, prop) as Record<string, ValueType> ?? {"": ""};
24
+ })
25
+ </script>
26
+
27
+ <template>
28
+ <map-item-list-input v-model="mv"
29
+ @change="onChange"
30
+ v-bind="$attrs"/>
31
+ </template>
32
+
33
+ <style scoped lang="scss">
34
+
35
+ </style>
@@ -1,191 +1,191 @@
1
- <script setup lang="ts">
2
- import {Minus, Plus} from "@element-plus/icons-vue";
3
- import {watch, ref, onBeforeMount, type Component} from "vue";
4
- import {ElButton, ElDatePicker, ElInput, ElInputNumber, ElSelect, ElSwitch} from "element-plus";
5
-
6
- type ValueType = string | number | boolean | undefined;
7
-
8
- const props = withDefaults(defineProps<{
9
- modelValue: Record<string, ValueType>,
10
- enumValues?: Record<string, string>,
11
- valueType?: 'String' | 'Integer' | 'Long' | 'Decimal' | 'Enum' | 'Boolean' | 'DATE' | 'TIMESTAMP',
12
- size?: 'small' | 'large' | 'default'
13
- }>(), {
14
- valueType: 'String'
15
- })
16
- const emits = defineEmits(["update:modelValue", "change"])
17
-
18
- function removeValue(index: number) {
19
- values.value?.splice(index, 1);
20
- }
21
-
22
- function addValue() {
23
- values.value?.push({k: ""})
24
- }
25
-
26
- const values = ref<{
27
- k: string,
28
- v?: ValueType
29
- }[]>([])
30
-
31
- let initializing = false;
32
- let internalChangedValue = false;
33
-
34
- let valueCompType = ref<Component>();
35
- let valueCompProps = ref<object>({});
36
-
37
- function setupValueComponentType() {
38
- console.log('map item value comp type:', props.valueType);
39
- switch (props.valueType) {
40
- case "String":
41
- valueCompType.value = ElInput;
42
- valueCompProps.value = {}
43
- break;
44
- case "Integer":
45
- case "Long":
46
- valueCompType.value = ElInputNumber;
47
- break;
48
- case "Decimal":
49
- valueCompType.value = ElInputNumber;
50
- valueCompProps.value = {
51
- precision: 2,
52
- step: 0.1
53
- }
54
- break;
55
- case "Enum":
56
- valueCompType.value = ElSelect;
57
- break;
58
- case "Boolean":
59
- valueCompType.value = ElSwitch;
60
- break;
61
- case "DATE":
62
- valueCompType.value = ElDatePicker;
63
- valueCompProps.value = {
64
- type: "date"
65
- }
66
- break;
67
- case "TIMESTAMP":
68
- valueCompType.value = ElDatePicker;
69
- valueCompProps.value = {
70
- type: "datetime"
71
- }
72
- break;
73
- }
74
- }
75
-
76
- onBeforeMount(() => {
77
- initializeModelValue(props.modelValue)
78
- setupValueComponentType();
79
- })
80
-
81
- function initializeModelValue(n: Record<string, ValueType>) {
82
- if (internalChangedValue) {
83
- internalChangedValue = false;
84
- return;
85
- }
86
- if (n) {
87
- initializing = true;
88
- const keys = Object.keys(n);
89
- values.value = keys.map(k => {
90
- return {k: k, v: n[k]}
91
- });
92
- if (values.value.length == 0) {
93
- values.value.push({k: ""});
94
- }
95
- } else {
96
- values.value = [{k: ""}]
97
- }
98
- }
99
-
100
- watch(() => props.modelValue, (n: Record<string, ValueType>) => {
101
- initializeModelValue(n);
102
- }, {
103
- deep: true
104
- })
105
-
106
- watch(() => values.value, () => {
107
- if (initializing) {
108
- initializing = false;
109
- return;
110
- }
111
- internalChangedValue = true;
112
- const newValue = values.value?.filter(v => v.k && v.v)
113
- .reduce((r, c) => {
114
- r[c.k] = c.v;
115
- return r;
116
- }, {} as Record<string, ValueType>)
117
- emits("update:modelValue", newValue)
118
- emits("change", newValue)
119
- }, {deep: true})
120
-
121
- watch(() => props.valueType, () => {
122
- setupValueComponentType();
123
- })
124
- </script>
125
-
126
- <template>
127
- <div style="width: 100%;" class="ja-enum-list">
128
- <div class="ja-input-box" v-for="(v, index) in values" :key="index">
129
- <el-input v-model="v.k" :size="size" placeholder="键"></el-input>
130
- <div class="splitter">
131
- <el-text>:</el-text>
132
- </div>
133
- <component v-model="v.v" :size="size" placeholder="值" :is="valueCompType"
134
- v-bind="valueCompProps">
135
- <template v-if="props.valueType == 'Enum'">
136
- <el-option v-for="k in Object.keys(props.enumValues?? {})" :key="k"
137
- :label="k" :value="props.enumValues ? props.enumValues[k]: ''"
138
- ></el-option>
139
- </template>
140
- </component>
141
- <el-tooltip content="删除" placement="right">
142
- <div class="el-input-group__append" v-show="index < (values?.length ?? 0) - 1">
143
- <el-button link :icon="Minus" @click="removeValue(index)" :size="size">
144
- </el-button>
145
- </div>
146
- </el-tooltip>
147
- <el-tooltip content="添加" placement="right">
148
- <div class="el-input-group__append" v-show="index === (values?.length ?? 0) - 1">
149
- <el-button @click="addValue()" :size="size"
150
- link :icon="Plus">
151
- </el-button>
152
- </div>
153
- </el-tooltip>
154
- </div>
155
- </div>
156
- </template>
157
-
158
- <style scoped lang="scss">
159
- .ja-enum-list {
160
- display: flex;
161
- flex-direction: column;
162
- gap: 8px;
163
-
164
- .ja-input-box {
165
- display: flex;
166
- gap: 4px;
167
-
168
- .el-input-group__append {
169
- flex: none;
170
- margin-left: 0 !important;
171
- }
172
-
173
- .el-select {
174
- flex: auto;
175
- }
176
-
177
- .el-input-number {
178
- flex: auto;
179
- width: 100% !important;
180
- }
181
-
182
- .el-input {
183
- flex: auto;
184
- }
185
-
186
- .splitter {
187
- flex: none;
188
- }
189
- }
190
- }
191
- </style>
1
+ <script setup lang="ts">
2
+ import {Minus, Plus} from "@element-plus/icons-vue";
3
+ import {watch, ref, onBeforeMount, type Component} from "vue";
4
+ import {ElButton, ElDatePicker, ElInput, ElInputNumber, ElSelect, ElSwitch} from "element-plus";
5
+
6
+ type ValueType = string | number | boolean | undefined;
7
+
8
+ const props = withDefaults(defineProps<{
9
+ modelValue: Record<string, ValueType>,
10
+ enumValues?: Record<string, string>,
11
+ valueType?: 'String' | 'Integer' | 'Long' | 'Decimal' | 'Enum' | 'Boolean' | 'DATE' | 'TIMESTAMP',
12
+ size?: 'small' | 'large' | 'default'
13
+ }>(), {
14
+ valueType: 'String'
15
+ })
16
+ const emits = defineEmits(["update:modelValue", "change"])
17
+
18
+ function removeValue(index: number) {
19
+ values.value?.splice(index, 1);
20
+ }
21
+
22
+ function addValue() {
23
+ values.value?.push({k: ""})
24
+ }
25
+
26
+ const values = ref<{
27
+ k: string,
28
+ v?: ValueType
29
+ }[]>([])
30
+
31
+ let initializing = false;
32
+ let internalChangedValue = false;
33
+
34
+ let valueCompType = ref<Component>();
35
+ let valueCompProps = ref<object>({});
36
+
37
+ function setupValueComponentType() {
38
+ console.log('map item value comp type:', props.valueType);
39
+ switch (props.valueType) {
40
+ case "String":
41
+ valueCompType.value = ElInput;
42
+ valueCompProps.value = {}
43
+ break;
44
+ case "Integer":
45
+ case "Long":
46
+ valueCompType.value = ElInputNumber;
47
+ break;
48
+ case "Decimal":
49
+ valueCompType.value = ElInputNumber;
50
+ valueCompProps.value = {
51
+ precision: 2,
52
+ step: 0.1
53
+ }
54
+ break;
55
+ case "Enum":
56
+ valueCompType.value = ElSelect;
57
+ break;
58
+ case "Boolean":
59
+ valueCompType.value = ElSwitch;
60
+ break;
61
+ case "DATE":
62
+ valueCompType.value = ElDatePicker;
63
+ valueCompProps.value = {
64
+ type: "date"
65
+ }
66
+ break;
67
+ case "TIMESTAMP":
68
+ valueCompType.value = ElDatePicker;
69
+ valueCompProps.value = {
70
+ type: "datetime"
71
+ }
72
+ break;
73
+ }
74
+ }
75
+
76
+ onBeforeMount(() => {
77
+ initializeModelValue(props.modelValue)
78
+ setupValueComponentType();
79
+ })
80
+
81
+ function initializeModelValue(n: Record<string, ValueType>) {
82
+ if (internalChangedValue) {
83
+ internalChangedValue = false;
84
+ return;
85
+ }
86
+ if (n) {
87
+ initializing = true;
88
+ const keys = Object.keys(n);
89
+ values.value = keys.map(k => {
90
+ return {k: k, v: n[k]}
91
+ });
92
+ if (values.value.length == 0) {
93
+ values.value.push({k: ""});
94
+ }
95
+ } else {
96
+ values.value = [{k: ""}]
97
+ }
98
+ }
99
+
100
+ watch(() => props.modelValue, (n: Record<string, ValueType>) => {
101
+ initializeModelValue(n);
102
+ }, {
103
+ deep: true
104
+ })
105
+
106
+ watch(() => values.value, () => {
107
+ if (initializing) {
108
+ initializing = false;
109
+ return;
110
+ }
111
+ internalChangedValue = true;
112
+ const newValue = values.value?.filter(v => v.k && v.v)
113
+ .reduce((r, c) => {
114
+ r[c.k] = c.v;
115
+ return r;
116
+ }, {} as Record<string, ValueType>)
117
+ emits("update:modelValue", newValue)
118
+ emits("change", newValue)
119
+ }, {deep: true})
120
+
121
+ watch(() => props.valueType, () => {
122
+ setupValueComponentType();
123
+ })
124
+ </script>
125
+
126
+ <template>
127
+ <div style="width: 100%;" class="ja-enum-list">
128
+ <div class="ja-input-box" v-for="(v, index) in values" :key="index">
129
+ <el-input v-model="v.k" :size="size" placeholder="键"></el-input>
130
+ <div class="splitter">
131
+ <el-text>:</el-text>
132
+ </div>
133
+ <component v-model="v.v" :size="size" placeholder="值" :is="valueCompType"
134
+ v-bind="valueCompProps">
135
+ <template v-if="props.valueType == 'Enum'">
136
+ <el-option v-for="k in Object.keys(props.enumValues?? {})" :key="k"
137
+ :label="k" :value="props.enumValues ? props.enumValues[k]: ''"
138
+ ></el-option>
139
+ </template>
140
+ </component>
141
+ <el-tooltip content="删除" placement="right">
142
+ <div class="el-input-group__append" v-show="index < (values?.length ?? 0) - 1">
143
+ <el-button link :icon="Minus" @click="removeValue(index)" :size="size">
144
+ </el-button>
145
+ </div>
146
+ </el-tooltip>
147
+ <el-tooltip content="添加" placement="right">
148
+ <div class="el-input-group__append" v-show="index === (values?.length ?? 0) - 1">
149
+ <el-button @click="addValue()" :size="size"
150
+ link :icon="Plus">
151
+ </el-button>
152
+ </div>
153
+ </el-tooltip>
154
+ </div>
155
+ </div>
156
+ </template>
157
+
158
+ <style scoped lang="scss">
159
+ .ja-enum-list {
160
+ display: flex;
161
+ flex-direction: column;
162
+ gap: 8px;
163
+
164
+ .ja-input-box {
165
+ display: flex;
166
+ gap: 4px;
167
+
168
+ .el-input-group__append {
169
+ flex: none;
170
+ margin-left: 0 !important;
171
+ }
172
+
173
+ .el-select {
174
+ flex: auto;
175
+ }
176
+
177
+ .el-input-number {
178
+ flex: auto;
179
+ width: 100% !important;
180
+ }
181
+
182
+ .el-input {
183
+ flex: auto;
184
+ }
185
+
186
+ .splitter {
187
+ flex: none;
188
+ }
189
+ }
190
+ }
191
+ </style>
@@ -1,7 +1,7 @@
1
- import {type SFCWithInstall, withInstall} from "../../utils/install";
2
- import MapItemList from "./JaMapItemList.vue";
3
- import MapItemListInput from "./MapItemListInput.vue";
4
-
5
- export const JaMapItemList: SFCWithInstall<typeof MapItemList> = withInstall(MapItemList);
6
-
7
- export const JaMapItemListRaw: SFCWithInstall<typeof MapItemListInput> = withInstall(MapItemListInput);
1
+ import {type SFCWithInstall, withInstall} from "../../utils/install";
2
+ import MapItemList from "./JaMapItemList.vue";
3
+ import MapItemListInput from "./MapItemListInput.vue";
4
+
5
+ export const JaMapItemList: SFCWithInstall<typeof MapItemList> = withInstall(MapItemList);
6
+
7
+ export const JaMapItemListRaw: SFCWithInstall<typeof MapItemListInput> = withInstall(MapItemListInput);
@@ -1,36 +1,36 @@
1
- <script setup lang="ts">
2
- import {inject, watch, ref} from "vue";
3
- import {getValue, setValue} from "../../utils/objectUtils";
4
- import type {ValidationInstance} from "../../hooks/useBackendValidations";
5
- import NumberListInput from "./NumberListInput.vue";
6
-
7
- const model = inject('aceFormModel') as Record<string, never>
8
- const prop = inject('aceFormItemProp') as string
9
- const validator = inject('aceFormValidator') as ValidationInstance
10
- const emit = defineEmits<{
11
- change: [value: number[]]
12
- }>()
13
-
14
- function onChange(value: number[]) {
15
- validator.removeFieldError(prop)
16
- setValue(model.formData, prop, mv.value);
17
- emit('change', value)
18
- }
19
-
20
- const mv = ref(getValue(model.formData, prop) as number[] ?? [0]);
21
- watch(() => model.formData, () => {
22
- mv.value = getValue(model.formData, prop) as number[] ?? [0]
23
- }, {
24
- deep: true
25
- })
26
- </script>
27
-
28
- <template>
29
- <number-list-input v-model="mv"
30
- @change="onChange"
31
- v-bind="$attrs"/>
32
- </template>
33
-
34
- <style scoped lang="scss">
35
-
36
- </style>
1
+ <script setup lang="ts">
2
+ import {inject, watch, ref} from "vue";
3
+ import {getValue, setValue} from "../../utils/objectUtils";
4
+ import type {ValidationInstance} from "../../hooks/useBackendValidations";
5
+ import NumberListInput from "./NumberListInput.vue";
6
+
7
+ const model = inject('aceFormModel') as Record<string, never>
8
+ const prop = inject('aceFormItemProp') as string
9
+ const validator = inject('aceFormValidator') as ValidationInstance
10
+ const emit = defineEmits<{
11
+ change: [value: number[]]
12
+ }>()
13
+
14
+ function onChange(value: number[]) {
15
+ validator.removeFieldError(prop)
16
+ setValue(model.formData, prop, mv.value);
17
+ emit('change', value)
18
+ }
19
+
20
+ const mv = ref(getValue(model.formData, prop) as number[] ?? [0]);
21
+ watch(() => model.formData, () => {
22
+ mv.value = getValue(model.formData, prop) as number[] ?? [0]
23
+ }, {
24
+ deep: true
25
+ })
26
+ </script>
27
+
28
+ <template>
29
+ <number-list-input v-model="mv"
30
+ @change="onChange"
31
+ v-bind="$attrs"/>
32
+ </template>
33
+
34
+ <style scoped lang="scss">
35
+
36
+ </style>