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