tianheng-ui 0.0.56 → 0.0.57

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 (238) hide show
  1. package/lib/039af9192b9bb277966ceb4e4ce29c41.js +16 -0
  2. package/lib/{c755e7fc08446566ee8dd3a8aa8fe43f.js → 2d84c80112a372bc149cad3464e90fa3.js} +404 -502
  3. package/lib/5977b934a4c6b480790864ea01303173.js +10834 -0
  4. package/lib/7745f3e776488705a38e62f85adad54d.js +16 -0
  5. package/lib/de8dee841ffdaaede3a2254deef30376.js +15395 -0
  6. package/lib/e78eab250e7f8ccac3d918dfdb06ca10.js +8904 -0
  7. package/lib/index.js +4 -2
  8. package/lib/theme-chalk/fonts/PingFang.ttf +0 -0
  9. package/lib/theme-chalk/fonts/bpmn.eot +0 -0
  10. package/lib/theme-chalk/fonts/bpmn.svg +224 -0
  11. package/lib/theme-chalk/fonts/bpmn.ttf +0 -0
  12. package/lib/theme-chalk/fonts/bpmn.woff +0 -0
  13. package/lib/theme-chalk/fonts/bpmn.woff2 +0 -0
  14. package/lib/theme-chalk/fonts/fontawesome-webfont.eot +0 -0
  15. package/lib/theme-chalk/fonts/fontawesome-webfont.svg +2671 -0
  16. package/lib/theme-chalk/fonts/fontawesome-webfont.ttf +0 -0
  17. package/lib/theme-chalk/fonts/fontawesome-webfont.woff +0 -0
  18. package/lib/theme-chalk/fonts/fontawesome-webfont.woff2 +0 -0
  19. package/lib/{iconfont.eot → theme-chalk/fonts/iconfont.eot} +0 -0
  20. package/lib/{iconfont.svg → theme-chalk/fonts/iconfont.svg} +0 -0
  21. package/lib/theme-chalk/fonts/iconfont.ttf +0 -0
  22. package/lib/theme-chalk/fonts/iconfont.woff +0 -0
  23. package/lib/theme-chalk/images/notData.png +0 -0
  24. package/lib/theme-chalk/index.scss +29 -0
  25. package/lib/theme-chalk/styles/button.scss +501 -0
  26. package/lib/theme-chalk/styles/card.scss +29 -0
  27. package/lib/theme-chalk/styles/cell.scss +54 -0
  28. package/lib/theme-chalk/styles/codeEditor.scss +9 -0
  29. package/lib/theme-chalk/styles/col.scss +151 -0
  30. package/lib/theme-chalk/styles/dialog.scss +59 -0
  31. package/lib/theme-chalk/styles/empty.scss +22 -0
  32. package/lib/theme-chalk/styles/feature.scss +42 -0
  33. package/lib/theme-chalk/styles/font.css +7 -0
  34. package/lib/theme-chalk/{icon.css → styles/icon.css} +3 -3
  35. package/lib/theme-chalk/styles/imagePreview.scss +113 -0
  36. package/lib/theme-chalk/styles/img.scss +35 -0
  37. package/lib/theme-chalk/styles/reset.scss +8 -0
  38. package/lib/theme-chalk/{root.css → styles/root.css} +2 -35
  39. package/lib/theme-chalk/styles/row.scss +23 -0
  40. package/lib/theme-chalk/styles/variable.scss +80 -0
  41. package/lib/tianheng-ui.js +71 -9
  42. package/package.json +24 -4
  43. package/packages/Button/index.js +8 -0
  44. package/packages/Button/index.vue +80 -0
  45. package/packages/Card/index.js +8 -0
  46. package/packages/Card/index.vue +37 -0
  47. package/packages/{cell → Cell}/index.js +0 -0
  48. package/packages/Cell/index.vue +68 -0
  49. package/packages/{codeEditor → CodeEditor}/index.js +0 -0
  50. package/packages/{codeEditor → CodeEditor}/index.vue +73 -108
  51. package/packages/Col/index.js +8 -0
  52. package/packages/Col/index.vue +41 -0
  53. package/packages/{dialog → Dialog}/index.js +0 -0
  54. package/packages/{dialog → Dialog}/index.vue +19 -10
  55. package/packages/Empty/images/notData.png +0 -0
  56. package/packages/{empty → Empty}/index.js +0 -0
  57. package/packages/Empty/index.vue +35 -0
  58. package/packages/FormMaking/Container.vue +1907 -0
  59. package/packages/{formMaking → FormMaking}/FormConfig.vue +22 -6
  60. package/packages/FormMaking/GenerateForm.vue +246 -0
  61. package/packages/{formMaking → FormMaking}/GenerateFormItem.vue +340 -172
  62. package/packages/FormMaking/GenerateFormItemH5.vue +828 -0
  63. package/packages/{formMaking → FormMaking}/Upload/index.vue +0 -0
  64. package/packages/FormMaking/WidgetConfig.vue +473 -0
  65. package/packages/{formMaking → FormMaking}/WidgetForm.vue +49 -31
  66. package/packages/FormMaking/WidgetFormItem.vue +157 -0
  67. package/packages/{formMaking/componentsConfig.js → FormMaking/custom/config.js} +379 -163
  68. package/packages/FormMaking/custom/configs/alliance.vue +0 -0
  69. package/packages/FormMaking/custom/configs/blank.vue +54 -0
  70. package/packages/FormMaking/custom/configs/button.vue +144 -0
  71. package/packages/FormMaking/custom/configs/cascader.vue +182 -0
  72. package/packages/FormMaking/custom/configs/cell.vue +81 -0
  73. package/packages/FormMaking/custom/configs/checkbox.vue +237 -0
  74. package/packages/FormMaking/custom/configs/color.vue +137 -0
  75. package/packages/FormMaking/custom/configs/date.vue +158 -0
  76. package/packages/FormMaking/custom/configs/divider.vue +61 -0
  77. package/packages/FormMaking/custom/configs/editor.vue +71 -0
  78. package/packages/FormMaking/custom/configs/filler.vue +52 -0
  79. package/packages/FormMaking/custom/configs/grid.vue +103 -0
  80. package/packages/FormMaking/custom/configs/image.vue +148 -0
  81. package/packages/FormMaking/custom/configs/input.vue +176 -0
  82. package/packages/FormMaking/custom/configs/number.vue +140 -0
  83. package/packages/FormMaking/custom/configs/radio.vue +215 -0
  84. package/packages/FormMaking/custom/configs/rate.vue +109 -0
  85. package/packages/FormMaking/custom/configs/select.vue +308 -0
  86. package/packages/FormMaking/custom/configs/slider.vue +142 -0
  87. package/packages/FormMaking/custom/configs/switch.vue +130 -0
  88. package/packages/FormMaking/custom/configs/table.vue +105 -0
  89. package/packages/FormMaking/custom/configs/table_h5.vue +102 -0
  90. package/packages/FormMaking/custom/configs/tabs.vue +175 -0
  91. package/packages/FormMaking/custom/configs/text.vue +71 -0
  92. package/packages/FormMaking/custom/configs/textarea.vue +167 -0
  93. package/packages/FormMaking/custom/configs/time.vue +153 -0
  94. package/packages/FormMaking/custom/configs/upload.vue +150 -0
  95. package/packages/FormMaking/custom/index.js +33 -0
  96. package/packages/FormMaking/custom/items/alliance.vue +132 -0
  97. package/packages/FormMaking/custom/items/blank.vue +16 -0
  98. package/packages/FormMaking/custom/items/button.vue +27 -0
  99. package/packages/FormMaking/custom/items/cascader.vue +29 -0
  100. package/packages/FormMaking/custom/items/cell.vue +18 -0
  101. package/packages/FormMaking/custom/items/checkbox.vue +46 -0
  102. package/packages/FormMaking/custom/items/color.vue +19 -0
  103. package/packages/FormMaking/custom/items/date.vue +29 -0
  104. package/packages/FormMaking/custom/items/divider.vue +14 -0
  105. package/packages/FormMaking/custom/items/editor.vue +22 -0
  106. package/packages/FormMaking/custom/items/filler.vue +17 -0
  107. package/packages/FormMaking/custom/items/grid.vue +129 -0
  108. package/packages/FormMaking/custom/items/image.vue +42 -0
  109. package/packages/FormMaking/custom/items/input.vue +36 -0
  110. package/packages/FormMaking/custom/items/login.vue +13 -0
  111. package/packages/FormMaking/custom/items/number.vue +24 -0
  112. package/packages/FormMaking/custom/items/radio.vue +44 -0
  113. package/packages/FormMaking/custom/items/rate.vue +20 -0
  114. package/packages/FormMaking/custom/items/select.vue +32 -0
  115. package/packages/FormMaking/custom/items/slider.vue +34 -0
  116. package/packages/FormMaking/custom/items/switch.vue +22 -0
  117. package/packages/FormMaking/custom/items/table.vue +106 -0
  118. package/packages/FormMaking/custom/items/table_h5.vue +126 -0
  119. package/packages/FormMaking/custom/items/tabs.vue +145 -0
  120. package/packages/FormMaking/custom/items/text.vue +18 -0
  121. package/packages/FormMaking/custom/items/textarea.vue +37 -0
  122. package/packages/FormMaking/custom/items/time.vue +32 -0
  123. package/packages/FormMaking/custom/items/upload.vue +83 -0
  124. package/packages/FormMaking/custom/mixins/index.js +61 -0
  125. package/packages/FormMaking/custom/register.js +18 -0
  126. package/packages/{formMaking → FormMaking}/iconfont/demo.css +0 -0
  127. package/packages/{formMaking → FormMaking}/iconfont/demo_index.html +0 -0
  128. package/packages/{formMaking → FormMaking}/iconfont/iconfont.css +0 -0
  129. package/packages/{formMaking → FormMaking}/iconfont/iconfont.eot +0 -0
  130. package/packages/{formMaking → FormMaking}/iconfont/iconfont.js +0 -0
  131. package/packages/{formMaking → FormMaking}/iconfont/iconfont.svg +0 -0
  132. package/{lib → packages/FormMaking/iconfont}/iconfont.ttf +0 -0
  133. package/{lib → packages/FormMaking/iconfont}/iconfont.woff +0 -0
  134. package/packages/{formMaking → FormMaking}/iconfont/iconfont.woff2 +0 -0
  135. package/packages/FormMaking/index.js +35 -0
  136. package/packages/{formMaking → FormMaking}/lang/en-US.js +1 -1
  137. package/packages/{formMaking → FormMaking}/lang/zh-CN.js +1 -1
  138. package/packages/{formMaking → FormMaking}/styles/cover.scss +1 -1
  139. package/packages/{formMaking → FormMaking}/styles/index.scss +445 -429
  140. package/packages/{formMaking → FormMaking/util}/generateCode.js +5 -5
  141. package/packages/{formMaking → FormMaking}/util/index.js +0 -0
  142. package/packages/{formMaking → FormMaking}/util/request.js +0 -0
  143. package/packages/{icons → Icons}/index.js +0 -0
  144. package/packages/{icons → Icons}/index.vue +26 -9
  145. package/packages/Image/index.js +8 -0
  146. package/packages/Image/index.vue +146 -0
  147. package/packages/ImagePreview/index.js +8 -0
  148. package/packages/ImagePreview/index.vue +386 -0
  149. package/packages/Row/index.js +8 -0
  150. package/packages/Row/index.vue +35 -0
  151. package/packages/{table → Table}/action.js +0 -0
  152. package/packages/{table → Table}/action.vue +1 -1
  153. package/packages/Table/column.vue +63 -0
  154. package/packages/{table → Table}/index.js +0 -0
  155. package/packages/{table → Table}/index.vue +25 -23
  156. package/packages/{table → Table}/search.js +0 -0
  157. package/packages/{table → Table}/search.vue +2 -2
  158. package/packages/{table → Table}/tools.js +0 -0
  159. package/packages/{table → Table}/tools.vue +0 -0
  160. package/packages/Workflow/Log.js +99 -0
  161. package/packages/Workflow/designer/ProcessDesigner.vue +628 -0
  162. package/packages/Workflow/designer/index.js +7 -0
  163. package/packages/Workflow/designer/plugins/content-pad/contentPadProvider.js +390 -0
  164. package/packages/Workflow/designer/plugins/content-pad/index.js +6 -0
  165. package/packages/Workflow/designer/plugins/defaultEmpty.js +24 -0
  166. package/packages/Workflow/designer/plugins/descriptor/activitiDescriptor.json +1071 -0
  167. package/packages/Workflow/designer/plugins/descriptor/camundaDescriptor.json +1087 -0
  168. package/packages/Workflow/designer/plugins/descriptor/flowableDescriptor.json +1215 -0
  169. package/packages/Workflow/designer/plugins/extension-moddle/activiti/activitiExtension.js +74 -0
  170. package/packages/Workflow/designer/plugins/extension-moddle/activiti/index.js +9 -0
  171. package/packages/Workflow/designer/plugins/extension-moddle/camunda/extension.js +148 -0
  172. package/packages/Workflow/designer/plugins/extension-moddle/camunda/index.js +6 -0
  173. package/packages/Workflow/designer/plugins/extension-moddle/flowable/flowableExtension.js +74 -0
  174. package/packages/Workflow/designer/plugins/extension-moddle/flowable/index.js +9 -0
  175. package/packages/Workflow/designer/plugins/palette/CustomPalette.js +156 -0
  176. package/packages/Workflow/designer/plugins/palette/index.js +6 -0
  177. package/packages/Workflow/designer/plugins/palette/paletteProvider.js +160 -0
  178. package/packages/Workflow/designer/plugins/translate/customTranslate.js +41 -0
  179. package/packages/Workflow/designer/plugins/translate/zh.js +238 -0
  180. package/packages/Workflow/highlight/index.js +5 -0
  181. package/packages/Workflow/index.js +26 -0
  182. package/packages/Workflow/index.vue +394 -0
  183. package/packages/Workflow/modules/auto-place/CustomAutoPlace.js +81 -0
  184. package/packages/Workflow/modules/auto-place/index.js +6 -0
  185. package/packages/Workflow/modules/custom-renderer/CustomRenderer.js +17 -0
  186. package/packages/Workflow/modules/custom-renderer/index.js +6 -0
  187. package/packages/Workflow/modules/rules/CustomRules.js +16 -0
  188. package/packages/Workflow/modules/rules/index.js +6 -0
  189. package/packages/Workflow/palette/ProcessPalette.vue +106 -0
  190. package/packages/Workflow/palette/index.js +7 -0
  191. package/packages/Workflow/penal/PropertiesPanel.vue +247 -0
  192. package/packages/Workflow/penal/base/ElementBaseInfo.vue +80 -0
  193. package/packages/Workflow/penal/flow-condition/FlowCondition.vue +142 -0
  194. package/packages/Workflow/penal/form/ElementForm.vue +367 -0
  195. package/packages/Workflow/penal/index.js +7 -0
  196. package/packages/Workflow/penal/listeners/ElementListeners.vue +299 -0
  197. package/packages/Workflow/penal/listeners/UserTaskListeners.vue +322 -0
  198. package/packages/Workflow/penal/listeners/template.js +178 -0
  199. package/packages/Workflow/penal/listeners/utilSelf.js +62 -0
  200. package/packages/Workflow/penal/multi-instance/ElementMultiInstance.vue +200 -0
  201. package/packages/Workflow/penal/other/ElementOtherConfig.vue +59 -0
  202. package/packages/Workflow/penal/properties/ElementProperties.vue +135 -0
  203. package/packages/Workflow/penal/signal-message/SignalAndMessage.vue +104 -0
  204. package/packages/Workflow/penal/task/ElementTask.vue +73 -0
  205. package/packages/Workflow/penal/task/task-components/ReceiveTask.vue +97 -0
  206. package/packages/Workflow/penal/task/task-components/ScriptTask.vue +85 -0
  207. package/packages/Workflow/penal/task/task-components/UserTask.vue +535 -0
  208. package/packages/Workflow/theme/element-variables.scss +70 -0
  209. package/packages/Workflow/theme/index.scss +2 -0
  210. package/packages/Workflow/theme/process-designer.scss +157 -0
  211. package/packages/Workflow/theme/process-panel.scss +107 -0
  212. package/packages/Workflow/translations.js +25 -0
  213. package/packages/Workflow/utils.js +71 -0
  214. package/packages/upload/ajax.js +85 -0
  215. package/packages/upload/index.js +8 -0
  216. package/packages/upload/index.vue +325 -0
  217. package/packages/upload/locale.js +9 -0
  218. package/packages/upload/upload-dragger.vue +70 -0
  219. package/packages/upload/upload-list.vue +101 -0
  220. package/packages/upload/upload.vue +211 -0
  221. package/lib/03250ed25fc1b305e9980cf7cf0dfb09.js +0 -1
  222. package/lib/theme-chalk/cell.css +0 -53
  223. package/lib/theme-chalk/dialog.css +0 -41
  224. package/lib/theme-chalk/empty.css +0 -27
  225. package/lib/theme-chalk/index.css +0 -6
  226. package/lib/theme-chalk/reset.css +0 -4
  227. package/lib/tianheng-ui.js.map +0 -1
  228. package/packages/cell/index.vue +0 -116
  229. package/packages/empty/index.vue +0 -33
  230. package/packages/formMaking/Container.vue +0 -591
  231. package/packages/formMaking/CusDialog.vue +0 -134
  232. package/packages/formMaking/GenerateForm.vue +0 -174
  233. package/packages/formMaking/WidgetConfig.vue +0 -1539
  234. package/packages/formMaking/WidgetFormItem.vue +0 -817
  235. package/packages/formMaking/iconfont/iconfont.ttf +0 -0
  236. package/packages/formMaking/iconfont/iconfont.woff +0 -0
  237. package/packages/formMaking/index.js +0 -77
  238. package/packages/table/column.vue +0 -111
