WidgetElementItem.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438
  1. <template>
  2. <span>
  3. <template v-if="element.type == 'input'">
  4. <el-input
  5. v-model="element.options.defaultValue"
  6. :style="{width: isTable ? '100%' : element.options.width}"
  7. :placeholder="element.options.placeholder"
  8. :disabled="elementDisabled"
  9. :show-password="element.options.showPassword"
  10. :maxlength="element.options.maxlength"
  11. :show-word-limit="element.options.showWordLimit"
  12. v-bind="{...element.options.customProps, ...extendProps}"
  13. ></el-input>
  14. </template>
  15. <template v-if="element.type == 'textarea'">
  16. <el-input type="textarea" :rows="element.options.rows"
  17. v-model="element.options.defaultValue"
  18. :style="{width: isTable ? '100%' : element.options.width}"
  19. :disabled="elementDisabled"
  20. :placeholder="element.options.placeholder"
  21. :maxlength="element.options.maxlength"
  22. :show-word-limit="element.options.showWordLimit"
  23. :autosize="element.options.autosize"
  24. v-bind="{...element.options.customProps, ...extendProps}"
  25. ></el-input>
  26. </template>
  27. <template v-if="element.type == 'number'">
  28. <el-input-number
  29. v-model="element.options.defaultValue"
  30. :disabled="elementDisabled"
  31. :controls-position="element.options.controlsPosition"
  32. :precision="element.options.precision"
  33. :controls="element.options.controls"
  34. :style="{width: isTable ? '100%' : element.options.width}"
  35. v-bind="{...element.options.customProps, ...extendProps}"
  36. ></el-input-number>
  37. </template>
  38. <template v-if="element.type == 'radio'">
  39. <el-radio-group v-model="element.options.defaultValue"
  40. :style="{width: isTable ? '100%' : element.options.width}"
  41. :disabled="elementDisabled"
  42. v-bind="{...element.options.customProps, ...extendProps}"
  43. >
  44. <el-radio
  45. :style="{display: element.options.inline ? 'inline-block' : 'block'}"
  46. :label="item.value" v-for="(item, index) in element.options.options" :key="item.value + index"
  47. >
  48. {{element.options.showLabel ? item.label : item.value}}
  49. </el-radio>
  50. </el-radio-group>
  51. </template>
  52. <template v-if="element.type == 'checkbox'">
  53. <el-checkbox-group v-model="element.options.defaultValue"
  54. :style="{width: isTable ? '100%' : element.options.width}"
  55. :disabled="elementDisabled"
  56. v-bind="{...element.options.customProps, ...extendProps}"
  57. >
  58. <el-checkbox
  59. :style="{display: element.options.inline ? 'inline-block' : 'block'}"
  60. :label="item.value" v-for="(item, index) in element.options.options" :key="item.value + index"
  61. >
  62. {{element.options.showLabel ? item.label : item.value}}
  63. </el-checkbox>
  64. </el-checkbox-group>
  65. </template>
  66. <template v-if="element.type == 'time'">
  67. <el-time-picker
  68. :key="elementKey"
  69. :default-value="element.options.defaultValue"
  70. v-model="element.options.defaultValue"
  71. :is-range="element.options.isRange"
  72. :placeholder="element.options.placeholder"
  73. :start-placeholder="element.options.startPlaceholder"
  74. :end-placeholder="element.options.endPlaceholder"
  75. :readonly="element.options.readonly"
  76. :disabled="elementDisabled"
  77. :editable="element.options.editable"
  78. :clearable="element.options.clearable"
  79. :style="{width: isTable ? '100%' : element.options.width}"
  80. :value-format="element.options.format"
  81. v-bind="{...element.options.customProps, ...extendProps}"
  82. >
  83. </el-time-picker>
  84. </template>
  85. <template v-if="element.type == 'date'">
  86. <el-date-picker
  87. :key="elementKey"
  88. v-model="element.options.defaultValue"
  89. :type="element.options.type"
  90. :is-range="element.options.isRange"
  91. :placeholder="element.options.placeholder"
  92. :start-placeholder="element.options.startPlaceholder"
  93. :end-placeholder="element.options.endPlaceholder"
  94. :readonly="element.options.readonly"
  95. :disabled="elementDisabled"
  96. :editable="element.options.editable"
  97. :clearable="element.options.clearable"
  98. :value-format="element.options.timestamp ? 'timestamp' : element.options.format"
  99. :format="element.options.format"
  100. :style="{width: isTable ? '100%' : element.options.width}"
  101. v-bind="{...element.options.customProps, ...extendProps}"
  102. >
  103. </el-date-picker>
  104. </template>
  105. <template v-if="element.type == 'rate'">
  106. <el-rate v-model="element.options.defaultValue"
  107. :max="element.options.max"
  108. :disabled="elementDisabled"
  109. :allow-half="element.options.allowHalf"
  110. :show-score="element.options.showScore"
  111. :style="{width: isTable ? '100%' : element.options.width, display: 'inline-block'}"
  112. v-bind="{...element.options.customProps, ...extendProps}"
  113. ></el-rate>
  114. </template>
  115. <template v-if="element.type == 'color'">
  116. <el-color-picker
  117. v-model="element.options.defaultValue"
  118. :disabled="elementDisabled"
  119. :show-alpha="element.options.showAlpha"
  120. v-bind="{...element.options.customProps, ...extendProps}"
  121. ></el-color-picker>
  122. </template>
  123. <template v-if="element.type == 'select'">
  124. <el-select
  125. v-model="element.options.defaultValue"
  126. :disabled="elementDisabled"
  127. :multiple="element.options.multiple"
  128. :clearable="element.options.clearable"
  129. :placeholder="element.options.placeholder"
  130. :style="{width: isTable ? '100%' : element.options.width}"
  131. v-bind="{...element.options.customProps, ...extendProps}"
  132. >
  133. <el-option v-for="item in element.options.options" :key="item.value" :value="item.value" :label="element.options.showLabel?item.label:item.value"></el-option>
  134. </el-select>
  135. </template>
  136. <template v-if="element.type == 'deptSelect'">
  137. <el-select
  138. v-model="element.options.defaultValue"
  139. :disabled="elementDisabled"
  140. :multiple="element.options.multiple"
  141. :clearable="element.options.clearable"
  142. :placeholder="element.options.placeholder"
  143. :style="{width: isTable ? '100%' : element.options.width}"
  144. v-bind="{...element.options.customProps, ...extendProps}"
  145. >
  146. <el-option v-for="item in element.options.options" :key="item.value" :value="item.value" :label="element.options.showLabel?item.label:item.value"></el-option>
  147. </el-select>
  148. </template>
  149. <template v-if="element.type == 'userSelect'">
  150. <el-select
  151. v-model="element.options.defaultValue"
  152. :disabled="elementDisabled"
  153. :multiple="element.options.multiple"
  154. :clearable="element.options.clearable"
  155. :placeholder="element.options.placeholder"
  156. :style="{width: isTable ? '100%' : element.options.width}"
  157. v-bind="{...element.options.customProps, ...extendProps}"
  158. >
  159. <el-option v-for="item in element.options.options" :key="item.value" :value="item.value" :label="element.options.showLabel?item.label:item.value"></el-option>
  160. </el-select>
  161. </template>
  162. <template v-if="element.type=='switch'">
  163. <el-switch
  164. v-model="element.options.defaultValue"
  165. :disabled="elementDisabled"
  166. :style="{width: isTable ? '100%' : element.options.width}"
  167. v-bind="{...element.options.customProps, ...extendProps}"
  168. >
  169. </el-switch>
  170. </template>
  171. <template v-if="element.type=='slider'">
  172. <el-slider
  173. v-model="element.options.defaultValue"
  174. :min="element.options.min"
  175. :max="element.options.max"
  176. :disabled="elementDisabled"
  177. :step="element.options.step"
  178. :show-input="element.options.showInput"
  179. :range="element.options.range"
  180. :style="{width: isTable ? '100%' : element.options.width}"
  181. v-bind="{...element.options.customProps, ...extendProps}"
  182. ></el-slider>
  183. </template>
  184. <template v-if="element.type=='imgupload'">
  185. <fm-upload
  186. v-model="element.options.defaultValue"
  187. :disabled="elementDisabled"
  188. :style="{'width': isTable ? '100%' : element.options.width}"
  189. :width="element.options.size.width"
  190. :height="element.options.size.height"
  191. token="xxx"
  192. domain="xxx"
  193. >
  194. </fm-upload>
  195. </template>
  196. <template v-if="element.type == 'cascader'">
  197. <el-cascader
  198. v-model="element.options.defaultValue"
  199. :disabled="elementDisabled"
  200. :clearable="element.options.clearable"
  201. :placeholder="element.options.placeholder"
  202. :style="{width: isTable ? '100%' : element.options.width}"
  203. :options="element.options.remote ? [] : element.options.options"
  204. :props="{multiple: element.options.multiple, checkStrictly: element.options.checkStrictly}"
  205. v-bind="{...element.options.customProps, ...extendProps}"
  206. >
  207. </el-cascader>
  208. </template>
  209. <template v-if="element.type == 'deptAndUserCascader'">
  210. <el-cascader
  211. v-model="element.options.defaultValue"
  212. :disabled="elementDisabled"
  213. :clearable="element.options.clearable"
  214. :placeholder="element.options.placeholder"
  215. :style="{width: isTable ? '100%' : element.options.width}"
  216. :options="element.options.remote ? [] : element.options.options"
  217. :props="{multiple: element.options.multiple, checkStrictly: element.options.checkStrictly}"
  218. v-bind="{...element.options.customProps, ...extendProps}"
  219. >
  220. </el-cascader>
  221. </template>
  222. <template v-if="element.type == 'deptCascader'">
  223. <el-cascader
  224. v-model="element.options.defaultValue"
  225. :disabled="elementDisabled"
  226. :clearable="element.options.clearable"
  227. :placeholder="element.options.placeholder"
  228. :style="{width: isTable ? '100%' : element.options.width}"
  229. :options="element.options.remote ? [] : element.options.options"
  230. :props="{multiple: element.options.multiple, checkStrictly: element.options.checkStrictly}"
  231. v-bind="{...element.options.customProps, ...extendProps}"
  232. >
  233. </el-cascader>
  234. </template>
  235. <template v-if="element.type == 'editor'">
  236. <vue-editor
  237. v-model="element.options.defaultValue"
  238. :style="{width: isTable ? '100%' : element.options.width, cursor: elementDisabled ? 'no-drop' : '', backgroundColor: elementDisabled ? '#F5F7FA' : ''}"
  239. :editor-toolbar="element.options.customToolbar"
  240. class="fm-editor"
  241. :disabled="elementDisabled"
  242. >
  243. </vue-editor>
  244. </template>
  245. <template v-if="element.type=='blank'">
  246. <div style="height: 50px;color: #999;background: #eee;line-height:50px;text-align:center;">{{element.model}}</div>
  247. </template>
  248. <template v-if="element.type == 'component'">
  249. <component :style="{width: isTable ? '100%' : element.options.width}" :is="`component-${element.key}`" :key="key" v-model="element.options.defaultValue"></component>
  250. </template>
  251. <template v-if="element.type == 'custom'">
  252. <component
  253. :is="element.el"
  254. v-model="element.options.defaultValue"
  255. :width="element.options.width"
  256. :height="element.options.height"
  257. :placeholder="element.options.placeholder"
  258. :readonly="element.options.readonly"
  259. :disabled="elementDisabled"
  260. :editable="element.options.editable"
  261. :clearable="element.options.clearable"
  262. v-bind="{...element.options.customProps, ...extendProps}"
  263. ></component>
  264. </template>
  265. <template v-if="element.type == 'text'">
  266. <span :style="{'width': isTable ? '100%' : (element.options.width || '100%'), display: 'inline-block'}">{{element.options.defaultValue}}</span>
  267. </template>
  268. <template v-if="element.type == 'html'">
  269. <span :style="{'width': isTable ? '100%' : (element.options.width || '100%'), display: 'inline-block'}" v-html="element.options.defaultValue"></span>
  270. </template>
  271. <template v-if="element.type == 'fileupload'">
  272. <el-upload
  273. action="https://jsonplaceholder.typicode.com/posts/"
  274. :style="{width: isTable ? '100%' : element.options.width}"
  275. :disabled="elementDisabled"
  276. :limit="element.options.limit"
  277. >
  278. <el-button size="small" type="primary">{{$t('fm.actions.upload')}}</el-button>
  279. </el-upload>
  280. </template>
  281. <template v-if="element.type == 'button'">
  282. <el-button
  283. :disabled="elementDisabled"
  284. :type="element.options.buttonType"
  285. :plain="element.options.buttonPlain"
  286. :round="element.options.buttonRound"
  287. :circle="element.options.buttonCircle"
  288. :style="{width: element.options.width}"
  289. v-bind="{...element.options.customProps, ...extendProps}"
  290. >
  291. {{element.options.buttonName}}
  292. </el-button>
  293. </template>
  294. <template v-if="element.type == 'link'">
  295. <el-link
  296. :disabled="elementDisabled"
  297. :type="element.options.linkType"
  298. :underline="element.options.underline"
  299. v-bind="{...element.options.customProps, ...extendProps}"
  300. >
  301. {{element.options.linkName}}
  302. </el-link>
  303. </template>
  304. <template v-if="element.type == 'steps'">
  305. <el-steps
  306. :active="element.options.defaultValue"
  307. :space="element.options.space"
  308. :direction="element.options.direction"
  309. :process-status="element.options.processStatus"
  310. :finish-status="element.options.finishStatus"
  311. :align-center="element.options.alignCenter"
  312. :simple="element.options.simple"
  313. :style="{'line-height': 'normal'}"
  314. v-bind="{...element.options.customProps, ...extendProps}"
  315. >
  316. <el-step :title="item.title" :description="item.description" v-for="(item, index) in element.options.steps" :key="index"></el-step>
  317. </el-steps>
  318. </template>
  319. <template v-if="element.type == 'pagination'">
  320. <el-pagination
  321. :current-page.sync="element.options.defaultValue"
  322. :page-size="element.options.pageSize"
  323. :pager-count="element.options.pagerCount"
  324. :disabled="elementDisabled"
  325. :background="element.options.background"
  326. layout="total, prev, pager, next"
  327. :total="element.options.total"
  328. v-bind="{...element.options.customProps, ...extendProps}"
  329. />
  330. </template>
  331. <template v-if="element.type == 'transfer'">
  332. <el-transfer
  333. :value="element.options.defaultValue"
  334. :data="element.options.data"
  335. :filterable="element.options.filterable"
  336. :titles="element.options.titles"
  337. :style="{'width': isTable ? '100%' : element.options.width}"
  338. v-bind="{...element.options.customProps, ...extendProps}"
  339. ></el-transfer>
  340. </template>
  341. </span>
  342. </template>
  343. <script>
  344. import FmUpload from './Upload'
  345. import Vue from 'vue'
  346. import {executeExpression, isExpression, extractExpression} from '../util/expression'
  347. export default {
  348. components: {
  349. FmUpload
  350. },
  351. props: ['element', 'isTable'],
  352. data () {
  353. return {
  354. key: Math.random().toString(36).slice(-8),
  355. elementKey: Math.random().toString(36).slice(-8)
  356. }
  357. },
  358. computed: {
  359. elementDisabled () {
  360. if (isExpression(this.element.options.disabled)) {
  361. return true
  362. }
  363. return this.element.options.disabled
  364. },
  365. extendProps () {
  366. let obj = {}
  367. this.element.options.extendProps && Object.keys(this.element.options.extendProps).forEach(key => {
  368. let value = this.element.options.extendProps[key]
  369. if (!isExpression(value)) {
  370. obj[key] = value
  371. } else {
  372. obj[key] = executeExpression(extractExpression(value), this.currentOptions, this.formContext)
  373. }
  374. })
  375. return obj
  376. },
  377. },
  378. created () {
  379. console.log('---***', this.element)
  380. if (this.element.type == 'component') {
  381. Vue.component(`component-${this.element.key}`, {
  382. template: `<span>${this.element.options.template}</span>`,
  383. props: ['dataModel', 'formState']
  384. })
  385. }
  386. },
  387. watch: {
  388. 'element.options.template': function (val) {
  389. Vue.component(`component-${this.element.key}`, {
  390. template: `<span>${val}</span>`,
  391. props: ['dataModel', 'formState']
  392. })
  393. this.key = Math.random().toString(36).slice(-8)
  394. },
  395. 'element.options.defaultValue': function (val) {
  396. console.log(val)
  397. this.elementKey = Math.random().toString(36).slice(-8)
  398. }
  399. }
  400. }
  401. </script>