resolver-egretimp-plus 0.1.119 → 0.1.121

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 (225) hide show
  1. package/dist/h5/index.js +18 -18
  2. package/dist/web/index.js +11 -11
  3. package/package.json +1 -1
  4. package/src/components/options/OptionsDefault.vue +0 -1
  5. package/src/components/packages-web/CustomComponentCycle.vue +38 -33
  6. package/src/components/packages-web/CustomComponentCycleTabPane.vue +40 -33
  7. package/src/components/packages-web/CustomComponentPlain.vue +6 -5
  8. package/src/components/packages-web/CustomComponentTable.jsx +48 -40
  9. package/src/components/packages-web/ElInput copy.jsx +0 -1
  10. package/src/components/packages-web/ElInput.jsx +0 -1
  11. package/src/config.js +2 -0
  12. package/src/hooks/pageConfig.js +10 -4
  13. package/src/index.jsx +15 -10
  14. package/src/renderer.jsx +4 -1
  15. package/src/resolver-common.vue +22 -2
  16. package/src/rules/rulesDriver.js +4 -0
  17. package/src/utils/common.js +13 -0
  18. package/src/utils/render.jsx +196 -96
  19. package/src-bak/analysisComponent.jsx +0 -343
  20. package/src-bak/api/builtIn.js +0 -10
  21. package/src-bak/bpm/bpmInstance.js +0 -388
  22. package/src-bak/bpm/udc-sdk-esm/cjs/impl/application.js +0 -8
  23. package/src-bak/bpm/udc-sdk-esm/cjs/impl/component.js +0 -97
  24. package/src-bak/bpm/udc-sdk-esm/cjs/impl/datasource.js +0 -88
  25. package/src-bak/bpm/udc-sdk-esm/cjs/impl/iframe/index.js +0 -3
  26. package/src-bak/bpm/udc-sdk-esm/cjs/impl/iframe/udcSdkForIframe/UdcComponent.js +0 -76
  27. package/src-bak/bpm/udc-sdk-esm/cjs/impl/iframe/udcSdkForIframe/index.js +0 -201
  28. package/src-bak/bpm/udc-sdk-esm/cjs/impl/index.js +0 -69
  29. package/src-bak/bpm/udc-sdk-esm/cjs/impl/page.js +0 -56
  30. package/src-bak/bpm/udc-sdk-esm/cjs/impl/utils.js +0 -76
  31. package/src-bak/bpm/udc-sdk-esm/cjs/index.js +0 -46
  32. package/src-bak/bpm/udc-sdk-esm/cjs/utils.js +0 -21
  33. package/src-bak/components/childDialog/index.js +0 -39
  34. package/src-bak/components/childDialog/src/index.vue +0 -185
  35. package/src-bak/components/cmiFormItem/index.js +0 -1
  36. package/src-bak/components/cmiFormItem/src/index.vue +0 -112
  37. package/src-bak/components/confirmInstance-H5/index.js +0 -53
  38. package/src-bak/components/confirmInstance-H5/src/index.vue +0 -54
  39. package/src-bak/components/helper/FormPolyfill.jsx +0 -25
  40. package/src-bak/components/helper/calcTooltip.jsx +0 -134
  41. package/src-bak/components/helper/dock.js +0 -141
  42. package/src-bak/components/helper/eventOrchestration.js +0 -763
  43. package/src-bak/components/helper/resolver.js +0 -163
  44. package/src-bak/components/helper/table.jsx +0 -103
  45. package/src-bak/components/icons/date.vue +0 -33
  46. package/src-bak/components/icons/info.vue +0 -62
  47. package/src-bak/components/icons/loading.vue +0 -19
  48. package/src-bak/components/icons/question-filled.vue +0 -8
  49. package/src-bak/components/loading/index.js +0 -6
  50. package/src-bak/components/loading/loading.js +0 -98
  51. package/src-bak/components/loading/loading.scss +0 -74
  52. package/src-bak/components/loading/loading.vue +0 -89
  53. package/src-bak/components/loadingComponent/LoadingComponent.vue +0 -33
  54. package/src-bak/components/modal/index.js +0 -9
  55. package/src-bak/components/modal/modal.scss +0 -195
  56. package/src-bak/components/modal/modal.vue +0 -201
  57. package/src-bak/components/options/OptionsDefault.vue +0 -47
  58. package/src-bak/components/packages-H5/CmiButton.vue +0 -120
  59. package/src-bak/components/packages-H5/CmiCalendar.vue +0 -152
  60. package/src-bak/components/packages-H5/CmiCell.vue +0 -87
  61. package/src-bak/components/packages-H5/CmiCheckbox.vue +0 -82
  62. package/src-bak/components/packages-H5/CmiDatetimePicker.vue +0 -98
  63. package/src-bak/components/packages-H5/CmiDivider.vue +0 -30
  64. package/src-bak/components/packages-H5/CmiDropdownMenu.vue +0 -58
  65. package/src-bak/components/packages-H5/CmiInput.vue +0 -69
  66. package/src-bak/components/packages-H5/CmiLink.vue +0 -28
  67. package/src-bak/components/packages-H5/CmiPicker.vue +0 -229
  68. package/src-bak/components/packages-H5/CmiRadio.vue +0 -29
  69. package/src-bak/components/packages-H5/CmiSearch.vue +0 -39
  70. package/src-bak/components/packages-H5/CmiSelect.vue +0 -84
  71. package/src-bak/components/packages-H5/CustomComponentCardH5.vue +0 -129
  72. package/src-bak/components/packages-H5/CustomComponentColH5.vue +0 -8
  73. package/src-bak/components/packages-H5/CustomComponentCollapseH5.vue +0 -141
  74. package/src-bak/components/packages-H5/CustomComponentFormLayoutH5.vue +0 -54
  75. package/src-bak/components/packages-H5/CustomComponentTabPaneH5.vue +0 -38
  76. package/src-bak/components/packages-H5/CustomComponentTableH5.vue +0 -352
  77. package/src-bak/components/packages-H5/CustomComponentTabsH5.vue +0 -170
  78. package/src-bak/components/packages-web/CustomComponentCard.vue +0 -40
  79. package/src-bak/components/packages-web/CustomComponentCol.vue +0 -66
  80. package/src-bak/components/packages-web/CustomComponentCollapse.vue +0 -164
  81. package/src-bak/components/packages-web/CustomComponentCycle.vue +0 -95
  82. package/src-bak/components/packages-web/CustomComponentCycleTabPane.vue +0 -155
  83. package/src-bak/components/packages-web/CustomComponentDialog.vue +0 -192
  84. package/src-bak/components/packages-web/CustomComponentEditor.vue +0 -50
  85. package/src-bak/components/packages-web/CustomComponentFileExport.vue +0 -60
  86. package/src-bak/components/packages-web/CustomComponentFileImport.vue +0 -60
  87. package/src-bak/components/packages-web/CustomComponentFormLayout.vue +0 -65
  88. package/src-bak/components/packages-web/CustomComponentGrid.vue +0 -29
  89. package/src-bak/components/packages-web/CustomComponentGridCol.vue +0 -29
  90. package/src-bak/components/packages-web/CustomComponentInputDialog.vue +0 -144
  91. package/src-bak/components/packages-web/CustomComponentNativeTabPane.vue +0 -84
  92. package/src-bak/components/packages-web/CustomComponentPlain.vue +0 -247
  93. package/src-bak/components/packages-web/CustomComponentRow.vue +0 -83
  94. package/src-bak/components/packages-web/CustomComponentSelectEmployees.vue +0 -203
  95. package/src-bak/components/packages-web/CustomComponentSendMail.vue +0 -62
  96. package/src-bak/components/packages-web/CustomComponentSteps.vue +0 -41
  97. package/src-bak/components/packages-web/CustomComponentTabPane.vue +0 -20
  98. package/src-bak/components/packages-web/CustomComponentTable.jsx +0 -814
  99. package/src-bak/components/packages-web/CustomComponentTabs.vue +0 -126
  100. package/src-bak/components/packages-web/CustomComponentTree.vue +0 -28
  101. package/src-bak/components/packages-web/ElButton.vue +0 -146
  102. package/src-bak/components/packages-web/ElCheckbox.vue +0 -97
  103. package/src-bak/components/packages-web/ElDatePicker.vue +0 -93
  104. package/src-bak/components/packages-web/ElInput copy.jsx +0 -393
  105. package/src-bak/components/packages-web/ElInput.jsx +0 -312
  106. package/src-bak/components/packages-web/ElInputNumber.vue +0 -81
  107. package/src-bak/components/packages-web/ElPagination.vue +0 -61
  108. package/src-bak/components/packages-web/ElRadio.vue +0 -47
  109. package/src-bak/components/packages-web/ElSelect.jsx +0 -249
  110. package/src-bak/components/packages-web/ElSelect_bak.vue +0 -155
  111. package/src-bak/components/packages-web/ElText.jsx +0 -187
  112. package/src-bak/components/packages-web/ElTextaa.vue +0 -169
  113. package/src-bak/components/packages-web/ElTimePicker.vue +0 -39
  114. package/src-bak/components/patchComponents-H5.js +0 -46
  115. package/src-bak/components/patchComponents-web.js +0 -46
  116. package/src-bak/components/simpleFormItemPc/index.js +0 -1
  117. package/src-bak/components/simpleFormItemPc/src/index.vue +0 -94
  118. package/src-bak/components/table/index.ts +0 -29
  119. package/src-bak/components/table/src/composables/use-scrollbar.ts +0 -30
  120. package/src-bak/components/table/src/config.ts +0 -256
  121. package/src-bak/components/table/src/filter-panel.vue +0 -260
  122. package/src-bak/components/table/src/h-helper.ts +0 -34
  123. package/src-bak/components/table/src/layout-observer.ts +0 -78
  124. package/src-bak/components/table/src/store/current.ts +0 -85
  125. package/src-bak/components/table/src/store/expand.ts +0 -76
  126. package/src-bak/components/table/src/store/helper.ts +0 -74
  127. package/src-bak/components/table/src/store/index.ts +0 -246
  128. package/src-bak/components/table/src/store/tree.ts +0 -230
  129. package/src-bak/components/table/src/store/watcher.ts +0 -543
  130. package/src-bak/components/table/src/table/defaults.ts +0 -402
  131. package/src-bak/components/table/src/table/key-render-helper.ts +0 -27
  132. package/src-bak/components/table/src/table/style-helper.ts +0 -378
  133. package/src-bak/components/table/src/table/utils-helper.ts +0 -47
  134. package/src-bak/components/table/src/table-body/defaults.ts +0 -52
  135. package/src-bak/components/table/src/table-body/events-helper.ts +0 -203
  136. package/src-bak/components/table/src/table-body/index.ts +0 -119
  137. package/src-bak/components/table/src/table-body/render-helper.ts +0 -283
  138. package/src-bak/components/table/src/table-body/styles-helper.ts +0 -164
  139. package/src-bak/components/table/src/table-column/defaults.ts +0 -237
  140. package/src-bak/components/table/src/table-column/index.ts +0 -202
  141. package/src-bak/components/table/src/table-column/render-helper.ts +0 -214
  142. package/src-bak/components/table/src/table-column/watcher-helper.ts +0 -88
  143. package/src-bak/components/table/src/table-footer/index.ts +0 -128
  144. package/src-bak/components/table/src/table-footer/mapState-helper.ts +0 -33
  145. package/src-bak/components/table/src/table-footer/style-helper.ts +0 -51
  146. package/src-bak/components/table/src/table-header/event-helper.ts +0 -213
  147. package/src-bak/components/table/src/table-header/index.ts +0 -244
  148. package/src-bak/components/table/src/table-header/style.helper.ts +0 -119
  149. package/src-bak/components/table/src/table-header/utils-helper.ts +0 -94
  150. package/src-bak/components/table/src/table-layout.ts +0 -259
  151. package/src-bak/components/table/src/table.vue +0 -389
  152. package/src-bak/components/table/src/tableColumn.ts +0 -3
  153. package/src-bak/components/table/src/tokens.ts +0 -5
  154. package/src-bak/components/table/src/util.ts +0 -521
  155. package/src-bak/components/table/style/css.ts +0 -5
  156. package/src-bak/components/table/style/index.ts +0 -5
  157. package/src-bak/components/tabs/index.js +0 -8
  158. package/src-bak/components/tabs/src/constants.js +0 -23
  159. package/src-bak/components/tabs/src/tab-bar.js +0 -8
  160. package/src-bak/components/tabs/src/tab-bar.vue +0 -92
  161. package/src-bak/components/tabs/src/tab-nav.jsx +0 -424
  162. package/src-bak/components/tabs/src/tab-pane.js +0 -16
  163. package/src-bak/components/tabs/src/tab-pane.vue +0 -80
  164. package/src-bak/components/tabs/src/tabs.jsx +0 -223
  165. package/src-bak/components/tabs/style/css.js +0 -2
  166. package/src-bak/components/tabs/style/index.js +0 -2
  167. package/src-bak/components/thirdPartyFrame/index.js +0 -32
  168. package/src-bak/components/thirdPartyFrame/src/ThirdPartyFrame.vue +0 -125
  169. package/src-bak/enums/index.js +0 -16
  170. package/src-bak/hooks/configLoad.js +0 -45
  171. package/src-bak/hooks/index.js +0 -189
  172. package/src-bak/hooks/mock.js +0 -6960
  173. package/src-bak/hooks/pageConfig.js +0 -127
  174. package/src-bak/index.jsx +0 -443
  175. package/src-bak/renderer.jsx +0 -77
  176. package/src-bak/resolver-H5.vue +0 -88
  177. package/src-bak/resolver-common.vue +0 -129
  178. package/src-bak/resolver-web.vue +0 -91
  179. package/src-bak/rules/eventsSupplement.js +0 -573
  180. package/src-bak/rules/parseCondition.js +0 -378
  181. package/src-bak/rules/ruleUtils.js +0 -273
  182. package/src-bak/rules/rulesDriver.js +0 -139
  183. package/src-bak/rulesImp/events.js +0 -588
  184. package/src-bak/rulesImp/index.js +0 -33
  185. package/src-bak/rulesImp/ruleInstance.js +0 -231
  186. package/src-bak/rulesImp/ruleUtils.js +0 -124
  187. package/src-bak/theme/element/components/button.scss +0 -122
  188. package/src-bak/theme/element/components/card.scss +0 -8
  189. package/src-bak/theme/element/components/checkbox.scss +0 -19
  190. package/src-bak/theme/element/components/collapse.scss +0 -174
  191. package/src-bak/theme/element/components/common.scss +0 -30
  192. package/src-bak/theme/element/components/cycle.scss +0 -0
  193. package/src-bak/theme/element/components/date.scss +0 -13
  194. package/src-bak/theme/element/components/dialog.scss +0 -44
  195. package/src-bak/theme/element/components/form.scss +0 -104
  196. package/src-bak/theme/element/components/index.scss +0 -55
  197. package/src-bak/theme/element/components/input.scss +0 -36
  198. package/src-bak/theme/element/components/message.scss +0 -48
  199. package/src-bak/theme/element/components/pagination.scss +0 -47
  200. package/src-bak/theme/element/components/popper.scss +0 -3
  201. package/src-bak/theme/element/components/radio.scss +0 -40
  202. package/src-bak/theme/element/components/scrollbar.scss +0 -14
  203. package/src-bak/theme/element/components/select.scss +0 -82
  204. package/src-bak/theme/element/components/steps.scss +0 -6
  205. package/src-bak/theme/element/components/table.scss +0 -218
  206. package/src-bak/theme/element/components/tabs.scss +0 -128
  207. package/src-bak/theme/element/components/tag.scss +0 -6
  208. package/src-bak/theme/element/components/text.scss +0 -20
  209. package/src-bak/theme/element/components/textarea.scss +0 -3
  210. package/src-bak/theme/element/components/tree.scss +0 -0
  211. package/src-bak/theme/element/index.scss +0 -55
  212. package/src-bak/utils/cipher.js +0 -141
  213. package/src-bak/utils/common.js +0 -664
  214. package/src-bak/utils/const.js +0 -259
  215. package/src-bak/utils/defaultVal.js +0 -92
  216. package/src-bak/utils/dom.js +0 -36
  217. package/src-bak/utils/format.js +0 -19
  218. package/src-bak/utils/index.js +0 -4
  219. package/src-bak/utils/is.js +0 -74
  220. package/src-bak/utils/loadModule.js +0 -75
  221. package/src-bak/utils/preserveFunc.js +0 -33
  222. package/src-bak/utils/render.jsx +0 -1138
  223. package/src-bak/utils/request.js +0 -136
  224. package/src-bak/utils/respone.js +0 -70
  225. package/src-bak/utils/valid.js +0 -89
