diff --git a/package.json b/package.json
index 0e9ad07..4223316 100644
--- a/package.json
+++ b/package.json
@@ -16,6 +16,7 @@
"core-js": "3.6.5",
"crypto-js": "^4.1.1",
"element-ui": "^2.15.12",
+ "file-saver": "^2.0.5",
"js-cookie": "2.2.0",
"js-md5": "^0.7.3",
"normalize.css": "7.0.0",
@@ -23,9 +24,12 @@
"path-to-regexp": "2.4.0",
"postcss-px-to-viewport": "^1.1.1",
"qs": "^6.11.0",
+ "script-loader": "^0.7.2",
"vue": "2.6.10",
"vue-router": "3.0.6",
- "vuex": "3.1.0"
+ "vuex": "3.1.0",
+ "xlsx": "^0.18.5",
+ "xlsx-style": "^0.8.13"
},
"devDependencies": {
"@vue/cli-plugin-babel": "4.4.4",
diff --git a/src/api/user/internalCompany.js b/src/api/user/internalCompany.js
new file mode 100644
index 0000000..8f12b33
--- /dev/null
+++ b/src/api/user/internalCompany.js
@@ -0,0 +1,52 @@
+import request from '@/utils/request'
+var service_name = 'oil-refinery'
+var group_name = 'xoilRefinerySettlement'
+export default {
+ getByPage(page) {
+ // 分页查询
+ return request({
+ url: `/${service_name}/${group_name}/getByPage`,
+ method: 'post',
+ data: page
+ })
+ },
+ getByIdDetail(id) {
+ // 根据id查询详情
+ return request({
+ url: `/${service_name}/${group_name}/get/${id}`,
+ method: 'get'
+ })
+ },
+ orderGetByPage(page) {
+ // 新增待选-分页查询
+ return request({
+ url: `/${service_name}/xoilRefineryOrder/getByPage`,
+ method: 'post',
+ data: page
+ })
+ },
+ settlementSave(sysCustomerInfo) {
+ // 新增-保存
+ return request({
+ url: `/${service_name}/${group_name}/save`,
+ method: 'post',
+ data: sysCustomerInfo
+ })
+ },
+ update(sysCustomerInfo) {
+ // 审核
+ return request({
+ url: `/${service_name}/${group_name}/update`,
+ method: 'post',
+ data: sysCustomerInfo
+ })
+ },
+ getLikeByCompanyType(oilCompanyInfo) {
+ // 根据企业名称模糊搜索
+ return request({
+ url: `/oil-user/oilCompanyInfo/getLikeByCompanyType`,
+ method: 'post',
+ data: oilCompanyInfo
+ })
+ }
+}
diff --git a/src/assets/img/oilFinalStatement/icon-daijiesuan.png b/src/assets/img/oilFinalStatement/icon-daijiesuan.png
new file mode 100644
index 0000000..3e8a65f
Binary files /dev/null and b/src/assets/img/oilFinalStatement/icon-daijiesuan.png differ
diff --git a/src/assets/img/oilFinalStatement/icon-jiesuandanqiehuan.png b/src/assets/img/oilFinalStatement/icon-jiesuandanqiehuan.png
new file mode 100644
index 0000000..b0b05a2
Binary files /dev/null and b/src/assets/img/oilFinalStatement/icon-jiesuandanqiehuan.png differ
diff --git a/src/assets/img/oilFinalStatement/jiesuandanQiye.png b/src/assets/img/oilFinalStatement/jiesuandanQiye.png
new file mode 100644
index 0000000..9e118e6
Binary files /dev/null and b/src/assets/img/oilFinalStatement/jiesuandanQiye.png differ
diff --git a/src/assets/img/oilFinalStatement/jiesuandanYouzhan.png b/src/assets/img/oilFinalStatement/jiesuandanYouzhan.png
new file mode 100644
index 0000000..eeb84cb
Binary files /dev/null and b/src/assets/img/oilFinalStatement/jiesuandanYouzhan.png differ
diff --git a/src/assets/img/oilFinalStatement/qiyeAdd.png b/src/assets/img/oilFinalStatement/qiyeAdd.png
new file mode 100644
index 0000000..5c792da
Binary files /dev/null and b/src/assets/img/oilFinalStatement/qiyeAdd.png differ
diff --git a/src/assets/img/oilFinalStatement/qiyeLogo.png b/src/assets/img/oilFinalStatement/qiyeLogo.png
new file mode 100644
index 0000000..45ff820
Binary files /dev/null and b/src/assets/img/oilFinalStatement/qiyeLogo.png differ
diff --git a/src/assets/img/oilFinalStatement/youzhanAdd.png b/src/assets/img/oilFinalStatement/youzhanAdd.png
new file mode 100644
index 0000000..5eca4ec
Binary files /dev/null and b/src/assets/img/oilFinalStatement/youzhanAdd.png differ
diff --git a/src/assets/img/oilFinalStatement/youzhanLogo.png b/src/assets/img/oilFinalStatement/youzhanLogo.png
new file mode 100644
index 0000000..1514ebf
Binary files /dev/null and b/src/assets/img/oilFinalStatement/youzhanLogo.png differ
diff --git a/src/router/index.js b/src/router/index.js
index f2bb743..5b24752 100644
--- a/src/router/index.js
+++ b/src/router/index.js
@@ -1,28 +1,38 @@
-import Vue from "vue";
-import Router from "vue-router";
+import Vue from 'vue'
+import Router from 'vue-router'
-Vue.use(Router);
+Vue.use(Router)
export const constantRoutes = [
{
- path: "/",
- redirect: "/product",
+ path: '/',
+ redirect: '/product'
},
{
- path: "/login",
- component: () => import("@/views/login/index"),
- hidden: true,
+ path: '/login',
+ component: () => import('@/views/login/index'),
+ hidden: true
},
{
- path: "/404",
- component: () => import("@/views/404"),
+ path: '/404',
+ component: () => import('@/views/404')
// hidden: true
},
-];
+ {
+ path: '/oilFinalStatementList',
+ component: () => import('@/views/oilFinalStatement/oilFinalStatementList')
+ // hidden: true
+ },
+ {
+ path: '/oilFinalStatementAddList',
+ component: () => import('@/views/oilFinalStatement/oilFinalStatementAddList')
+ // hidden: true
+ }
+]
const router = new Router({
// scrollBehavior: () => ({ y: 0 }),
- routes: constantRoutes,
-});
+ routes: constantRoutes
+})
-export default router;
+export default router
diff --git a/src/vendor/Export2Excel.js b/src/vendor/Export2Excel.js
new file mode 100644
index 0000000..4294ccc
--- /dev/null
+++ b/src/vendor/Export2Excel.js
@@ -0,0 +1,312 @@
+/* eslint-disable */
+require('script-loader!file-saver');
+import XLSX from 'xlsx-style';
+
+
+function generateArray(table) {
+ var out = [];
+ var rows = table.querySelectorAll('tr');
+ var ranges = [];
+ for (var R = 0; R < rows.length; ++R) {
+ var outRow = [];
+ var row = rows[R];
+ var columns = row.querySelectorAll('td');
+ for (var C = 0; C < columns.length; ++C) {
+ var cell = columns[C];
+ var colspan = cell.getAttribute('colspan');
+ var rowspan = cell.getAttribute('rowspan');
+ var cellValue = cell.innerText;
+ if (cellValue !== "" && cellValue == +cellValue) cellValue = +cellValue;
+
+ //Skip ranges
+ ranges.forEach(function (range) {
+ if (R >= range.s.r && R <= range.e.r && outRow.length >= range.s.c && outRow.length <= range.e.c) {
+ for (var i = 0; i <= range.e.c - range.s.c; ++i) outRow.push(null);
+ }
+ });
+
+ //Handle Row Span
+ if (rowspan || colspan) {
+ rowspan = rowspan || 1;
+ colspan = colspan || 1;
+ ranges.push({
+ s: {
+ r: R,
+ c: outRow.length
+ },
+ e: {
+ r: R + rowspan - 1,
+ c: outRow.length + colspan - 1
+ }
+ });
+ };
+
+ //Handle Value
+ outRow.push(cellValue !== "" ? cellValue : null);
+
+ //Handle Colspan
+ if (colspan)
+ for (var k = 0; k < colspan - 1; ++k) outRow.push(null);
+ }
+ out.push(outRow);
+ }
+ return [out, ranges];
+};
+
+function datenum(v, date1904) {
+ if (date1904) v += 1462;
+ var epoch = Date.parse(v);
+ return (epoch - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);
+}
+
+function sheet_from_array_of_arrays(data, opts) {
+ var ws = {};
+ var range = {
+ s: {
+ c: 10000000,
+ r: 10000000
+ },
+ e: {
+ c: 0,
+ r: 0
+ }
+ };
+ // 设置表格中cell默认的字体,居中,颜色等
+ var defaultCellStyle = {
+ alignment: {
+ // 居中
+ horizontal: "center",
+ vertical: "center",
+ indent: 0
+ },
+ border: {bottom:{style:"thin"},top:{style:"thin"},
+ left:{style:"thin"},right:{style:"thin"}}
+}
+ for (var R = 0; R != data.length; ++R) {
+ for (var C = 0; C != data[R].length; ++C) {
+ if (range.s.r > R) range.s.r = R;
+ if (range.s.c > C) range.s.c = C;
+ if (range.e.r < R) range.e.r = R;
+ if (range.e.c < C) range.e.c = C;
+ var cell = {
+ v: data[R][C]?data[R][C]:"",
+ s: defaultCellStyle
+ };
+ if (cell.v == null) continue;
+ var cell_ref = XLSX.utils.encode_cell({
+ c: C,
+ r: R
+ });
+
+ if (typeof cell.v === 'number') cell.t = 'n';
+ else if (typeof cell.v === 'boolean') cell.t = 'b';
+ else if (cell.v instanceof Date) {
+ cell.t = 'n';
+ cell.z = XLSX.SSF._table[14];
+ cell.v = datenum(cell.v);
+ } else cell.t = 's';
+
+ ws[cell_ref] = cell;
+ }
+ }
+ if (range.s.c < 10000000) ws['!ref'] = XLSX.utils.encode_range(range);
+ return ws;
+}
+
+function Workbook() {
+ if (!(this instanceof Workbook)) return new Workbook();
+ this.SheetNames = [];
+ this.Sheets = {};
+}
+
+function s2ab(s) {
+ var buf = new ArrayBuffer(s.length);
+ var view = new Uint8Array(buf);
+ for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
+ return buf;
+}
+
+export function export_table_to_excel(id) {
+ var theTable = document.getElementById(id);
+ var oo = generateArray(theTable);
+ var ranges = oo[1];
+
+ /* original data */
+ var data = oo[0];
+ var ws_name = "SheetJS";
+
+ var wb = new Workbook(),
+ ws = sheet_from_array_of_arrays(data);
+
+ /* add ranges to worksheet */
+ // ws['!cols'] = ['apple', 'banan'];
+ ws['!merges'] = ranges;
+
+ /* add worksheet to workbook */
+ wb.SheetNames.push(ws_name);
+ wb.Sheets[ws_name] = ws;
+
+ var wbout = XLSX.write(wb, {
+ bookType: 'xlsx',
+ bookSST: false,
+ type: 'binary'
+ });
+
+ saveAs(new Blob([s2ab(wbout)], {
+ type: "application/octet-stream"
+ }), "test.xlsx")
+}
+
+export function export_json_to_excel({
+ multiHeader = [],
+ header,
+ data,
+ filename,
+ merges = [],
+ autoWidth = true,
+ bookType= 'xlsx'
+} = {}) {
+ /* original data */
+ filename = filename || 'excel-list'
+ data = [...data]
+ data.unshift(header);
+
+ for (let i = multiHeader.length-1; i > -1; i--) {
+ data.unshift(multiHeader[i])
+ }
+
+ var ws_name = "导出结果";
+ var wb = new Workbook(),
+ ws = sheet_from_array_of_arrays(data);
+
+ if (merges.length > 0) {
+ if (!ws['!merges']) ws['!merges'] = [];
+ merges.forEach(item => {
+ ws['!merges'].push(XLSX.utils.decode_range(item))
+ })
+ }
+
+ if (autoWidth) {
+ /*设置worksheet每列的最大宽度*/
+ const colWidth = data.map(row => row.map(val => {
+ /*先判断是否为null/undefined*/
+ if (val == null) {
+ return {
+ 'wch': 10
+ };
+ }
+ /*再判断是否为中文*/
+ else if (val.toString().charCodeAt(0) > 255) {
+ return {
+ 'wch': val.toString().length * 2.5
+ };
+ } else {
+ return {
+ 'wch': val.toString().length * 1.2
+ };
+ }
+ }))
+ /*以第一行为初始值*/
+ let result = colWidth[0];
+ for (let i = 1; i < colWidth.length; i++) {
+ for (let j = 0; j < colWidth[i].length; j++) {
+ if (result[j]['wch'] < colWidth[i][j]['wch']) {
+ result[j]['wch'] = colWidth[i][j]['wch'];
+ }
+ }
+ }
+ ws['!cols'] = result;
+ }
+
+ /* add worksheet to workbook */
+ wb.SheetNames.push(ws_name);
+ wb.Sheets[ws_name] = ws;
+ // if ( filename === '司机账户信息表') {
+ for(var key in ws) {
+ if(key.replace(/[^0-9]/ig, '') === '1') {
+ ws[key].s = {
+ alignment: {
+ // 居中
+ horizontal: "center",
+ vertical: "center"
+ },
+ font: {
+ color: { rgb: 'ffffff' },
+ bold: true
+ },
+ fill: {
+ fgColor: { rgb: '2f75b5' }
+ },
+ border: {bottom:{style:"thin"},top:{style:"thin"},
+ left:{style:"thin"},right:{style:"thin"}}
+ }
+ }
+ }
+ // }
+ if ( filename === '星卡互联平台业务量数据') {
+ for(var key in ws) {
+ if(key.replace(/[^0-9]/ig, '') === '1' || key.replace(/[^0-9]/ig, '') === '2') {
+ ws[key].s = {
+ alignment: {
+ // 居中
+ horizontal: "top",
+ vertical: "center",
+ indent: 0
+ },
+ font: {
+ sz: '14',
+ color: { rgb: 'ffffff' },
+ bold: true
+ },
+ fill: {
+ fgColor: { rgb: '2f75b5' }
+ },
+ border: {bottom:{style:"thin"},top:{style:"thin"},
+ left:{style:"thin"},right:{style:"thin"}}
+ }
+ }
+ if (key.replace(/[^0-9]/ig, '') === '3'||key.replace(/[^0-9]/ig, '') === '4') {
+ ws[key].s = {
+ alignment: {
+ // 居中
+ horizontal: "center",
+ vertical: "center"
+ },
+ font: {
+ color: { rgb: 'ffffff' },
+ bold: true
+ },
+ fill: {
+ fgColor: { rgb: '2f75b5' }
+ },
+ border: {bottom:{style:"thin"},top:{style:"thin"},
+ left:{style:"thin"},right:{style:"thin"}}
+ }
+ }
+ }
+ }
+ // var dataInfo = wb.Sheets[wb.SheetNames[0]];
+
+ // for (var i in dataInfo) {
+ // if (i == '!ref' || i == '!merges' || i == '!cols') {
+
+ // } else {
+ // dataInfo[i + ''].s = {
+ // alignment: {
+ // horizontal: "center",
+ // vertical: "center"
+ // },
+ // fill: {
+ // bgColor: { rgb: 'ffff00' } }
+ // }
+ // }
+ // };
+ var wbout = XLSX.write(wb, {
+ bookType: bookType,
+ bookSST: false,
+ type: 'binary'
+ });
+ saveAs(new Blob([s2ab(wbout)], {
+ type: "application/octet-stream"
+ }), `${filename}.${bookType}`);
+}
diff --git a/src/views/oilFinalStatement/oilFinalStatementAddList.vue b/src/views/oilFinalStatement/oilFinalStatementAddList.vue
new file mode 100644
index 0000000..620567b
--- /dev/null
+++ b/src/views/oilFinalStatement/oilFinalStatementAddList.vue
@@ -0,0 +1,895 @@
+
+
+ {{ importData.settlementNo }}
+
+
+ {{ importData.settlementType == 1 ? '企业' : '炼厂' }}
+
+ {{ importData.settlementObjectName }}
+
+ {{ importData.settlementAmount }}
+
+ {{ importData.orderAmount }}
+
+ {{ importData.rechargeAmount }}
+
+ {{ importData.invoicedAmount }}
+
+ {{ importData.createUserName }}
+
+ {{ importData.createTime }}
+
+ {{ importData.auditUserName }}
+
+ {{ importData.auditTime }}
+