@@ -0,0 +1,473 @@
1
+ <template>
2
+ <div v-if="show">
3
+ <component
4
+ :widget="data"
5
+ :config="config"
6
+ :remoteApis="remoteApis"
7
+ :is="compsData[data.type].content"
8
+ @events-show="handleEventDialogShow"
9
+ @events-edit="handleEventsCollapseClick"
10
+ ></component>
11
+
12
+ <th-dialog
13
+ title="动作设置"
14
+ v-model="eventsDialog.visible"
15
+ @on-fullscreen="$refs.codeEditor && $refs.codeEditor.resize()"
16
+ >
17
+ <div class="eventsSetting">
18
+ <div class="list">
19
+ <div class="list-header" @click="handleAddEvent">
20
+ <div>动作库</div>
21
+ <el-button type="text" icon="el-icon-plus" size="mini"
22
+ >添加</el-button
23
+ >
24
+ </div>
25
+ <div
26
+ class="list-item"
27
+ v-for="(item, index) in eventsDialog.eventScript"
28
+ :key="item.key"
29
+ @click="eventsDialog.active = item"
30
+ >
31
+ <div class="list-item-title">Function</div>
32
+ <div class="list-item-value">{{ item.name }}</div>
33
+ <i
34
+ class="el-icon-delete"
35
+ @click.stop="handleEventDialogDelete(item, index)"
36
+ ></i>
37
+ </div>
38
+ </div>
39
+ <div class="detail" v-if="eventsDialog.active">
40
+ <div>
41
+ <span>Function Name</span>
42
+ <el-input
43
+ v-model="eventsDialog.active.name"
44
+ placeholder="请输入动作名称"
45
+ size="small"
46
+ :disabled="
47
+ eventsDialog.active.name === 'mounted' ||
48
+ eventsDialog.active.name === 'refresh'
49
+ "
50
+ ></el-input>
51
+ </div>
52
+ <div>
53
+ <div>
54
+ function(
55
+ {{
56
+ eventsDialog.active.name !== "mounted" &&
57
+ eventsDialog.active.name !== "refresh"
58
+ ? "item,value"
59
+ : ""
60
+ }}
61
+ ) {
62
+
63
+ <el-popover
64
+ placement="top-start"
65
+ title="可用Api"
66
+ width="200"
67
+ trigger="hover"
68
+ >
69
+ <i
70
+ style="float: right;"
71
+ slot="reference"
72
+ class="el-icon-question"
73
+ ></i>
74
+ <div class="functions">
75
+ <div>setData</div>
76
+ <div>getData</div>
77
+ <div>display</div>
78
+ <div>hide</div>
79
+ </div>
80
+ </el-popover>
81
+ </div>
82
+ <th-code-editor
83
+ style="height:calc(100% - 48px)"
84
+ v-model="eventsDialog.active.func"
85
+ :completions="aceCompletions"
86
+ ref="codeEditor"
87
+ ></th-code-editor>
88
+ <div>}</div>
89
+ </div>
90
+ </div>
91
+ </div>
92
+ <span slot="footer" class="dialog-footer">
93
+ <el-button size="small" @click="eventsDialog.visible = false"
94
+ >取 消</el-button
95
+ >
96
+ <el-button type="primary" size="small" @click="handleEventDialogAffirm"
97
+ >保 存</el-button
98
+ >
99
+ </span>
100
+ </th-dialog>
101
+ </div>
102
+ </template>
103
+
104
+ <script>
105
+ import compsData from "./custom/register";
106
+ import ThDialog from "ui/dialog/index.vue";
107
+ import ThCodeEditor from "ui/codeEditor/index.vue";
108
+ export default {
109
+ components: { ThDialog, ThCodeEditor },
110
+ props: {
111
+ data: {
112
+ type: Object,
113
+ default: () => {
114
+ return {};
115
+ }
116
+ },
117
+ remoteApis: {
118
+ type: Array,
119
+ default: () => {
120
+ return [];
121
+ }
122
+ },
123
+ config: {
124
+ type: Object,
125
+ default: () => {
126
+ return {};
127
+ }
128
+ }
129
+ },
130
+ data() {
131
+ return {
132
+ compsData: JSON.parse(JSON.stringify(compsData)),
133
+ validator: {
134
+ type: null,
135
+ required: null,
136
+ pattern: null,
137
+ range: null,
138
+ length: null
139
+ },
140
+ eventsDialog: {
141
+ visible: false,
142
+ eventScript: [],
143
+ active: null
144
+ },
145
+ aceCompletions: [
146
+ {
147
+ meta: "设置数据",
148
+ caption: "setData",
149
+ value: "setData({ })",
150
+ score: 1
151
+ },
152
+ {
153
+ meta: "获取数据",
154
+ caption: "getData",
155
+ value: "getData()",
156
+ score: 1
157
+ },
158
+ {
159
+ meta: "显示组件",
160
+ caption: "display",
161
+ value: "display([ ])",
162
+ score: 1
163
+ },
164
+ {
165
+ meta: "隐藏组件",
166
+ caption: "hide",
167
+ value: "hide([ ])",
168
+ score: 1
169
+ }
170
+ ]
171
+ };
172
+ },
173
+ computed: {
174
+ show() {
175
+ if (this.data && Object.keys(this.data).length > 0) {
176
+ return true;
177
+ }
178
+ return false;
179
+ }
180
+ },
181
+ created() {
182
+ const keys = Object.keys(this.compsData);
183
+ for (const key of keys) {
184
+ this.compsData[key].content = require(`./custom/configs/${key}`).default;
185
+ }
186
+ },
187
+ methods: {
188
+ generateRule() {
189
+ this.data.rules = [];
190
+ Object.keys(this.validator).forEach(key => {
191
+ if (this.validator[key]) {
192
+ this.data.rules.push(this.validator[key]);
193
+ }
194
+ });
195
+ },
196
+
197
+ validateRequired(val) {
198
+ if (val) {
199
+ this.validator.required = {
200
+ required: true,
201
+ message: `${this.data.name}必须填写`
202
+ };
203
+ } else {
204
+ this.validator.required = null;
205
+ }
206
+
207
+ this.$nextTick(() => {
208
+ this.generateRule();
209
+ });
210
+ },
211
+
212
+ validateDataType(val) {
213
+ if (!this.show) {
214
+ return false;
215
+ }
216
+
217
+ if (val) {
218
+ this.validator.type = {
219
+ type: val,
220
+ message: this.data.name + "格式不正确"
221
+ };
222
+ } else {
223
+ this.validator.type = null;
224
+ }
225
+
226
+ this.generateRule();
227
+ },
228
+ valiatePattern(val) {
229
+ if (!this.show) {
230
+ return false;
231
+ }
232
+
233
+ if (val) {
234
+ this.validator.pattern = {
235
+ pattern: val,
236
+ message: this.data.name + "格式不匹配"
237
+ };
238
+ } else {
239
+ this.validator.pattern = null;
240
+ }
241
+
242
+ this.generateRule();
243
+ },
244
+ handleInputNumberChange() {
245
+ if (this.data.options.minRows > this.data.options.maxRows) {
246
+ this.data.options.maxRows = this.data.options.minRows;
247
+ }
248
+ },
249
+ handleImguploadType(val) {
250
+ if (val == "picture-card") {
251
+ this.data.options.drag = false;
252
+ }
253
+ },
254
+ handleImguploadDrag(val) {
255
+ if (val) {
256
+ this.data.options.listType = "default";
257
+ }
258
+ },
259
+ handleEventDialogShow() {
260
+ this.eventsDialog = {
261
+ visible: true,
262
+ eventScript: JSON.parse(JSON.stringify(this.config.eventScript)),
263
+ active: null
264
+ };
265
+ },
266
+ handleAddEvent() {
267
+ const key = new Date().getTime();
268
+ const dic = {
269
+ key: key,
270
+ name: key,
271
+ func: ""
272
+ };
273
+ this.eventsDialog.eventScript.push(dic);
274
+ this.eventsDialog.active = dic;
275
+ },
276
+ handleEventDialogAffirm() {
277
+ this.config.eventScript = this.eventsDialog.eventScript;
278
+ this.eventsDialog = {
279
+ visible: false,
280
+ eventScript: [],
281
+ active: null
282
+ };
283
+ },
284
+ handleEventDialogDelete(item, index) {
285
+ this.$confirm(`确定要删除该方法 ${item.name} ?`, "", {
286
+ confirmButtonText: "确定",
287
+ cancelButtonText: "取消",
288
+ type: "warning"
289
+ })
290
+ .then(() => {
291
+ if (
292
+ this.eventsDialog.active &&
293
+ item.key === this.eventsDialog.active.key
294
+ ) {
295
+ this.eventsDialog.active = null;
296
+ }
297
+ this.eventsDialog.eventScript.splice(index, 1);
298
+ })
299
+ .catch();
300
+ },
301
+ handleEventsCollapseClick(eventKey) {
302
+ for (let i = 0; i < this.config.eventScript.length; i++) {
303
+ const event = this.config.eventScript[i];
304
+ if (event.key === eventKey) {
305
+ const eventScript = JSON.parse(
306
+ JSON.stringify(this.config.eventScript)
307
+ );
308
+ this.eventsDialog = {
309
+ visible: true,
310
+ eventScript: eventScript,
311
+ active: eventScript[i]
312
+ };
313
+ break;
314
+ }
315
+ }
316
+ }
317
+ },
318
+ watch: {
319
+ "data.options.isRange": function(val) {
320
+ if (typeof val !== "undefined") {
321
+ if (val) {
322
+ this.data.options.defaultValue = null;
323
+ } else {
324
+ if (Object.keys(this.data.options).indexOf("defaultValue") >= 0)
325
+ this.data.options.defaultValue = "";
326
+ }
327
+ }
328
+ },
329
+ "data.options.required": function(val) {
330
+ this.validateRequired(val);
331
+ },
332
+ "data.options.dataType": function(val) {
333
+ this.validateDataType(val);
334
+ },
335
+ "data.options.pattern": function(val) {
336
+ this.valiatePattern(val);
337
+ },
338
+ "data.name": function(val) {
339
+ if (this.data.options) {
340
+ this.validateRequired(this.data.options.required);
341
+ this.validateDataType(this.data.options.dataType);
342
+ this.valiatePattern(this.data.options.pattern);
343
+ }
344
+ }
345
+ }
346
+ };
347
+ </script>
348
+
349
+ <style lang="less" scoped>
350
+ .remoteApis {
351
+ width: 100%;
352
+ margin-bottom: 6px;
353
+
354
+ /deep/ .el-input--prefix .el-input__inner {
355
+ padding-left: 85px;
356
+ }
357
+
358
+ /deep/ .el-input__prefix {
359
+ left: 0;
360
+ width: 75px;
361
+ color: #999;
362
+ }
363
+ }
364
+
365
+ /deep/ .el-form-item__label {
366
+ width: 100%;
367
+ }
368
+
369
+ .el-dialog__body {
370
+ padding: 20px;
371
+ }
372
+
373
+ .eventsSetting {
374
+ height: 100%;
375
+ display: flex;
376
+ border: 1px solid #eee;
377
+
378
+ .list {
379
+ width: 270px;
380
+ min-height: 430px;
381
+ overflow-y: overlay;
382
+ border-right: 1px solid #eee;
383
+
384
+ .list-header {
385
+ position: sticky;
386
+ top: 0;
387
+ display: flex;
388
+ align-items: center;
389
+ justify-content: space-between;
390
+ padding: 5px;
391
+ line-height: 30px;
392
+ border-bottom: 1px solid #eee;
393
+ background: #f2f6fc;
394
+ }
395
+
396
+ .list-item {
397
+ display: flex;
398
+ // align-items: center;
399
+ margin: 5px;
400
+ padding: 10px;
401
+ border-radius: 3px;
402
+ border: 1px solid #dcdfe6;
403
+ transition: 0.25s;
404
+
405
+ .list-item-title {
406
+ color: var(--th-green);
407
+ }
408
+ .list-item-value {
409
+ flex: 1;
410
+ padding: 0 5px;
411
+ }
412
+ i {
413
+ cursor: pointer;
414
+ }
415
+ }
416
+
417
+ .list-item:hover {
418
+ background-color: #f2f6fc;
419
+ }
420
+ }
421
+
422
+ .detail {
423
+ flex: 1;
424
+ padding: 10px;
425
+
426
+ > div:nth-child(1) {
427
+ position: relative;
428
+ display: flex;
429
+ align-items: center;
430
+ margin-bottom: 20px;
431
+ padding-left: 10px;
432
+
433
+ /deep/ .el-input {
434
+ flex: 1;
435
+ margin-left: 10px;
436
+ }
437
+ }
438
+
439
+ > div:nth-child(1)::after {
440
+ content: "*";
441
+ position: absolute;
442
+ left: 0;
443
+ color: red;
444
+ }
445
+
446
+ > div:nth-child(2) {
447
+ height: calc(100% - 48px);
448
+ > div:nth-child(1) {
449
+ margin-bottom: 10px;
450
+ color: var(--th-blue);
451
+ }
452
+
453
+ > div:nth-child(3) {
454
+ margin-top: 10px;
455
+ color: var(--th-blue);
456
+ }
457
+ }
458
+ }
459
+ }
460
+ .selectableRange {
461
+ width: 100%;
462
+
463
+ /deep/ .el-range-separator {
464
+ width: 20px;
465
+ }
466
+ }
467
+
468
+ .functions {
469
+ span {
470
+ margin: 0 5px;
471
+ }
472
+ }
473
+ </style>
@@ -1,15 +1,26 @@
1
1
  <template>
