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.

854 lines
24 KiB

3 weeks ago
2 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
2 weeks ago
2 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
3 weeks ago
  1. <!-- 这是客户金币明细页面 -->
  2. <script setup>
  3. import { ref, onMounted, computed ,nextTick} from 'vue'
  4. import { ElMessage } from 'element-plus'
  5. import axios from 'axios'
  6. import moment from 'moment'
  7. import API from '@/util/http'
  8. import { writeFile, utils } from 'xlsx'
  9. // 变量aaaaaaaaaaaaaaaaaaaaa
  10. const adminData = ref({})
  11. const getAdminData = async function () {
  12. try {
  13. const result = await API({
  14. url: '/admin/userinfo',
  15. method: 'post',
  16. data: {}
  17. })
  18. adminData.value = result
  19. console.log('请求成功', result)
  20. console.log('用户信息', adminData.value)
  21. } catch (error) {
  22. console.log('请求失败', error)
  23. }
  24. }
  25. // 定义加载状态
  26. const isLoadingArea = ref(false);
  27. const area = ref([])
  28. const getArea = async () => {
  29. isLoadingArea.value = true;
  30. try {
  31. const result = await API({
  32. url: '/detailY/getarea'
  33. });
  34. // 假设后端返回的是字符串数组,转换为 { value, label } 格式
  35. if (Array.isArray(result.data) && typeof result.data[0] === 'string') {
  36. area.value = result.data.map(item => ({ value: item, label: item }));
  37. } else {
  38. area.value = result.data;
  39. }
  40. } catch (error) {
  41. console.error('获取地区数据失败:', error);
  42. ElMessage.error('获取地区数据失败,请稍后重试');
  43. // 可以提供默认数据
  44. area.value = [];
  45. } finally {
  46. isLoadingArea.value = false;
  47. }
  48. };
  49. // 充值明细表格
  50. const tableData = ref([])
  51. // 各金币总数
  52. const rechargeCoin = ref(0)
  53. const freeCoin = ref(0)
  54. const taskCoin = ref(0)
  55. // 搜索===========================================
  56. //分页总条目
  57. const total = ref(100)
  58. // 搜索对象时间
  59. const getTime = ref([])
  60. // 搜索detailY
  61. const detailY = ref({})
  62. // 搜索对象
  63. const getObj = ref({
  64. pageNum: 1,
  65. pageSize: 50
  66. })
  67. // 开启条件筛选导出excel
  68. const getPutEX = ref(false)
  69. // 支付方式选项
  70. const num = [
  71. {
  72. value: '1',
  73. label: '增加'
  74. },
  75. {
  76. value: '2',
  77. label: '减少'
  78. }
  79. ]
  80. // 方法
  81. // 搜索===========================================================================
  82. // 搜索方法
  83. const get = async function (val) {
  84. try {
  85. // 地区赋值
  86. if (adminData.value.area === '泰国') {
  87. detailY.value.areas = ['泰国', '越南']
  88. } else if (adminData.value.area !== '总部') {
  89. detailY.value.area = adminData.value.area
  90. }
  91. // 搜索参数页码赋值
  92. if (typeof val === 'number') {
  93. getObj.value.pageNum = val
  94. }
  95. if (getTime.value.length === 2) {
  96. detailY.value.startDate = getTime.value[0]
  97. detailY.value.endDate = getTime.value[1]
  98. } else {
  99. detailY.value.startDate = ''
  100. detailY.value.endDate = ''
  101. }
  102. // 添加排序字段和排序方式到请求参数
  103. detailY.value.sortField = sortField.value
  104. detailY.value.sortOrder = sortOrder.value
  105. console.log('搜索参数', getObj.value)
  106. // 发送POST请求
  107. const result = await API({
  108. url: '/detailY',
  109. method: 'post',
  110. data: { ...getObj.value, detailY: { ...detailY.value } }
  111. })
  112. tableData.value = result.data.list
  113. total.value = result.data.total
  114. } catch (error) {
  115. console.log('请求失败', error)
  116. }
  117. }
  118. // 精网号去空格,处理 detailY 中的 jwcode
  119. const trimJwCode = () => {
  120. if (detailY.value.jwcode) {
  121. detailY.value.jwcode = detailY.value.jwcode.replace(/\s/g, '');
  122. }
  123. }
  124. // 搜索
  125. const search = function () {
  126. trimJwCode();
  127. getObj.value.pageNum = 1
  128. get()
  129. }
  130. // 重置
  131. const reset = function () {
  132. delete detailY.value.jwcode
  133. delete detailY.value.num
  134. delete detailY.value.startDate
  135. delete detailY.value.endDate
  136. delete detailY.value.area
  137. delete sortField.value
  138. delete sortOrder.value
  139. getTime.value = []
  140. delete detailY.value.consumePlatform
  141. }
  142. // 今天
  143. const getToday = function () {
  144. const today = moment()
  145. const startDate = today.startOf('day').toDate()
  146. const endDate = today.add(1, 'days').startOf('day').toDate()
  147. getTime.value = [startDate, endDate]
  148. search()
  149. }
  150. // 昨天
  151. const getYesterday = function () {
  152. const today = moment()
  153. const yesterday = moment().subtract(1, 'day')
  154. const startDate = yesterday.startOf('day').toDate()
  155. const endDate = today.startOf('day').toDate()
  156. getTime.value = [startDate, endDate]
  157. search()
  158. }
  159. // 近7天
  160. const get7Days = function () {
  161. const startDate = moment().subtract(6, 'day').startOf('day').toDate()
  162. const endDate = moment().add(1,'days').startOf('day').toDate()
  163. getTime.value = [startDate, endDate]
  164. search()
  165. }
  166. // 验证跳转输入框的数字是否合法
  167. const checkNumber = function () {
  168. if (typeof parseInt(getObj.value.pageNum) === 'number') {
  169. console.log('总共有多少页' + Math.ceil(total.value / getObj.value.pageSize))
  170. if (
  171. getObj.value.pageNum > 0 &&
  172. getObj.value.pageNum <= Math.ceil(total.value / getObj.value.pageSize)
  173. ) {
  174. getObj.value.pageNum = parseInt(getObj.value.pageNum)
  175. console.log('输入的数字合法')
  176. get()
  177. } else {
  178. //提示
  179. ElMessage({
  180. type: 'error',
  181. message: '请检查输入内容'
  182. })
  183. }
  184. } else {
  185. //提示
  186. ElMessage({
  187. type: 'error',
  188. message: '请检查输入内容'
  189. })
  190. }
  191. }
  192. // 计算金币数量的方法
  193. const calculateGoldAmount = (row) => {
  194. const totalGold = (row.rechargeCoin + row.freeCoin + row.taskCoin) / 100;
  195. if (row.updateType === 1) { // 消费
  196. return -totalGold;
  197. }
  198. return totalGold;
  199. }
  200. // 导出Excel的方法
  201. const headers = [
  202. '序号',
  203. '姓名',
  204. '精网号',
  205. '所属地区',
  206. '平台信息',
  207. //'更新数量',
  208. '更新类型',
  209. '金币数量',
  210. '永久金币',
  211. '免费金币',
  212. '任务金币',
  213. '提交人',
  214. '更新时间'
  215. ]
  216. const showExportInfoPanel = ref(false)
  217. // 点击导出按钮直接显示信息面板
  218. const exportExcel = async () => {
  219. try {
  220. console.log('点击导出按钮,尝试显示信息面板');
  221. showExportInfoPanel.value = true;
  222. await nextTick();//组件更新显示信息面板
  223. } catch (error) {
  224. console.error('显示信息面板失败:', error);
  225. ElMessage.error('显示信息面板失败,请稍后重试');
  226. }
  227. };
  228. // 新增导出状态相关变量
  229. const exportProgress = ref(0)
  230. const isExporting = ref(false)
  231. const exportCancelToken = ref(null)
  232. // 优化后的导出方法
  233. const doExportExcel = async () => {
  234. try {
  235. isExporting.value = true
  236. exportProgress.value = 0
  237. showExportInfoPanel.value = false
  238. // 初始化Excel
  239. const wb = utils.book_new()
  240. const ws = utils.aoa_to_sheet([headers])
  241. utils.book_append_sheet(wb, ws, 'Sheet1')
  242. // 流式写入配置
  243. const writer = {
  244. write: (d, o) => {
  245. if (!d) return
  246. utils.sheet_add_aoa(ws, d, { origin: -1 })
  247. }
  248. }
  249. let page = 1
  250. let totalExported = 0
  251. const pageSize = 5000 // 每次请求5000条
  252. let totalRecords = 0
  253. // 首次请求获取总记录数
  254. const firstResult = await API({
  255. url: '/detailY',
  256. method: 'post',
  257. data: {
  258. pageNum: 1,
  259. pageSize,
  260. detailY: { ...detailY.value }
  261. }
  262. })
  263. totalRecords = firstResult.data.total
  264. // 创建取消令牌
  265. const CancelToken = axios.CancelToken
  266. exportCancelToken.value = CancelToken.source()
  267. // 平台信息映射
  268. const platformMap = {
  269. 0: '初始化金币',
  270. 1: 'ERP系统',
  271. 2: 'Homily Chart',
  272. 3: 'Homily Link',
  273. 4: '金币系统'
  274. };
  275. // 更新类型映射
  276. const updateTypeMap = {
  277. 0: '充值',
  278. 1: '消费',
  279. 2: '退款',
  280. 3: '其他'
  281. };
  282. // 处理首次请求的数据
  283. const firstData = firstResult.data.list
  284. if (firstData.length) {
  285. const rows = firstData.map((row, index) => {
  286. const consumePlatform = parseInt(row.consumePlatform, 10); // 转换为数字类型
  287. const platformInfo = platformMap[consumePlatform] || '';
  288. return [
  289. totalExported + index + 1,
  290. row.username || '',
  291. row.jwcode || '',
  292. row.area || '',
  293. platformInfo,
  294. (row.gold / 100).toFixed(2) || '0.00',
  295. updateTypeMap[row.updateType] || '',
  296. (row.rechargeCoin / 100).toFixed(2) || '0.00',
  297. (row.freeCoin / 100).toFixed(2) || '0.00',
  298. (row.taskCoin / 100).toFixed(2) || '0.00',
  299. row.name || '',
  300. moment(row.createTime).format('YYYY-MM-DD HH:mm:ss') || ''
  301. ]
  302. })
  303. writer.write(rows)
  304. totalExported += firstData.length
  305. exportProgress.value = Math.round((totalExported / totalRecords) * 100)
  306. page++
  307. }
  308. while (totalExported < totalRecords) {
  309. const result = await API({
  310. url: '/detailY',
  311. method: 'post',
  312. data: {
  313. pageNum: page,
  314. pageSize,
  315. detailY: { ...detailY.value }
  316. },
  317. cancelToken: exportCancelToken.value.token
  318. })
  319. const data = result.data.list
  320. if (!data.length) break
  321. // 转换数据
  322. const rows = data.map((row, index) => [
  323. totalExported + index + 1,
  324. row.username || '',
  325. row.jwcode || '',
  326. row.area || '',
  327. platformMap[row.consumePlatform] || '',
  328. (row.gold / 100).toFixed(2) || '0.00',
  329. updateTypeMap[row.updateType] || '',
  330. (row.rechargeCoin / 100).toFixed(2) || '0.00',
  331. (row.freeCoin / 100).toFixed(2) || '0.00',
  332. (row.taskCoin / 100).toFixed(2) || '0.00',
  333. row.name || '',
  334. moment(row.createTime).format('YYYY-MM-DD HH:mm:ss') || ''
  335. ])
  336. // 流式写入
  337. writer.write(rows)
  338. totalExported += data.length
  339. exportProgress.value = Math.round((totalExported / totalRecords) * 100)
  340. // 内存控制:每500页释放内存
  341. if (page % 500 === 0) {
  342. await new Promise(resolve => setTimeout(resolve, 0))
  343. }
  344. page++
  345. }
  346. // 生成最终文件
  347. writeFile(wb, '客户金币明细.xlsx')
  348. ElMessage.success(`导出成功,共${totalExported}条数据`)
  349. } catch (error) {
  350. if (!axios.isCancel(error)) {
  351. ElMessage.error(`导出失败: ${error.message}`)
  352. }
  353. } finally {
  354. isExporting.value = false
  355. exportCancelToken.value = null
  356. }
  357. }
  358. // 新增取消导出方法
  359. const cancelExport = () => {
  360. if (exportCancelToken.value) {
  361. exportCancelToken.value.cancel('用户取消导出')
  362. ElMessage.warning('导出已取消')
  363. isExporting.value = false
  364. }
  365. }
  366. const putExcel = ref({
  367. startDate: new Date(),
  368. endDate: new Date(new Date().setDate(new Date().getDate() + 1))
  369. })
  370. // 新增校验精网号的方法
  371. const checkJwCode = async (jwcode) => {
  372. try {
  373. const result = await API({
  374. url: '/recharge/user',
  375. method: 'post',
  376. data: {
  377. jwcode,
  378. area: adminData.value.area
  379. }
  380. })
  381. // 根据后端返回的 code 判断精网号是否存在
  382. return result.code !== 0
  383. } catch (error) {
  384. console.log('校验精网号失败', error)
  385. return false
  386. }
  387. }
  388. // 选消费平台
  389. const platform = [
  390. {
  391. value: '4',
  392. label: '金币系统'
  393. },
  394. {
  395. value: '1',
  396. label: 'ERP系统'
  397. },
  398. {
  399. value: '2',
  400. label: 'Homily Chart'
  401. },
  402. {
  403. value: '3',
  404. label: 'Homily Link'
  405. },
  406. {
  407. value: '0',
  408. label: '初始化金币'
  409. }
  410. ]
  411. // 新增排序字段和排序方式
  412. const sortField = ref('')
  413. const sortOrder = ref('')
  414. // 处理排序事件
  415. const handleSortChange = (column) => {
  416. if (column.prop === 'rechargeCoin') {
  417. sortField.value = 'recharge_coin'
  418. } else if (column.prop === 'taskCoin') {
  419. sortField.value = 'task_coin'
  420. } else if (column.prop === 'freeCoin') {
  421. sortField.value = 'free_coin'
  422. } else if (column.prop === 'createTime') {
  423. sortField.value = 'create_time'
  424. } else if (column.prop === 'gold') {
  425. sortField.value = 'gold'
  426. }
  427. sortOrder.value = column.order === 'ascending' ? 'ASC' : 'DESC'
  428. //get()要写在handleSortChange方法里面,不然会导致排序失效
  429. get()
  430. }
  431. const handlePageSizeChange = function (val) {
  432. getObj.value.pageSize = val
  433. get()
  434. }
  435. const handleCurrentChange = function (val) {
  436. getObj.value.pageNum = val
  437. get()
  438. }
  439. // // 用于控制显示内容的变量
  440. // const activeTab = ref('detailY')
  441. // // 切换标签页的方法
  442. // const changeTab = (tabName) => {
  443. // activeTab.value = tabName
  444. // }
  445. // 挂载
  446. onMounted(async function () {
  447. await getArea()
  448. await getAdminData()
  449. await get()
  450. })
  451. </script>
  452. <template>
  453. <div>
  454. <!-- <el-button-group>
  455. <el-button
  456. :type="activeTab === 'detailY' ? 'primary' : 'default'"
  457. @click="changeTab('detailY')"
  458. >
  459. 金币明细
  460. </el-button>
  461. <el-button
  462. :type="activeTab === 'goldInfo' ? 'primary' : 'default'"
  463. @click="changeTab('goldInfo')"
  464. >
  465. 金币余额
  466. </el-button>
  467. </el-button-group> -->
  468. <!-- 根据activeTab切换显示内容 -->
  469. <!-- 客户金币明细的布局---------------------------------------------------------- -->
  470. <!-- <div v-if="activeTab === 'detailY'"> -->
  471. <!-- 导出excel提前展示的信息面板 -->
  472. <el-dialog
  473. v-model="showExportInfoPanel"
  474. title="导出信息确认"
  475. width="400px"
  476. :close-on-click-modal="false"
  477. >
  478. <div class="info-panel-header">导出信息</div>
  479. <!-- 直接使用 detailY 显示信息添加可选链操作符 -->
  480. <!-- detailY是一个ref所以在模板中应该直接使用detailY.consumePlatform
  481. 而不是detailY.value.consumePlatform
  482. 因为在模板中ref变量会自动解包不需要.value
  483. 例如在代码中我们可能错误地在模板中使用了detailY.value但实际上应该直接使用detailY -->
  484. <div v-if="!detailY.jwcode && !detailY.consumePlatform && !detailY.num && !detailY.area && (getTime.length < 2)">
  485. 你正在导出所有数据
  486. </div>
  487. <div v-else>
  488. 你正在导出以下数据
  489. </div>
  490. <div v-if="detailY.jwcode">精网号{{ detailY.jwcode || '' }}</div>
  491. <div v-if="detailY.consumePlatform">平台信息{{ detailY.consumePlatform ? (platform.find(item => item.value === detailY.consumePlatform)?.label) : '' }}</div>
  492. <div v-if="detailY.num">数量更新类型{{ detailY.num ? (num.find(item => item.value === detailY.num)?.label || '') : '' }}</div>
  493. <div v-if="detailY.area">所属地区{{ detailY.area || '' }}</div>
  494. <div v-if="Array.isArray(getTime) && getTime.length >= 2">
  495. <span>更新时间</span>
  496. <!-- 修改时间格式为精确到秒 -->
  497. <span v-if="Array.isArray(getTime) && getTime.length >= 2">
  498. {{ moment(getTime[0]).format('YYYY-MM-DD HH:mm:ss') }} {{ moment(getTime[1]).format('YYYY-MM-DD HH:mm:ss') }}
  499. </span>
  500. <span v-else></span>
  501. </div>
  502. <template #footer>
  503. <span class="dialog-footer">
  504. <el-button @click="showExportInfoPanel = false">取消</el-button>
  505. <el-button type="primary" @click="doExportExcel">导出</el-button>
  506. </span>
  507. </template>
  508. </el-dialog>
  509. <!-- 导出进度弹窗 -->
  510. <el-dialog
  511. v-model="isExporting"
  512. title="正在导出"
  513. width="400px"
  514. :close-on-click-modal="false"
  515. :show-close="false"
  516. >
  517. <el-progress
  518. :percentage="exportProgress"
  519. :stroke-width="15"
  520. striped
  521. animated
  522. />
  523. <div class="export-status">
  524. 已导出 {{ Math.round((exportProgress / 100) * total) }} / {{ total }}
  525. </div>
  526. <template #footer>
  527. <el-button type="danger" @click="cancelExport">取消导出</el-button>
  528. </template>
  529. </el-dialog>
  530. <el-row>
  531. <el-col>
  532. <el-card style="margin-bottom: 20px;margin-top: 10px;">
  533. <el-row style="margin-bottom: 10px">
  534. <el-col :span="5">
  535. <div class="head-card-element">
  536. <el-text class="mx-1" size="large">精网号</el-text>
  537. <el-input
  538. v-model="detailY.jwcode"
  539. style="width: 150px"
  540. placeholder="请输入精网号"
  541. clearable
  542. />
  543. </div>
  544. </el-col>
  545. <el-col :span="6">
  546. <div class="head-card-element">
  547. <el-text class="mx-1" size="large">平台信息</el-text>
  548. <el-select
  549. v-model="detailY.consumePlatform"
  550. placeholder="请选择平台信息"
  551. style="width: 180px"
  552. clearable
  553. >
  554. <el-option
  555. v-for="item in platform"
  556. :key="item.value"
  557. :label="item.label"
  558. :value="item.value"
  559. />
  560. </el-select>
  561. </div>
  562. </el-col>
  563. <el-col :span="6">
  564. <div class="head-card-element">
  565. <el-text class="mx-1" size="large">数量更新类型</el-text>
  566. <el-select
  567. v-model="detailY.num"
  568. placeholder="请选择更新类型"
  569. style="width: 180px"
  570. clearable
  571. >
  572. <el-option
  573. v-for="item in num"
  574. :key="item.value"
  575. :label="item.label"
  576. :value="item.value"
  577. />
  578. </el-select>
  579. </div>
  580. </el-col>
  581. <el-col :span="6">
  582. <div class="head-card-element">
  583. <el-text class="mx-1" size="large">所属地区</el-text>
  584. <el-select
  585. v-model="detailY.area"
  586. placeholder="请选择所属地区"
  587. style="width: 180px"
  588. clearable
  589. :loading="isLoadingArea"
  590. >
  591. <el-option
  592. v-for="item in area"
  593. :key="item.value || item"
  594. :label="item.label || item"
  595. :value="item.value || item"
  596. />
  597. </el-select>
  598. </div>
  599. </el-col>
  600. </el-row>
  601. <div class="head-card-element">
  602. <el-text class="mx-1" size="large">更新时间</el-text>
  603. <el-date-picker
  604. v-model="getTime"
  605. type="datetimerange"
  606. range-separator="至"
  607. start-placeholder="起始时间"
  608. end-placeholder="结束时间"
  609. style="margin-right: 50px"
  610. />
  611. <el-button @click="getToday()"></el-button>
  612. <el-button @click="getYesterday()"></el-button>
  613. <el-button @click="get7Days()">近7天</el-button>
  614. <el-button type="success" @click="reset()">重置</el-button>
  615. <el-button type="primary" @click="search()">查询</el-button>
  616. <el-button type="primary" @click="exportExcel">导出Excel表格</el-button>
  617. </div>
  618. </el-card>
  619. </el-col>
  620. </el-row>
  621. <el-row>
  622. <el-col>
  623. <el-card>
  624. <div style="height: 584px; overflow-y: auto">
  625. <el-table
  626. :data="tableData"
  627. style="width: 100%"
  628. @sort-change="handleSortChange"
  629. height="584px"
  630. >
  631. <el-table-column
  632. type="index"
  633. label="序号"
  634. width="100px"
  635. fixed="left"
  636. >
  637. <template #default="scope">
  638. <span>{{
  639. scope.$index + 1 + (getObj.pageNum - 1) * getObj.pageSize
  640. }}</span>
  641. </template>
  642. </el-table-column>
  643. <el-table-column
  644. fixed="left"
  645. prop="username"
  646. label="姓名"
  647. width="150"
  648. />
  649. <el-table-column
  650. fixed="left"
  651. prop="jwcode"
  652. label="精网号"
  653. width="120"
  654. />
  655. <el-table-column prop="area" label="所属地区" width="120" />
  656. <el-table-column
  657. prop="consumePlatform"
  658. label="平台信息"
  659. width="140"
  660. >
  661. <template #default="scope">
  662. <!-- 使用非严格相等比较 -->
  663. <span v-if="scope.row.consumePlatform == 0">初始化金币</span>
  664. <span v-if="scope.row.consumePlatform == 1">ERP系统</span>
  665. <span v-if="scope.row.consumePlatform == 3">Homily Link</span>
  666. <span v-if="scope.row.consumePlatform == 2">Homily Chart</span>
  667. <span v-if="scope.row.consumePlatform == 4">金币系统</span>
  668. </template>
  669. </el-table-column>
  670. <!-- <el-table-column
  671. prop="gold"
  672. label="更新数量"
  673. width="120"
  674. sortable="custom"
  675. >
  676. <template #default="scope">
  677. <span>{{ scope.row.gold / 100 }}</span>
  678. </template>
  679. </el-table-column> -->
  680. <el-table-column prop="updateType" label="更新类型" width="110">
  681. <!-- 模板内容 -->
  682. <template #default="scope">
  683. <span v-if="scope.row.updateType == 1">消费</span>
  684. <span v-if="scope.row.updateType == 0">充值</span>
  685. <span v-if="scope.row.updateType == 2">退款</span>
  686. <span v-if="scope.row.updateType == 3">其他</span>
  687. </template>
  688. </el-table-column>
  689. <el-table-column label="金币数量" width="120">
  690. <template #default="scope">
  691. <span>{{ calculateGoldAmount(scope.row) }}</span>
  692. </template>
  693. </el-table-column>
  694. <el-table-column
  695. prop="rechargeCoin"
  696. sortable="custom"
  697. label="永久金币"
  698. width="110"
  699. >
  700. <template #default="scope">
  701. <span>{{ scope.row.rechargeCoin / 100 }}</span>
  702. </template>
  703. </el-table-column>
  704. <el-table-column
  705. prop="freeCoin"
  706. sortable="custom"
  707. label="免费金币"
  708. width="110"
  709. >
  710. <template #default="scope">
  711. <span>{{ scope.row.freeCoin / 100 }}</span>
  712. </template>
  713. </el-table-column>
  714. <el-table-column
  715. prop="taskCoin"
  716. sortable="custom"
  717. label="任务金币"
  718. width="110"
  719. >
  720. <template #default="scope">
  721. <span>{{ scope.row.taskCoin / 100 }}</span>
  722. </template>
  723. </el-table-column>
  724. <el-table-column prop="name" label="提交人" width="110" />
  725. <el-table-column
  726. prop="createTime"
  727. sortable="custom"
  728. label="更新时间"
  729. width="210"
  730. show-overflow-tooltip
  731. >
  732. <template #default="scope">
  733. <span>{{
  734. moment(scope.row.createTime).format('YYYY-MM-DD HH:mm:ss')
  735. }}</span>
  736. </template>
  737. </el-table-column>
  738. </el-table>
  739. </div>
  740. <!-- 此处分页 -->
  741. <div class="pagination" style="margin-top: 20px">
  742. <el-pagination
  743. background
  744. :page-size="getObj.pageSize"
  745. :page-sizes="[5, 10, 20, 50, 100]"
  746. layout="total, sizes, prev, pager, next, jumper"
  747. :total="total"
  748. @size-change="handlePageSizeChange"
  749. @current-change="handleCurrentChange"
  750. ></el-pagination>
  751. </div>
  752. </el-card>
  753. </el-col>
  754. </el-row>
  755. <!-- </div> -->
  756. <!-- 客户金币余额的布局---------------------------------------------------------- -->
  757. <!-- <div v-else-if="activeTab === 'goldInfo'"> -->
  758. <!-- </div> -->
  759. </div>
  760. </template>
  761. <style scoped>
  762. .pagination {
  763. display: flex;
  764. }
  765. .status {
  766. display: flex;
  767. }
  768. .head-card {
  769. display: flex;
  770. }
  771. .info-panel-header {
  772. font-weight: bold;
  773. margin-bottom: 10px;
  774. }
  775. .dialog-footer {
  776. display: flex;
  777. justify-content: flex-end;
  778. }
  779. .export-status {
  780. margin-top: 15px;
  781. text-align: center;
  782. color: #666;
  783. }
  784. .el-progress-bar__inner {
  785. transition: width 0.5s ease;
  786. }
  787. </style>