/**
* 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'});
}
}