2
- <div class="widget-form-container">
3
- <div v-if="data.list.length == 0" class="form-empty">
2
+ <div class="widget-form-container" ref="formContainer">
3
+ <!-- <div v-if="data.list.length == 0" class="form-empty">
4
4
  从左侧拖拽来添加字段
5
- </div>
5
+ </div> -->
6
+ <th-empty
7
+ class="form-empty"
8
+ v-if="data.list.length == 0"
9
+ :image="require('@/assets/images/notData.png')"
10
+ description="从左侧拖拽来添加字段"
11
+ ></th-empty>
6
12
  <el-form
13
+ :class="{ 'form-hideLabel': data.config.hideLabel }"
14
+ style="margin: 0 auto;padding:5px;height:100%;"
15
+ :style="{ width: formWidth }"
7
16
  :size="data.config.size"
8
- label-suffix=":"
17
+ :label-suffix="data.config.labelSuffix"
9
18
  :label-position="data.config.labelPosition"
10
- :label-width="data.config.labelWidth + 'px'"
19
+ :label-width="`${data.config.labelWidth}px`"
20
+ :disabled="data.config.disabled"
11
21
  >
12
22
  <draggable
23
+ style="height:100%"
13
24
  v-model="data.list"
14
25
  v-bind="{
15
26
  group: 'people',