@@ -1,229 +0,0 @@
1
- <script setup>
2
- import { computed, defineProps, inject, onMounted, ref, useAttrs, watch } from 'vue'
3
- import { commonPropsType } from '../../utils/index.js'
4
-
5
- const filterKey = ref('')
6
- const pickerRef = ref(null)
7
- const selects = inject('selects')
8
- const rootForm = inject('rootForm')
9
- const attrs = useAttrs()
10
- const lang = inject('lang')
11
- const modelValue = defineModel()
12
- const props = defineProps({
13
- ...commonPropsType,
14
- filterable: {
15
- type: String
16
- },
17
- multiple: {
18
- type: String
19
- }
20
- })
21
- const open = computed({
22
- get() {
23
- return props?.config?.open == '1'
24
- },
25
- set(val) {
26
- props.config.open = val ? '1' : '0'
27
- }
28
- })
29
- const prefixIcon = computed(() => {
30
- return props?.config?.prefixIcon
31
- })
32
- const suffixIcon = computed(() => {
33
- return props?.config?.suffixIcon ?? 'arrow-down'
34
- })
35
-
36
- const formatValue = computed({
37
- get() {
38
- return modelValue.value ? modelValue.value.split(',') : []
39
- },
40
- set(val) {
41
- const formatVal = Array.isArray(val) ? val.join(',') : val
42
- modelValue.value = formatVal
43
- }
44
- })
45
-
46
- // 是否为多选
47
- const isMutiple = computed(() => {
48
- return props.multiple == '1'
49
- })
50
- // 是否开启过滤, todo == 暂时不支持多列
51
- const isFilter = computed(() => {
52
- return props.filterable == '1'
53
- })
54
- const calcProps = computed(() => {
55
- const ret = {
56
- type: isFilter.value ? 'normal' : props?.config?.displayType,
57
- title: lang.value?.indexOf('zh') > -1 ? props.config?.metaNameZh : props.config?.metaNameEn,
58
- canceltext: props?.config?.canceltext,
59
- confirmtext: props?.config?.confirmtext,
60
- forbidmaskclick: props?.config?.forbidmaskclick == '1',
61
- fastpick: isFilter.value ? true : (props?.config?.fastpick == '1'),
62
- bottomhidden: props?.config?.bottomhidden == '1',
63
- }
64
- return ret
65
- })
66
- const getColumns = (filterKey) => {
67
- const selectKeyArr = props.config?.selectKey?.split?.(',') || []
68
- return selectKeyArr.map((key, idx) => {
69
- const values = selects?.value?.[key]?.map(option => ({
70
- label: lang?.value?.indexOf('zh') > -1 ? option.columnDesc_zh : option.columnDesc,
71
- value: option.columnValue
72
- }))?.filter(item => {
73
- if (filterKey) {
74
- return `${item.label || ''}`.toLocaleLowerCase()?.includes(`${filterKey}`.toLocaleLowerCase())
75
- } else {
76
- return true
77
- }
78
- }) || []
79
- let index = values.findIndex(option => option?.value === formatValue.value[idx])
80
- return {
81
- defaultIndex: index > -1 ? index : (isFilter.value ? -1 : 0),
82
- values,
83
- }
84
- })
85
- }
86
-
87
- const onFocus = (e) => {
88
- open.value = true
89
- pickerRef.value?.setColumns?.(getColumns())
90
- e.preventDefault()
91
- e.stopPropagation()
92
- e.target.blur()
93
- }
94
-
95
- const onClose = () => {
96
- props.config?.onClose?.()
97
- open.value = false
98
- }
99
- const onConfirm = (e) => {
100
- const val = (e.detail.value || []).map(item => {
101
- if (typeof item.value === 'object') {
102
- return item.value?.value
103
- } else {
104
- return item.value
105
- }
106
- })
107
- formatValue.value = val
108
-
109
- props.config?.onConfirm?.(formatValue.value)
110
- // pick组件不主动出发formItem上面绑定的额自定义校验,这边就手动出发下
111
- rootForm.value?.validateField?.(props.config?.dynamicHireRelat)
112
- open.value = false
113
- }
114
-
115
- const modelvalDesc = computed(() => {
116
- const columns = getColumns()
117
- return formatValue.value?.reduce?.((ret, cur, idx) => {
118
- const col = columns[idx]
119
- const curItem = (col?.values || []).find(item => {
120
- if (typeof item === 'object') {
121
- return item.value === cur
122
- } else {
123
- return item == cur
124
- }
125
- })
126
- const label = (typeof curItem === 'object' ? curItem.label : curItem) || ''
127
- return ret ? `${ret},${label}` : `${label}`
128
- }, '')
129
- })
130
-
131
- const inputProps = computed(() => {
132
- return {
133
- placeholder: lang?.value?.indexOf('zh') > -1 ? props.config?.defPlacehold : props.config?.defPlaceholdEn,
134
- disabled: props.disabled
135
- }
136
- })
137
-
138
- watch(filterKey, (val) => {
139
- pickerRef.value?.setColumns?.(getColumns(val))
140
- })
141
- watch(open, (val) => {
142
- if (!val) {
143
- filterKey.value = ''
144
- }
145
- }, {
146
- immediate: true
147
- })
148
-
149
- function filterChange(e) {
150
- filterKey.value = e.detail.value
151
- }
152
-
153
- onMounted(() => {
154
- // 支持过滤的时候,因为是上下层级结构,默认情况下头部的高被限制住了,会显示不全,所以这边需要进行webComponent中样式修改
155
- watch(isFilter, (() => {
156
- let oldTop = null
157
- let oldBottom = null
158
- return (val) => {
159
- const pickerContentDom = pickerRef.value.shadowRoot?.querySelector('.cmi-picker-content')
160
- if (pickerContentDom) {
161
- if (val) {
162
- const tabStyles = window.getComputedStyle(pickerContentDom)
163
- oldTop = tabStyles.top
164
- oldBottom = tabStyles.bottom
165
- pickerContentDom.style.top = '24vw'
166
- pickerContentDom.style.bottom = '10.2vw'
167
- } else {
168
- if (oldTop) {
169
- pickerContentDom.style.top = oldTop
170
- }
171
- if (oldBottom) {
172
- pickerContentDom.style.bottom = oldBottom
173
- }
174
- }
175
-
176
- }
177
- }
178
- })(), {
179
- immediate: true
180
- })
181
-
182
- })
183
- </script>
184
-
185
- <template>
186
- <cmi-input :value="modelvalDesc" suffixIcon @focus="onFocus" v-bind="{...attrs, ...inputProps}" >
187
- <div slot="suffix" v-if="suffixIcon" class="suffix-wrap">
188
- <component v-if="!inputProps.disabled || 'arrow-down' != suffixIcon" @click="() => { ('arrow-down' == suffixIcon) && onFocus();}" :is="`cmi-icon-${suffixIcon}`" color="#4E5969"></component>
189
- </div>
190
- <span slot="prefix" v-if="prefixIcon">
191
- <component :is="`cmi-icon-${prefixIcon}`" color="#4E5969"></component>
192
- </span>
193
- </cmi-input>
194
- <cmi-picker
195
- ref="pickerRef"
196
- v-bind="{...attrs, ...calcProps}"
197
- :open="open"
198
- @close="onClose"
199
- @confirm="onConfirm"
200
- >
201
- <div v-if="isFilter" slot="header" class="filter-header-wrap">
202
- <span class="filte-title">{{ calcProps.title }}</span>
203
- <cmi-input class="filter-input" @change="filterChange" :value="filterKey"></cmi-input>
204
- </div>
205
- </cmi-picker>
206
- </template>
207
- <style lang="scss" scoped>
208
- .suffix-wrap {
209
- display: flex;
210
- justify-content: center;
211
- align-items: center;
212
- font-size: 16px;
213
- }
214
- .filter-header-wrap {
215
- display: flex;
216
- justify-content: flex-start;
217
- align-items: start;
218
- flex-direction: column;
219
- width: 100%;
220
- .filte-title {
221
- margin-bottom: 6px;
222
- // max-width: 50%;
223
- }
224
- .filter-input {
225
- flex: 1;
226
- // margin-left: 16px;
227
- }
228
- }
229
- </style>
@@ -1,29 +0,0 @@
1
- <script setup>
2
- import { computed, defineProps, inject, ref, useAttrs } from 'vue'
3
- import { commonPropsType } from '../../utils/index.js'
4
-
5
- const lang = inject('lang')
6
- const modelValue = defineModel()
7
- const props = defineProps({
8
- ...commonPropsType,
9
- })
10
- const calcProps = computed(() => {
11
- return {
12
- direction: props.config?.direction,
13
- }
14
- })
15
- const attrs = useAttrs()
16
- const onChange = (e) => {
17
- modelValue.value = e.detail.value
18
- }
19
- </script>
20
-
21
- <template>
22
- <cmi-radio-group :value="modelValue" v-bind="{ ...attrs, ...calcProps}" @change="onChange">
23
- <cmi-radio
24
- v-for="option in props.options" :key="option.columnValue"
25
- :disabled="props.disabled || option.columnStatus == '0' || option.columnStatus == '2'"
26
- :name="option.columnValue" :label="lang.indexOf('zh') > -1 ? option.columnDesc_zh : option.columnDesc"
27
- />
28
- </cmi-radio-group>
29
- </template>
@@ -1,39 +0,0 @@
1
- <script setup>
2
- import { computed, defineProps, inject, useAttrs } from 'vue'
3
- import { commonPropsType } from '../../utils/index.js'
4
-
5
- const lang = inject('lang')
6
- const modelValue = defineModel()
7
- const props = defineProps({
8
- ...commonPropsType,
9
- })
10
- const calcProps = computed(() => {
11
- return {
12
- shape: props.config?.shape,
13
- dark: props.config?.dark,
14
- showback: props.config?.showback == '1',
15
- showaction: props.config?.showaction == '1',
16
- actiontext: props.config?.actiontext,
17
- iconcolor: props.config?.iconcolor,
18
- placeholder: lang?.value?.indexOf('zh') > -1 ? props.config?.defPlacehold : props.config?.defPlaceholdEn,
19
- maxlength: props.config?.maxlength,
20
- autofocus: props.config?.autofocus,
21
- clearable: props.config?.clearable == '1',
22
- disabled: props.disabled,
23
- readonly: props.readonly,
24
- noborder: props.config?.noborder,
25
- }
26
- })
27
- const attrs = useAttrs()
28
- const onChange = (e) => {
29
- modelValue.value = e.detail.value
30
- }
31
-
32
- </script>
33
-
34
- <template>
35
- <cmi-search
36
- :value="modelValue" v-bind="{ ...attrs, ...calcProps}"
37
- @change="onChange"
38
- ></cmi-search>
39
- </template>
@@ -1,84 +0,0 @@
1
- <script setup>
2
- import { computed, defineProps, inject, useAttrs } from 'vue'
3
- import { commonPropsType } from '../../utils/index.js'
4
-
5
- const modelValue = defineModel()
6
- const props = defineProps({
7
- ...commonPropsType,
8
- multiple: [String, Boolean]
9
- })
10
- const attrs = useAttrs()
11
- const lang = inject('lang')
12
-
13
- // 是否为多选
14
- const isMutiple = computed(() => {
15
- return props.multiple == '1' || (typeof props.multiple === 'boolean' && props.multiple)
16
- })
17
- const showAll = computed(() => {
18
- return props.showAll == '1'
19
- })
20
- const value = computed({
21
- get() {
22
- if (isMutiple.value) {
23
- const val = modelValue.value || ''
24
- return val ? val.split(',') : []
25
- } else {
26
- if (modelValue.value !== null && modelValue.value !== undefined) {
27
- if (props.options?.some(item => item.columnValue == modelValue.value)) {
28
- props.config.isMatch = true
29
- return `${modelValue.value}`
30
- } else {
31
- props.config.isMatch = false
32
- return ''
33
- }
34
- } else {
35
- return ''
36
- }
37
- }
38
- },
39
- set(val) {
40
- if (isMutiple.value) {
41
- modelValue.value = Array.isArray(val) ? val.join(',') : val
42
- } else {
43
- modelValue.value = val
44
- }
45
- }
46
- })
47
-
48
- const selectProps = computed(() => {
49
- return {
50
- // label: lang?.value?.indexOf('zh') > -1 ? props.config?.metaNameZh : props.config?.metaNameEn,
51
- value: value.value,
52
- disabled: props.disabled,
53
- clearable: props.clearable,
54
- multiple: isMutiple.value,
55
- placeholder: lang?.value?.indexOf('zh') > -1 ? props.config?.defPlacehold : props.config?.defPlaceholdEn,
56
- 'max-options-visible': props.config?.['max-options-visible'] || props.config?.maxOptionsVisible,
57
- // required: props.required,
58
- }
59
- })
60
- const clear = () => {
61
- value.value = ''
62
- }
63
- const onChange = ({detail}) => {
64
- value.value = detail.value || ""
65
- props.config?.onChange(modelValue.value)
66
- }
67
- </script>
68
-
69
- <template>
70
- <cmi-select class="custom-self-select" v-bind="{...attrs, ...selectProps}" @change="onChange" @clear="clear">
71
- <cmi-option v-if="showAll" value="all" multiple>{{ lang.indexOf('zh') > -1 ? '全选' : 'All' }}</cmi-option>
72
- <cmi-option v-for="option in (props.options || [])" :key="option.columnValue"
73
- :label="lang.indexOf('zh') > -1 ? option.columnDesc_zh : option.columnDesc"
74
- :value="option.columnValue"
75
- :multiple="isMutiple"
76
- :disabled="option.columnStatus == '0' || option.columnStatus == '2'"
77
- />
78
- </cmi-select>
79
- </template>
80
-
81
- <style lang="scss">
82
- .custom-self-select {
83
- }
84
- </style>
@@ -1,129 +0,0 @@
1
- <script setup>
2
- import { computed, inject, onMounted, ref, resolveComponent, useAttrs, watch } from "vue";
3
- import Renderer from '../../renderer.jsx'
4
- import { commonPropsType, DISPLAY_HIDDEN, hasOwn } from '../../utils/index.js'
5
-
6
- const modelValue = defineModel()
7
- const props = defineProps({
8
- ...commonPropsType,
9
- subtitleZh: String,
10
- subtitleEn: String,
11
- content: String,
12
- noborder: [Boolean, String],
13
- cardbgcolor: String,
14
- })
15
-
16
- const collapseLimt = ref(Number.MAX_VALUE)
17
- const isCollapse = ref(true)
18
- const attrs = useAttrs()
19
- const lang = inject('lang')
20
- const cmiProps = computed(() => {
21
- return {
22
- title: lang?.value?.indexOf('zh') > -1 ? props.config?.metaNameZh : props.config?.metaNameEn,
23
- subtitle: lang?.value?.indexOf('zh') > -1 ? props.config.subtitleZh : props.config.subtitleEn,
24
- content: props.content,
25
- noborder: props.noborder == '1' ? true : false,
26
- cardbgcolor: props.cardbgcolor || '#FAFAFA',
27
- open: props.config?.defaultOpenFlag == '1'
28
- }
29
- })
30
-
31
- const propCollapseLimt = computed(() => {
32
- return props.config?.collapseLimt || 5
33
- })
34
-
35
- const pmPageMetaList = computed(() => {
36
- return props.config?.pmPageMetaList || []
37
- })
38
-
39
- const showPageMeteList = computed(() => {
40
- return pmPageMetaList.value.filter(item => item.displayType != DISPLAY_HIDDEN && item.hidden != '1')
41
- })
42
-
43
- const lastShowPageMeteItem = computed(() => {
44
- return showPageMeteList.value?.length ? showPageMeteList.value[showPageMeteList.value.length - 1] : null
45
- })
46
-
47
- const showCollapseBtn = computed(() => {
48
- return showPageMeteList.value?.length > collapseLimt.value
49
- })
50
-
51
-
52
- // 定位到最后显示的组件在折叠组件中的索引
53
- const lasetLimitIdx = computed(() => {
54
- const limt = isCollapse.value ? collapseLimt.value : Number.MAX_VALUE
55
- return pmPageMetaList.value?.findIndex(item => item == showPageMeteList.value[limt - 1])
56
- })
57
-
58
- // 通过监听最后一个显示组件的索引,控制那些组件隐藏(通过collapseHidden控制隐藏)
59
- watch(lasetLimitIdx, (val) => {
60
- pmPageMetaList.value?.forEach((item, index) => {
61
- item.collapseHidden = '0'
62
- if (item.metaType === 'cmi-cell') {
63
- item.borderHidden = '0'
64
- }
65
- if (val > -1) {
66
- if (index > val) {
67
- item.collapseHidden = '1'
68
- }
69
- if (index === val) {
70
- if (item.metaType === 'cmi-cell') {
71
- item.borderHidden = '1'
72
- }
73
- }
74
- }
75
- })
76
- if (val === -1) {
77
- if (lastShowPageMeteItem.value?.metaType === 'cmi-cell') {
78
- lastShowPageMeteItem.value.borderHidden = '1'
79
- }
80
- }
81
- }, {
82
- immediate: true
83
- })
84
-
85
-
86
- const collapseLabel = computed(() => {
87
- const isCh = lang?.value?.indexOf('zh') > -1
88
- return isCollapse.value ? (isCh ? '更多' : 'More') : (isCh ? '收起' : 'Close')
89
- })
90
- function toCollapse() {
91
- isCollapse.value = !isCollapse.value
92
- }
93
-
94
- onMounted(() => {
95
- watch(() => props.config._componentLoad, (val) => {
96
- if (val) {
97
- collapseLimt.value = propCollapseLimt.value
98
- watch(propCollapseLimt, (val) => {
99
- collapseLimt.value = val
100
- })
101
- }
102
- }, {
103
- immediate: true
104
- })
105
- })
106
- </script>
107
- <template>
108
- <cmi-card v-bind="{...attrs, ...cmiProps}">
109
- <div slot="content" :style="{'background-color': cmiProps.cardbgcolor}">
110
- <Renderer :config="pmPageMetaList" v-model="modelValue"></Renderer>
111
- <div v-if="showCollapseBtn" class="collapse-wrap">
112
- <cmi-button type="text" size="small" @click="toCollapse">
113
- {{ collapseLabel }}
114
- </cmi-button>
115
- </div>
116
- </div>
117
- </cmi-card>
118
- </template>
119
- <style lang="scss">
120
- .collapse-wrap {
121
- display: flex;
122
- justify-content: end;
123
- }
124
- cmi-card {
125
- cmi-form-item {
126
- background-color: transparent;
127
- }
128
- }
129
- </style>
@@ -1,8 +0,0 @@
1
- <script setup>
2
- </script>
3
- <template>
4
- <div>
5
- <slot></slot>
6
- </div>
7
- </template>
8
- <style lang="scss"></style>
@@ -1,141 +0,0 @@
1
- <script setup>
2
- import Renderer from '../../renderer.jsx'
3
- import { computed, inject, useAttrs, defineEmits, defineProps, ref, watch } from 'vue'
4
- import { commonPropsType, DISPLAY_HIDDEN, hasOwn } from '../../utils/index.js'
5
-
6
- defineOptions({
7
- inheritAttrs: false
8
- })
9
-
10
- const isCollapse = ref(true)
11
- const modelValue = defineModel()
12
- const attrs = useAttrs()
13
- const lang = inject('lang')
14
- const props = defineProps({
15
- ...commonPropsType,
16
- })
17
- const collapseLimt = computed(() => {
18
- return props.config?.collapseLimt || 5
19
- })
20
- const collapseProps = computed(() => {
21
- return {
22
- title: lang?.value?.indexOf('zh') > -1 ? props.config?.metaNameZh : props.config?.metaNameEn,
23
- open: props.config?.defaultOpenFlag == '1',
24
- transition: props.config?.defaultOpenFlag == '1',
25
- // hideicon: props.config?.hideicon != '1'
26
- }
27
- })
28
-
29
- const pmPageMetaList = computed(() => {
30
- return props.config?.pmPageMetaList || []
31
- })
32
-
33
- const showPageMeteList = computed(() => {
34
- return pmPageMetaList.value.filter(item => item.displayType != DISPLAY_HIDDEN && item.hidden != '1')
35
- })
36
-
37
- const lastShowPageMeteItem = computed(() => {
38
- return showPageMeteList.value?.length ? showPageMeteList.value[showPageMeteList.value.length - 1] : null
39
- })
40
-
41
- const showCollapseBtn = computed(() => {
42
- return showPageMeteList.value?.length > collapseLimt.value
43
- })
44
-
45
- // 定位到最后显示的组件在折叠组件中的索引
46
- const lasetLimitIdx = computed(() => {
47
- const limt = isCollapse.value ? collapseLimt.value : Number.MAX_VALUE
48
- return pmPageMetaList.value?.findIndex(item => item == showPageMeteList.value[limt - 1])
49
- })
50
-
51
- // 通过监听最后一个显示组件的索引,控制那些组件隐藏(通过collapseHidden控制隐藏)
52
- watch(lasetLimitIdx, (val) => {
53
- pmPageMetaList.value?.forEach((item, index) => {
54
- item.collapseHidden = '0'
55
- if (item.metaType === 'cmi-cell') {
56
- item.borderHidden = '0'
57
- }
58
- if (val > -1) {
59
- if (index > val) {
60
- item.collapseHidden = '1'
61
- }
62
- if (index === val) {
63
- if (item.metaType === 'cmi-cell') {
64
- if (!showCollapseBtn.value) {
65
- item.borderHidden = '1'
66
- }
67
- }
68
- }
69
- }
70
- })
71
- if (val === -1) {
72
- if (lastShowPageMeteItem.value?.metaType === 'cmi-cell') {
73
- if (!showCollapseBtn.value) {
74
- lastShowPageMeteItem.value.borderHidden = '1'
75
- }
76
- }
77
- }
78
- }, {
79
- immediate: true
80
- })
81
-
82
- const collapseLabel = computed(() => {
83
- const isCh = lang?.value?.indexOf('zh') > -1
84
- return isCollapse.value ? (isCh ? '更多' : 'More') : (isCh ? '收起' : 'Less')
85
- })
86
- function toCollapse() {
87
- isCollapse.value = !isCollapse.value
88
- }
89
- </script>
90
-
91
- <template>
92
- <div :style="attrs.style">
93
- <cmi-collapse v-bind="{...attrs, ...collapseProps}">
94
- <div class="render-wrap">
95
- <Renderer :config="pmPageMetaList" v-model="modelValue"></Renderer>
96
- </div>
97
- <div v-if="showCollapseBtn" class="collapse-wrap">
98
- <span class="collapse-span" @click="toCollapse">
99
- {{ collapseLabel }}
100
- </span>
101
- </div>
102
- </cmi-collapse>
103
- </div>
104
- </template>
105
-
106
- <style lang="scss">
107
- .render-wrap {
108
- div:last-child {
109
- cmi-cell {
110
- &::after {
111
- display: none;
112
- }
113
- }
114
- }
115
- }
116
- .collapse-wrap {
117
- display: flex;
118
- justify-content: end;
119
- & > .collapse-span {
120
- color: #3271FE;
121
- margin: 8px 16px 16px 16px;
122
- }
123
- }
124
- </style>
125
- <style lang="scss">
126
- .CustomComponentCollapseH5 {
127
- margin-bottom: 16px;
128
- }
129
-
130
- .CustomComponentCollapseH5:first-child {
131
- margin-bottom: 16px;
132
- }
133
- .CustomComponentCollapseH5 + .CustomComponentCollapseH5 {
134
- margin-bottom: 16px;
135
- }
136
-
137
- // 加权
138
- .CustomComponentCollapseH5.CustomComponentCollapseH5.CustomComponentCollapseH5:last-child {
139
- margin-bottom: 0;
140
- }
141
- </style>