@jari-ace/element-plus-component 0.1.0 → 0.1.6

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 (148) hide show
  1. package/README.md +18 -18
  2. package/dist/components/enumPicker/index.d.ts +4 -0
  3. package/dist/components/enumPicker/index.d.ts.map +1 -0
  4. package/dist/components/enumPicker/index.js +4 -0
  5. package/dist/components/enumPicker/index.js.map +1 -0
  6. package/dist/components/enumPicker/src/EnumPicker.vue.d.ts +29 -0
  7. package/dist/components/enumPicker/src/EnumPicker.vue.d.ts.map +1 -0
  8. package/dist/components/enumPicker/src/EnumPicker.vue.js +140 -0
  9. package/dist/components/enumPicker/src/EnumPicker.vue.js.map +1 -0
  10. package/dist/components/form/JaForm.vue.d.ts +23 -126
  11. package/dist/components/form/JaForm.vue.d.ts.map +1 -1
  12. package/dist/components/form/JaForm.vue.js +127 -192
  13. package/dist/components/form/JaForm.vue.js.map +1 -1
  14. package/dist/components/formItem/JaFormItem.vue.d.ts +12 -12
  15. package/dist/components/index.d.ts +1 -0
  16. package/dist/components/index.d.ts.map +1 -1
  17. package/dist/components/index.js +1 -0
  18. package/dist/components/index.js.map +1 -1
  19. package/dist/components/rolePicker/baseRolePicker.vue.d.ts.map +1 -1
  20. package/dist/components/rolePicker/baseRolePicker.vue.js +1 -0
  21. package/dist/components/rolePicker/baseRolePicker.vue.js.map +1 -1
  22. package/dist/components/userTag/UserInfoTag.vue.d.ts +1 -1
  23. package/dist/hooks/useBackendValidations.d.ts +7 -1
  24. package/dist/hooks/useBackendValidations.d.ts.map +1 -1
  25. package/dist/hooks/useBackendValidations.js +21 -2
  26. package/dist/hooks/useBackendValidations.js.map +1 -1
  27. package/dist/hooks/useBridage.d.ts +3 -3
  28. package/dist/hooks/useBridage.d.ts.map +1 -1
  29. package/dist/hooks/useBridage.js +29 -22
  30. package/dist/hooks/useBridage.js.map +1 -1
  31. package/lib/index.css +1 -1
  32. package/lib/index.js +1437 -1283
  33. package/lib/index.umd.cjs +2 -2
  34. package/package.json +61 -61
  35. package/packages/components/autoComplete/JaAutoComplete.vue +47 -47
  36. package/packages/components/autoComplete/index.ts +5 -5
  37. package/packages/components/avatar/JaAvatar.vue +126 -126
  38. package/packages/components/avatar/avatarToken.ts +11 -11
  39. package/packages/components/avatar/defaultImg.ts +14 -14
  40. package/packages/components/avatar/index.ts +7 -7
  41. package/packages/components/button/JaButton.vue +51 -51
  42. package/packages/components/button/index.ts +4 -4
  43. package/packages/components/channelPicker/index.ts +7 -7
  44. package/packages/components/channelPicker/src/ChannelPicker.vue +43 -43
  45. package/packages/components/channelPicker/src/JaChannelPicker.vue +42 -42
  46. package/packages/components/checkbox/JaCheckbox.vue +73 -73
  47. package/packages/components/checkbox/index.ts +4 -4
  48. package/packages/components/checkboxGroup/JaCheckboxGroup.vue +45 -45
  49. package/packages/components/checkboxGroup/index.ts +4 -4
  50. package/packages/components/customGroupTree/index.ts +10 -10
  51. package/packages/components/customGroupTree/src/customGroupTree.vue +91 -91
  52. package/packages/components/datePicker/JaDatePicker.vue +52 -52
  53. package/packages/components/datePicker/index.ts +4 -4
  54. package/packages/components/departmentPicker/index.ts +4 -4
  55. package/packages/components/departmentPicker/src/DepartmentPicker.vue +107 -107
  56. package/packages/components/departmentPicker/src/consts.ts +2 -2
  57. package/packages/components/departmentTree/index.ts +10 -10
  58. package/packages/components/departmentTree/src/departmentTree.vue +135 -135
  59. package/packages/components/dropdownButton/JaDropdownButton.vue +59 -59
  60. package/packages/components/dropdownButton/index.ts +4 -4
  61. package/packages/components/enumList/EnumListInput.vue +107 -107
  62. package/packages/components/enumList/JaEnumList.vue +39 -39
  63. package/packages/components/enumList/index.ts +7 -7
  64. package/packages/components/enumPicker/index.ts +5 -0
  65. package/packages/components/enumPicker/src/EnumPicker.vue +103 -0
  66. package/packages/components/form/JaForm.vue +186 -126
  67. package/packages/components/form/index.ts +5 -5
  68. package/packages/components/form/types.ts +4 -4
  69. package/packages/components/formItem/JaFormItem.vue +68 -68
  70. package/packages/components/formItem/index.ts +4 -4
  71. package/packages/components/index.ts +34 -33
  72. package/packages/components/input/JaInput.vue +143 -143
  73. package/packages/components/input/index.ts +4 -4
  74. package/packages/components/inputI18n/I18nBundleEditor.vue +76 -76
  75. package/packages/components/inputI18n/InputI18n.vue +142 -142
  76. package/packages/components/inputI18n/JaInputI18n.vue +50 -50
  77. package/packages/components/inputI18n/index.ts +8 -8
  78. package/packages/components/inputNumber/JaInputNumber.vue +98 -98
  79. package/packages/components/inputNumber/index.ts +4 -4
  80. package/packages/components/mapItemList/JaMapItemList.vue +35 -35
  81. package/packages/components/mapItemList/MapItemListInput.vue +191 -191
  82. package/packages/components/mapItemList/index.ts +7 -7
  83. package/packages/components/numberList/JaNumberList.vue +36 -36
  84. package/packages/components/numberList/NumberListInput.vue +111 -111
  85. package/packages/components/numberList/index.ts +7 -7
  86. package/packages/components/properyPicker/JaPropertyPicker.vue +38 -38
  87. package/packages/components/properyPicker/PropertyPicker.vue +314 -314
  88. package/packages/components/properyPicker/index.ts +7 -7
  89. package/packages/components/radioGroup/JaRadioGroup.vue +50 -50
  90. package/packages/components/radioGroup/index.ts +4 -4
  91. package/packages/components/rolePicker/RoleEditor.vue +129 -129
  92. package/packages/components/rolePicker/RolePicker.vue +44 -44
  93. package/packages/components/rolePicker/RolePickerRaw.vue +56 -56
  94. package/packages/components/rolePicker/baseRolePicker.vue +87 -86
  95. package/packages/components/rolePicker/index.ts +10 -10
  96. package/packages/components/scrollbar/Scrollbar.vue +89 -89
  97. package/packages/components/scrollbar/index.ts +5 -5
  98. package/packages/components/scrollbar/utils.ts +17 -17
  99. package/packages/components/select/JaSelect.vue +48 -48
  100. package/packages/components/select/index.ts +4 -4
  101. package/packages/components/stringList/JaStringList.vue +36 -36
  102. package/packages/components/stringList/StringListInput.vue +96 -96
  103. package/packages/components/stringList/index.ts +7 -7
  104. package/packages/components/switch/JaSwitch.vue +50 -50
  105. package/packages/components/switch/index.ts +4 -4
  106. package/packages/components/timePicker/JaTimePicker.vue +52 -52
  107. package/packages/components/timePicker/index.ts +5 -5
  108. package/packages/components/tip/index.ts +4 -4
  109. package/packages/components/tip/src/AceTip.vue +43 -43
  110. package/packages/components/upload/index.ts +6 -6
  111. package/packages/components/upload/src/Upload.vue +25 -25
  112. package/packages/components/upload/src/type.ts +3 -3
  113. package/packages/components/userGroupPicker/index.ts +4 -4
  114. package/packages/components/userGroupPicker/src/UserGroupPicker.vue +94 -94
  115. package/packages/components/userGroupTree/index.ts +10 -10
  116. package/packages/components/userGroupTree/src/userGroupTree.vue +149 -149
  117. package/packages/components/userPicker/index.ts +10 -10
  118. package/packages/components/userPicker/src/CustomGroupManager.vue +189 -189
  119. package/packages/components/userPicker/src/JaUserList.vue +283 -283
  120. package/packages/components/userPicker/src/JaUserPicker.vue +37 -37
  121. package/packages/components/userPicker/src/UserPicker.vue +366 -366
  122. package/packages/components/userSelectDialog/index.ts +6 -6
  123. package/packages/components/userSelectDialog/src/userSelectDialog.vue +447 -447
  124. package/packages/components/userTag/UserInfoTag.vue +397 -397
  125. package/packages/components/userTag/index.ts +6 -6
  126. package/packages/components/userTag/sharedAxios.ts +8 -8
  127. package/packages/directives/auth/index.ts +41 -41
  128. package/packages/directives/autofocus/index.ts +29 -29
  129. package/packages/directives/index.ts +10 -10
  130. package/packages/directives/shortcut/index.ts +192 -192
  131. package/packages/hooks/useAppInstances.ts +34 -34
  132. package/packages/hooks/useBackendValidations.ts +34 -8
  133. package/packages/hooks/useBridage.ts +157 -148
  134. package/packages/hooks/useDateTimeShortCuts.ts +65 -65
  135. package/packages/hooks/useTreeData.ts +45 -45
  136. package/packages/hooks/useUserRefQuery.ts +222 -222
  137. package/packages/index.ts +21 -21
  138. package/packages/list.json +7 -7
  139. package/packages/types/custom.d.ts +13 -13
  140. package/packages/types/window.d.ts +16 -16
  141. package/packages/utils/install.ts +43 -43
  142. package/packages/utils/objectUtils.ts +31 -31
  143. package/theme-style/fonts/iconfont.json +5196 -5196
  144. package/theme-style/index.scss +10 -10
  145. package/theme-style/styles/element-plus-var.scss +1419 -1419
  146. package/theme-style/styles/iconfont.css +2979 -2979
  147. package/theme-style/styles/theme-var.scss +72 -72
  148. 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>