/** * Created by Tony on 2017/4/1. */ var JV = require('../rpt_component/Jpc_ValueDefine'); var fs = require('fs'); var jpcCmnHelper = require('../rpt_component/helper/Jpc_Helper_Common'); var DPI = jpcCmnHelper.getScreenDPI()[0]; const dftHeadXml = ''; function writeContentTypes(sheets) { var rst = []; rst.push(dftHeadXml + '\r\n'); rst.push(''); //... rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); for (var i = 0; i < sheets.length; i++) { rst.push('') } rst.push(''); rst.push(''); return rst; } function writeRootRels(){ var rst = []; rst.push(dftHeadXml + '\r\n'); rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); return rst; } function writeApp(sheets) { var rst = []; rst.push(dftHeadXml + '\r\n'); rst.push(''); rst.push('Microsoft Excel'); rst.push('0'); rst.push('false'); rst.push(''); rst.push(''); rst.push('¹¤×÷±í'); rst.push('' + sheets.length + ''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); for (var i = 0; i < sheets.length; i++) { rst.push('' + sheets[i].sheetName + '') } rst.push(''); rst.push(''); rst.push('SmartCost'); rst.push('false'); rst.push('false'); rst.push('false'); rst.push('12.0000'); //rst.push(''); rst.push(''); return rst; } function writeCore() { var rst = []; p_fillZero = function(val){ var rst = val; if (val < 10) { rst = '0' + val; } return rst; }; rst.push(dftHeadXml + '\r\n'); rst.push(''); rst.push('SmartCost'); rst.push('SmartCost'); var dt = new Date(), dtStr = dt.getFullYear() + '-' + p_fillZero(dt.getMonth()) + '-' + p_fillZero(dt.getDate()) + 'T' + p_fillZero(dt.getHours()) + ':' + p_fillZero(dt.getMinutes()) + ':' + p_fillZero(dt.getSeconds()) + 'Z'; rst.push('' + dtStr + ''); rst.push('' + dtStr + ''); //rst.push(''); rst.push(''); return rst; } function writeXlWorkBook(sheets){ var rst = []; rst.push(dftHeadXml + '\r\n'); rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); for (var i = 0; i < sheets.length; i++) { rst.push('') } rst.push(''); rst.push(''); //rst.push(''); rst.push(''); return rst; } function writeXlRels(sheets){ var rst = [], idx = 1; rst.push(dftHeadXml + '\r\n'); rst.push(''); for (var i = 0; i < sheets.length; i++) { rst.push(''); idx++; rst.push(''); idx++; rst.push(''); //rst.push(''); rst.push(''); return rst; } function writeTheme(){ var rst = fs.readFileSync('./excel_base_files/theme1.xml', 'utf8', 'r'); return rst; } function writeStyles(pageData){ // } function writeSharedString(pageData){ // } function writeSheets(pageData){ var rst = [], sharedStrList = []; for (var i = 0; i < pageData.items.length; i++) { // } } function writeSheet(sheetData, sharedStrList, styleList){ var rst = [], xPos = [0], yPos = [0], headerStr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; private_pre_analyze_pos = function(){ var cell, pos; sheetData.cells.sort(function(cell1, cell2) { var rst = 0; if (cell1[JV.PROP_AREA][JV.PROP_TOP] > cell2[JV.PROP_AREA][JV.PROP_TOP]) { rst = 1; } else if (cell1[JV.PROP_AREA][JV.PROP_TOP] < cell2[JV.PROP_AREA][JV.PROP_TOP]) { rst = -1; } else { if (cell1[JV.PROP_AREA][JV.PROP_LEFT] > cell2[JV.PROP_AREA][JV.PROP_LEFT]) { rst = 1; } else if (cell1[JV.PROP_AREA][JV.PROP_LEFT] < cell2[JV.PROP_AREA][JV.PROP_LEFT]) { rst = -1; } } }); for (var i = 0; i < sheetData.cells.length; i++) { cell = sheetData.cells[i]; pos = cell[JV.PROP_AREA][JV.PROP_LEFT]; if (xPos.indexOf(pos) < 0) xPos.push(pos); pos = cell[JV.PROP_AREA][JV.PROP_RIGHT]; if (xPos.indexOf(pos) < 0) xPos.push(pos); pos = cell[JV.PROP_AREA][JV.PROP_TOP]; if (yPos.indexOf(pos) < 0) yPos.push(pos); pos = cell[JV.PROP_AREA][JV.PROP_BOTTOM]; if (yPos.indexOf(pos) < 0) yPos.push(pos); } xPos.sort(); yPos.sort(); }; private_getCellIdxStr = function(idx){ var rst = 'A'; if (idx < 26) { rst = headerStr[idx]; } else if (idx < 26*26+26) { var ti = Math.floor(idx / 26), tj = idx % 26; rst = headerStr[ti - 1] + headerStr[tj]; } else if (idx < 26*26*26+26) { var ti = Math.floor(idx / (26*26)), tj = Math.floor((idx - ti * 26*26) / 26), tk = idx % 26; rst = headerStr[ti - 1] + headerStr[tj-1] + headerStr[tk]; } return rst; }; private_getSharedStrIdx = function(val) { var rst = sharedStrList.indexOf(val); if (rst < 0) { sharedStrList.push(val); rst = sharedStrList.length - 1; } return rst; }; private_getStyleIdx = function(cell) { var rst = 1; // return rst; }; private_setCols = function(){ rst.push(''); var w = 0; for (var i = 1; i < xPos.length; i++) { w = 1.0 * (xPos[i] - xPos[i - 1]) / DPI; w = Math.round(w * 1000) / 1000; rst.push(''); } rst.push(''); }; private_setMergedCells = function() { var cell, idxR, idxL, idxT, idxB, cnt = 0; rst.push(''); var startIdx = rst.length - 1; for (var i = 0; i < sheetData.cells.length; i++) { cell = sheetData.cells[i]; idxR = xPos.indexOf(cell[JV.PROP_AREA][JV.PROP_RIGHT]); idxL = xPos.indexOf(cell[JV.PROP_AREA][JV.PROP_LEFT]); idxB = yPos.indexOf(cell[JV.PROP_AREA][JV.PROP_BOTTOM]); idxT = yPos.indexOf(cell[JV.PROP_AREA][JV.PROP_TOP]); if (idxR - idxL > 1 || idxB - idxT > 1) { rst.push(''); cnt++; } } rst[startIdx] = ''; rst.push(''); }; private_setSheetData = function(){ rst.push(''); var spanX = xPos.length - 1, cellIdx = 0, h = 0, hasMoreCols = true; for (var i = 0; i < yPos.length - 1; i++) { if (i === 0) { h = 1.0 * (yPos[i]) / DPI; } else { h = 1.0 * (yPos[i] - yPos[i - 1]) / DPI; } h = Math.round(h * 1000) / 1000; rst.push(''); //then put the cells of this row var colIdxStr = ''; for (var j = 0; j < xPos.length; j++) { colIdxStr = private_getCellIdxStr(j); if (hasMoreCols) { var ridx = yPos.indexOf(sheetData.cells[cellIdx][JV.PROP_AREA][JV.PROP_TOP]); } else { rst.push(''); } } rst.push(''); }; private_pre_analyze_pos(); rst.push(dftHeadXml + '\r\n'); rst.push(''); var colStr = private_getCellIdxStr(xPos.length - 2); rst.push(''); rst.push(''); rst.push(''); rst.push(''); rst.push(''); private_setCols private_setSheetData(); private_setMergedCells(); rst.push(''); rst.push(''); //rst.push(''); rst.push(''); rst.push(''); //rst.push(''); return rst; } module.exports = { exportExcel: function (pageData, options) { var rptOptions = (options || {singlePage: false, fileName: 'report'}); } }