DataSetting.vue 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008
  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="dataSourceStyle"
  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="dataSourceStyle === 'dataset'"
  43. label="数据集"
  44. >
  45. <data-set-select
  46. :dataset-name="datasetName"
  47. :ds-id="config.dataSource.businessKey"
  48. @getDsId="dsId => { getDataSetDetailsById(dsId, 'treeTable');}"
  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="dataSourceStyle === '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 "
  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"
  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. dataSourceStyle: 'dataset', // 数据来源方式
  646. fieldsList: [],
  647. params: [], // 参数配置
  648. datasetName: '',
  649. headerList: [],
  650. pageSizeList: [10, 20, 50, 100],
  651. rules: {
  652. // 'dataSource.businessKey': [
  653. // { required: true, message: '请选择数据集', trigger: 'change' }
  654. // ],
  655. // 'dataSource.dimensionField': [
  656. // { required: true, message: '请选择维度', trigger: 'change' }
  657. // ],
  658. // 'dataSource.dimensionFieldList': [
  659. // { required: true, message: '请选择维度', trigger: 'change' }
  660. // ],
  661. // 'dataSource.metricField': [
  662. // { required: true, message: '请选择指标', trigger: 'change' }
  663. // ],
  664. params: [
  665. {
  666. validator: (rule, value, callback) => {
  667. if (!value) {
  668. this.params.map(sort => {
  669. if (!sort.value) {
  670. callback(new Error('请输入参数值'))
  671. } else {
  672. callback()
  673. }
  674. })
  675. } else {
  676. callback()
  677. }
  678. }
  679. }
  680. ]
  681. }
  682. }
  683. },
  684. computed: {
  685. ...mapState({
  686. pageInfo: state => state.bigScreen.pageInfo,
  687. config: state => state.bigScreen.activeItemConfig
  688. // 缓存数据集
  689. // cacheDataSets: state => state.bigScreen.pageInfo.pageConfig.cacheDataSets
  690. }),
  691. dataSourceDataList () {
  692. return this.fieldsList?.map(item => ({
  693. ...item,
  694. comment: item?.fieldDesc || item?.fieldName,
  695. name: item?.fieldName
  696. }))
  697. },
  698. appCode: {
  699. get () {
  700. return this.$store.state.bigScreen.pageInfo.appCode
  701. }
  702. },
  703. seriesFieldProp () {
  704. if (this.config.option.displayOption.seriesField.required) {
  705. return 'dataSource.seriesField'
  706. } else {
  707. return ''
  708. }
  709. },
  710. pageCode () {
  711. return this.$route.query.code
  712. },
  713. // 映射字段
  714. sourceFieldList () {
  715. const list = this?.config?.customize?.bindComponents || this.fieldsList
  716. const modifiedList = list?.map(field => ({
  717. label: field.comment || field.fieldDesc,
  718. value: field.name || field.fieldName
  719. })) || []
  720. if (['input', 'timePicker', 'dateTimePicker'].includes(this.config.type)) {
  721. modifiedList.push({ label: '当前组件值', value: this.config.code })
  722. }
  723. return modifiedList
  724. }
  725. },
  726. watch: {
  727. // 切换数据集时将其他配置清空
  728. 'config.dataSource.businessKey' (val) {
  729. this.clearCustomVerify()
  730. this.clearVerify()
  731. },
  732. // 切换数据集类型时将其他配置清空
  733. 'config.dataSource.dataSetType' () {
  734. this.config.dataSource.businessKey = ''
  735. this.clearCustomVerify()
  736. this.clearVerify()
  737. },
  738. // 参数改变时
  739. params: {
  740. handler (val) {
  741. if (!isEmpty(val)) {
  742. const params = cloneDeep(val)
  743. const paramsMap = params.reduce((obj, param) => {
  744. obj[param.name] = param.value
  745. return obj
  746. }, {})
  747. this.config.dataSource.params = paramsMap
  748. }
  749. },
  750. deep: true
  751. },
  752. 'config.dataSource.dimensionField' (val) {
  753. if (['select'].includes(this.config.type)) {
  754. if (this.config.customize?.placeholder) {
  755. this.config.customize.placeholder = '请选择' + this.dataSourceDataList.find(item => item.fieldName === val).comment
  756. }
  757. }
  758. }
  759. },
  760. mounted () {
  761. if (this.config.dataSource && this.config.dataSource.businessKey) {
  762. this.getDataSetDetailsById(this.config.dataSource.businessKey, 'initial')
  763. }
  764. },
  765. methods: {
  766. // 打开表达式弹窗
  767. openExpression () {
  768. this.$refs.expressionDialog.init()
  769. },
  770. // 切换前后端分页
  771. serverPaginationChange (val) {
  772. this.config.customize.webPagination = !val
  773. },
  774. // 清空自定义组件配置,与手动配置的组件区分开
  775. clearCustomVerify () {
  776. this.config.setting = this.config.setting?.map(set => {
  777. this.datasetName = ''
  778. if (set.tabName === 'data') {
  779. set.value = ''
  780. }
  781. return set
  782. })
  783. },
  784. // 清空手动配置的组件配置
  785. clearVerify () {
  786. this.config.dataSource.metricField = ''
  787. this.config.dataSource.dimensionField = ''
  788. this.config.dataSource.dimensionFieldList = []
  789. this.config.dataSource.seriesField = ''
  790. this.config.dataSource.params = {}
  791. },
  792. // 根据数据集来获取数据集详情
  793. getDataSetDetailsById (id, type) {
  794. this.clearVerify()
  795. this.config.customize.columnConfig=[]
  796. if (id) {
  797. this.config.dataSource.businessKey = id
  798. getDataSetDetails(id).then(res => {
  799. this.fieldsList = res.fields
  800. // 初始化时以组件本来的参数设置为主
  801. if (type === 'initial') {
  802. const deleteKeys = []
  803. for (const key in this.config.dataSource.params) {
  804. const param = res?.params?.find(field => field.name === key)
  805. // 如果组件参数在数据集中找不到,说明参数已经被删除,不需要再显示
  806. if (param) {
  807. deleteKeys.push(key)
  808. this.params.push({
  809. name: key,
  810. value: this.config.dataSource.params[key],
  811. type: param?.type,
  812. remark: param?.remark
  813. })
  814. }
  815. }
  816. if (res.params) {
  817. // 如果数据集中有新增的参数,需要显示出来
  818. res.params.forEach(param => {
  819. if (!this.params.find(item => item.name === param.name)) {
  820. this.params.push({
  821. name: param.name,
  822. value: param.value,
  823. type: param.type,
  824. remark: param.remark
  825. })
  826. }
  827. })
  828. }
  829. deleteKeys.forEach(key => {
  830. delete this.config.dataSource.params[key]
  831. })
  832. } else {
  833. this.params = res.params
  834. }
  835. this.datasetName = res.name
  836. // 选择数据集的时候,如果数据集类型是dataModel,则不显示参数配置
  837. this.config.option.displayOption.params.enable = res.type !== 'dataModel'
  838. // 根据数据集初始化组件的入参:inparams
  839. if (res.type !== 'dataModel') {
  840. this.config.inParams =
  841. this.params?.map(param => {
  842. return {
  843. name: param.remark, // 参数名
  844. code: param.name // 参数值
  845. }
  846. }) || []
  847. } else {
  848. this.config.inParams =
  849. this.fieldsList?.map(field => {
  850. return {
  851. name: field.fieldDesc, // 参数名
  852. code: field.fieldName // 参数值
  853. }
  854. }) || []
  855. }
  856. // 根据数据集的参数初始化表单项
  857. this.config.paramsList = this.params
  858. if (type === 'treeTable') {
  859. const enumeration = {
  860. dataSetType: '1', // 数据集类型
  861. dataSetKey: '', // 数据集
  862. itemKeyName: '', // 选项显示字段
  863. itemValueName: '', // 选项value字段
  864. params: []
  865. }
  866. this.config.fields =
  867. this.params?.map(param => {
  868. return {
  869. name: param.name,
  870. label: param.remark || param.name,
  871. component: 'input',
  872. display: res.type !== 'dataModel',
  873. enumeration: {
  874. ...enumeration
  875. },
  876. queryRule: 'like'
  877. }
  878. }) || []
  879. }
  880. })
  881. }
  882. },
  883. // 改变维度
  884. dimensionFieldListChange (list) {
  885. const colFieldList = []
  886. if (list.length > 0) {
  887. list.forEach(item => {
  888. colFieldList.push(
  889. this.dataSourceDataList.find(field => field.name === item)
  890. )
  891. })
  892. }
  893. this.headerList = []
  894. colFieldList.forEach(item => {
  895. this.headerList.push({ name: item.comment, code: item.name, width: '150', align: 'left' })
  896. })
  897. this.config.customize.columnConfig = cloneDeep(this.headerList)
  898. this.$store.commit('bigScreen/changeActiveItemConfig', this.config)
  899. },
  900. valuePositionChange (value) {
  901. const sortedColumnData = {}
  902. const columnData = cloneDeep(this.config.option?.columnData)
  903. value.forEach((item, index) => {
  904. sortedColumnData[item] = columnData[item]
  905. })
  906. this.config.option.columnData = sortedColumnData
  907. this.$store.commit('bigScreen/changeActiveItemConfig', this.config)
  908. },
  909. changeCustomProps (value, setting) {
  910. this.config.setting = this.config.setting.map(item => {
  911. if (item.field === setting.field) {
  912. item.value = value
  913. }
  914. return item
  915. })
  916. }
  917. // 改变缓存数据集key
  918. // changeCacheBusinessKey (id) {
  919. // // 根据id在缓存中获取fields
  920. // this.fieldsList = this.cacheDataSets?.find(cache => cache.dataSetId === id)?.fields
  921. // this.params = this.cacheDataSets?.find(cache => cache.dataSetId === id)?.params
  922. // }
  923. }
  924. }
  925. </script>
  926. <style lang="scss" scoped>
  927. @import "../../assets/style/settingWrap.scss";
  928. .add-filter-box {
  929. position: relative;
  930. .add-filter {
  931. margin-left: 100px;
  932. }
  933. .add-filter-btn {
  934. position: absolute;
  935. top: 0;
  936. }
  937. }
  938. .form {
  939. padding: 12px;
  940. }
  941. ::v-deep .el-tag__close.el-icon-close::before {
  942. color: #fff;
  943. }
  944. ::v-deep .el-tag__close.el-icon-close {
  945. top: -1px;
  946. &:hover {
  947. background-color:var(--bs-el-color-primary);
  948. }
  949. }
  950. .opt-wrap{
  951. margin-top: 10px;
  952. }
  953. .link-set-item {
  954. position: relative;
  955. border: 1px solid #f5f7fa;
  956. padding: 30px 16px 10px;
  957. box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  958. margin: 10px;
  959. .del-icon {
  960. cursor: pointer;
  961. position: absolute;
  962. right: 10px;
  963. top: 5px;
  964. font-size: 20px;
  965. color: #f00;
  966. }
  967. .opt-wrap {
  968. display: flex;
  969. justify-content: center;
  970. }
  971. }
  972. //表达式样式
  973. .expression{
  974. &:hover{
  975. cursor: pointer;
  976. }
  977. }
  978. // 修改设置面板样式
  979. .data-setting-box{
  980. .data-setting-data-box{
  981. .lc-field-head{
  982. height: 30px;
  983. .lc-field-title{
  984. position: relative;
  985. padding-left: 12px;
  986. line-height: 30px;
  987. height: 30px;
  988. &:after{
  989. position: absolute;
  990. left: 0;
  991. top: 50%;
  992. transform: translateY(-50%);
  993. content: '';
  994. width: 4px;
  995. height: 14px;
  996. background-color: var(--bs-el-color-primary);
  997. }
  998. }
  999. }
  1000. }
  1001. }
  1002. </style>