@@ -21,16 +32,17 @@
21
32
  @add="handleWidgetAdd"
22
33
  >
23
34
  <transition-group name="fade" tag="div" class="widget-form-list">
24
- <template v-for="(element, index) in data.list">
25
- <widget-form-item
26
- v-if="element && element.key"
27
- :key="element.key"
28
- :element="element"
29
- :select.sync="selectWidget"
30
- :index="index"
31
- :data="data"
32
- ></widget-form-item>
33
- </template>
35
+ <widget-form-item
36
+ v-for="(element, elementIndex) in data.list.filter(item => {
37
+ return item.key;
38
+ })"
39
+ :key="elementIndex"
40
+ :widget="element"
41
+ :widgetIndex="elementIndex"
42
+ :widgetArray="data"
43
+ :config="data.config"
44
+ :select.sync="selectWidget"
45
+ ></widget-form-item>
34
46
  </transition-group>
35
47
  </draggable>
36
48
  </el-form>
@@ -40,19 +52,36 @@
40
52
  <script>
41
53
  import Draggable from "vuedraggable";
42
54
  import WidgetFormItem from "./WidgetFormItem";
55
+ import ThEmpty from "ui/empty/index.vue";
43
56
 
44
57
  export default {
45
- components: {
46
- Draggable,
47
- WidgetFormItem
48
- },
49
- props: ["data", "select"],
58
+ components: { Draggable, WidgetFormItem, ThEmpty },
59
+ props: ["data", "select", "client"],
50
60
  data() {
51
61
  return {
52
62
  selectWidget: this.select,
53
63
  config: {}
54
64
  };
55
65
  },
66
+ watch: {
67
+ select(val) {
68
+ this.selectWidget = val;
69
+ },
70
+ selectWidget: {
71
+ handler(val) {
72
+ this.$emit("update:select", val);
73
+ },
74
+ deep: true
75
+ }
76
+ },
77
+ computed: {
78
+ formWidth() {
79
+ if (this.data.config.width) return this.data.config.width;
80
+ if (this.client === "mobile") return "375px";
81
+
82
+ return "";
83
+ }
84
+ },
56
85
  mounted() {
57
86
  document.body.ondrop = function(event) {
58
87
  let isFirefox = navigator.userAgent.toLowerCase().indexOf("firefox") > -1;
@@ -118,17 +147,6 @@ export default {
118
147
 
119
148
  this.selectWidget = this.data.list[newIndex];
120
149
  }
121
- },
122
- watch: {
123
- select(val) {
124
- this.selectWidget = val;
125
- },
126
- selectWidget: {
127
- handler(val) {
128
- this.$emit("update:select", val);
129
- },
130
- deep: true
131
- }
132
150
  }
133
151
  };
134
152
  </script>