AimPlaceContents.vue 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698
  1. <template>
  2. <div>
  3. <div class="filters-container">
  4. <el-input placeholder="关键字" size="small" v-model="filter1" clearable class="filter-item"></el-input>
  5. <el-button @click="searchData" type="primary" size="small" icon="el-icon-search" class="filter-item">搜索
  6. </el-button>
  7. <el-button @click="showAdvancedQueryDialog = !showAdvancedQueryDialog" type="primary" size="small" icon="el-icon-search" class="filter-item">高级查询
  8. </el-button>
  9. <el-button @click="showTableSortDialog = !showTableSortDialog" type="primary" size="small" icon="el-icon-sort" class="filter-item">排序
  10. </el-button>
  11. <el-button @click="$router.push({path:'/aimPlaceContent',query:{column:$route.query.column}})" type="primary" size="small" icon="el-icon-edit" class="filter-item">添加
  12. </el-button>
  13. <el-button @click="exportExcel" type="primary" size="small" icon="el-icon-share" class="filter-item">导出EXCEL
  14. </el-button>
  15. <el-dropdown trigger="click" size="medium" class="table-column-filter">
  16. <span>
  17. 筛选数据
  18. <i class="el-icon-arrow-down el-icon--right"></i>
  19. </span>
  20. <el-dropdown-menu slot="dropdown" class="table-column-filter-wrapper">
  21. <el-checkbox v-for="item in tableColumns" :key="item.value" v-model="item.show">{{item.label}}
  22. </el-checkbox>
  23. </el-dropdown-menu>
  24. </el-dropdown>
  25. </div>
  26. <el-table :data="tableData" :height="tableHeight" row-key="id" ref="table">
  27. <el-table-column type="expand">
  28. <template scope="props">
  29. <el-table :data="props.row.aimPlaceContentChildList" border stripe v-if="props.row.aimPlaceContentChildList" size="mini">
  30. <el-table-column label="操作" align="center" min-width="80">
  31. <template slot-scope="scope">
  32. <el-button @click="editRow(scope.row)" type="primary" size="mini" plain>编辑</el-button>
  33. <el-button @click="deleteRow(scope.row)" type="danger" size="mini" plain>删除</el-button>
  34. </template>
  35. </el-table-column>
  36. <el-table-column prop="id" label="ID" min-width="100">
  37. </el-table-column>
  38. <el-table-column prop="aimPlaceContentId" label="目标点内容ID" min-width="100">
  39. </el-table-column>
  40. <el-table-column prop="type" label="类别" min-width="100">
  41. </el-table-column>
  42. <el-table-column prop="itemName" label="名称" min-width="100">
  43. </el-table-column>
  44. <el-table-column prop="itemMess" label="描述" min-width="100">
  45. </el-table-column>
  46. <el-table-column prop="itemDes" label="详细" min-width="100">
  47. </el-table-column>
  48. <el-table-column prop="remark1" label="备注1" min-width="100">
  49. </el-table-column>
  50. <el-table-column prop="remark2" label="备注2" min-width="100">
  51. </el-table-column>
  52. <el-table-column prop="remark3" label="备注3" min-width="100">
  53. </el-table-column>
  54. </el-table>
  55. </template>
  56. </el-table-column>
  57. <el-table-column v-if="multipleMode" align="center" type="selection" width="50">
  58. </el-table-column>
  59. <el-table-column type="index" min-width="50" align="center">
  60. </el-table-column>
  61. <el-table-column v-if="isColumnShow('id')" prop="id" label="ID" min-width="100">
  62. </el-table-column>
  63. <el-table-column v-if="isColumnShow('name')" prop="name" label="名称" min-width="100">
  64. </el-table-column>
  65. <el-table-column v-if="isColumnShow('type')" prop="type" label="类别" min-width="100">
  66. </el-table-column>
  67. <el-table-column v-if="isColumnShow('ownedLandMarkId')" prop="ownedLandMarkId" label="所属地标ID" min-width="100">
  68. </el-table-column>
  69. <el-table-column v-if="isColumnShow('arContentGroupId')" prop="arContentGroupId" label="AR内容组ID" min-width="100">
  70. </el-table-column>
  71. <el-table-column v-if="isColumnShow('arKitPosX')" prop="arKitPosX" label="ArKit坐标X" min-width="100">
  72. </el-table-column>
  73. <el-table-column v-if="isColumnShow('arKitPosY')" prop="arKitPosY" label="ArKit坐标Y" min-width="100">
  74. </el-table-column>
  75. <el-table-column v-if="isColumnShow('arKitPosZ')" prop="arKitPosZ" label="ArKit坐标Z" min-width="100">
  76. </el-table-column>
  77. <el-table-column v-if="isColumnShow('arKitScale')" prop="arKitScale" label="ArKit缩放" min-width="100">
  78. </el-table-column>
  79. <el-table-column v-if="isColumnShow('arKitAngle')" prop="arKitAngle" label="ArKit角度" min-width="100">
  80. </el-table-column>
  81. <el-table-column v-if="isColumnShow('arKitShowLenth')" prop="arKitShowLenth" label="ArKit一定距离显示" min-width="100">
  82. </el-table-column>
  83. <el-table-column v-if="isColumnShow('gyroPosX')" prop="gyroPosX" label="Gyro坐标X" min-width="100">
  84. </el-table-column>
  85. <el-table-column v-if="isColumnShow('gyroPosY')" prop="gyroPosY" label="Gyro坐标Y" min-width="100">
  86. </el-table-column>
  87. <el-table-column v-if="isColumnShow('gyroPosZ')" prop="gyroPosZ" label="Gyro坐标Z" min-width="100">
  88. </el-table-column>
  89. <el-table-column v-if="isColumnShow('gyroPosScale')" prop="gyroPosScale" label="Gyro缩放" min-width="100">
  90. </el-table-column>
  91. <el-table-column v-if="isColumnShow('gyroPosAngle')" prop="gyroPosAngle" label="Gyro角度" min-width="100">
  92. </el-table-column>
  93. <el-table-column v-if="isColumnShow('gyroPosShowLenth')" prop="gyroPosShowLenth" label="Gyro一定距离显示" min-width="100">
  94. </el-table-column>
  95. <el-table-column v-if="isColumnShow('vuforiaImageInfoAreaMarking')" prop="vuforiaImageInfoAreaMarking" label="Gyro绑定识别图区域标记编号" min-width="100">
  96. </el-table-column>
  97. <el-table-column v-if="isColumnShow('remark1')" prop="remark1" label="备注1" min-width="100">
  98. </el-table-column>
  99. <el-table-column v-if="isColumnShow('remark2')" prop="remark2" label="备注2" min-width="100">
  100. </el-table-column>
  101. <el-table-column v-if="isColumnShow('remark3')" prop="remark3" label="备注3" min-width="100">
  102. </el-table-column>
  103. <el-table-column v-if="isColumnShow('remark4')" prop="remark4" label="备注4" min-width="100">
  104. </el-table-column>
  105. <el-table-column v-if="isColumnShow('remark5')" prop="remark5" label="备注5" min-width="100">
  106. </el-table-column>
  107. <el-table-column v-if="isColumnShow('remark6')" prop="remark6" label="备注6" min-width="100">
  108. </el-table-column>
  109. <el-table-column label="操作" align="center" fixed="right" min-width="150">
  110. <template slot-scope="scope">
  111. <el-button @click="$router.push({path:'/AimPlaceContentChilds',query:{column:scope.row.id+',aimPlaceContentId'}})" type="primary" size="small" plain>内容子集
  112. </el-button>
  113. <el-button @click="editRow(scope.row)" type="primary" size="mini" plain>编辑</el-button>
  114. <el-button @click="deleteRow(scope.row)" type="danger" size="mini" plain>删除</el-button>
  115. </template>
  116. </el-table-column>
  117. </el-table>
  118. <div class="pagination-wrapper">
  119. <div class="multiple-mode-wrapper" v-if="0">
  120. <el-button size="small" v-if="!multipleMode" @click="toggleMultipleMode(true)">批量编辑</el-button>
  121. <el-button-group v-else>
  122. <el-button size="small" @click="operation1">批量操作1</el-button>
  123. <el-button size="small" @click="operation2">批量操作2</el-button>
  124. <el-button size="small" @click="toggleMultipleMode(false)">取消</el-button>
  125. </el-button-group>
  126. </div>
  127. <el-pagination background @size-change="pageSizeChange" @current-change="currentPageChange" :current-page="currentPage" :page-sizes="[10, 20, 30, 40, 50]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="totalNumber">
  128. </el-pagination>
  129. </div>
  130. <el-dialog title="高级查询" :visible.sync="showAdvancedQueryDialog">
  131. <el-button @click="addField" type="text" icon="el-icon-plus">添加</el-button>
  132. <el-table :data="advancedQueryFields">
  133. <el-table-column prop="link" label="链接符" align="center">
  134. <template slot-scope="{row}">
  135. <el-select placeholder="链接" size="small" v-model="row.link" class="filter-item">
  136. <el-option label="AND" value="AND">
  137. </el-option>
  138. <el-option label="OR" value="OR">
  139. </el-option>
  140. </el-select>
  141. </template>
  142. </el-table-column>
  143. <el-table-column prop="name" label="字段" align="center">
  144. <template slot-scope="{row}">
  145. <el-select v-model="row.name">
  146. <el-option v-for="item in advancedQueryColumns" :label="item.label" :value="item.value" :key="item.value"></el-option>
  147. </el-select>
  148. </template>
  149. </el-table-column>
  150. <el-table-column prop="searchMethod" label="搜索方式" width="150" align="center">
  151. <template slot-scope="{row}">
  152. <el-select v-model="row.searchMethod">
  153. <el-option v-for="item in searchMethods" :label="item" :value="item" :key="item"></el-option>
  154. </el-select>
  155. </template>
  156. </el-table-column>
  157. <el-table-column prop="value" label="参数" align="center">
  158. <template slot-scope="{row}">
  159. <el-input v-model="row.value"></el-input>
  160. </template>
  161. </el-table-column>
  162. <el-table-column width="60" align="center">
  163. <template slot-scope="{ row, column, $index }">
  164. <el-button @click="removeField($index)" size="small" type="text">删除</el-button>
  165. </template>
  166. </el-table-column>
  167. </el-table>
  168. <span slot="footer" class="dialog-footer">
  169. <el-button @click="advancedQuery" :loading="$store.state.fetchingData">确定</el-button>
  170. </span>
  171. </el-dialog>
  172. <el-dialog title="排序" :visible.sync="showTableSortDialog">
  173. <el-button @click="addSortField" type="text" icon="el-icon-plus">添加</el-button>
  174. <el-table :data="tableSortFields">
  175. <el-table-column prop="name" label="字段" align="center">
  176. <template slot-scope="{row}">
  177. <el-select v-model="row.name">
  178. <el-option v-for="item in advancedQueryColumns" :label="item.label" :value="item.value" :key="item.value"></el-option>
  179. </el-select>
  180. </template>
  181. </el-table-column>
  182. <el-table-column prop="order" label="排序" align="center">
  183. <template slot-scope="{row}">
  184. <el-select v-model="row.order">
  185. <el-option label="降序" value="desc">
  186. </el-option>
  187. <el-option label="升序" value="asc">
  188. </el-option>
  189. </el-select>
  190. </template>
  191. </el-table-column>
  192. <el-table-column width="60" align="center">
  193. <template slot-scope="{ row, column, $index }">
  194. <el-button @click="removeSortField($index)" size="small" type="text">删除</el-button>
  195. </template>
  196. </el-table-column>
  197. </el-table>
  198. <span slot="footer" class="dialog-footer">
  199. <el-button @click="tableSortQuery" :loading="$store.state.fetchingData">确定</el-button>
  200. </span>
  201. </el-dialog>
  202. <el-dialog title="查看图片" :visible.sync="imageDialogVisible" size="small">
  203. <img width="100%" :src="imgSrc" alt="">
  204. </el-dialog>
  205. </div>
  206. </template>
  207. <script>
  208. import { mapState } from 'vuex'
  209. import { format } from 'date-fns'
  210. import zh from 'date-fns/locale/zh_cn'
  211. export default {
  212. name: 'AimPlaceContents',
  213. // props:{
  214. // ownedLandMarkId(){
  215. // type:Number,
  216. // }
  217. // },
  218. created() {
  219. this.getData();
  220. },
  221. data() {
  222. return {
  223. totalNumber: 0,
  224. totalPage: 10,
  225. currentPage: 1,
  226. pageSize: 20,
  227. tableData: [],
  228. filter1: '',
  229. filter2: '',
  230. tableColumns: [
  231. {
  232. label: 'ID',
  233. value: 'id',
  234. show: true
  235. },
  236. {
  237. label: '名称',
  238. value: 'name',
  239. show: true
  240. },
  241. {
  242. label: '类别',
  243. value: 'type',
  244. show: true
  245. },
  246. {
  247. label: '所属地标ID',
  248. value: 'ownedLandMarkId',
  249. show: true
  250. },
  251. {
  252. label: 'AR内容组ID',
  253. value: 'arContentGroupId',
  254. show: true
  255. },
  256. {
  257. label: 'ArKit坐标X',
  258. value: 'arKitPosX',
  259. show: true
  260. },
  261. {
  262. label: 'ArKit坐标Y',
  263. value: 'arKitPosY',
  264. show: true
  265. },
  266. {
  267. label: 'ArKit坐标Z',
  268. value: 'arKitPosZ',
  269. show: true
  270. },
  271. {
  272. label: 'ArKit缩放',
  273. value: 'arKitScale',
  274. show: true
  275. },
  276. {
  277. label: 'ArKit角度',
  278. value: 'arKitAngle',
  279. show: true
  280. },
  281. {
  282. label: 'ArKit一定距离显示',
  283. value: 'arKitShowLenth',
  284. show: true
  285. },
  286. {
  287. label: 'Gyro坐标X',
  288. value: 'gyroPosX',
  289. show: true
  290. },
  291. {
  292. label: 'Gyro坐标Y',
  293. value: 'gyroPosY',
  294. show: true
  295. },
  296. {
  297. label: 'Gyro坐标Z',
  298. value: 'gyroPosZ',
  299. show: true
  300. },
  301. {
  302. label: 'Gyro缩放',
  303. value: 'gyroPosScale',
  304. show: true
  305. },
  306. {
  307. label: 'Gyro角度',
  308. value: 'gyroPosAngle',
  309. show: true
  310. },
  311. {
  312. label: 'Gyro一定距离显示',
  313. value: 'gyroPosShowLenth',
  314. show: true
  315. },
  316. {
  317. label: 'Gyro绑定识别图区域标记编号',
  318. value: 'vuforiaImageInfoAreaMarking',
  319. show: true
  320. },
  321. {
  322. label: '备注1',
  323. value: 'remark1',
  324. show: true
  325. },
  326. {
  327. label: '备注2',
  328. value: 'remark2',
  329. show: true
  330. },
  331. {
  332. label: '备注3',
  333. value: 'remark3',
  334. show: true
  335. },
  336. {
  337. label: '备注4',
  338. value: 'remark4',
  339. show: true
  340. },
  341. {
  342. label: '备注5',
  343. value: 'remark5',
  344. show: true
  345. },
  346. {
  347. label: '备注6',
  348. value: 'remark6',
  349. show: true
  350. },
  351. ],
  352. multipleMode: false,
  353. showAdvancedQueryDialog: false,
  354. advancedQueryFields: [],
  355. showTableSortDialog: false,
  356. tableSortFields: [],
  357. searchMethods: ['=', '!=', '>', '>=', '<', '<=', 'like'],
  358. advancedQueryColumns: [
  359. {
  360. label: 'ID',
  361. value: 'id'
  362. },
  363. {
  364. label: '名称',
  365. value: 'name'
  366. },
  367. {
  368. label: '类别',
  369. value: 'type'
  370. },
  371. {
  372. label: '所属地标ID',
  373. value: 'owned_land_mark_id'
  374. },
  375. {
  376. label: 'AR内容组ID',
  377. value: 'ar_content_group_id'
  378. },
  379. {
  380. label: 'ArKit坐标X',
  381. value: 'ar_kit_pos_x'
  382. },
  383. {
  384. label: 'ArKit坐标Y',
  385. value: 'ar_kit_pos_y'
  386. },
  387. {
  388. label: 'ArKit坐标Z',
  389. value: 'ar_kit_pos_z'
  390. },
  391. {
  392. label: 'ArKit缩放',
  393. value: 'ar_kit_scale'
  394. },
  395. {
  396. label: 'ArKit角度',
  397. value: 'ar_kit_angle'
  398. },
  399. {
  400. label: 'ArKit一定距离显示',
  401. value: 'ar_kit_show_lenth'
  402. },
  403. {
  404. label: 'Gyro坐标X',
  405. value: 'gyro_pos_x'
  406. },
  407. {
  408. label: 'Gyro坐标Y',
  409. value: 'gyro_pos_y'
  410. },
  411. {
  412. label: 'Gyro坐标Z',
  413. value: 'gyro_pos_z'
  414. },
  415. {
  416. label: 'Gyro缩放',
  417. value: 'gyro_pos_scale'
  418. },
  419. {
  420. label: 'Gyro角度',
  421. value: 'gyro_pos_angle'
  422. },
  423. {
  424. label: 'Gyro一定距离显示',
  425. value: 'gyro_pos_show_lenth'
  426. },
  427. {
  428. label: 'Gyro绑定识别图区域标记编号',
  429. value: 'vuforia_image_info_area_marking'
  430. },
  431. {
  432. label: '备注1',
  433. value: 'remark1'
  434. },
  435. {
  436. label: '备注2',
  437. value: 'remark2'
  438. },
  439. {
  440. label: '备注3',
  441. value: 'remark3'
  442. },
  443. {
  444. label: '备注4',
  445. value: 'remark4'
  446. },
  447. {
  448. label: '备注5',
  449. value: 'remark5'
  450. },
  451. {
  452. label: '备注6',
  453. value: 'remark6'
  454. },
  455. ],
  456. advancedQuerySearchKey: '',
  457. orderByStr: '',
  458. imgSrc: '',
  459. imageDialogVisible: false,
  460. }
  461. },
  462. computed: {
  463. ...mapState(['tableHeight']),
  464. selection() {
  465. return this.$refs.table.selection.map(i => i.id);
  466. }
  467. },
  468. methods: {
  469. pageSizeChange(size) {
  470. this.currentPage = 1;
  471. this.pageSize = size;
  472. this.getData();
  473. },
  474. currentPageChange(page) {
  475. this.currentPage = page;
  476. this.getData();
  477. },
  478. getData() {
  479. var data = {
  480. currentPage: this.currentPage,
  481. pageNumber: this.pageSize,
  482. searchKey: this.filter1,
  483. advancedQuery: this.advancedQuerySearchKey,
  484. orderByStr: this.orderByStr,
  485. ownedLandMarkId: this.$route.query.id
  486. }
  487. // if (this.$route.query.column) {
  488. // var tempColumn = this.$route.query.column;
  489. // data[tempColumn.split(',')[1]] = tempColumn.split(',')[0];
  490. // }
  491. this.$http.get({
  492. url: '/aimPlaceContent/page',
  493. data: data
  494. }).then(res => {
  495. if (res.success) {
  496. this.totalNumber = res.data.page.totalNumber;
  497. this.tableData = res.data.pp;
  498. }
  499. })
  500. },
  501. isColumnShow(column) {
  502. var row = this.tableColumns.find(i => i.value === column);
  503. return row ? row.show : false;
  504. },
  505. toggleMultipleMode(multipleMode) {
  506. this.multipleMode = multipleMode;
  507. if (!multipleMode) {
  508. this.$refs.table.clearSelection();
  509. }
  510. },
  511. editRow(row) {
  512. this.$router.push({
  513. path: '/aimPlaceContent',
  514. query: {
  515. id: row.id,
  516. column: this.$route.query.column,
  517. }
  518. })
  519. },
  520. operation1() {
  521. this.$notify({
  522. title: '提示',
  523. message: this.selection
  524. });
  525. },
  526. operation2() {
  527. this.$message('操作2');
  528. },
  529. addField() {
  530. this.advancedQueryFields.push({
  531. link: 'AND',
  532. name: '',
  533. searchMethod: '=',
  534. value: '',
  535. });
  536. },
  537. removeField(i) {
  538. if (this.advancedQueryFields.length > 0) {
  539. this.advancedQueryFields.splice(i, 1);
  540. }
  541. },
  542. advancedQuery() {
  543. this.advancedQuerySearchKey = '';
  544. if (this.advancedQueryFields.length > 0) {
  545. var templist = [];
  546. this.advancedQueryFields.forEach(item => {
  547. if (item.link && item.name && item.searchMethod && item.value) {
  548. var tempItem = item.link + '_,' + item.name + '_,' + item.searchMethod + '_,' + item.value;
  549. templist.push(tempItem);
  550. }
  551. })
  552. if (templist.length > 0) {
  553. this.advancedQuerySearchKey = templist.join('_;');
  554. }
  555. }
  556. this.getData();
  557. this.showAdvancedQueryDialog = false;
  558. },
  559. addSortField() {
  560. this.tableSortFields.push({
  561. name: '',
  562. order: 'asc',
  563. });
  564. },
  565. removeSortField(i) {
  566. if (this.tableSortFields.length > 0) {
  567. this.tableSortFields.splice(i, 1);
  568. }
  569. },
  570. tableSortQuery() {
  571. this.orderByStr = '';
  572. if (this.tableSortFields.length > 0) {
  573. var templist = [];
  574. this.tableSortFields.forEach(item => {
  575. if (item.name && item.order) {
  576. var tempItem = item.name + '_,' + item.order;
  577. templist.push(tempItem);
  578. }
  579. })
  580. if (templist.length > 0) {
  581. this.orderByStr = templist.join('_;');
  582. }
  583. }
  584. this.getData();
  585. this.showTableSortDialog = false;
  586. },
  587. exportExcel() {
  588. window.location.href = this.$baseUrl + "/aimPlaceContent/exportExcel?searchKey="
  589. + this.filter1 + "&advancedQuery=" + this.advancedQuerySearchKey + "&orderByStr=" + this.orderByStr;
  590. },
  591. searchData() {
  592. this.currentPage = 1;
  593. this.getData();
  594. },
  595. deleteRow(row) {
  596. this.$alert('删除将无法恢复,确认要删除么?', '警告', { type: 'error' }).then(() => {
  597. return this.$http.post({
  598. url: '/aimPlaceContent/del',
  599. data: { id: row.id }
  600. })
  601. }).then(() => {
  602. this.$message.success('删除成功');
  603. this.getData();
  604. }).catch(action => {
  605. if (action === 'cancel') {
  606. this.$message.info('删除取消');
  607. } else {
  608. this.$message.error('删除失败');
  609. }
  610. })
  611. },
  612. DateTimeFormatter(row, column, cellValue) {
  613. if (cellValue) {
  614. return format(cellValue, 'YYYY/MM/DD HH:mm', { locale: zh })
  615. }
  616. },
  617. DateFormatter(row, column, cellValue) {
  618. if (cellValue) {
  619. return format(cellValue, 'YYYY/MM/DD', { locale: zh })
  620. }
  621. },
  622. showImg(img) {
  623. this.imgSrc = img;
  624. this.imageDialogVisible = true;
  625. },
  626. }
  627. }
  628. </script>
  629. <style lang="less" scoped>
  630. </style>