123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306 |
- /**
- * Created by Tony on 2018/9/4.
- */
- let virtualSummaryOprObj = {
- summaryWorkBook: null,
- summaryParentNode: null,
- iniSpreadJs: function (summaryParentNode) {
- let me = this;
- if (me.summaryWorkBook === null) {
- me.summaryWorkBook = new GC.Spread.Sheets.Workbook($('#rptTplSummaryWorkbook')[0], {sheetCount: 1});
- me.summaryWorkBook.options.tabStripVisible = false;
- me.summaryWorkBook.options.allowCopyPasteExcelStyle = false;
- me.summaryWorkBook.options.allowUserDragDrop = false;
- me.summaryWorkBook.options.allowContextMenu = false;
- let sheet = me.summaryWorkBook.getActiveSheet();
- sheet.options.allowCellOverflow = false;
- sheet.options.clipBoardOptions = GC.Spread.Sheets.ClipboardPasteOptions.values;
- sheet.bind(GC.Spread.Sheets.Events.EnterCell, me.onCellEnter);
- }
- me.summaryParentNode = summaryParentNode;
- },
- restoreSummary: function () {
- let me = this;
- let rptTpl = (zTreeOprObj.currentNode)?zTreeOprObj.currentNode.rptTpl:null;
- me.setupSummary(rptTpl, me.summaryParentNode);
- },
- setupSummary: function (rptTpl, summaryParentNode) {
- let me = this, columnParentNode = null;
- let selectedBand = virtualCommonOprObj.getBandEx(summaryParentNode[JV.PROP_BAND_NAME], rptTpl);
- if (summaryParentNode && selectedBand) {
- let preNode = summaryParentNode.getPreNode();
- while (preNode) {
- if (preNode[JV.PROP_NAME] === JV.NODE_FLOW_COLUMN) {
- columnParentNode = preNode;
- break;
- } else {
- preNode = preNode.getPreNode();
- }
- }
- let fieldNode = summaryParentNode.items[0], textNode = summaryParentNode.items[1];
- if (columnParentNode) {
- let yColumnPos = [], xPos = [], ySummaryPos = [0], xSummaryPos = [0];
- let sheet = me.summaryWorkBook.getActiveSheet();
- let columnBand = virtualCommonOprObj.getBandEx(columnParentNode[JV.PROP_BAND_NAME], rptTpl);
- let bandH = Math.round(parseFloat(columnBand[JV.BAND_PROP_HEIGHT]) / 2.54 * 96);
- let bandW = 700;
- let pIdx = JV.PAGES_SIZE_STR.indexOf(rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_PAGE_SIZE]);
- if (pIdx >= 0) {
- bandW = Math.round(JV.PAGES_SIZE[pIdx][0] * 96 - (parseFloat(rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_LEFT]) + parseFloat(rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_RIGHT])) /2.54*96 );
- if (rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_ORIENTATION] === JV.ORIENTATION_LANDSCAPE ||
- rptTpl[JV.NODE_MAIN_INFO][JV.NODE_PAGE_INFO][JV.PROP_ORIENTATION] === JV.ORIENTATION_LANDSCAPE_CHN) {
- bandW = Math.round(JV.PAGES_SIZE[pIdx][1] * 96 - (parseFloat(rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_LEFT]) + parseFloat(rptTpl[JV.NODE_MAIN_INFO][JV.NODE_MARGINS][JV.PROP_RIGHT])) /2.54*96 );
- }
- }
- //1. 设置column位置(让用户知道位置,后期无需用户再调)
- for (let itemNode of columnParentNode.items) {
- virtualCommonOprObj.pushPos(itemNode, itemNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_LEFT, bandW, xPos);
- virtualCommonOprObj.pushPos(itemNode, itemNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_RIGHT, bandW, xPos);
- virtualCommonOprObj.pushPos(itemNode, itemNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_TOP, bandH, yColumnPos);
- virtualCommonOprObj.pushPos(itemNode, itemNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_BOTTOM, bandH, yColumnPos);
- }
- sheet.setRowCount(yColumnPos.length - 1, GC.Spread.Sheets.SheetArea.colHeader);
- sheet.setColumnCount(xPos.length - 1, GC.Spread.Sheets.SheetArea.viewport);
- // sheet.clear();
- xPos.sort(function(x1, x2){
- return (x1 - x2);
- });
- yColumnPos.sort(function(y1, y2){
- return (y1 - y2);
- });
- for (let idx = 1; idx < xPos.length; idx++) {
- sheet.setColumnWidth(idx - 1, xPos[idx] - xPos[idx - 1]);
- }
- for (let idx = 1; idx < yColumnPos.length; idx++) {
- sheet.setRowHeight(idx - 1, yColumnPos[idx] - yColumnPos[idx - 1]);
- sheet.getRange(idx - 1, -1, 1, -1).backColor(undefined);
- }
- for (let itemNode of columnParentNode.items) {
- let idx1 = xPos.indexOf(virtualCommonOprObj.getActPosEx(itemNode, itemNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_LEFT, bandW, xPos));
- let idx2 = xPos.indexOf(virtualCommonOprObj.getActPosEx(itemNode, itemNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_RIGHT, bandW, xPos));
- let idy1 = yColumnPos.indexOf(virtualCommonOprObj.getActPosEx(itemNode, itemNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_TOP, bandH, yColumnPos));
- let idy2 = yColumnPos.indexOf(virtualCommonOprObj.getActPosEx(itemNode, itemNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_BOTTOM, bandH, yColumnPos));
- if (idx2 - idx1 > 1 || idy2 - idy1 > 1) {
- sheet.addSpan(idy1, idx1, idy2 - idy1, idx2 - idx1, GC.Spread.Sheets.SheetArea.colHeader);
- }
- me.private_setupCell(sheet.getCell(idy1, idx1, GC.Spread.Sheets.SheetArea.colHeader), rptTpl, itemNode);
- }
- //2. 设置已有的统计信息
- let sumBandH = Math.round(parseFloat(selectedBand[JV.BAND_PROP_HEIGHT]) / 2.54 * 96);
- for (let fNode of fieldNode.items) {
- virtualCommonOprObj.pushPos(fNode, fNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_LEFT, bandW, xSummaryPos);
- virtualCommonOprObj.pushPos(fNode, fNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_RIGHT, bandW, xSummaryPos);
- virtualCommonOprObj.pushPos(fNode, fNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_TOP, sumBandH, ySummaryPos);
- virtualCommonOprObj.pushPos(fNode, fNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_BOTTOM, sumBandH, ySummaryPos);
- }
- for (let tNode of textNode.items) {
- virtualCommonOprObj.pushPos(tNode, tNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_LEFT, bandW, xSummaryPos);
- virtualCommonOprObj.pushPos(tNode, tNode[JV.PROP_AREA][JV.PROP_H_CALCULATION], JV.PROP_RIGHT, bandW, xSummaryPos);
- virtualCommonOprObj.pushPos(tNode, tNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_TOP, sumBandH, ySummaryPos);
- virtualCommonOprObj.pushPos(tNode, tNode[JV.PROP_AREA][JV.PROP_V_CALCULATION], JV.PROP_BOTTOM, sumBandH, ySummaryPos);
- }
- sheet.setRowCount(ySummaryPos.length - 1, GC.Spread.Sheets.SheetArea.viewport);
- }
- }
- },
- addRow: function () {
- let me = this,
- sheet = me.summaryWorkBook.getActiveSheet();
- sheet.addRows(sheet.getRowCount() - 1, 1);
- let rc = sheet.getRowCount();
- for (let cc = 0; cc < sheet.getColumnCount(); cc++) {
- me.private_setupCellDft(sheet.getCell(rc - 2, cc));
- }
- },
- deleteRow: function () {
- let me = this,
- sheet = me.summaryWorkBook.getActiveSheet(),
- selectedRanges = sheet.getSelections()
- ;
- if (selectedRanges.length > 0) {
- sheet.deleteRows(selectedRanges[0].row, 1);
- }
- },
- onCellEnter: function (sender, args) {
- let me = virtualSummaryOprObj,
- sheet = me.summaryWorkBook.getActiveSheet();
- if (args.row === sheet.getRowCount() - 1) {
- } else {
- }
- },
- mergeCells: function () {
- let me = virtualSummaryOprObj,
- sheet = me.summaryWorkBook.getActiveSheet();
- let selectedRanges = sheet.getSelections();
- if (selectedRanges.length > 0) {
- sheet.suspendPaint();
- sheet.addSpan(selectedRanges[0].row, selectedRanges[0].col, selectedRanges[0].rowCount, selectedRanges[0].colCount);
- sheet.resumePaint();
- }
- },
- disMergeCells: function () {
- let me = virtualSummaryOprObj,
- sheet = me.summaryWorkBook.getActiveSheet();
- let selectedRanges = sheet.getSelections();
- let spans =sheet.getSpans();
- if (selectedRanges.length > 0 && spans.length > 0) {
- let selectedSpans = [];
- for(let i = 0; i < spans.length; i++)
- {
- for (let j = 0; j < selectedRanges.length; j++) {
- if (spans[i].row >= selectedRanges[j].row && spans[i].col >= selectedRanges[j].col &&
- spans[i].row <= selectedRanges[j].row + selectedRanges[j].rowCount && spans[i].col <= selectedRanges[j].col + selectedRanges[j].colCount) {
- selectedSpans.push(spans[i]);
- }
- }
- }
- for (let span of selectedSpans) {
- sheet.removeSpan(span.row, span.col, GC.Spread.Sheets.SheetArea.viewport);
- }
- }
- },
- changeCtrl: function (dom) {
- let me = virtualSummaryOprObj,
- sheet = me.summaryWorkBook.getActiveSheet()
- ;
- let selectedRanges = sheet.getSelections();
- for(let i = 0; i < selectedRanges.length; i++){
- // let ctrl = me.columnFieldCtrls[selectedRanges[i].col]
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_SHRINK]] = 'F';
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_SHOW_ZERO]] = 'F';
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_WRAP]] = 'F';
- // ctrl.isNarrow = false;
- // ctrl.isAutoHeight = false;
- // if ($("#eleShrinkEx")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_SHRINK]] = 'T';
- // }
- // if ($("#eleShowZeroEx")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_SHOW_ZERO]] = 'T';
- // }
- // if ($("#eleAutoWrapEx")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_WRAP]] = 'T';
- // }
- // if ($("#eleIsNarrowEx")[0].checked) {
- // ctrl.isNarrow = true;
- // }
- // if ($("#eleIsAutoHeightEx")[0].checked) {
- // ctrl.isAutoHeight = true;
- // }
- //
- // if ($("#hOptionLeft")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_HORIZON]] = JV.OUTPUT_ALIGN.H[0];
- // } else if ($("#hOptionCenter")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_HORIZON]] = JV.OUTPUT_ALIGN.H[1];
- // } else {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_HORIZON]] = JV.OUTPUT_ALIGN.H[2];
- // }
- // if ($("#vOptionUp")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_VERTICAL]] = JV.OUTPUT_ALIGN.V[0];
- // } else if ($("#vOptionCenter")[0].checked) {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_VERTICAL]] = JV.OUTPUT_ALIGN.V[1];
- // } else {
- // ctrl[JV.CONTROL_PROPS[JV.CONTROL_PROP_IDX_VERTICAL]] = JV.OUTPUT_ALIGN.V[2];
- // }
- }
- },
- private_setupCellDft: function (cell) {
- cell.font(`9pt 宋体`);
- cell.hAlign(GC.Spread.Sheets.HorizontalAlign.center);
- cell.vAlign(GC.Spread.Sheets.VerticalAlign.center);
- cell.wordWrap(true);
- cell.value(``);
- },
- private_setupCell: function (cell, rptTpl, textNode) {
- let me = this;
- me.private_setCellFont(cell, textNode);
- me.private_setCellControl(cell, textNode);
- me.private_setCellStyle(cell, textNode);
- let value = textNode[JV.PROP_NAME];
- if (textNode[JV.PROP_NAME].indexOf(`|`) >= 0) {
- value = textNode[JV.PROP_NAME].split('|').join('\n');
- }
- cell.wordWrap(true);
- cell.value(value);
- },
- private_setCellControl: function (cell, textNode) {
- let ctrl = null;
- if (typeof textNode[JV.PROP_CONTROL] === 'string') {
- let idx = rpt_tpl_cfg_helper.reportCfg.controlArr.indexOf(textNode[JV.PROP_CONTROL]);
- ctrl = rpt_tpl_cfg_helper.reportCfg.ctrls[idx];
- } else {
- ctrl = textNode[JV.PROP_CONTROL];
- }
- if (ctrl) {
- switch (ctrl.Horizon) {
- case `center`:
- cell.hAlign(GC.Spread.Sheets.HorizontalAlign.center);
- break;
- case `right`:
- cell.hAlign(GC.Spread.Sheets.HorizontalAlign.right);
- break;
- default:
- cell.hAlign(GC.Spread.Sheets.HorizontalAlign.left);
- break;
- }
- switch (ctrl.Vertical) {
- case `center`:
- cell.vAlign(GC.Spread.Sheets.VerticalAlign.center);
- break;
- case `bottom`:
- cell.vAlign(GC.Spread.Sheets.VerticalAlign.bottom);
- break;
- default:
- cell.vAlign(GC.Spread.Sheets.VerticalAlign.top);
- break;
- }
- }
- },
- private_setCellStyle: function (cell, textNode) {
- //默认是normal,暂时不管
- },
- private_setCellFont: function (cell, textNode) {
- for (let font of rpt_tpl_cfg_helper.reportCfg.fonts) {
- if (font.ID === textNode[JV.PROP_FONT]) {
- cell.font(Math.round(font[JV.FONT_PROPS[JV.FONT_PROP_IDX_HEIGHT]] * 3 / 4) + 'pt ' + font[JV.FONT_PROPS[JV.FONT_PROP_IDX_NAME]]);
- break;
- }
- }
- },
- applySummaryBack: function () {
- let me = this;
- let rptTpl = (zTreeOprObj.currentNode)?zTreeOprObj.currentNode.rptTpl:null;
- if (rptTpl && me.summaryParentNode) {
- let sheet = me.summaryWorkBook.getActiveSheet();
- let rAmt = sheet.getRowCount(), pixH = [0];
- if (rAmt > 0) {
- let texts = [], colWidthArr = [], rowHeightArr = [];
- virtualCommonOprObj.collectSheetTxt(sheet, texts, colWidthArr, rowHeightArr);
- for (let node of summaryParentNode.items) {
- dataInfoMapTreeOprObj.treeObj.removeChildNodes(node);
- }
- let txtNodes = [], fieldNodes = [];
- for (let text of texts) {
- if (!stringUtil.isEmptyString(text[`text`]) && text[`text`].indexOf(`{`) === 0) {
- //创建指标
- } else {
- //创建文本
- let node = virtualCommonOprObj.createTxtNode(text, me.columnParentNode, colWidthArr, rowHeightArr);
- txtNodes.push(node);
- }
- }
- //....
- let selectedBand = virtualCommonOprObj.getBandEx(summaryParentNode[JV.PROP_BAND_NAME], rptTpl);
- selectedBand[JV.BAND_PROP_HEIGHT] = (rowHeightArr[rowHeightArr.length - 1] / 96 * 2.54).toFixed(2);
- } else {
- displayMessage("模板行数量不足!", "red", 2000, "id_summary_setup_lbl");
- }
- }
- }
- };
|