|
@@ -25,8 +25,9 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
ValuedIdxLst.push(vIdx);
|
|
|
}
|
|
|
let JpcFlowTabResult = {};
|
|
|
- JpcFlowTabResult.initialize = function() {
|
|
|
+ JpcFlowTabResult.initialize = function(isEx) {
|
|
|
let me = this;
|
|
|
+ me.isEx = isEx;
|
|
|
me.segments = [];
|
|
|
me.dispValueIdxLst = [];
|
|
|
me.page_seg_map = [];
|
|
@@ -39,17 +40,19 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
me.groupSumValLst = [];
|
|
|
me.segSumValLst = [];
|
|
|
me.multiCols = 1;
|
|
|
+ me.pagesAmt = 0;
|
|
|
};
|
|
|
JpcFlowTabResult.sorting = function(rptTpl, dataObj, dataSeq) {
|
|
|
let me = this;
|
|
|
- JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_SEG_SUM][JV.PROP_SUM_FIELDS], me.seg_sum_tab_fields, me.seg_sum_fields_idx);
|
|
|
- JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_PAGE_SUM][JV.PROP_SUM_FIELDS], null, me.page_sum_fields_idx);
|
|
|
- JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_GROUP][JV.PROP_GROUP_FIELDS], null, me.group_fields_idx);
|
|
|
+ let FLOW_NODE_STR = me.isEx?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
+ JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_SEG_SUM][JV.PROP_SUM_FIELDS], me.seg_sum_tab_fields, me.seg_sum_fields_idx, me.isEx);
|
|
|
+ JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_PAGE_SUM][JV.PROP_SUM_FIELDS], null, me.page_sum_fields_idx, me.isEx);
|
|
|
+ JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_GROUP][JV.PROP_GROUP_FIELDS], null, me.group_fields_idx, me.isEx);
|
|
|
for (let si = 0; si < dataSeq.length; si++) {
|
|
|
me.segments.push(dataSeq[si].slice(0));
|
|
|
}
|
|
|
//pre-sum the data(for seg sum display)
|
|
|
- let data_details = dataObj[JV.DATA_DETAIL_DATA],
|
|
|
+ let data_details = me.isEx?dataObj[JV.DATA_DETAIL_DATA_EX]:dataObj[JV.DATA_DETAIL_DATA],
|
|
|
data_fields = [];
|
|
|
for (let i = 0; i < me.seg_sum_fields_idx.length; i++) {
|
|
|
let data_field = data_details[me.seg_sum_fields_idx[i]];
|
|
@@ -72,14 +75,18 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
};
|
|
|
JpcFlowTabResult.preSetupPages = function (rptTpl, dataOjb, defProperties) {
|
|
|
let rst = 0, me = this, counterRowRec = 0, maxRowRec = 1, pageIdx = 0;
|
|
|
- JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_CONTENT][JV.PROP_FLOW_FIELDS], null, me.disp_fields_idx);
|
|
|
+ let CURRENT_FLOW_INFO = (me.isEx)?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
+ JpcFieldHelper.findAndPutDataFieldIdx(rptTpl, rptTpl[CURRENT_FLOW_INFO][JV.NODE_FLOW_CONTENT][JV.PROP_FLOW_FIELDS], null, me.disp_fields_idx, me.isEx);
|
|
|
let bands = JpcBand.createNew(rptTpl, defProperties);
|
|
|
let pageStatus = [true, true, false, false, false, false, false, false];
|
|
|
- if (rptTpl[JV.NODE_FLOW_INFO][JV.PROP_MULTI_COLUMN]) {
|
|
|
- me.multiCols = 1 * rptTpl[JV.NODE_FLOW_INFO][JV.PROP_MULTI_COLUMN];
|
|
|
+ if (me.isEx) {
|
|
|
+ pageStatus[JV.STATUS_REPORT_START] = false;
|
|
|
+ }
|
|
|
+ if (rptTpl[CURRENT_FLOW_INFO][JV.PROP_MULTI_COLUMN]) {
|
|
|
+ me.multiCols = 1 * rptTpl[CURRENT_FLOW_INFO][JV.PROP_MULTI_COLUMN];
|
|
|
}
|
|
|
function private_resetBandArea() {
|
|
|
- JpcBandHelper.setBandArea(bands, rptTpl, pageStatus);
|
|
|
+ JpcBandHelper.setBandArea(bands, rptTpl, pageStatus, !me.isEx, me.isEx);
|
|
|
maxRowRec = JpcFlowTabHelper.getMaxRowsPerPage(bands, rptTpl);
|
|
|
}
|
|
|
for (let segIdx = 0; segIdx < me.segments.length; segIdx++) {
|
|
@@ -106,13 +113,15 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
pageStatus[JV.STATUS_REPORT_START] = false;
|
|
|
}
|
|
|
rst = Math.ceil(1.0 * pageIdx / me.multiCols);
|
|
|
+ me.pagesAmt = rst;
|
|
|
return rst;
|
|
|
};
|
|
|
JpcFlowTabResult.outputAsSimpleJSONPage = function (rptTpl, dataObj, page, bands, controls, $CURRENT_RPT) {
|
|
|
let me = this, rst = [], tabRstLst = [];
|
|
|
+ let FLOW_NODE_STR = me.isEx?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
let segIdx = JpcCommonHelper.getSegIdxByPageIdx(page, me.page_seg_map);
|
|
|
//1 calculate the band position
|
|
|
- JpcBandHelper.setBandArea(bands, rptTpl, me.pageStatusLst[page - 1]);
|
|
|
+ JpcBandHelper.setBandArea(bands, rptTpl, me.pageStatusLst[page - 1], !me.isEx, me.isEx);
|
|
|
//2. start to output detail-part
|
|
|
let unitFactor = JpcCommonHelper.getUnitFactor(rptTpl);
|
|
|
for (let pi = 0; pi < me.multiCols; pi++) {
|
|
@@ -126,7 +135,7 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
//2.4 Sum Page
|
|
|
//2.5 Discrete
|
|
|
if (pi == 0) {
|
|
|
- tabRstLst.push(JpcDiscreteHelper.outputDiscreteInfo(rptTpl[JV.NODE_FLOW_INFO][JV.NODE_DISCRETE_INFO], bands, dataObj, unitFactor, me.pageStatusLst[actualPage - 1], segIdx, 1, pi, $CURRENT_RPT));
|
|
|
+ tabRstLst.push(JpcDiscreteHelper.outputDiscreteInfo(rptTpl[FLOW_NODE_STR][JV.NODE_DISCRETE_INFO], bands, dataObj, unitFactor, me.pageStatusLst[actualPage - 1], segIdx, 1, pi, $CURRENT_RPT));
|
|
|
}
|
|
|
}
|
|
|
for (let i = 0; i < tabRstLst.length; i++) {
|
|
@@ -137,13 +146,14 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
};
|
|
|
JpcFlowTabResult.outputContent = function(rptTpl, dataObj, page, bands, unitFactor, controls, multiColIdx, $CURRENT_RPT) {
|
|
|
let me = this, rst = [];
|
|
|
- let tab = rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_CONTENT];
|
|
|
+ let FLOW_NODE_STR = me.isEx?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
+ let tab = rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_CONTENT];
|
|
|
let band = bands[tab[JV.PROP_BAND_NAME]];
|
|
|
if (band) {
|
|
|
let pageStatus = me.pageStatusLst[page - 1];
|
|
|
if (pageStatus[band[JV.BAND_PROP_DISPLAY_TYPE]] == true) {
|
|
|
let tab_fields = tab[JV.PROP_FLOW_FIELDS];
|
|
|
- let data_details = dataObj[JV.DATA_DETAIL_DATA];
|
|
|
+ let data_details = me.isEx?dataObj[JV.DATA_DETAIL_DATA_EX]:dataObj[JV.DATA_DETAIL_DATA];
|
|
|
let contentValuesIdx = me.dispValueIdxLst[page - 1];
|
|
|
for (let i = 0; i < tab_fields.length; i++) {
|
|
|
let tab_field = tab_fields[i];
|
|
@@ -168,7 +178,8 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
};
|
|
|
JpcFlowTabResult.outputColumn = function (rptTpl, dataObj, page, segIdx, bands, unitFactor, controls, multiColIdx) {
|
|
|
let me = this, rst = [];
|
|
|
- let tab = rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_COLUMN];
|
|
|
+ let FLOW_NODE_STR = me.isEx?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
+ let tab = rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_COLUMN];
|
|
|
let band = bands[tab[JV.PROP_BAND_NAME]];
|
|
|
if (band) {
|
|
|
let pageStatus = me.pageStatusLst[page - 1];
|
|
@@ -190,7 +201,8 @@ JpcFlowTabSrv.prototype.createNew = function(){
|
|
|
};
|
|
|
JpcFlowTabResult.outputSegSum = function (rptTpl, dataObj, page, segIdx, bands, unitFactor, controls) {
|
|
|
let me = this, rst = [];
|
|
|
- let tab = rptTpl[JV.NODE_FLOW_INFO][JV.NODE_FLOW_SEG_SUM];
|
|
|
+ let FLOW_NODE_STR = me.isEx?JV.NODE_FLOW_INFO_EX:JV.NODE_FLOW_INFO;
|
|
|
+ let tab = rptTpl[FLOW_NODE_STR][JV.NODE_FLOW_SEG_SUM];
|
|
|
let band = bands[tab[JV.PROP_BAND_NAME]];
|
|
|
if (band) {
|
|
|
let pageStatus = me.pageStatusLst[page - 1];
|