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 @@ + + + + + diff --git a/src/views/oilFinalStatement/oilFinalStatementList.vue b/src/views/oilFinalStatement/oilFinalStatementList.vue new file mode 100644 index 0000000..12916e9 --- /dev/null +++ b/src/views/oilFinalStatement/oilFinalStatementList.vue @@ -0,0 +1,538 @@ + + + + + diff --git a/src/views/oilFinalStatement/oilFinalStatementListInfo.vue b/src/views/oilFinalStatement/oilFinalStatementListInfo.vue new file mode 100644 index 0000000..e0c91d9 --- /dev/null +++ b/src/views/oilFinalStatement/oilFinalStatementListInfo.vue @@ -0,0 +1,482 @@ + + + diff --git a/src/views/order/components/billOfLading.vue b/src/views/order/components/billOfLading.vue index e8a8a78..70f6b9d 100644 --- a/src/views/order/components/billOfLading.vue +++ b/src/views/order/components/billOfLading.vue @@ -57,7 +57,7 @@
提货单列表 - 创建提货单 + 创建提货单