40eb7f0fc3fd72a4da3c2fb9ec96ed1a.json 14 KB

1
  1. {"remainingRequest":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\finance\\billingRecords\\index.vue?vue&type=script&lang=js","dependencies":[{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\src\\pages\\finance\\billingRecords\\index.vue","mtime":1761185180085},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\crmeb5.0\\template\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:DQppbXBvcnQgZXhwb3J0RXhjZWwgZnJvbSAnQC91dGlscy9uZXdUb0V4Y2VsLmpzJzsNCmltcG9ydCBjb21taXNzaW9uRGV0YWlscyBmcm9tICcuLi9jb21wb25lbnRzL2NvbW1pc3Npb25EZXRhaWxzJzsNCmltcG9ydCB7IGdldFJlY29yZCB9IGZyb20gJ0AvYXBpL3N0YXRpc3RpYy5qcyc7DQppbXBvcnQgeyBnZXRGbG93TGlzdCB9IGZyb20gJ0AvYXBpL2ZpbmFuY2UnOw0KDQpleHBvcnQgZGVmYXVsdCB7DQogIG5hbWU6ICdiaWxsJywNCiAgY29tcG9uZW50czogew0KICAgIGNvbW1pc3Npb25EZXRhaWxzLA0KICB9LA0KICBkYXRhKCkgew0KICAgIHJldHVybiB7DQogICAgICBtb2RhbHM6IGZhbHNlLA0KICAgICAgcGlja2VyT3B0aW9uczogdGhpcy4kdGltZU9wdGlvbnMsDQogICAgICBpZHM6ICcnLA0KICAgICAgdG90YWw6IDAsDQogICAgICBsb2FkaW5nOiBmYWxzZSwNCiAgICAgIHRhYjogJ2RheScsDQogICAgICBvcmRlckxpc3Q6IFsNCiAgICAgICAgew0KICAgICAgICAgIGlkOiAnMScsDQogICAgICAgICAgb3JkZXJfaWQ6ICcyMDAnLA0KICAgICAgICAgIHBheV9wcmljZTogJzIwMCcsDQogICAgICAgICAgc3RhdHVzOiAxLA0KICAgICAgICAgIHBob25lOiAnMTMwMDAwMDAwMDAnLA0KICAgICAgICAgIGFkZHJlc3M6ICcxMDAnLA0KICAgICAgICB9LA0KICAgICAgXSwNCiAgICAgIGZvcm1WYWxpZGF0ZTogew0KICAgICAgICBzdG9yZV9pZDogJycsDQogICAgICAgIHRpbWU6ICcnLA0KICAgICAgICBwYWdlOiAxLA0KICAgICAgICBsaW1pdDogMTUsDQogICAgICB9LA0KICAgICAgdGltZVZhbDogW10sDQogICAgfTsNCiAgfSwNCiAgY29tcHV0ZWQ6IHsNCiAgICBsYWJlbFdpZHRoKCkgew0KICAgICAgcmV0dXJuIHRoaXMuaXNNb2JpbGUgPyB1bmRlZmluZWQgOiAnODBweCc7DQogICAgfSwNCiAgICBsYWJlbFBvc2l0aW9uKCkgew0KICAgICAgcmV0dXJuIHRoaXMuaXNNb2JpbGUgPyAndG9wJyA6ICdyaWdodCc7DQogICAgfSwNCiAgfSwNCiAgbW91bnRlZCgpIHsNCiAgICB0aGlzLm9uQ2xpY2tUYWIodGhpcy50YWIpOw0KICB9LA0KICBtZXRob2RzOiB7DQogICAgb25DbGlja1RhYigpIHsNCiAgICAgIHRoaXMuZ2V0TGlzdCgpOw0KICAgIH0sDQogICAgc2VhcmNoKCkgew0KICAgICAgdGhpcy5nZXRMaXN0KCk7DQogICAgfSwNCiAgICBnZXRMaXN0KCkgew0KICAgICAgdGhpcy5sb2FkaW5nID0gdHJ1ZTsNCiAgICAgIGxldCBkYXRhID0gew0KICAgICAgICB0eXBlOiB0aGlzLnRhYiwNCiAgICAgICAgdGltZTogdGhpcy5mb3JtVmFsaWRhdGUudGltZSwNCiAgICAgICAgcGFnZTogdGhpcy5mb3JtVmFsaWRhdGUucGFnZSwNCiAgICAgICAgbGltaXQ6IHRoaXMuZm9ybVZhbGlkYXRlLmxpbWl0LA0KICAgICAgICBzdG9yZV9pZDogdGhpcy5mb3JtVmFsaWRhdGUuc3RvcmVfaWQsDQogICAgICB9Ow0KICAgICAgZ2V0UmVjb3JkKGRhdGEpLnRoZW4oKHJlcykgPT4gew0KICAgICAgICB0aGlzLm9yZGVyTGlzdCA9IHJlcy5kYXRhLmxpc3Q7DQogICAgICAgIHRoaXMubG9hZGluZyA9IGZhbHNlOw0KICAgICAgICB0aGlzLnRvdGFsID0gcmVzLmRhdGEuY291bnQ7DQogICAgICB9KTsNCiAgICB9LA0KICAgIC8vIOmAieaLqeaXtumXtA0KICAgIHNlbGVjdENoYW5nZSh0YWIpIHsNCiAgICAgIHRoaXMuZm9ybVZhbGlkYXRlLnBhZ2UgPSAxOw0KICAgICAgdGhpcy5mb3JtVmFsaWRhdGUudGltZSA9IHRhYjsNCiAgICAgIHRoaXMudGltZVZhbCA9IFtdOw0KICAgICAgdGhpcy5nZXRMaXN0KCk7DQogICAgfSwNCiAgICAvLyDlhbfkvZPml6XmnJ8NCiAgICBvbmNoYW5nZVRpbWUoZSkgew0KICAgICAgdGhpcy50aW1lVmFsID0gZSB8fCBbXTsNCiAgICAgIHRoaXMuZm9ybVZhbGlkYXRlLnRpbWUgPSB0aGlzLnRpbWVWYWxbMF0gPyAodGhpcy50aW1lVmFsID8gdGhpcy50aW1lVmFsLmpvaW4oJy0nKSA6ICcnKSA6ICcnOw0KICAgICAgdGhpcy5mb3JtVmFsaWRhdGUucGFnZSA9IDE7DQogICAgICB0aGlzLmdldExpc3QoKTsNCiAgICB9LA0KICAgIC8vIOi0puWNleivpuaDhQ0KICAgIEluZm8ocm93KSB7DQogICAgICB0aGlzLmlkcyA9IHJvdy5pZHMgfHwgJyc7DQogICAgICB0aGlzLm1vZGFscyA9IHRydWU7DQogICAgfSwNCiAgICBjYW5jZWwoKSB7DQogICAgICB0aGlzLm1vZGFscyA9IGZhbHNlOw0KICAgIH0sDQogICAgLy/kuIvovb0NCiAgICBhc3luYyBkb3dubG9hZChyb3cpIHsNCiAgICAgIGxldCBbdGgsIGZpbGVLZXksIGRhdGEsIGZpbGVOYW1lXSA9IFtbXSwgW10sIFtdLCAnJ107DQogICAgICBsZXQgZXhjZWxEYXRhID0gew0KICAgICAgICBpZHM6IHJvdy5pZHMsDQogICAgICAgIHBhZ2U6IDEsDQogICAgICAgIGV4cG9ydDogMSwNCiAgICAgICAgdGltZTogdGhpcy5mb3JtVmFsaWRhdGUudGltZSwNCiAgICAgIH07DQogICAgICBsZXQgbGViRGF0YSA9IGF3YWl0IHRoaXMuZ2V0RXhjZWxEYXRhKGV4Y2VsRGF0YSk7DQogICAgICBpZiAoIWZpbGVOYW1lKSBmaWxlTmFtZSA9IGxlYkRhdGEuZmlsZU5hbWU7DQogICAgICBpZiAoIWZpbGVLZXkubGVuZ3RoKSB7DQogICAgICAgIGZpbGVLZXkgPSBsZWJEYXRhLmZpbGVLZXk7DQogICAgICB9DQogICAgICBpZiAoIXRoLmxlbmd0aCkgdGggPSBsZWJEYXRhLmhlYWRlcjsNCiAgICAgIGRhdGEgPSBkYXRhLmNvbmNhdChsZWJEYXRhLmxpc3QpOw0KICAgICAgZXhwb3J0RXhjZWwodGgsIGZpbGVLZXksIGZpbGVOYW1lLCBkYXRhKTsNCiAgICAgIHJldHVybjsNCiAgICB9LA0KICAgIGdldEV4Y2VsRGF0YShleGNlbERhdGEpIHsNCiAgICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7DQogICAgICAgIGdldEZsb3dMaXN0KGV4Y2VsRGF0YSkudGhlbigocmVzKSA9PiB7DQogICAgICAgICAgcmV0dXJuIHJlc29sdmUocmVzLmRhdGEpOw0KICAgICAgICB9KTsNCiAgICAgIH0pOw0KICAgIH0sDQogIH0sDQp9Ow0K"},{"version":3,"sources":["index.vue"],"names":[],"mappings":";AAuGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/pages/finance/billingRecords","sourcesContent":["<template>\r\n <div>\r\n <el-card :bordered=\"false\" shadow=\"never\" :body-style=\"{ padding: 0 }\">\r\n <div class=\"padding-add\">\r\n <el-form\r\n ref=\"formValidate\"\r\n :model=\"formValidate\"\r\n :label-width=\"labelWidth\"\r\n :label-position=\"labelPosition\"\r\n @submit.native.prevent\r\n >\r\n <el-form-item label=\"创建时间:\">\r\n <el-date-picker\r\n clearable\r\n v-model=\"timeVal\"\r\n type=\"daterange\"\r\n :editable=\"false\"\r\n @change=\"onchangeTime\"\r\n format=\"yyyy/MM/dd\"\r\n value-format=\"yyyy/MM/dd\"\r\n start-placeholder=\"开始日期\"\r\n end-placeholder=\"结束日期\"\r\n :picker-options=\"pickerOptions\"\r\n style=\"width: 250px\"\r\n class=\"mr20\"\r\n ></el-date-picker>\r\n </el-form-item>\r\n </el-form>\r\n </div>\r\n </el-card>\r\n <el-card :bordered=\"false\" shadow=\"never\" class=\"mt16\" :body-style=\"{ padding: '0 20px 20px' }\">\r\n <div class=\"ivu-mt\">\r\n <el-tabs v-model=\"tab\" @tab-click=\"onClickTab\">\r\n <el-tab-pane label=\"日账单\" name=\"day\" />\r\n <el-tab-pane label=\"周账单\" name=\"week\" />\r\n <el-tab-pane label=\"月账单\" name=\"month\" />\r\n </el-tabs>\r\n </div>\r\n <div class=\"table\">\r\n <el-table\r\n :data=\"orderList\"\r\n ref=\"table\"\r\n v-loading=\"loading\"\r\n highlight-current-row\r\n no-userFrom-text=\"暂无数据\"\r\n no-filtered-userFrom-text=\"暂无筛选结果\"\r\n >\r\n <el-table-column label=\"ID\" width=\"80\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.id }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"标题\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.title }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"日期\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ scope.row.add_time }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"收入金额\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span style=\"color: #f5222d\">¥{{ scope.row.income_price }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"支出金额\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span style=\"color: #00c050\">¥{{ scope.row.exp_price }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"入账金额\" min-width=\"130\">\r\n <template slot-scope=\"scope\">\r\n <span>¥{{ scope.row.entry_price }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"操作\" fixed=\"right\" width=\"170\">\r\n <template slot-scope=\"scope\">\r\n <a v-db-click @click=\"Info(scope.row)\">账单详情</a>\r\n <el-divider direction=\"vertical\"></el-divider>\r\n <a v-db-click @click=\"download(scope.row)\">下载</a>\r\n </template>\r\n </el-table-column>\r\n </el-table>\r\n <div class=\"acea-row row-right page\">\r\n <pagination\r\n v-if=\"total\"\r\n :total=\"total\"\r\n :page.sync=\"formValidate.page\"\r\n :limit.sync=\"formValidate.limit\"\r\n @pagination=\"getList\"\r\n />\r\n </div>\r\n </div>\r\n </el-card>\r\n <el-dialog :visible.sync=\"modals\" title=\"账单详情\" width=\"1000px\">\r\n <commission-details v-if=\"modals\" ref=\"commission\" :ids=\"ids\" :time=\"formValidate.time\"></commission-details>\r\n </el-dialog>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport exportExcel from '@/utils/newToExcel.js';\r\nimport commissionDetails from '../components/commissionDetails';\r\nimport { getRecord } from '@/api/statistic.js';\r\nimport { getFlowList } from '@/api/finance';\r\n\r\nexport default {\r\n name: 'bill',\r\n components: {\r\n commissionDetails,\r\n },\r\n data() {\r\n return {\r\n modals: false,\r\n pickerOptions: this.$timeOptions,\r\n ids: '',\r\n total: 0,\r\n loading: false,\r\n tab: 'day',\r\n orderList: [\r\n {\r\n id: '1',\r\n order_id: '200',\r\n pay_price: '200',\r\n status: 1,\r\n phone: '13000000000',\r\n address: '100',\r\n },\r\n ],\r\n formValidate: {\r\n store_id: '',\r\n time: '',\r\n page: 1,\r\n limit: 15,\r\n },\r\n timeVal: [],\r\n };\r\n },\r\n computed: {\r\n labelWidth() {\r\n return this.isMobile ? undefined : '80px';\r\n },\r\n labelPosition() {\r\n return this.isMobile ? 'top' : 'right';\r\n },\r\n },\r\n mounted() {\r\n this.onClickTab(this.tab);\r\n },\r\n methods: {\r\n onClickTab() {\r\n this.getList();\r\n },\r\n search() {\r\n this.getList();\r\n },\r\n getList() {\r\n this.loading = true;\r\n let data = {\r\n type: this.tab,\r\n time: this.formValidate.time,\r\n page: this.formValidate.page,\r\n limit: this.formValidate.limit,\r\n store_id: this.formValidate.store_id,\r\n };\r\n getRecord(data).then((res) => {\r\n this.orderList = res.data.list;\r\n this.loading = false;\r\n this.total = res.data.count;\r\n });\r\n },\r\n // 选择时间\r\n selectChange(tab) {\r\n this.formValidate.page = 1;\r\n this.formValidate.time = tab;\r\n this.timeVal = [];\r\n this.getList();\r\n },\r\n // 具体日期\r\n onchangeTime(e) {\r\n this.timeVal = e || [];\r\n this.formValidate.time = this.timeVal[0] ? (this.timeVal ? this.timeVal.join('-') : '') : '';\r\n this.formValidate.page = 1;\r\n this.getList();\r\n },\r\n // 账单详情\r\n Info(row) {\r\n this.ids = row.ids || '';\r\n this.modals = true;\r\n },\r\n cancel() {\r\n this.modals = false;\r\n },\r\n //下载\r\n async download(row) {\r\n let [th, fileKey, data, fileName] = [[], [], [], ''];\r\n let excelData = {\r\n ids: row.ids,\r\n page: 1,\r\n export: 1,\r\n time: this.formValidate.time,\r\n };\r\n let lebData = await this.getExcelData(excelData);\r\n if (!fileName) fileName = lebData.fileName;\r\n if (!fileKey.length) {\r\n fileKey = lebData.fileKey;\r\n }\r\n if (!th.length) th = lebData.header;\r\n data = data.concat(lebData.list);\r\n exportExcel(th, fileKey, fileName, data);\r\n return;\r\n },\r\n getExcelData(excelData) {\r\n return new Promise((resolve, reject) => {\r\n getFlowList(excelData).then((res) => {\r\n return resolve(res.data);\r\n });\r\n });\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"scss\">\r\n::v-deep .el-tabs__item {\r\n height: 54px !important;\r\n line-height: 54px !important;\r\n}\r\n::v-deep .ivu-card-body {\r\n padding: 0;\r\n}\r\n\r\n.tabbox {\r\n padding: 16px 20px 0px;\r\n}\r\n.box {\r\n padding: 20px;\r\n padding-bottom: 1px;\r\n}\r\n.tablebox {\r\n margin-top: 15px;\r\n padding-bottom: 10px;\r\n}\r\n.btnbox {\r\n padding: 20px 0px 0px 30px;\r\n .btns {\r\n width: 99px;\r\n height: 32px;\r\n background: var(--prev-color-primary);\r\n border-radius: 4px;\r\n text-align: center;\r\n line-height: 32px;\r\n color: #ffffff;\r\n cursor: pointer;\r\n }\r\n}\r\n</style>\r\n"]}]}