DataSetting.vue 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010
  1. <template>
  2. <div
  3. class="bs-setting-wrap"
  4. @click.stop
  5. >
  6. <el-form
  7. ref="form"
  8. :model="config"
  9. :rules="rules"
  10. label-width="100px"
  11. label-position="left"
  12. class="setting-body bs-el-form"
  13. >
  14. <div class="data-setting-box">
  15. <div
  16. v-if="config.option.displayOption.dataSourceType.enable"
  17. class="data-setting-data-box"
  18. >
  19. <div class="lc-field-head">
  20. <div class="lc-field-title">
  21. 数据来源
  22. </div>
  23. </div>
  24. <div class="lc-field-body">
  25. <el-form-item
  26. v-if="config.option.displayOption.expression && config.option.displayOption.expression.enable"
  27. label="数据来源"
  28. >
  29. <el-radio-group
  30. v-model="config.dataSource.source "
  31. class="bs-el-radio-group"
  32. >
  33. <el-radio label="dataset">
  34. 数据集
  35. </el-radio>
  36. <el-radio label="expression">
  37. 表达式
  38. </el-radio>
  39. </el-radio-group>
  40. </el-form-item>
  41. <el-form-item
  42. v-if="config.dataSource.source === 'dataset'"
  43. label="数据集"
  44. >
  45. <data-set-select
  46. :dataset-name="datasetName"
  47. :ds-id="config.dataSource.businessKey"
  48. @getDsId="changeDsid"
  49. >
  50. <template #dataSetSelect="{value}">
  51. <slot
  52. name="dataSetSelect"
  53. :value="value"
  54. />
  55. </template>
  56. </data-set-select>
  57. </el-form-item>
  58. <el-form-item
  59. v-if="config.dataSource.source === 'expression' && config.option.displayOption.expression && config.option.displayOption.expression.enable"
  60. label="表达式"
  61. >
  62. <i
  63. class="el-icon-edit expression"
  64. @click="openExpression"
  65. />
  66. </el-form-item>
  67. <el-form-item
  68. v-if="config.option.displayOption.text && config.option.displayOption.text.enable"
  69. label="文本内容"
  70. >
  71. <el-input
  72. v-model="config.customize.title"
  73. placeholder="请输入文本内容"
  74. clearable
  75. />
  76. </el-form-item>
  77. </div>
  78. </div>
  79. <div
  80. v-if="['customComponent','marquee', 'echartsComponent'].includes(config.type)"
  81. class="data-setting-data-box"
  82. >
  83. <div class="lc-field-head">
  84. <div class="lc-field-title">
  85. 数据处理
  86. </div>
  87. </div>
  88. <div class="lc-field-body">
  89. <el-form-item
  90. label="数据处理脚本"
  91. >
  92. <el-input
  93. v-model="config.dataHandler"
  94. type="textarea"
  95. :rows="5"
  96. placeholder="示例:
  97. data.forEach(item => {
  98. // 数据处理
  99. })"
  100. />
  101. </el-form-item>
  102. </div>
  103. </div>
  104. <div
  105. v-if="!['tree','multipleNumberChart','carousel'].includes(config.type) && config.option.displayOption.dataSourceType.enable && config.dataSource.source !== 'expression'"
  106. class="data-setting-data-box"
  107. >
  108. <div class="lc-field-head">
  109. <div
  110. v-if="config.type!=='flyMap'"
  111. class="lc-field-title"
  112. >
  113. 数据配置
  114. </div>
  115. </div>
  116. <!-- 基础组件数据配置 -->
  117. <template v-if="!['customComponent', 'remoteComponent','echartsComponent'].includes(config.type)">
  118. <!--维度多选-->
  119. <el-form-item
  120. v-if="config.option.displayOption.dimensionField.enable"
  121. :label="config.option.displayOption.dimensionField.label"
  122. :prop="config.option.displayOption.dimensionField.multiple? 'dataSource.dimensionFieldList' : 'dataSource.dimensionField'"
  123. class="data-form-item"
  124. >
  125. <el-drag-select
  126. v-if="config.option.displayOption.dimensionField.enable && config.option.displayOption.dimensionField.multiple"
  127. v-model="config.dataSource.dimensionFieldList"
  128. class="bs-el-select"
  129. popper-class="bs-el-select"
  130. filterable
  131. clearable
  132. :multiple="config.option.displayOption.dimensionField.multiple"
  133. @change="dimensionFieldListChange"
  134. @valuePositionChange="valuePositionChange"
  135. >
  136. <el-option
  137. v-for="(field, index) in dataSourceDataList"
  138. :key="index"
  139. :label="field.comment"
  140. :value="field.name"
  141. >
  142. <div class="source-key-option">
  143. <div>
  144. {{ field.comment !== "" ? field.comment : field.name }}
  145. </div>
  146. <div class="option-txt">
  147. {{ field.name }}
  148. </div>
  149. </div>
  150. </el-option>
  151. </el-drag-select>
  152. <!--维度单选-->
  153. <el-select
  154. v-else
  155. v-model="config.dataSource.dimensionField"
  156. class="bs-el-select"
  157. popper-class="bs-el-select"
  158. filterable
  159. clearable
  160. >
  161. <el-option
  162. v-for="(field, index) in dataSourceDataList"
  163. :key="index"
  164. :label="field.comment"
  165. :value="field.name"
  166. >
  167. <div class="source-key-option">
  168. <div>
  169. {{ field.comment !== "" ? field.comment : field.name }}
  170. </div>
  171. <div class="option-txt">
  172. {{ field.name }}
  173. </div>
  174. </div>
  175. </el-option>
  176. </el-select>
  177. </el-form-item>
  178. <!--指标-->
  179. <el-form-item
  180. v-if="config.option.displayOption.metricField.enable"
  181. :label="config.option.displayOption.metricField.label"
  182. prop="dataSource.metricField"
  183. class="data-form-item"
  184. >
  185. <el-select
  186. v-model="config.dataSource.metricField"
  187. class="bs-el-select"
  188. popper-class="bs-el-select"
  189. filterable
  190. clearable
  191. >
  192. <el-option
  193. v-for="(field, index) in dataSourceDataList"
  194. :key="index"
  195. :label="field.comment"
  196. :value="field.name"
  197. >
  198. <div class="source-key-option">
  199. <div>
  200. {{ field.comment !== "" ? field.comment : field.name }}
  201. </div>
  202. <div class="option-txt">
  203. {{ field.name }}
  204. </div>
  205. </div>
  206. </el-option>
  207. </el-select>
  208. </el-form-item>
  209. </template>
  210. <!-- g2plot和远程组件数据配置 -->
  211. <template v-else>
  212. <template
  213. v-for="(setting, index) in config.setting.filter(set => set.tabName === 'data')"
  214. >
  215. <el-form-item
  216. :key="index"
  217. :label="setting.label"
  218. class="data-form-item"
  219. >
  220. <el-select
  221. v-if="setting.type === 'select'"
  222. class="bs-el-select select"
  223. popper-class="bs-el-select"
  224. :value="setting.value"
  225. filterable
  226. clearable
  227. :multiple="setting.multiple"
  228. :placeholder="`请选择${setting.label}`"
  229. @change="changeCustomProps(...arguments, setting)"
  230. >
  231. <el-option
  232. v-for="(field, fieldIndex) in dataSourceDataList"
  233. :key="fieldIndex"
  234. :label="field.comment"
  235. :value="field.name"
  236. >
  237. <div class="source-key-option">
  238. <div>
  239. {{ field.comment !== "" ? field.comment : field.name }}
  240. </div>
  241. <div class="option-txt">
  242. {{ field.name }}
  243. </div>
  244. </div>
  245. </el-option>
  246. </el-select>
  247. <el-input
  248. v-else
  249. :value="setting.value"
  250. :placeholder="`请输入${setting.label}`"
  251. @change="changeCustomProps(...arguments, setting)"
  252. />
  253. </el-form-item>
  254. </template>
  255. </template>
  256. </div>
  257. <div
  258. v-if="config.option.displayOption.headerField && config.option.displayOption.headerField.enable"
  259. name="轮播表配置"
  260. >
  261. <template slot="title">
  262. <div class="lc-field-head">
  263. <div class="lc-field-title">
  264. 轮播表配置
  265. </div>
  266. </div>
  267. </template>
  268. <div class="lc-field-body">
  269. <el-table
  270. ref="headerTable"
  271. :border="true"
  272. :data="config.customize.columnConfig"
  273. class="params-config"
  274. >
  275. <el-table-column
  276. prop="code"
  277. label="参数名称"
  278. align="center"
  279. >
  280. <template slot-scope="scope">
  281. <el-input
  282. v-model="scope.row.code"
  283. placeholder="请输入名称"
  284. readonly
  285. />
  286. </template>
  287. </el-table-column>
  288. <el-table-column
  289. prop="name"
  290. label="列名称"
  291. align="center"
  292. >
  293. <template slot-scope="scope">
  294. <el-input
  295. v-model="scope.row.name"
  296. placeholder="请输入字段名称"
  297. />
  298. </template>
  299. </el-table-column>
  300. <el-table-column
  301. prop="width"
  302. label="列宽"
  303. width="90"
  304. align="center"
  305. >
  306. <template slot-scope="scope">
  307. <el-input
  308. v-model="scope.row.width"
  309. placeholder="请输入列宽"
  310. clearable
  311. />
  312. </template>
  313. </el-table-column>
  314. <el-table-column
  315. prop="align"
  316. label="对齐方式"
  317. align="center"
  318. >
  319. <template slot-scope="scope">
  320. <el-select
  321. v-model="scope.row.align"
  322. class="bs-el-select"
  323. popper-class="bs-el-select"
  324. filterable
  325. clearable
  326. placeholder="请选择对齐方式"
  327. >
  328. <el-option
  329. value="left"
  330. label="左对齐"
  331. />
  332. <el-option
  333. value="center"
  334. label="居中"
  335. />
  336. <el-option
  337. value="right"
  338. label="右对齐"
  339. />
  340. </el-select>
  341. </template>
  342. </el-table-column>
  343. </el-table>
  344. </div>
  345. </div>
  346. <div
  347. v-if="config.option.displayOption.mapField && config.option.displayOption.mapField.enable"
  348. name="地图数据配置"
  349. >
  350. <template slot="title">
  351. <div class="lc-field-head">
  352. <div class="lc-field-title">
  353. 地图数据配置
  354. </div>
  355. </div>
  356. </template>
  357. <div class="lc-field-body">
  358. <el-form-item
  359. label="展示字段"
  360. class="data-form-item"
  361. >
  362. <el-select
  363. v-model="config.customize.value"
  364. class="bs-el-select"
  365. popper-class="bs-el-select"
  366. filterable
  367. clearable
  368. >
  369. <el-option
  370. v-for="(field, index) in dataSourceDataList"
  371. :key="index"
  372. :label="field.comment"
  373. :value="field.name"
  374. >
  375. <div class="source-key-option">
  376. <div>
  377. {{ field.comment !== "" ? field.comment : field.name }}
  378. </div>
  379. <div class="option-txt">
  380. {{ field.name }}
  381. </div>
  382. </div>
  383. </el-option>
  384. </el-select>
  385. </el-form-item>
  386. <el-form-item
  387. label="地名字段"
  388. class="data-form-item"
  389. >
  390. <el-select
  391. v-model="config.customize.name"
  392. class="bs-el-select"
  393. popper-class="bs-el-select"
  394. filterable
  395. clearable
  396. >
  397. <el-option
  398. v-for="(field, index) in dataSourceDataList"
  399. :key="index"
  400. :label="field.comment"
  401. :value="field.name"
  402. >
  403. <div class="source-key-option">
  404. <div>
  405. {{ field.comment !== "" ? field.comment : field.name }}
  406. </div>
  407. <div class="option-txt">
  408. {{ field.name }}
  409. </div>
  410. </div>
  411. </el-option>
  412. </el-select>
  413. </el-form-item>
  414. <el-form-item
  415. label="x坐标"
  416. class="data-form-item"
  417. >
  418. <el-select
  419. v-model="config.customize.xaxis"
  420. class="bs-el-select"
  421. popper-class="bs-el-select"
  422. filterable
  423. clearable
  424. >
  425. <el-option
  426. v-for="(field, index) in dataSourceDataList"
  427. :key="index"
  428. :label="field.comment"
  429. :value="field.name"
  430. >
  431. <div class="source-key-option">
  432. <div>
  433. {{ field.comment !== "" ? field.comment : field.name }}
  434. </div>
  435. <div class="option-txt">
  436. {{ field.name }}
  437. </div>
  438. </div>
  439. </el-option>
  440. </el-select>
  441. </el-form-item>
  442. <el-form-item
  443. label="y坐标"
  444. class="data-form-item"
  445. >
  446. <el-select
  447. v-model="config.customize.yaxis"
  448. class="bs-el-select"
  449. popper-class="bs-el-select"
  450. filterable
  451. clearable
  452. >
  453. <el-option
  454. v-for="(field, index) in dataSourceDataList"
  455. :key="index"
  456. :label="field.comment"
  457. :value="field.name"
  458. >
  459. <div class="source-key-option">
  460. <div>
  461. {{ field.comment !== "" ? field.comment : field.name }}
  462. </div>
  463. <div class="option-txt">
  464. {{ field.name }}
  465. </div>
  466. </div>
  467. </el-option>
  468. </el-select>
  469. </el-form-item>
  470. </div>
  471. </div>
  472. <div
  473. v-if="config.option.displayOption.params.enable && config.dataSource.source !== 'expression'"
  474. class="data-setting-data-box"
  475. >
  476. <div class="lc-field-head">
  477. <div class="lc-field-title">
  478. 参数配置
  479. </div>
  480. </div>
  481. <div class="lc-field-body">
  482. <el-table
  483. ref="singleTable"
  484. :border="true"
  485. :data="params"
  486. class="params-config"
  487. >
  488. <el-table-column
  489. prop="name"
  490. label="参数名称"
  491. align="center"
  492. >
  493. <template slot-scope="scope">
  494. <div>
  495. <el-form-item>
  496. <el-input
  497. v-model="scope.row.name"
  498. placeholder="请输入名称"
  499. readonly
  500. />
  501. <el-tooltip
  502. :content="
  503. `${
  504. scope.row.type ? '参数类型:' + scope.row.type : ''
  505. }
  506. ${
  507. scope.row.remark ? '备注:' + scope.row.remark : ''
  508. }`
  509. "
  510. placement="top"
  511. >
  512. <span
  513. class="el-icon-question"
  514. style="color:#9e9e9e"
  515. />
  516. </el-tooltip>
  517. </el-form-item>
  518. </div>
  519. </template>
  520. </el-table-column>
  521. <el-table-column
  522. prop="value"
  523. label="参数值"
  524. align="center"
  525. >
  526. <template slot-scope="scope">
  527. <el-form-item
  528. :prop="scope.row.require === 1 ? 'params' : null"
  529. >
  530. <el-date-picker
  531. v-if="scope.row.type === 'Date'"
  532. v-model="scope.row.value"
  533. type="datetime"
  534. value-format="yyyy-MM-dd HH:mm:ss"
  535. placeholder="选择日期时间"
  536. />
  537. <el-input
  538. v-else
  539. v-model="scope.row.value"
  540. clearable
  541. placeholder="请输入参数值"
  542. />
  543. </el-form-item>
  544. </template>
  545. </el-table-column>
  546. </el-table>
  547. </div>
  548. </div>
  549. <div
  550. v-if="config.option.displayOption.serverPagination.enable"
  551. class="data-setting-data-box"
  552. name="分页配置"
  553. >
  554. <div class="lc-field-head">
  555. <div class="lc-field-title">
  556. 分页配置
  557. </div>
  558. </div>
  559. <div class="form">
  560. <el-form-item
  561. v-if="config.option.displayOption.serverPagination.enable"
  562. label="服务端分页"
  563. prop="dataSource.serverPagination"
  564. >
  565. <el-radio-group
  566. v-model="config.dataSource.serverPagination"
  567. class="bs-el-radio-group"
  568. size="mini"
  569. @change="serverPaginationChange"
  570. >
  571. <el-radio-button :label="true">
  572. 开启
  573. </el-radio-button>
  574. <el-radio-button :label="false">
  575. 关闭
  576. </el-radio-button>
  577. </el-radio-group>
  578. </el-form-item>
  579. <el-form-item
  580. v-if="
  581. config.dataSource.serverPagination &&
  582. config.option.displayOption.pageSize.enable
  583. "
  584. label="分页长度"
  585. prop="dataSource.pageSize"
  586. >
  587. <el-select
  588. v-model="config.dataSource.pageSize"
  589. class="bs-el-select"
  590. popper-class="bs-el-select"
  591. filterable
  592. allow-create
  593. default-first-option
  594. >
  595. <el-option
  596. v-for="size in pageSizeList"
  597. :key="size"
  598. :label="size"
  599. :value="size"
  600. />
  601. </el-select>
  602. </el-form-item>
  603. </div>
  604. </div>
  605. <ComponentBinding
  606. v-if="['button'].includes(config.type)"
  607. :config="config"
  608. :source-field-list="sourceFieldList"
  609. />
  610. <ComponentRelation
  611. v-if="!['carousel','gauge','liquid','marquee'].includes(config.type)"
  612. :config="config"
  613. :source-field-list="sourceFieldList"
  614. />
  615. <expression-dialog
  616. ref="expressionDialog"
  617. :config="config"
  618. />
  619. </div>
  620. </el-form>
  621. </div>
  622. </template>
  623. <script>
  624. import ElDragSelect from './ElDragSelect.vue'
  625. // import { isEmpty, cloneDeep } from 'lodash'
  626. import isEmpty from 'lodash/isEmpty'
  627. import cloneDeep from 'lodash/cloneDeep'
  628. import ComponentRelation from 'data-room-ui/BigScreenDesign/RightSetting/ComponentRelation/index.vue'
  629. import ComponentBinding from 'data-room-ui/BigScreenDesign/RightSetting/ComponentBinding/index.vue'
  630. import dataSetSelect from 'data-room-ui/DataSetSetting/index.vue'
  631. import { mapState } from 'vuex'
  632. import { getDataSetDetails } from 'data-room-ui/js/api/bigScreenApi'
  633. import ExpressionDialog from 'data-room-ui/BigScreenDesign/RightSetting/ExpressionDialog.vue'
  634. export default {
  635. name: 'DataSetting',
  636. components: {
  637. ComponentRelation,
  638. ComponentBinding,
  639. dataSetSelect,
  640. ElDragSelect,
  641. ExpressionDialog
  642. },
  643. data () {
  644. return {
  645. fieldsList: [],
  646. params: [], // 参数配置
  647. datasetName: '',
  648. headerList: [],
  649. pageSizeList: [10, 20, 50, 100],
  650. rules: {
  651. // 'dataSource.businessKey': [
  652. // { required: true, message: '请选择数据集', trigger: 'change' }
  653. // ],
  654. // 'dataSource.dimensionField': [
  655. // { required: true, message: '请选择维度', trigger: 'change' }
  656. // ],
  657. // 'dataSource.dimensionFieldList': [
  658. // { required: true, message: '请选择维度', trigger: 'change' }
  659. // ],
  660. // 'dataSource.metricField': [
  661. // { required: true, message: '请选择指标', trigger: 'change' }
  662. // ],
  663. params: [
  664. {
  665. validator: (rule, value, callback) => {
  666. if (!value) {
  667. this.params.map(sort => {
  668. if (!sort.value) {
  669. callback(new Error('请输入参数值'))
  670. } else {
  671. callback()
  672. }
  673. })
  674. } else {
  675. callback()
  676. }
  677. }
  678. }
  679. ]
  680. }
  681. }
  682. },
  683. computed: {
  684. ...mapState({
  685. pageInfo: state => state.bigScreen.pageInfo,
  686. config: state => state.bigScreen.activeItemConfig
  687. // 缓存数据集
  688. // cacheDataSets: state => state.bigScreen.pageInfo.pageConfig.cacheDataSets
  689. }),
  690. dataSourceDataList () {
  691. return this.fieldsList?.map(item => ({
  692. ...item,
  693. comment: item?.fieldDesc || item?.fieldName,
  694. name: item?.fieldName
  695. }))
  696. },
  697. appCode: {
  698. get () {
  699. return this.$store.state.bigScreen.pageInfo.appCode
  700. }
  701. },
  702. seriesFieldProp () {
  703. if (this.config.option.displayOption.seriesField.required) {
  704. return 'dataSource.seriesField'
  705. } else {
  706. return ''
  707. }
  708. },
  709. pageCode () {
  710. return this.$route.query.code
  711. },
  712. // 映射字段
  713. sourceFieldList () {
  714. const list = this?.config?.customize?.bindComponents || this.fieldsList
  715. const modifiedList = list?.map(field => ({
  716. label: field.comment || field.fieldDesc,
  717. value: field.name || field.fieldName
  718. })) || []
  719. if (['input', 'timePicker', 'dateTimePicker'].includes(this.config.type)) {
  720. modifiedList.push({ label: '当前组件值', value: this.config.code })
  721. }
  722. return modifiedList
  723. }
  724. },
  725. watch: {
  726. // 切换数据集时将其他配置清空
  727. 'config.dataSource.businessKey' (val) {
  728. this.clearCustomVerify()
  729. this.clearVerify()
  730. },
  731. // 切换数据集类型时将其他配置清空
  732. 'config.dataSource.dataSetType' () {
  733. this.config.dataSource.businessKey = ''
  734. this.clearCustomVerify()
  735. this.clearVerify()
  736. },
  737. // 参数改变时
  738. params: {
  739. handler (val) {
  740. if (!isEmpty(val)) {
  741. const params = cloneDeep(val)
  742. const paramsMap = params.reduce((obj, param) => {
  743. obj[param.name] = param.value
  744. return obj
  745. }, {})
  746. this.config.dataSource.params = paramsMap
  747. }
  748. },
  749. deep: true
  750. },
  751. 'config.dataSource.dimensionField' (val) {
  752. if (['select'].includes(this.config.type)) {
  753. if (this.config.customize?.placeholder) {
  754. this.config.customize.placeholder = '请选择' + this.dataSourceDataList.find(item => item.fieldName === val).comment
  755. }
  756. }
  757. }
  758. },
  759. mounted () {
  760. if (this.config.dataSource && this.config.dataSource.businessKey) {
  761. this.getDataSetDetailsById(this.config.dataSource.businessKey, 'initial')
  762. }
  763. },
  764. methods: {
  765. changeDsid (dsId) {
  766. this.clearVerify()
  767. this.config.customize.columnConfig = []
  768. this.getDataSetDetailsById(dsId, 'treeTable')
  769. },
  770. // 打开表达式弹窗
  771. openExpression () {
  772. this.$refs.expressionDialog.init()
  773. },
  774. // 切换前后端分页
  775. serverPaginationChange (val) {
  776. this.config.customize.webPagination = !val
  777. },
  778. // 清空自定义组件配置,与手动配置的组件区分开
  779. clearCustomVerify () {
  780. this.config.setting = this.config.setting?.map(set => {
  781. this.datasetName = ''
  782. if (set.tabName === 'data') {
  783. set.value = ''
  784. }
  785. return set
  786. })
  787. },
  788. // 清空手动配置的组件配置
  789. clearVerify () {
  790. this.config.dataSource.metricField = ''
  791. this.config.dataSource.dimensionField = ''
  792. this.config.dataSource.dimensionFieldList = []
  793. this.config.dataSource.seriesField = ''
  794. this.config.dataSource.params = {}
  795. },
  796. // 根据数据集来获取数据集详情
  797. getDataSetDetailsById (id, type) {
  798. if (id) {
  799. this.config.dataSource.businessKey = id
  800. getDataSetDetails(id).then(res => {
  801. this.fieldsList = res.fields
  802. // 初始化时以组件本来的参数设置为主
  803. if (type === 'initial') {
  804. const deleteKeys = []
  805. for (const key in this.config.dataSource.params) {
  806. const param = res?.params?.find(field => field.name === key)
  807. // 如果组件参数在数据集中找不到,说明参数已经被删除,不需要再显示
  808. if (param) {
  809. deleteKeys.push(key)
  810. this.params.push({
  811. name: key,
  812. value: this.config.dataSource.params[key],
  813. type: param?.type,
  814. remark: param?.remark
  815. })
  816. }
  817. }
  818. if (res.params) {
  819. // 如果数据集中有新增的参数,需要显示出来
  820. res.params.forEach(param => {
  821. if (!this.params.find(item => item.name === param.name)) {
  822. this.params.push({
  823. name: param.name,
  824. value: param.value,
  825. type: param.type,
  826. remark: param.remark
  827. })
  828. }
  829. })
  830. }
  831. deleteKeys.forEach(key => {
  832. delete this.config.dataSource.params[key]
  833. })
  834. } else {
  835. this.params = res.params
  836. }
  837. this.datasetName = res.name
  838. // 选择数据集的时候,如果数据集类型是dataModel,则不显示参数配置
  839. this.config.option.displayOption.params.enable = res.type !== 'dataModel'
  840. // 根据数据集初始化组件的入参:inparams
  841. if (res.type !== 'dataModel') {
  842. this.config.inParams =
  843. this.params?.map(param => {
  844. return {
  845. name: param.remark, // 参数名
  846. code: param.name // 参数值
  847. }
  848. }) || []
  849. } else {
  850. this.config.inParams =
  851. this.fieldsList?.map(field => {
  852. return {
  853. name: field.fieldDesc, // 参数名
  854. code: field.fieldName // 参数值
  855. }
  856. }) || []
  857. }
  858. // 根据数据集的参数初始化表单项
  859. this.config.paramsList = this.params
  860. if (type === 'treeTable') {
  861. const enumeration = {
  862. dataSetType: '1', // 数据集类型
  863. dataSetKey: '', // 数据集
  864. itemKeyName: '', // 选项显示字段
  865. itemValueName: '', // 选项value字段
  866. params: []
  867. }
  868. this.config.fields =
  869. this.params?.map(param => {
  870. return {
  871. name: param.name,
  872. label: param.remark || param.name,
  873. component: 'input',
  874. display: res.type !== 'dataModel',
  875. enumeration: {
  876. ...enumeration
  877. },
  878. queryRule: 'like'
  879. }
  880. }) || []
  881. }
  882. })
  883. }
  884. },
  885. // 改变维度
  886. dimensionFieldListChange (list) {
  887. const colFieldList = []
  888. if (list.length > 0) {
  889. list.forEach(item => {
  890. colFieldList.push(
  891. this.dataSourceDataList.find(field => field.name === item)
  892. )
  893. })
  894. }
  895. this.headerList = []
  896. colFieldList.forEach(item => {
  897. this.headerList.push({ name: item.comment, code: item.name, width: '150', align: 'left' })
  898. })
  899. this.config.customize.columnConfig = cloneDeep(this.headerList)
  900. this.$store.commit('bigScreen/changeActiveItemConfig', this.config)
  901. },
  902. valuePositionChange (value) {
  903. const sortedColumnData = {}
  904. const columnData = cloneDeep(this.config.option?.columnData)
  905. value.forEach((item, index) => {
  906. sortedColumnData[item] = columnData[item]
  907. })
  908. this.config.option.columnData = sortedColumnData
  909. this.$store.commit('bigScreen/changeActiveItemConfig', this.config)
  910. },
  911. changeCustomProps (value, setting) {
  912. this.config.setting = this.config.setting.map(item => {
  913. if (item.field === setting.field) {
  914. item.value = value
  915. }
  916. return item
  917. })
  918. }
  919. // 改变缓存数据集key
  920. // changeCacheBusinessKey (id) {
  921. // // 根据id在缓存中获取fields
  922. // this.fieldsList = this.cacheDataSets?.find(cache => cache.dataSetId === id)?.fields
  923. // this.params = this.cacheDataSets?.find(cache => cache.dataSetId === id)?.params
  924. // }
  925. }
  926. }
  927. </script>
  928. <style lang="scss" scoped>
  929. @import "../../assets/style/settingWrap.scss";
  930. .add-filter-box {
  931. position: relative;
  932. .add-filter {
  933. margin-left: 100px;
  934. }
  935. .add-filter-btn {
  936. position: absolute;
  937. top: 0;
  938. }
  939. }
  940. .form {
  941. padding: 12px;
  942. }
  943. ::v-deep .el-tag__close.el-icon-close::before {
  944. color: #fff;
  945. }
  946. ::v-deep .el-tag__close.el-icon-close {
  947. top: -1px;
  948. &:hover {
  949. background-color:var(--bs-el-color-primary);
  950. }
  951. }
  952. .opt-wrap{
  953. margin-top: 10px;
  954. }
  955. .link-set-item {
  956. position: relative;
  957. border: 1px solid #f5f7fa;
  958. padding: 30px 16px 10px;
  959. box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  960. margin: 10px;
  961. .del-icon {
  962. cursor: pointer;
  963. position: absolute;
  964. right: 10px;
  965. top: 5px;
  966. font-size: 20px;
  967. color: #f00;
  968. }
  969. .opt-wrap {
  970. display: flex;
  971. justify-content: center;
  972. }
  973. }
  974. //表达式样式
  975. .expression{
  976. &:hover{
  977. cursor: pointer;
  978. }
  979. }
  980. // 修改设置面板样式
  981. .data-setting-box{
  982. .data-setting-data-box{
  983. .lc-field-head{
  984. height: 30px;
  985. .lc-field-title{
  986. position: relative;
  987. padding-left: 12px;
  988. line-height: 30px;
  989. height: 30px;
  990. &:after{
  991. position: absolute;
  992. left: 0;
  993. top: 50%;
  994. transform: translateY(-50%);
  995. content: '';
  996. width: 4px;
  997. height: 14px;
  998. background-color: var(--bs-el-color-primary);
  999. }
  1000. }
  1001. }
  1002. }
  1003. }
  1004. </style>