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,247 +0,0 @@
1
- <template>
2
- <span class="custom-component-plain" :class="classObj" @click.stop.self="clickAction">{{ props.formatter?.(value) ?? value }}</span>
3
- </template>
4
- <script setup>
5
- import { findComponent } from '../../utils/common';
6
- import { commonPropsType, PLAIN_TYPE_OPTIONS_COLUMNS } from '../../utils/const' // 这边不能用utils/index去引用,因为这个组件在utils/render.js中被引入了,会造成循环引用
7
- import { computed, defineModel, inject, getCurrentInstance, watch, nextTick } from 'vue'
8
- import dayjs from 'dayjs'
9
- import { isNaN } from '../../utils/is';
10
- import { useFormItem } from 'element-plus'
11
-
12
- defineOptions({
13
- inheritAttrs: false
14
- })
15
-
16
- const { formItem: elFormItem } = useFormItem()
17
- const modelValue = defineModel()
18
- const props = defineProps({
19
- ...commonPropsType,
20
- type: {
21
- type: String,
22
- default: ''
23
- },
24
- formatter: {
25
- type: Function,
26
- default: null
27
- },
28
- isPointer: {
29
- type: [String, Number]
30
- },
31
- // 多选的分割符号
32
- separator: {
33
- type: [String],
34
- default: ','
35
- },
36
- // 多选显示时候 分隔的符号
37
- separatorDesc: {
38
- type: [String],
39
- default: null
40
- },
41
- showMoney: {
42
- type: [String, Number],
43
- default: ''
44
- },
45
- // 金额显示的分割,默认‘,’
46
- moneySeg: {
47
- type: [String],
48
- default: ','
49
- },
50
- min: {
51
- type: Number,
52
- default: -Infinity
53
- },
54
- max: {
55
- type: Number,
56
- default: Infinity
57
- },
58
- // 小数位数
59
- decimal: {
60
- type: Number,
61
- default: 2
62
- },
63
- // 保留小数点0后缀
64
- decimalSuffix: {
65
- type: [Number, String],
66
- default: '0'
67
- },
68
- // 金额显示时保留小数点0后缀
69
- keepLastZero: {
70
- type: [Number, String],
71
- default: '0'
72
- },
73
- // 在显示金额的时候,可以显示的符号
74
- canShowFlag: {
75
- type: Array,
76
- default: ['na', '-']
77
- },
78
- // 是否显示货币符号
79
- showSymbol: {
80
- type: String,
81
- default: ''
82
- },
83
- // 货币符号
84
- symbol: {
85
- type: String,
86
- default: '¥'
87
- },
88
- // 符号位置:before/after
89
- symbolPosition: {
90
- type: String,
91
- default: 'before',
92
- validator: value => ['before', 'after'].includes(value)
93
- },
94
- })
95
- const lang = inject('lang')
96
- function isPatchComponent(components, props) {
97
- return (findComponent(components, props?.config?.renderby) !== -1 || findComponent(components, props?.config?.metaType) !== -1)
98
- }
99
- const value = computed(() => {
100
- if (
101
- isPatchComponent(PLAIN_TYPE_OPTIONS_COLUMNS, props)
102
- ) {
103
- return selectFormat(modelValue.value)
104
- } else if (isPatchComponent(['ElInputNumber'], props)) {
105
- return inputNumebrFormat(modelValue.value, props)
106
- } else {
107
- if (isPatchComponent(['ElDatePicker'], props)) {
108
- if (!modelValue.value) {
109
- return ''
110
- }
111
- let val = ''
112
- if (isNaN(Number(modelValue.value))) {
113
- val = modelValue.value
114
- } else {
115
- if (props.config?.valueFormat === 'timestamp' || `${modelValue.value}`.length >= 13) {
116
- val = Number(modelValue.value)
117
- } else {
118
- val = modelValue.value
119
- }
120
- }
121
- return dayjs(val).format(props?.config?.format || 'YYYY-MM-DD')
122
- }
123
- if (props.showMoney == '1') {
124
- return formatValue(modelValue.value)
125
- }
126
- return modelValue.value
127
- }
128
- })
129
-
130
- // 转换inputNumber类型的值
131
- function inputNumebrFormat(val, props) {
132
- if (val === undefined || val === null) return ''
133
- const precise = parseInt(props.config.precise)
134
- if (isNaN(precise)) {
135
- return parseFloat(val)
136
- } else {
137
- return parseFloat(val)?.toFixed?.(precise)
138
- }
139
- }
140
-
141
- const classObj = computed(() => ({
142
- [`custom-component-plain--${props.type}`]: true,
143
- cursor: props.isPointer == '1'
144
- }))
145
-
146
-
147
- const appContext = getCurrentInstance()?.appContext
148
- const buttonActions = inject('buttonActions', {})
149
-
150
- const dynamicMapComp = inject('dynamicMapComp')
151
- const hireRelatMapRules = inject('hireRelatMapRules')
152
- const components = inject('components')
153
- const selects = inject('selects')
154
- const rootValue = inject('rootValue')
155
- const dataLoad = inject('dataLoad')
156
- const rootForm = inject('rootForm')
157
- const clickAction = () => {
158
- const actionKey = props.config?.clickActionKey || props.config?.buttonActionKey || props.config?.hireRelat
159
- const actionFn = buttonActions[actionKey]
160
- actionFn && actionFn(props, {
161
- dynamicMapComp,
162
- hireRelatMapRules,
163
- components,
164
- selects,
165
- rootValue,
166
- dataLoad,
167
- rootForm
168
- }, appContext)
169
- }
170
-
171
- function selectFormat(value) {
172
- let valList = `${value}`
173
- const multiple = props?.config?.multiple == '1'
174
- const isStrVal = props.config?.valueType !== 'list'
175
- // 在满足多选,并且不是str格式的时候,就表示value为数组类型,取反就表示不满足的时候,需要转换成数组格式进行计算
176
- if (!(multiple && !isStrVal)) {
177
- try {
178
- valList = valList ? (valList?.split(props.separator) || []) : []
179
- } catch (error) {
180
- debugger
181
- }
182
- }
183
- return valList?.reduce((ret, val) => {
184
- const str = props?.options?.find(item => item.columnValue == val)?.[lang?.value?.indexOf('zh') > -1 ? 'columnDesc_zh' : 'columnDesc'] || ''
185
- return `${ret}${ret ? (props.separatorDesc || props.separator) : ''}${str}`
186
- }, '')
187
- }
188
-
189
- // 格式化显示
190
- function formatValue(value) {
191
- if (props.canShowFlag?.includes(String(value).toLowerCase())) {
192
- return value
193
- }
194
- if (value === null || isNaN(value)) return ''
195
- let val = `${value}`.replace(props.moneySeg, '')
196
- val = parseFloat(val)
197
- if (isNaN(val)) {
198
- return ''
199
- }
200
-
201
- // 转换数字并限制范围
202
- val = Math.max(props.min, Math.min(props.max, val))
203
-
204
- // 处理千分位
205
- if (props.decimal != '-1') {
206
- val = val.toFixed(props.decimal)
207
- }
208
- if (props.decimalSuffix != '1') {
209
- val = parseFloat(val)
210
- }
211
- const parts = `${val}`.split('.')
212
-
213
- parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, props.moneySeg)
214
-
215
- // 添加货币符号
216
- const formatted = parts.join('.')
217
- return props.showSymbol == '1'
218
- ? props.symbolPosition === 'before'
219
- ? `${props.symbol} ${formatted}`
220
- : `${formatted} ${props.symbol}`
221
- : formatted
222
- }
223
-
224
- watch(modelValue, () => {
225
- nextTick(() => {
226
- elFormItem?.validate?.('blur').catch()
227
- })
228
- }, {
229
- immediate: true
230
- })
231
- </script>
232
- <style lang="scss" scoped>
233
- .custom-component-plain {
234
- white-space: nowrap;
235
- text-overflow: ellipsis;
236
- overflow: hidden;
237
- }
238
- .custom-component-plain--primary {
239
- color: var(--el-color-primary);
240
- }
241
- .custom-component-plain--error {
242
- color: #F54A45;
243
- }
244
- .cursor {
245
- cursor: pointer;
246
- }
247
- </style>
@@ -1,83 +0,0 @@
1
- <template>
2
- <ElRow class="custom-component-row" :class="classRef" v-bind="{...attrs, ...elRowProps}">
3
- <Renderer :config="pmPageMetaList" v-model="props.refValue.value"></Renderer>
4
- </ElRow>
5
- </template>
6
- <script setup>
7
- import Renderer from '../../renderer.jsx'
8
- import { ElRow } from 'element-plus'
9
- import { computed, defineProps, useAttrs } from 'vue'
10
- import { commonPropsType } from '../../utils/index.js'
11
-
12
- defineEmits(['update:modelValue'])
13
-
14
- const props = defineProps({
15
- ...commonPropsType,
16
- ...ElRow.props
17
- })
18
- const elRowProps = computed(() => {
19
- return Object.keys(ElRow.props).reduce((ret, key) => {
20
- ret[key] = props[key]
21
- return ret
22
- }, {})
23
- })
24
- const attrs = useAttrs()
25
- const classRef = computed(() => {
26
- return {
27
- 'clear-right-margin': !reserveRightMargin.value,
28
- 'clear-bottom-margin': !reserveBottomMargin.value,
29
- 'not-context': allHidden.value
30
- }
31
- })
32
-
33
- const pmPageMetaList = computed(() => {
34
- return props.config?.pmPageMetaList || []
35
- })
36
-
37
- const allHidden = computed(() => {
38
- return !pmPageMetaList.value?.find(config => !((typeof config.hidden === 'boolean' && config.hidden) || config.hidden == '1'))
39
- })
40
- // 保留内部formItem的margin-right
41
- const reserveRightMargin = computed(() => {
42
- return props.config?.reserveRightMargin
43
- })
44
- // 保留内部formItem的margin-bottom
45
- const reserveBottomMargin = computed(() => {
46
- return props.config?.reserveBottomMargin
47
- })
48
- </script>
49
- <style lang="scss">
50
- .el-form-item__content, simple-form-item-content {
51
- & > .custom-component-row {
52
- width: 100%;
53
- }
54
- }
55
- .custom-component-row {
56
- max-width: 100%;
57
- .el-col {
58
- & > .el-form-item {
59
- }
60
- }
61
- }
62
- .clear-right-margin {
63
- .el-col {
64
- & > {
65
- .el-form-item, .simple-form-item {
66
- margin-right: 0;
67
- }
68
- }
69
- }
70
- }
71
- .not-context.not-context.not-context.not-context {
72
- margin-bottom: 0;
73
- }
74
- .clear-bottom-margin {
75
- .el-col {
76
- & > {
77
- .el-form-item, .simple-form-item {
78
- margin-bottom: 0;
79
- }
80
- }
81
- }
82
- }
83
- </style>
@@ -1,203 +0,0 @@
1
- <template>
2
- <div class="select-employees">
3
- <!-- <el-input @focus="showSelUserDialog">
4
- <template #suffix>
5
- <el-icon style="cursor: pointer;" @click="showSelUserDialog"><SearchIcon /></el-icon>
6
- </template>
7
- </el-input> -->
8
- <div :id="metaCode" :style="styleObj" class="xm-select-user" :class="[props.disabled ? 'is-disabled' : '']"></div>
9
- <div v-if="props.disabled" class="disable-employees"></div>
10
- </div>
11
- </template>
12
- <script setup>
13
- import { onMounted, inject, watch, defineProps, computed, defineEmits, nextTick, resolveComponent } from 'vue';
14
- import { useSelEmployeeJs } from '../helper/dock.js'
15
- import { commonPropsType, debounce, isBoolean, isString } from '../../utils/index.js'
16
- import { useFormItem } from 'element-plus'
17
-
18
- // const SearchIcon = resolveComponent('Search')
19
- // console.log('SearchIcon==:', SearchIcon)
20
- const { formItem: elFormItem } = useFormItem()
21
- const emit = defineEmits(['change'])
22
- const props = defineProps({
23
- ...commonPropsType,
24
- multiple: {
25
- type: [String, Boolean],
26
- default: false
27
- },
28
- // ====start==== 按部门查找人员,type为user时有效,结构为{deptIds:'xxx,yyy', cascade: true, excludeDeptIds:'xxx,yyy'}, deptIds为部门ID(如有多个用英文逗号分隔),cascade为是否包含下级部门人员, excludeDeptIds为除外部门ID(如有多个用英文逗号分隔)
29
- cascade: {
30
- type: Boolean,
31
- default: true
32
- },
33
- deptIds: {
34
- type: String,
35
- default: ''
36
- },
37
- excludeDeptIds: {
38
- type: String,
39
- default: ''
40
- },
41
- // ====end==== 按部门查找人员,type为user时有效,结构为{deptIds:'xxx,yyy', cascade: true, excludeDeptIds:'xxx,yyy'}, deptIds为部门ID(如有多个用英文逗号分隔),cascade为是否包含下级部门人员, excludeDeptIds为除外部门ID(如有多个用英文逗号分隔)
42
- type: {
43
- type: String,
44
- default: 'user'
45
- },
46
- isFrame: {
47
- type: [String, Number],
48
- default: '0'
49
- },
50
- placeholder: {
51
- type: String,
52
- default: ''
53
- },
54
- placeholderEn: {
55
- type: String,
56
- default: ''
57
- },
58
- // 多选的分割符号
59
- separator: {
60
- type: [String],
61
- default: ','
62
- },
63
- positionType: {
64
- type: String,
65
- default: 'fixed'
66
- },
67
- })
68
- const dataLoad = inject('dataLoad')
69
- const separator = computed(() => {
70
- return props.separator
71
- })
72
- const metaCode = computed(() => {
73
- return props.config.dynamicHireRelat?.replace(/(\]|\[|(->))/g, '')?.replace(' ', '').replace(/[!@#$%^&*]/g, '')
74
- // return `${props.config?.metaCode}-${props?.rowScope?.$index || ''}`
75
- })
76
- const styleObj = computed(() => {
77
- const obj = {}
78
- if (props.width) {
79
- obj.width = props.width
80
- }
81
- return obj
82
- })
83
- const lang = inject('lang')
84
- const modelValue = defineModel()
85
- watch(modelValue, () => {
86
- nextTick(() => {
87
- elFormItem?.validate?.('blur').catch()
88
- })
89
- })
90
- const initSelEmployee = async () => {
91
- let feiShuTokens = ''
92
- const { getToken, loadStyle, loadScript, initSelUser } = useSelEmployeeJs()
93
- let ret = await Promise.all([getToken(), loadStyle(), loadScript()])
94
- if (ret && ret.length) {
95
- feiShuTokens = ret[0]
96
- if (!feiShuTokens) return
97
- }
98
-
99
- const unWatch = watch(() => {
100
- return dataLoad.value
101
- }, async (val) => {
102
- if (!val) return
103
- await seelp(200)
104
- console.log('select-employees modelValue:', modelValue.value)
105
- const data = modelValue.value ? modelValue.value.split(separator.value) : []
106
- let deptForUser = {}
107
- if (props.deptIds || props.excludeDeptIds) {
108
- deptForUser.deptIds = isString(props.deptIds) ? props.deptIds : ''
109
- deptForUser.excludeDeptIds = isString(props.excludeDeptIds) ? props.excludeDeptIds : ''
110
- deptForUser.cascade = isBoolean(props.cascade) ? props.cascade : !!(props.cascade)
111
- }
112
- const initParams = {
113
- el: `#${metaCode.value}`,
114
- data,
115
- token: feiShuTokens,
116
- type: props.type,
117
- deptForUser,
118
- lang: lang.value,
119
- multiple: typeof props.multiple === 'boolean' ? props.multiple : props.multiple == '1',
120
- placeholder: lang?.value?.indexOf('zh') > -1 ? props.placeholder : props.placeholderEn,
121
- // disabled: props.disabled,
122
- onSelectedChange: (data, arr) => {
123
- console.log('onSelectedChange===:', data, arr)
124
- emit('change', data, arr, props)
125
- modelValue.value = data?.join(separator.value) || ''
126
- },
127
- }
128
- if (props.positionType) {
129
- initParams.positionType = props.positionType
130
- }
131
- if (props.disabled) {
132
- initParams.userIds = data
133
- }
134
- console.log(`metaCode:${props?.config?.metaCode},initParams:`, initParams)
135
- initSelUser(initParams)
136
- unWatch && unWatch()
137
- }, {
138
- immediate: true
139
- })
140
- }
141
-
142
- const showSelUserDialog = debounce(async function () {
143
- let feiShuTokens = ''
144
- const { getToken, loadScriptDepartment } = useSelEmployeeJs()
145
- let ret = await Promise.all([getToken(), loadScriptDepartment()])
146
- if (ret && ret.length) {
147
- feiShuTokens = ret[0]
148
- if (!feiShuTokens) return
149
- }
150
- _DIC_COMMON_JS_.showSelUserDialog({
151
- token: feiShuTokens,
152
- }, {
153
- needCompleteData: false,
154
- chooseType: 'all'
155
- })?.then((res) => {
156
- debugger
157
- })
158
- }, 200)
159
-
160
- function seelp(time) {
161
- return new Promise((resolve) => {
162
- setTimeout(() => {
163
- resolve(true)
164
- }, time);
165
- })
166
- }
167
- onMounted(() => {
168
- initSelEmployee()
169
- })
170
- </script>
171
-
172
- <style lang="scss">
173
- .select-employees {
174
- position: relative;
175
- width: 100%;
176
- .disable-employees {
177
- position: absolute;
178
- top: 0;
179
- bottom: 0;
180
- left: 0;
181
- right: 0;
182
- cursor: not-allowed;
183
- background: transparent;
184
- // cursor: no-drop;
185
- // background: #EFF0F1;
186
- // border: 1px solid #D0D3D6;
187
- // padding: 0 12px;
188
- // border-radius: 4px;
189
- // height: 32px;
190
- }
191
- xm-select > .xm-label .scroll .label-content {
192
- line-height: 24px;
193
- padding-left: 10px !important;
194
- padding-top: 3px !important;
195
- padding-bottom: 3px !important;
196
- }
197
- .is-disabled {
198
- xm-select {
199
- background: var(--el-disabled-bg-color);
200
- }
201
- }
202
- }
203
- </style>
@@ -1,62 +0,0 @@
1
- <template>
2
- <ElButton @click="buttonAction" v-bind="{...attrs, ...calcPorps}">
3
- {{label}}
4
- </ElButton>
5
- </template>
6
- <script setup>
7
- import { ElButton } from 'element-plus'
8
- import { defineProps, inject, computed, useAttrs } from 'vue'
9
- import { commonPropsType } from '../../utils/index.js'
10
- import thirdPartyFrame from '../thirdPartyFrame'
11
- import { MAIL_SEND_URL } from '../../api/builtIn.js'
12
-
13
- const props = defineProps({
14
- ...commonPropsType,
15
- ...ElButton.props,
16
- toHref: String,
17
- plain: [String, Number, Boolean],
18
- circle: [String, Number, Boolean]
19
- })
20
- const calcPorps = computed(() => {
21
- const ret = {
22
- ...props
23
- }
24
- if (ret.plain == '1') {
25
- ret.plain = true
26
- } else {
27
- ret.plain = false
28
- }
29
-
30
- if (ret.circle == '1') {
31
- ret.circle = true
32
- } else {
33
- ret.circle = false
34
- }
35
- if (props?.config?.rounds && props?.config?.rounds == '1') {
36
- ret.round = true
37
- }
38
- if (props?.config?.widgetSize) {
39
- ret.size = props?.config?.widgetSize
40
- }
41
- if (props?.config?.displayType) {
42
- ret.type = props?.config?.displayType
43
- }
44
- return ret
45
- })
46
-
47
- const attrs = useAttrs()
48
-
49
- const lang = inject('lang')
50
-
51
- const label = computed(() => {
52
- return lang.value.indexOf('zh') > -1 ? (props.config?.labelZh || props.config?.metaNameZh) : (props.config?.labelEn || props.config?.metaNameEn)
53
- })
54
-
55
- const buttonAction = () => {
56
- thirdPartyFrame({
57
- lang: lang?.value,
58
- showClose: true,
59
- src: `${MAIL_SEND_URL}?showMenuHead=5&fullScreen=true&apToken=${props.toHref}`
60
- })
61
- }
62
- </script>
@@ -1,41 +0,0 @@
1
- <script setup>
2
- import { ElSteps } from 'element-plus'
3
- import { computed, defineProps, inject, useAttrs } from 'vue'
4
- import { commonPropsType, hasOwn } from '../../utils/index.js'
5
-
6
- const modelValue = defineModel()
7
- const props = defineProps({
8
- ...commonPropsType,
9
- ...ElSteps.props,
10
- })
11
- const calcProps = computed(() => {
12
- const ret = Object.keys(ElSteps.props).reduce((total, key) => {
13
- total[key] = props[key]
14
- return total
15
- }, {})
16
- ret.simple = props.config?.displayType === 'simple'
17
- if (!hasOwn(props.config, 'finish-status') && !hasOwn(props.config, 'finishStatus')) {
18
- ret.finishStatus = 'finish'
19
- }
20
- if (!ret.direction) {
21
- ret.direction = 'horizontal'
22
- }
23
- return ret
24
- })
25
- const lang = inject('lang')
26
- const attrs = useAttrs()
27
-
28
- const optionItems = computed(() => {
29
- return JSON.parse(props.config?.optionItems || '[]')
30
- })
31
-
32
- </script>
33
- <template>
34
- <ElSteps v-bind="{...attrs, ...calcProps}" :active="modelValue || 0">
35
- <el-step v-for="(item, index) in optionItems" :key="index"
36
- :title="lang.indexOf('zh') > -1 ? item.title_zh : item.title_en"
37
- :description="lang.indexOf('zh') > -1 ? item.description_zh : item.description_en"
38
- :icon="!!item.icon ? item.icon : ''"
39
- />
40
- </ElSteps>
41
- </template>
@@ -1,20 +0,0 @@
1
- <template>
2
- <component :is="comp" v-bind="attrs"></component>
3
- </template>
4
- <script setup>
5
- import { useAttrs } from 'vue'
6
- import CustomComponentCycleTabPane from './CustomComponentCycleTabPane.vue'
7
- import CustomComponentNativeTabPane from './CustomComponentNativeTabPane.vue'
8
- import { computed } from 'vue'
9
-
10
- const attrs = useAttrs()
11
- const props = defineProps({
12
- isCycle: {
13
- type: [String, Number],
14
- default: '0'
15
- }
16
- })
17
- const comp = computed(() => {
18
- return props.isCycle == '1' ? CustomComponentCycleTabPane : CustomComponentNativeTabPane
19
- })
20
- </script>