You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

759 lines
22 KiB

1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
1 month ago
  1. <script setup>
  2. import {computed, onMounted, ref} from 'vue'
  3. import {dayjs, ElMessage} from 'element-plus'
  4. import request from '@/util/http.js'
  5. import API from '@/util/http.js'
  6. import moment from 'moment'
  7. import {reverseMarketMapping} from "@/utils/marketMap.js";
  8. // 之后整理一下
  9. /*
  10. ====================工具方法==============================
  11. */
  12. const trimJwCode = () => {
  13. if (consumeUser.value.jwcode) {
  14. consumeUser.value.jwcode = consumeUser.value.jwcode.replace(/\s/g, '');
  15. }
  16. }
  17. // 时间格式化
  18. const formatTime = (val) => val ? dayjs(val).format('YYYY-MM-DD HH:mm:ss') : ''
  19. const defaultTime = [
  20. new Date(2000, 1, 1, 0, 0, 0),
  21. new Date(2000, 2, 1, 23, 59, 59),
  22. ]
  23. /*
  24. ====================数据=================================
  25. */
  26. //这是获取用户信息的接口
  27. const adminData = ref({})
  28. // 充值明细表格
  29. const tableData = ref([])
  30. // 搜索consumeUser 表单
  31. const consumeUser = ref({
  32. jwcode: null,
  33. payPlatform: "",
  34. market: "",
  35. startTime: '',
  36. endTime: '',
  37. goodsName: '',
  38. })
  39. // 标记当前激活的时间范围按钮
  40. const activeTimeRange = ref('')
  41. // 日期选择器变化时清除按钮激活状态
  42. const handleDatePickerChange = () => {
  43. activeTimeRange.value = ''
  44. }
  45. // 搜索对象
  46. const getObj = ref({
  47. pageNum: 1,
  48. pageSize: 50
  49. })
  50. //分页总条目
  51. const total = ref(100)
  52. // 搜索对象时间
  53. const getTime = ref({
  54. startTime: '',
  55. endTime: ''
  56. })
  57. // 搜索活动列表
  58. const activity = ref([])
  59. // 搜索地区列表
  60. const market = ref("")
  61. // 新增排序字段和排序方式
  62. const sortField = ref('')
  63. const sortOrder = ref('')
  64. // 消费平台选项
  65. const consumePlatform = [
  66. {
  67. value: '金币系统',
  68. label: '金币系统'
  69. },
  70. {
  71. value: 'HomilyChart',
  72. label: 'HomilyChart'
  73. },
  74. {
  75. value: 'HomilyLink',
  76. label: 'HomilyLink'
  77. },
  78. {
  79. value: 'ERP',
  80. label: 'ERP'
  81. },
  82. {
  83. value: '其他',
  84. label: '其他'
  85. },
  86. {
  87. value: '初始化金币',
  88. label: '初始化金币'
  89. },
  90. ]
  91. // 合计数的显示数据
  92. const tableDataTotal = ref({})
  93. const permanentGold = ref(0)
  94. const freeGold = ref(0)
  95. const taskGold = ref(0)
  96. const totalGold = ref(0)
  97. // 定义响应式变量存储金币合计数
  98. const permanentGolds = ref(0)
  99. const freeGolds = ref(0)
  100. const taskGolds = ref(0)
  101. // 查询商品的接口的表单
  102. const goods = ref([])
  103. const totalGoldSearch = ref({
  104. jwcode: null,
  105. payPlatform: "",
  106. market: "",
  107. startTime: "",
  108. endTime: "",
  109. goodsName: ""
  110. })
  111. /*
  112. ====================方法=================================
  113. */
  114. // 获取登录用户信息
  115. const getAdminData = async function () {
  116. try {
  117. const result = await request({
  118. url: '/admin/userinfo',
  119. data: {}
  120. })
  121. adminData.value = result
  122. console.log('请求成功', result)
  123. console.log('用户信息', adminData.value)
  124. } catch (error) {
  125. console.log('请求失败', error)
  126. }
  127. }
  128. const ConsumeSelectBy = async function (val) {
  129. try {
  130. // 搜索参数页码赋值
  131. if (typeof val === 'number') {
  132. getObj.value.pageNum = val
  133. }
  134. // 搜索参数时间赋值
  135. if (getTime.value != null) {
  136. if (getTime.value.startTime != '' && getTime.value.endTime != '') {
  137. consumeUser.value.startTime = formatTime(getTime.value[0])
  138. consumeUser.value.endTime = formatTime(getTime.value[1])
  139. }
  140. } else {
  141. consumeUser.value.startTime = ''
  142. consumeUser.value.endTime = ''
  143. }
  144. consumeUser.value.sortField = sortField.value
  145. consumeUser.value.sortOrder = sortOrder.value
  146. console.log('搜索参数_时间', consumeUser.value.startTime)
  147. console.log('搜索参数1', getObj.value)
  148. console.log('搜索参数2', consumeUser.value)
  149. // 发送POST请求
  150. if (consumeUser.value.market === '9' || consumeUser.value.market === '9999') {
  151. consumeUser.value.market = '';
  152. }
  153. if (consumeUser.value.jwcode) {
  154. // 纯数字
  155. const numberRegex = /^\d{1,9}$/;
  156. // 检查是否不是数字
  157. if (!numberRegex.test(consumeUser.value.jwcode)) {
  158. ElMessage.error('请检查精网号格式')
  159. return
  160. }
  161. }
  162. const result = await request({
  163. url: '/consume/selectBy',
  164. data: {
  165. pageNum: getObj.value.pageNum,
  166. pageSize: getObj.value.pageSize,
  167. consumeUser: {
  168. ...consumeUser.value,
  169. sortField: sortField.value,
  170. sortOrder: sortOrder.value
  171. }
  172. }
  173. })
  174. console.log('请求成功2', sortField)
  175. // 合计数的接口
  176. // 复制一份 detail.value 并移除排序字段和排序方式
  177. const detailWithoutSort = {...consumeUser.value}
  178. delete detailWithoutSort.sortField
  179. delete detailWithoutSort.sortOrder
  180. // 赋值
  181. totalGoldSearch.value.startTime = consumeUser.value.startTime
  182. totalGoldSearch.value.endTime = consumeUser.value.endTime
  183. totalGoldSearch.value.payPlatform = consumeUser.value.payPlatform
  184. totalGoldSearch.value.market = consumeUser.value.market
  185. totalGoldSearch.value.goodsName = consumeUser.value.goodsName
  186. totalGoldSearch.value.jwcode = consumeUser.value.jwcode
  187. //
  188. const resultTotalGold = await request({
  189. // url: '/consume/statsGold',
  190. url: '/consume/statsGold',
  191. data: totalGoldSearch.value
  192. })
  193. console.log("总计", resultTotalGold)
  194. if (resultTotalGold.code === 200 && resultTotalGold.data) {
  195. const data = resultTotalGold.data
  196. console.log('获取到的金币数据:', data)
  197. permanentGolds.value = Number(data.permanentGolds) || 0
  198. freeGolds.value = Number(data.freeGolds) || 0
  199. taskGolds.value = Number(data.taskGolds) || 0
  200. }
  201. // 存储表格数据
  202. tableData.value = result.data.list
  203. tableDataTotal.value = resultTotalGold.data
  204. if (resultTotalGold.data == null) {
  205. console.log('请求成功2', resultTotalGold)
  206. // 这是啥东西啊
  207. tableDataTotal.value = resultTotalGold.data
  208. }
  209. const sumGoldList = tableData.value.map(item => item.sumGold);
  210. console.log("sumGold", sumGoldList); // 输出包含所有 sumGold 值的数组
  211. console.log('@@@@@@@@@@tableDataT', tableDataTotal.value.list)
  212. // totalGold.value = tableData.value.sum
  213. // // 修改为保留两位小数
  214. // permanentGold.value = parseFloat(
  215. // (tableDataTotal.value.list.sumGold / 100).toFixed(2)
  216. // )
  217. // freeGold.value = parseFloat(
  218. // (tableDataTotal.value.sumFcion / 100).toFixed(2)
  219. // )
  220. // taskGold.value = parseFloat(
  221. // (tableDataTotal.value.sumTcion / 100).toFixed(2)
  222. // )
  223. // totalGold.value = parseFloat(
  224. // (tableDataTotal.value.sumcion / 100).toFixed(2)
  225. // )
  226. console.log('tableData', tableData.value)
  227. // 存储分页总数
  228. total.value = result.data.total
  229. console.log('total', total.value)
  230. } catch (error) {
  231. console.log('请求失败', error)
  232. // 在这里可以处理错误逻辑,比如显示错误提示等
  233. }
  234. }
  235. // 搜索
  236. const search = function () {
  237. trimJwCode()
  238. getObj.value.pageNum = 1
  239. ConsumeSelectBy()
  240. }
  241. // 重置
  242. const reset = function () {
  243. console.log('兄弟,你点了重置')
  244. consumeUser.value.goodsName = ''
  245. consumeUser.value.market = ""
  246. consumeUser.value.payPlatform = ''
  247. consumeUser.value.startTime = ''
  248. consumeUser.value.endTime = ''
  249. consumeUser.value.jwcode = null
  250. sortField.value = ''
  251. sortOrder.value = ''
  252. getTime.value = {}
  253. activeTimeRange.value = '' // 清除激活状态
  254. selectedMarketPath.value = []
  255. // 点完重置后,重新请求数据
  256. ConsumeSelectBy()
  257. console.log('consumeUser', consumeUser.value)
  258. }
  259. // 今天
  260. const getToday = function () {
  261. const today = dayjs()
  262. const startTime = today.startOf('day').format('YYYY-MM-DD HH:mm:ss')
  263. const endTime = today.endOf('day').format('YYYY-MM-DD HH:mm:ss')
  264. getTime.value = [startTime, endTime]
  265. console.log('getTime', getTime.value)
  266. activeTimeRange.value = 'today' // 标记当前激活状态
  267. ConsumeSelectBy()
  268. }
  269. // 昨天
  270. const getYesterday = function () {
  271. const today = dayjs()
  272. const startTime = today.subtract(1, 'day').startOf('day').format('YYYY-MM-DD HH:mm:ss')
  273. const endTime = today.subtract(1, 'day').endOf('day').format('YYYY-MM-DD HH:mm:ss')
  274. getTime.value = [startTime, endTime]
  275. console.log('getTime', getTime.value)
  276. activeTimeRange.value = 'yesterday' // 标记当前激活状态
  277. ConsumeSelectBy()
  278. }
  279. // 近7天
  280. const get7Days = function () {
  281. const today = dayjs()
  282. const startTime = today.subtract(6, 'day').startOf('day').format('YYYY-MM-DD HH:mm:ss')
  283. const endTime = today.add(1, 'day').endOf('day').format('YYYY-MM-DD HH:mm:ss')
  284. getTime.value = [startTime, endTime]
  285. console.log('getTime', getTime.value)
  286. activeTimeRange.value = '7days' // 标记当前激活状态
  287. ConsumeSelectBy()
  288. }
  289. // 获取商品列表
  290. const getGoods = async function () {
  291. try {
  292. // 发送POST请求
  293. const result = await request({
  294. url: '/general/goods',
  295. data: {}
  296. })
  297. // 将响应结果存储到响应式数据中
  298. console.log('请求成功product', result)
  299. // 存储全部数据
  300. goods.value = result.data
  301. console.log('goods 数据', goods.value) // 修改日志输出
  302. } catch (error) {
  303. console.log('请求失败', error)
  304. // 在这里可以处理错误逻辑,比如显示错误提示等
  305. }
  306. }
  307. // 处理排序事件
  308. const handleSortChange = (column) => {
  309. console.log('排序字段:', column.prop)
  310. console.log('排序方式:', column.order)
  311. if (column.prop === 'permanentGold') {
  312. sortField.value = 'permanentGold'
  313. } else if (column.prop === 'taskGold') {
  314. sortField.value = 'taskGold'
  315. } else if (column.prop === 'freeGold') {
  316. sortField.value = 'freeGold'
  317. } else if (column.prop === 'createTime') {
  318. sortField.value = 'createTime'
  319. }
  320. sortOrder.value = column.order === 'ascending' ? 'DESC' : 'ASC'
  321. ConsumeSelectBy()
  322. }
  323. const handlePageSizeChange = function (val) {
  324. getObj.value.pageSize = val
  325. ConsumeSelectBy()
  326. }
  327. const handleCurrentChange = function (val) {
  328. getObj.value.pageNum = val
  329. ConsumeSelectBy()
  330. }
  331. /*
  332. ====================计算属性=================================
  333. */
  334. // 计算总金币数
  335. const sumGold = computed(() => permanentGolds.value + freeGolds.value + taskGolds.value)
  336. /*
  337. ====================监听=================================
  338. */
  339. /*
  340. ====================挂载=================================
  341. */
  342. onMounted(async function () {
  343. await getAdminData()
  344. await ConsumeSelectBy()
  345. // getActivity();
  346. await getMarket()
  347. await getGoods()
  348. })
  349. const exportExcel = async function () {
  350. const params = {
  351. consumeUser: {
  352. jwcode: consumeUser.value.jwcode || '',
  353. payPlatform: consumeUser.value.payPlatform || '',
  354. marketss: consumeUser.value.market || "",
  355. startTime: consumeUser.value.startTime || '',
  356. endTime: consumeUser.value.endTime || '',
  357. goodsName: consumeUser.value.goodsName || '',
  358. sortField: sortField.value || '',
  359. sortOrder: sortOrder.value || ''
  360. }
  361. }
  362. const res = await API({url: '/export/exportConsume', data: params})
  363. if (res.code === 200) {
  364. ElMessage.success('导出成功')
  365. }
  366. }
  367. const exportListVisible = ref(false)
  368. // 打开导出列表弹窗
  369. const openExportList = () => {
  370. getExportList()
  371. exportListVisible.value = true
  372. }
  373. // 导出列表数据
  374. const exportList = ref([])
  375. // 导出列表加载状态
  376. const exportListLoading = ref(false)
  377. // 获取导出列表
  378. const getExportList = async () => {
  379. exportListLoading.value = true
  380. try {
  381. const result = await API({url: '/export/export'})
  382. if (result.code === 200) {
  383. const filteredData = result.data.filter(item => {
  384. return item.type === 4; //4表示金币消耗列表
  385. });
  386. exportList.value = filteredData
  387. } else {
  388. ElMessage.error(result.msg || '获取导出列表失败')
  389. }
  390. } catch (error) {
  391. console.error('获取导出列表出错:', error)
  392. ElMessage.error('获取导出列表失败,请稍后重试')
  393. } finally {
  394. exportListLoading.value = false
  395. }
  396. }
  397. // 下载导出文件
  398. const downloadExportFile = (item) => {
  399. if (item.state === 2) {
  400. const link = document.createElement('a')
  401. link.href = item.url
  402. link.download = item.fileName
  403. link.click()
  404. } else {
  405. ElMessage.warning('文件还在导出中,请稍后再试')
  406. }
  407. }
  408. //根据状态返回对应的标签类型
  409. const getTagType = (state) => {
  410. switch (state) {
  411. case 0:
  412. return 'info';
  413. case 1:
  414. return 'primary';
  415. case 2:
  416. return 'success';
  417. case 3:
  418. return 'danger';
  419. default:
  420. return 'info';
  421. }
  422. }
  423. //根据状态返回对应的标签文案
  424. const getTagText = (state) => {
  425. switch (state) {
  426. case 0:
  427. return '待执行';
  428. case 1:
  429. return '执行中';
  430. case 2:
  431. return '执行完成';
  432. case 3:
  433. return '执行出错';
  434. default:
  435. return '未知状态';
  436. }
  437. }
  438. // 存储地区选择变化
  439. const selectedMarketPath = ref("")
  440. const handleMarketChange = (value) => {
  441. if (value && value.length > 0) {
  442. const lastValue = value[value.length - 1]
  443. consumeUser.value.market = reverseMarketMapping[lastValue]
  444. } else {
  445. consumeUser.value.market = ''
  446. }
  447. }
  448. // 获取地区,修改为级联下拉框
  449. const getMarket = async function () {
  450. try {
  451. // 发送POST请求
  452. const result = await API({
  453. url: '/market/selectMarket',
  454. });
  455. // 将响应结果存储到响应式数据中
  456. console.log('请求成功', result)
  457. // 递归转换树形结构为级联选择器需要的格式(跳过第一级节点)
  458. const transformTree = (nodes) => {
  459. // 直接处理第一级节点的子节点
  460. const allChildren = nodes.flatMap(node => node.children || []);
  461. return allChildren.map(child => {
  462. const grandchildren = child.children && child.children.length
  463. ? transformTree([child]) // 递归处理子节点
  464. : null;
  465. return {
  466. value: child.name,
  467. label: child.name,
  468. children: grandchildren
  469. };
  470. });
  471. };
  472. // 存储地区信息
  473. market.value = transformTree(result.data)
  474. console.log('转换后的地区树==============', market.value)
  475. } catch (error) {
  476. console.log('请求失败', error)
  477. }
  478. }
  479. </script>
  480. <template>
  481. <el-row>
  482. <el-col>
  483. <el-card style="margin-bottom: 20px;margin-top:10px">
  484. <el-row style="margin-bottom: 10px">
  485. <el-col :span="5">
  486. <div class="head-card-element">
  487. <el-text class="mx-1">精网号</el-text>
  488. <el-input v-model="consumeUser.jwcode" placeholder="请输入精网号" style="width: 150px" clearable/>
  489. </div>
  490. </el-col>
  491. <el-col :span="6">
  492. <div class="head-card-element">
  493. <el-text class="mx-1" size="large">商品名称</el-text>
  494. <el-select v-model="consumeUser.goodsName" placeholder="请选择商品名称" style="width: 180px"
  495. clearable>
  496. <!-- 修改 v-for 绑定逻辑 -->
  497. <el-option v-for="(item, index) in goods" :key="index" :label="item" :value="item"/>
  498. </el-select>
  499. </div>
  500. </el-col>
  501. <el-col :span="6">
  502. <el-text class="mx-1" size="large">所属地区</el-text>
  503. <el-cascader
  504. v-model="selectedMarketPath"
  505. :options="market"
  506. placeholder="请选择所属地区"
  507. clearable
  508. style="width:180px"
  509. @change="handleMarketChange"
  510. />
  511. </el-col>
  512. <el-col :span="6">
  513. <div class="head-card-element">
  514. <el-text class="mx-1" size="large">消耗平台</el-text>
  515. <el-select v-model="consumeUser.payPlatform" placeholder="请选择消耗平台"
  516. style="width: 180px"
  517. clearable>
  518. <el-option v-for="item in consumePlatform" :key="item.value" :label="item.label" :value="item.value"/>
  519. </el-select>
  520. </div>
  521. </el-col>
  522. </el-row>
  523. <el-row>
  524. <el-col :span="24">
  525. <div class="head-card-element">
  526. <el-text class="mx-1" size="large">消耗时间</el-text>
  527. <el-date-picker v-model="getTime" type="datetimerange" range-separator="" start-placeholder="起始时间"
  528. end-placeholder="结束时间" style="width: 400px" @change="handleDatePickerChange"
  529. :default-time="defaultTime"/>
  530. <el-button @click="getToday()" style="margin-left: 10px"
  531. :type="activeTimeRange === 'today' ? 'primary' : ''">
  532. </el-button>
  533. <el-button @click="getYesterday()" style="margin-left: 10px"
  534. :type="activeTimeRange === 'yesterday' ? 'primary' : ''">
  535. </el-button>
  536. <el-button @click="get7Days()" style="margin-left: 10px"
  537. :type="activeTimeRange === '7days' ? 'primary' : ''"> 近7天
  538. </el-button>
  539. <!-- </div>
  540. </el-col>
  541. <el-col :span="3">
  542. <div class="head-card-btn"> -->
  543. <el-button type="success" @click="reset()">重置</el-button>
  544. <el-button type="primary" @click="search()">查询</el-button>
  545. <el-button type="primary" @click="exportExcel()">导出excel</el-button>
  546. <el-button type="primary" @click="openExportList">查看导出列表</el-button>
  547. </div>
  548. </el-col>
  549. </el-row>
  550. </el-card>
  551. </el-col>
  552. </el-row>
  553. <el-row>
  554. <el-col>
  555. <el-card>
  556. <div>
  557. 消耗总金额{{ Math.abs(permanentGolds) / 100 }}新币永久金币{{ Math.abs(permanentGolds) / 100 }}免费金币{{
  558. Math.abs(freeGolds) / 100
  559. }}任务金币{{ Math.abs(taskGolds) / 100 }}
  560. </div>
  561. <!-- 设置表格容器的高度和滚动样式 -->
  562. <div style="height: 576px; overflow-y: auto">
  563. <el-table :data="tableData" style="width: 100%" height="576px" @sort-change="handleSortChange">
  564. <el-table-column type="index" label="序号" width="80px" fixed="left">
  565. <template #default="scope">
  566. <span>{{
  567. scope.$index + 1 + (getObj.pageNum - 1) * getObj.pageSize
  568. }}</span>
  569. </template>
  570. </el-table-column>
  571. <!-- 固定姓名列 -->
  572. <el-table-column prop="name" label="姓名" width="150px" fixed="left"/>
  573. <!-- 固定精网号列 -->
  574. <el-table-column prop="jwcode" label="精网号" width="110px" fixed="left"/>
  575. <el-table-column prop="market" label="所属地区" width="110px"/>
  576. <el-table-column prop="goodsName" label="商品" width="160px" show-overflow-tooltip/>
  577. <el-table-column prop="payPlatform" label="消耗平台" width="120px">
  578. <template #default="scope">
  579. <!-- 使用非严格相等比较 -->
  580. {{ scope.row.payPlatform }}
  581. <!-- <span scope.row.consumePlatform == 1">Homily Chart</span>-->
  582. </template>
  583. </el-table-column>
  584. <!-- <el-table-column
  585. prop="consumeType"
  586. label="消费类型"
  587. width="120px"
  588. /> -->
  589. <el-table-column prop="sumGold" label="消耗金币总数" width="120px">
  590. <template #default="scope">
  591. {{
  592. (scope.row.taskGold +
  593. scope.row.freeGold +
  594. scope.row.permanentGold) / 100
  595. }}
  596. </template>
  597. </el-table-column>
  598. <el-table-column prop="permanentGold" label="永久金币" sortable="“custom”" width="110px">
  599. <template #default="scope">
  600. {{ scope.row.permanentGold / 100 }}
  601. </template>
  602. </el-table-column>
  603. <el-table-column prop="freeGold" label="免费金币" sortable="“custom”" width="110px">
  604. <template #default="scope">
  605. {{ scope.row.freeGold / 100 }}
  606. </template>
  607. </el-table-column>
  608. <el-table-column prop="taskGold" label="任务金币" sortable="“custom”" width="110px">
  609. <template #default="scope">
  610. {{ scope.row.taskGold / 100 }}
  611. </template>
  612. </el-table-column>
  613. <el-table-column prop="remark" label="备注" width="200px" show-overflow-tooltip/>
  614. <el-table-column prop="adminName" label="提交人" width="110px"/>
  615. <el-table-column prop="createTime" label="消耗时间" sortable="custom" width="180px"/>
  616. </el-table>
  617. </div>
  618. <!-- 分页 -->
  619. <div class="pagination">
  620. <el-pagination background :page-size="getObj.pageSize" :page-sizes="[5, 10, 20, 50, 100]"
  621. layout="total, sizes, prev, pager, next, jumper" :total="total"
  622. @size-change="handlePageSizeChange"
  623. @current-change="handleCurrentChange"></el-pagination>
  624. </div>
  625. </el-card>
  626. </el-col>
  627. </el-row>
  628. <!-- 导出弹窗 -->
  629. <el-dialog v-model="exportListVisible" title="导出列表" width="80%">
  630. <el-table :data="exportList" style="width: 100% ;height: 60vh;" :loading="exportListLoading">
  631. <el-table-column prop="fileName" label="文件名"/>
  632. <el-table-column prop="state" label="状态">
  633. <template #default="scope">
  634. <el-tag :type="getTagType(scope.row.state)" :effect="scope.row.state === 3 ? 'light' : 'plain'">
  635. {{ getTagText(scope.row.state) }}
  636. </el-tag>
  637. </template>
  638. </el-table-column>
  639. <el-table-column prop="createTime" label="创建时间">
  640. <template #default="scope">
  641. {{ moment(scope.row.createTime).format('YYYY-MM-DD HH:mm:ss') }}
  642. </template>
  643. </el-table-column>
  644. <el-table-column label="操作">
  645. <template #default="scope">
  646. <el-button type="primary" size="small" @click="downloadExportFile(scope.row)"
  647. :disabled="scope.row.state !== 2">
  648. 下载
  649. </el-button>
  650. </template>
  651. </el-table-column>
  652. </el-table>
  653. <template #footer>
  654. <div class="dialog-footer">
  655. <el-button text @click="exportListVisible = false">关闭</el-button>
  656. </div>
  657. </template>
  658. </el-dialog>
  659. </template>
  660. <style scoped>
  661. .status {
  662. display: flex;
  663. }
  664. .head-card {
  665. display: flex;
  666. }
  667. .head-card-element {
  668. margin-right: 20px;
  669. }
  670. .head-card-btn {
  671. margin-left: auto;
  672. }
  673. .pagination {
  674. display: flex;
  675. margin-top: 20px;
  676. }
  677. </style>