@resolveio/server-lib 20.5.14 → 20.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/collections/monitor-function.collection.d.ts +3 -0
  2. package/collections/monitor-function.collection.js +2 -0
  3. package/collections/monitor-function.collection.js.map +1 -0
  4. package/http/auth.js +1 -1
  5. package/http/auth.js.map +1 -1
  6. package/managers/local-log.manager.d.ts +1 -1
  7. package/managers/local-log.manager.js.map +1 -1
  8. package/managers/method.manager.d.ts +2 -4
  9. package/managers/method.manager.js +1 -1
  10. package/managers/method.manager.js.map +1 -1
  11. package/managers/mongo.manager.js +1 -1
  12. package/managers/mongo.manager.js.map +1 -1
  13. package/managers/monitor.manager.d.ts +7 -6
  14. package/managers/monitor.manager.js +1 -1
  15. package/managers/monitor.manager.js.map +1 -1
  16. package/managers/subscription.manager.js +1 -1
  17. package/managers/subscription.manager.js.map +1 -1
  18. package/methods/aws.js +1 -1
  19. package/methods/aws.js.map +1 -1
  20. package/methods/cron-jobs.js +1 -1
  21. package/methods/cron-jobs.js.map +1 -1
  22. package/methods/logs.js +1 -1
  23. package/methods/logs.js.map +1 -1
  24. package/methods/pdf.js +1 -1
  25. package/methods/pdf.js.map +1 -1
  26. package/methods.ts +0 -3
  27. package/models/log.model.d.ts +1 -1
  28. package/models/monitor-function.model.d.ts +14 -0
  29. package/models/{worker-task-request.model.js → monitor-function.model.js} +1 -1
  30. package/models/monitor-function.model.js.map +1 -0
  31. package/package.json +1 -1
  32. package/server-app.d.ts +33 -2
  33. package/server-app.js +1 -1
  34. package/server-app.js.map +1 -1
  35. package/collections/worker-task-request.collection.d.ts +0 -3
  36. package/collections/worker-task-request.collection.js +0 -2
  37. package/collections/worker-task-request.collection.js.map +0 -1
  38. package/collections/worker-task-response.collection.d.ts +0 -3
  39. package/collections/worker-task-response.collection.js +0 -2
  40. package/collections/worker-task-response.collection.js.map +0 -1
  41. package/models/worker-task-request.model.d.ts +0 -10
  42. package/models/worker-task-request.model.js.map +0 -1
  43. package/models/worker-task-response.model.d.ts +0 -9
  44. package/models/worker-task-response.model.js +0 -2
  45. package/models/worker-task-response.model.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/methods/cron-jobs.ts"],"names":["report_builder_report_collection_1","require","simpl_schema_1","common_1","moment","XLSX","Excel","file_collection_1","cron_job_collection_1","loadCronJobMethods","methodManager","methods","cronEmailMergedDocsCleanUp","function","_this","this","Promise","resolve","reject","__awaiter","Files","find","$and","type","createdAt","$lte","subtract","toDate","files","_a","sent","length","callMethodInternal","deleteMany","_id","$in","map","a","stuckCronJob","fiveMin","CronJobs","running","updatedAt","cronJobs","updateMany","$set","reportbuilderCronJob","check","default","data","Object","blackbox","ReportBuilderReports","findById","report","fields_selected","forEach","field","fieldData","fieldPath","replace","split","fieldPathObj","i","_b","groups_row","fieldsObj_1","count_1","collection_name","collection_root","mergeDeep","sortIndex","fields_sort","findIndex","sortObj_1","sortField","startsWith","order","rootOptions_1","limit","skip","fields","sort","filters_1","fields_filter","filterAnd","ors","filter","includes","endDate","and","and_1","or_1","condition","value","Array","isArray","fieldType","is_rolling","startDate","rolling_interval","startOf","quarter","endOf","Date","setHours","setMinutes","setSeconds","setMilliseconds","push","$gte","_c","_d","highValue","_e","$exists","_f","$ne","_g","_h","$eq","filt","$or","_j","_k","errCollTree","collectionTree","allLeaves_1","filterArrayFields_1","filterArrays_1","layers","getTreeLeaves","children","and_2","or_2","filterLeaf","fields_custom","fields_total","fields_link","id_date_field","date_interval","group_type","err","res","results_1","results","reportTotals","totals","show","leafValueType","leafFormatType","id","undefined","result","format","getTime","round","toLocaleString","style","currency","lines_1","wb","group","columnName","header","utils","book_new","ws","tmp","join","treeItem","parseFloat","json_to_sheet","wbout_1","book_append_sheet","write","bookType","email","sendEmail","serverConfig","report_name","filename","content","encoding","modifyDataTypeField","ws_1","Workbook","addWorksheet","views","showGridLines","currentRow_1","properties","date1904","calcProperties","fullCalcOnLoad","row","getRow","copy","getCell","font","name","bold","size","deepCopy","widths_1","tabGroupExcelRecursive","tabGroupExcelWidthRecursive","columns","width","now_1","xlsx","writeBuffer","then","buffer","getFullYear","getMonth","getDate","catch","console","log","datedUniqueDates_1","datedUniqueGroups_1","datedData_1","reportTotalGroups_1","reportTotalDates_1","dataPt","month","tmpData_1","JSON","stringify","keys","key","splice","tmpResults","day","week","year","tmpGroup","tmpDate","date","tz","hour","minute","second","process","env","TZ_CLIENT","dateString","dateLast","toString","concat","b","tmpData","tmpTotalDated","tmpTotalCnt","tmpTotalType","match","totalKey","tmpTotalGroup","filteredData","total","reduce","currentRow","currentCol_1","row_1","toTitleCase","j","groupRow","k","items","resArray","allowLookups","item","isLeaf","lookup_collection","index","processFieldValue","array","groupKey","subResult","level","fill","fgColor","argb","fill_color","pattern","color","font_color","mergeCells","$col$row","border","top","left","right","fieldIndex","numFmt","bottom","tDataRes","tIndex","resIndex","RegExp","cols","Math","max","exports"],"mappings":"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","file":"cron-jobs.js","sourcesContent":["import { MethodManager } from '../managers/method.manager';\nimport { ReportBuilderReports } from '../collections/report-builder-report.collection';\nimport SimpleSchema from 'simpl-schema';\nimport { mergeDeep, deepCopy, toTitleCase, round } from '../util/common';\nimport { PaginationOptions } from '../models/pagination.model';\nimport * as moment from 'moment-timezone';\nimport * as XLSX from 'xlsx';\nimport * as Excel from 'exceljs';\nimport { Files } from '../collections/file.collection';\nimport { CronJobs } from '../collections/cron-job.collection';\n\nexport function loadCronJobMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tcronEmailMergedDocsCleanUp: {\n\t\t\tfunction: function() {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet files = await Files.find({$and: [{type: 'Email Merged Docs'}, {createdAt: {$lte: moment().subtract(1, 'day').toDate()}}]});\n\t\t\t\t\t\n\t\t\t\t\tif (files.length) {\n\t\t\t\t\t\tthis.callMethodInternal('deleteFiles');\n\t\t\t\t\t\tFiles.deleteMany({_id: {$in: files.map(a => a._id)}});\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(true);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tstuckCronJob: {\n\t\t\tfunction: function() {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet fiveMin = moment().subtract(5, 'minutes').toDate();\n\t\t\t\t\tlet cronJobs = await CronJobs.find({running: true, updatedAt: {$lte: fiveMin}});\n\n\t\t\t\t\tif (cronJobs.length) {\n\t\t\t\t\t\tCronJobs.updateMany({_id: {$in: cronJobs.map(a => a._id)}}, {$set: {running: false}});\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(true);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportbuilderCronJob: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tdata: {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(data: Object) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet report = await ReportBuilderReports.findById(data['id_report']);\n\n\t\t\t\t\treport.fields_selected.forEach((field: any) => {\n\t\t\t\t\t\tlet dotPath = field.fieldPath.replace(/\\.\\$/g, '');\n\t\t\t\t\t\tlet fieldData = dotPath.split('.');\n\t\t\t\t\t\tfield.fieldPathObj = null;\n\t\t\t\t\t\tfor (let i = fieldData.length - 1; i >= 0; i--) {\n\t\t\t\t\t\t\tif (!field.fieldPathObj) {\n\t\t\t\t\t\t\t\tfield.fieldPathObj = {[fieldData[i]]: 1};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tfield.fieldPathObj = {[fieldData[i]]: field.fieldPathObj};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\n\t\t\t\t\tif ((report.fields_selected && report.fields_selected.length) || (report.groups_row && report.groups_row.length)) {\n\t\t\t\t\t\tlet fieldsObj = {};\n\n\t\t\t\t\t\tlet count = 0;\n\n\t\t\t\t\t\treport.fields_selected.forEach((field: any) => {\n\t\t\t\t\t\t\tif (field.collection_name === report.collection_root) {\n\t\t\t\t\t\t\t\tfieldsObj = mergeDeep(fieldsObj, field.fieldPathObj);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tlet sortIndex = report.fields_sort.findIndex(a => a.field === field['id']);\n\n\t\t\t\t\t\t\tif (sortIndex >= 0) {\n\t\t\t\t\t\t\t\treport.fields_sort[sortIndex].field = ('f_' + count);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tfield['id'] = 'f_' + count;\n\n\t\t\t\t\t\t\tcount += 1;\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tlet sortObj = {};\n\t\t\t\t\t\tif (report.fields_sort.length) {\n\t\t\t\t\t\t\treport.fields_sort.forEach(sortField => {\n\t\t\t\t\t\t\t\tif (sortField.field.startsWith('gr_')) {\n\t\t\t\t\t\t\t\t\tsortObj['_id.' + sortField.field] = (sortField.order === 'asc' ? 1 : -1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\tsortObj[sortField.field] = (sortField.order === 'asc' ? 1 : -1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tsortObj = null;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet rootOptions: PaginationOptions = {\n\t\t\t\t\t\t\tlimit: 0,\n\t\t\t\t\t\t\tskip: 0,\n\t\t\t\t\t\t\tfields: fieldsObj,\n\t\t\t\t\t\t\tsort: sortObj\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tlet filters = [];\n\t\t\t\t\t\treport.fields_filter.forEach(filterAnd => {\n\t\t\t\t\t\t\tlet ors = [];\n\t\t\t\t\t\t\tfilterAnd.ors.filter(a => !a.field.includes('.$.')).forEach(filter => {\n\t\t\t\t\t\t\t\tif (filter.condition && filter.field && ((filter.value !== null && (!Array.isArray(filter.value) || filter.value.length)) || filter.condition === 'null' || filter.condition === 'nnull')) {\n\t\t\t\t\t\t\t\t\tif (filter.condition === 'bw') {\n\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'Date' && filter.is_rolling) {\n\t\t\t\t\t\t\t\t\t\t\tlet startDate = null;\n\t\t\t\t\t\t\t\t\t\t\tlet endDate = null;\n\n\t\t\t\t\t\t\t\t\t\t\tif (filter.rolling_interval === 'Q1') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(2).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q2') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(2).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(3).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q3') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(3).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(4).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q4') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(4).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Today') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Yesterday') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(1, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Week') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Week') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('isoWeek').subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Month') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Month') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('month').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last 30 Days') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(30, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(moment().quarter()).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(moment().quarter()).subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('quarter').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Year') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Year') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'All') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = new Date(2017, 0, 1, 0, 0, 0, 0);\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\tendDate.setHours(23);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setMinutes(59);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setSeconds(59);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setMilliseconds(999);\n\n\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field]: {'$gte': startDate}}, {[filter.field]: {'$lte': endDate}}]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field]: {'$gte': filter.value}}, {[filter.field]: {'$lte': filter.highValue}}]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (filter.condition === 'nnull') {\n\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$exists': true}});\n\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$ne': null}});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$ne': ''}});\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (filter.condition === 'null') {\n\t\t\t\t\t\t\t\t\t\tors.push({[filter.field]: {'$eq': null}});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\tif (Array.isArray(filter.value)) {\n\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'ne') {\n\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (and.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(and[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\tlet or = [];\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tor.push({[filter.field]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tif (or.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$or: or});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(or[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field]: {['$' + filter.condition]: filter.value}});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (ors.length) {\n\t\t\t\t\t\t\t\tfilters.push({$or: ors});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tthis.callMethodInternal('reportBuilderBuildTree', report.collection_root, (errCollTree, collectionTree) => {\n\t\t\t\t\t\t\tif (collectionTree) {\n\t\t\t\t\t\t\t\tcollectionTree.layers = [collectionTree];\n\t\t\t\t\n\t\t\t\t\t\t\t\tlet treeLeaves = [];\n\t\t\t\t\t\t\t\tlet allLeaves = [];\n\t\t\t\t\t\t\t\tgetTreeLeaves(collectionTree.children, treeLeaves);\n\t\t\t\t\t\t\t\tgetTreeLeaves(collectionTree.children, allLeaves, true);\n\n\t\t\t\t\t\t\t\tlet filterArrayFields = [];\n\t\t\t\t\t\t\t\tlet filterArrays = [];\n\t\t\t\t\t\t\t\treport.fields_filter.forEach(filterAnd => {\n\t\t\t\t\t\t\t\t\tlet ors = [];\n\t\t\t\t\t\t\t\t\tfilterAnd.ors.filter(a => a.field.includes('.$.')).forEach(filter => {\n\t\t\t\t\t\t\t\t\t\tlet filterLeaf = allLeaves.find(a => a.fieldPath === filter.field);\n\t\t\t\t\t\t\t\t\t\tif (filterLeaf) {\n\t\t\t\t\t\t\t\t\t\t\tfilterArrayFields.push(filterLeaf);\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (filter.condition && filter.field && ((filter.value !== null && (!Array.isArray(filter.value) || filter.value.length)) || filter.condition === 'null' || filter.condition === 'nnull')) {\n\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'bw') {\n\t\t\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'Date' && filter.is_rolling) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet startDate = null;\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet endDate = null;\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (filter.rolling_interval === 'Q1') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(2).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q2') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(2).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(3).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q3') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(3).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(4).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q4') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(4).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Today') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Yesterday') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(1, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Week') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Week') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('isoWeek').subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Month') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Month') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('month').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last 30 Days') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(30, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(moment().quarter()).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(moment().quarter()).subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('quarter').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Year') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Year') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'All') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = new Date(2017, 0, 1, 0, 0, 0, 0);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setHours(23);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setMinutes(59);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setSeconds(59);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setMilliseconds(999);\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field.replace(/\\.\\$/g, '')]: {'$gte': startDate}}, {[filter.field.replace(/\\.\\$/g, '')]: {'$lte': endDate}}]});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tfilterArrays.push({$and: [{[filter.field.replace(/\\.\\$/g, '')]: {'$gte': filter.value}}, {[filter.field.replace(/\\.\\$/g, '')]: {'$lte': filter.highValue}}]});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.condition === 'nnull') {\n\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$exists': true}});\n\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$ne': null}});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$ne': ''}});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.condition === 'null') {\n\t\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field.replace(/\\.\\$/g, '')]: {'$eq': null}});\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(filter.value)) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'ne') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (and.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(and[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet or = [];\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tor.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (or.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$or: or});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(or[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: filter.value}});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tif (ors.length) {\n\t\t\t\t\t\t\t\t\t\tfilterArrays.push({$or: ors});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\tthis.callMethodInternal('reportBuilderGetResults', report.type, report.collection_root, rootOptions, filters, filterArrays, filterArrayFields, report.fields_selected, report.fields_custom, report.groups_row, report.fields_total, report.fields_link, report.id_date_field || null, report.date_interval || null, report.group_type, (err, res) => {\n\t\t\t\t\t\t\t\t\tif (res && res[0]) {\n\t\t\t\t\t\t\t\t\t\tlet results = res[0].results;\n\t\t\t\t\t\t\t\t\t\tlet reportTotals = res[0].totals;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tif (report.type === 'List') {\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tif ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined ).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id].toLocaleString();\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id].toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'Currency') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = round(result[field.id], 2).toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && (!field.leafFormatType || field.leafFormatType === 'Boolean')) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 'True' : 'False';\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && field.leafFormatType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 'Yes' : 'No';\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && field.leafFormatType === 'Boolean_Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 1 : 0;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && (field.leafFormatType === 'Date')) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('L');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Time') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LT');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'DateTime') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('MM/DD/YYYY h:mm A');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Date_long') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LL');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'DateTime_long') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LLL');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Timestamp') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).toDate().getTime();\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet lines: any = [];\n\n\t\t\t\t\t\t\t\t\t\t\tlet tmpHeaders = {};\n\n\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\ttmpHeaders[group.id] = group.columnName;\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(header => {\n\t\t\t\t\t\t\t\t\t\t\t\ttmpHeaders[header.columnName] = header.columnName;\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet wb = XLSX.utils.book_new();\n\n\t\t\t\t\t\t\t\t\t\t\tresults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmp = {};\n\t\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(result._id[group.id])) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id].join(',');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (group.treeItem.fieldType === 'Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id] ? (typeof(result._id[group.id]) === 'string' ? parseFloat(result._id[group.id].replace(/,/g, '').replace(/\\$/g, '')) : result._id[group.id]) : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(header => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(result[header.id])) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id].join(',');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (header.fieldType === 'Number' || header.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id] ? (typeof(result[header.id]) === 'string' ? parseFloat(result[header.id].replace(/,/g, '').replace(/\\$/g, '')) : result[header.id]) : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tlines.push(tmp);\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet ws = XLSX.utils.json_to_sheet(lines);\n\t\t\t\t\t\t\t\t\t\t\tXLSX.utils.book_append_sheet(wb, ws, 'RB Data');\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tlet wbout = XLSX.write(wb, {bookType: 'xlsx', type: 'base64'});\n\n\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(email,\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>` + this.serverConfig['CLIENT_NAME'] + ` Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>` + report.report_name + `<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>` + data['user'] + `<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: report.report_name + '-' + moment().format('MM-DD-YYYY-hh-mm-A') + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: wbout,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tencoding: 'base64'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse if (report.type === 'Group') {\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tresults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tmodifyDataTypeField(report, result, field, 1);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet wb = new Excel.Workbook();\n\t\t\t\t\t\t\t\t\t\t\tlet ws = wb.addWorksheet('RB_1', {views: [{showGridLines: false}]});\n\t\t\t\t\t\t\t\t\t\t\twb.properties.date1904 = false;\n\t\t\t\t\t\t\t\t\t\t\twb.calcProperties.fullCalcOnLoad = true;\n\n\t\t\t\t\t\t\t\t\t\t\tlet currentRow = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet row = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Report Name:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = report.report_name;\n\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Run Date:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = moment().format('LLL');\n\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 2;\n\n\t\t\t\t\t\t\t\t\t\t\tlet copy = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\tlet widths = [];\n\t\t\t\t\t\t\t\t\t\t\tcopy.forEach(res => {\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow = tabGroupExcelRecursive(report, ws, currentRow, 1, res);\n\t\t\t\t\t\t\t\t\t\t\t\ttabGroupExcelWidthRecursive(report, 1, res, widths);\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tfor (let i = 1; i < ws.columns.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\tws.columns[i].width = widths[i - 1];\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\tlet now = new Date();\n\n\t\t\t\t\t\t\t\t\t\t\twb.xlsx.writeBuffer().then(buffer => {\n\t\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(email,\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>` + this.serverConfig['CLIENT_NAME'] + ` Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>` + report.report_name + `<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>` + data['user'] + `<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tHave a great day!<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: 'Group_Report_' + report.report_name + '_' + now.getFullYear() + '_' + (now.getMonth() + 1) + '_' + now.getDate() + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: buffer\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t}).catch(err => console.log('Error writing excel export', err));\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse if (report.type === 'Dated') {\n\t\t\t\t\t\t\t\t\t\t\tlet datedUniqueDates = [];\n\t\t\t\t\t\t\t\t\t\t\tlet datedUniqueGroups = [];\n\t\t\t\t\t\t\t\t\t\t\tlet datedData = [];\n\t\t\t\t\t\t\t\t\t\t\tlet reportTotalGroups = [];\n\t\t\t\t\t\t\t\t\t\t\tlet reportTotalDates = [];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 1: Handle quarterly dates if applicable\n\t\t\t\t\t\t\t\t\t\t\tif (report.date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\t\t\tresults.forEach(dataPt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (dataPt._id.month < 4) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (dataPt._id.month < 7) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 2;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (dataPt._id.month < 10) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 3;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 4;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tdelete dataPt._id.month;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Deduplicate quarterly data\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let i = results.length - 1; i >= 1; i--) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet dataPt = results[i];\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (results.filter(a => JSON.stringify(a._id) === JSON.stringify(dataPt._id)).length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet tmpData = results.find(a => JSON.stringify(a._id) === JSON.stringify(dataPt._id));\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(tmpData)\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.filter(a => a !== '_id')\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData[key] += dataPt[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresults.splice(i, 1); // Remove the duplicate entry\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t// Step 2: Prepare unique groups\n\t\t\t\t\t\t\t\t\t\t\tlet tmpResults = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\ttmpResults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.day;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.week;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.month;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.quarter;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.year;\n\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpGroup = {};\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpGroup[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (!datedUniqueGroups.find(a => JSON.stringify(a) === JSON.stringify(tmpGroup))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.push(tmpGroup);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t// Step 3: Prepare unique dates\n\t\t\t\t\t\t\t\t\t\t\ttmpResults = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\ttmpResults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id)\n\t\t\t\t\t\t\t\t\t\t\t\t\t.filter(a => a !== 'second' && a !== 'hour' && a !== 'minute' && a !== 'day' && a !== 'week' && a !== 'month' && a !== 'quarter' && a !== 'year')\n\t\t\t\t\t\t\t\t\t\t\t\t\t.forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpDate = {};\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpDate[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (!datedUniqueDates.find(a => JSON.stringify(a) === JSON.stringify(tmpDate))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.push(tmpDate);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t// Build the date strings\n\t\t\t\t\t\t\t\t\t\t\t// Ensure moment is using America/Chicago timezone for all date processing\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tif (!result.year) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'No Date';\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.date_interval === 'Seconds') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1, // Use `month - 1` since months are zero-indexed in moment as well\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tminute: result.minute,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsecond: result.second\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH:mm:ss');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Minutes') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tminute: result.minute\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH:mm');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Hours') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Daily') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Weekly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tweek: result.week\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).day('Monday').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateLast = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tweek: result.week\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).day('Sunday').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'Week #' + result.week + ' ' + result.year + ' (' + moment(result.date).format('MM/DD/YY') + ' - ' + moment(result.dateLast).format('MM/DD/YY') + ')';\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Monthly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1, // Months are zero-indexed in moment\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM YYYY');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).quarter(result.quarter).toDate();;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'Q' + result.quarter + ' ' + result.year;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Yearly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = result.year.toString();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates = datedUniqueDates.filter(a => !a.date)\n\t\t\t\t\t\t\t\t\t\t\t\t.concat(datedUniqueDates.filter(a => a.date).sort((a, b) => a.date.getTime() - b.date.getTime()));\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 4: Build datedData and reportTotalGroups\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(date => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpData = [];\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalDated = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalCnt = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalType = {};\n\n\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet result = results.find(a => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet match = true;\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Match the group fields\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(group).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== group[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Match the date fields\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(date).filter(key => key !== 'date' && key !== 'dateLast' && key !== 'dateString').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== date[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\treturn match;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (result) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData.push(result);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).filter(a => a).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.fields_total.filter(a => a.fields.includes(key)).length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalDated[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] += result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalCnt[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalType[key] = report.fields_total.find(a => a.fields.includes(key)).type;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result).filter(a => a && a !== '_id').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.fields_total.filter(a => a.fields.includes(key)).length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalDated[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] = result[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] += result[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalCnt[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalType[key] = report.fields_total.find(a => a.fields.includes(key)).type;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData.push(null);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Handle averaging for totals\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(tmpTotalType).forEach(totalKey => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (tmpTotalType[totalKey] === 'avg') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[totalKey] = tmpTotalDated[totalKey] / tmpTotalCnt[totalKey];\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[totalKey] = round(tmpTotalDated[totalKey], 2);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\treportTotalDates.push(tmpTotalDated);\n\t\t\t\t\t\t\t\t\t\t\t\tdatedData.push(tmpData);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Calculate group-level totals\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalGroup = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet filteredData = results.filter(a => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet match = (!Object.keys(group).length || group._id === null) ? false : true;\n\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(group).filter(a => a !== 'date' && a !== 'dateLast' && a !== 'dateString' && a !== 'second' && a !== 'minute' && a !== 'hour' && a !== 'day' && a !== 'week' && a !== 'month' && a !== 'quarter' && a !== 'year').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== group[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn match;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\treport.fields_total.forEach(total => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttotal.fields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (filteredData.length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = filteredData.filter(a => a && a[field])\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.map(a => a[field])\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (total.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = round(tmpTotalGroup[field] / filteredData.length, 2);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = 0;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\treportTotalGroups.push(tmpTotalGroup);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 5: Proceed with Excel generation using datedData and reportTotalGroups\n\t\t\t\t\t\t\t\t\t\t\tlet wb = new Excel.Workbook();\n\t\t\t\t\t\t\t\t\t\t\tlet ws = wb.addWorksheet('Dated_Report', {views: [{showGridLines: true}]});\n\t\t\t\t\t\t\t\t\t\t\twb.properties.date1904 = false;\n\t\t\t\t\t\t\t\t\t\t\twb.calcProperties.fullCalcOnLoad = true;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tlet currentRow = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet currentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet row = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Report Name:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = report.report_name;\n\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Run Date:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = moment().format('LLL');\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 2;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add group column headers\n\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = group.columnName;\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add field headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add the date interval headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(date => {\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = date.dateString;\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add totals headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_total.forEach(total => {\n\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = 'Totals - ' + toTitleCase(total.type);\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Populate data for each group and field with date intervals\n\t\t\t\t\t\t\t\t\t\t\tfor (let i = 0; i < datedUniqueGroups.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\tlet group = datedUniqueGroups[i];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let j = 0; j < report.fields_selected.filter(a => a.show).length; j++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet field = report.fields_selected.filter(a => a.show)[j];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate group data\n\t\t\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(groupRow => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = (j === 0) ? group[groupRow.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate field data\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = field.columnName;\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate date interval data for each field\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let k = 0; k < datedUniqueDates.length; k++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet result = datedData[k];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (result[i]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = result[i][field.id] ? result[i][field.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Add totals for each field in the report\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let k = 0; k < report.fields_total.length; k++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet total = report.fields_total[k];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = reportTotalGroups[i][field.id] ? reportTotalGroups[i][field.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow++; // Move to the next row for the next field\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add report totals at the bottom\n\t\t\t\t\t\t\t\t\t\t\tif (reportTotals) {\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let i = 0; i < report.fields_total.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet total = report.fields_total[i];\n\t\t\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = toTitleCase(total.type) + ' Totals';\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol += report.groups_row.length; // Skip group columns\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Skip the date columns for the totals row\n\t\t\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Set totals in the correct fields\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let j = 0; j < report.fields_selected.filter(a => a.show).length; j++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet field = report.fields_selected.filter(a => a.show)[j];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = reportTotals[total.id + '_' + field.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow++; // Move to the next row for the next total\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Save the Excel file and send it via email\n\t\t\t\t\t\t\t\t\t\t\twb.xlsx.writeBuffer().then(buffer => {\n\t\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\temail,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>${this.serverConfig['CLIENT_NAME']} Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>${report.report_name}<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>${data['user']}<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: report.report_name + '-' + moment().format('MM-DD-YYYY-hh-mm-A') + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: buffer\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t}).catch(err => console.log('Error writing excel export', err));\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse {\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tthis.callMethodInternal('insertErrorLog', 'Report Builder Cron Job - Report Builder Get Results', [\n\t\t\t\t\t\t\t\t\t\t\terr\n\t\t\t\t\t\t\t\t\t\t]);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\treject(err);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction getTreeLeaves(items, resArray, allowLookups = false) {\n\titems.forEach(item => {\n\t\tif (item.isLeaf) {\n\t\t\tresArray.push(item);\n\t\t}\n\t\telse {\n\t\t\tif (!item.lookup_collection || allowLookups) {\n\t\t\t\tgetTreeLeaves(item.children, resArray, allowLookups);\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction modifyDataTypeField(report, result, field, index) {\n\tconst processFieldValue = (value, field) => {\n\t\tif (value === undefined || value === null) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (field.fieldType === 'Boolean') {\n\t\t\tif (!field.leafFormatType || field.leafFormatType === 'Boolean') {\n\t\t\t\treturn value === true ? 'True' : 'False';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'String') {\n\t\t\t\treturn value === true ? 'Yes' : 'No';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Boolean_Number') {\n\t\t\t\treturn value === true ? 1 : 0;\n\t\t\t}\n\t\t}\n\t\telse if (field.fieldType === 'Number' || field.leafValueType === 'Count') {\n\t\t\tif (field.leafFormatType === 'Number') {\n\t\t\t\treturn value.toLocaleString();\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'String') {\n\t\t\t\treturn value.toString();\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Currency') {\n\t\t\t\treturn round(value, 2).toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t}\n\t\t}\n\t\telse if (field.fieldType === 'Date') {\n\t\t\tswitch (field.leafFormatType) {\n\t\t\t\tcase 'Date':\n\t\t\t\t\treturn moment(value).format('L');\n\t\t\t\tcase 'Time':\n\t\t\t\t\treturn moment(value).format('LT');\n\t\t\t\tcase 'DateTime':\n\t\t\t\t\treturn moment(value).format('MM/DD/YYYY h:mm A');\n\t\t\t\tcase 'Date_long':\n\t\t\t\t\treturn moment(value).format('LL');\n\t\t\t\tcase 'DateTime_long':\n\t\t\t\t\treturn moment(value).format('LLL');\n\t\t\t\tcase 'Timestamp':\n\t\t\t\t\treturn moment(value).toDate().getTime();\n\t\t\t\tdefault:\n\t\t\t\t\treturn value;\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t};\n\n\tconst processArrayField = (array, field) => {\n\t\treturn array.map(value => processFieldValue(value, field));\n\t};\n\n\tif (index < report.groups_row.length) {\n\t\t// Handle grouped data\n\t\tconst groupKey = 'gr_' + (index + 1);\n\t\tif (result[groupKey]) {\n\t\t\tresult[groupKey].forEach(subResult => {\n\t\t\t\tmodifyDataTypeField(report, subResult, field, index + 1);\n\t\t\t});\n\t\t}\n\t}\n\telse {\n\t\t// Process final-level fields\n\t\tif (Array.isArray(result[field.id])) {\n\t\t\tresult[field.id] = processArrayField(result[field.id], field);\n\t\t}\n\t\telse {\n\t\t\tresult[field.id] = processFieldValue(result[field.id], field);\n\t\t}\n\t}\n}\n\nfunction tabGroupExcelRecursive(report, ws: Excel.Worksheet, currentRow, level, result) {\n\tlet row = ws.getRow(currentRow);\n\n\tif (level < report.groups_row.length) {\n\t\trow.getCell(2).fill = {\n\t\t\tfgColor: {argb: report.groups_row[level - 1].fill_color ? report.groups_row[level - 1].fill_color.replace('#', '') : 'ffffff'},\n\t\t\ttype: 'pattern',\n\t\t\tpattern: 'solid'\n\t\t};\n\t\trow.getCell(2).font = {\n\t\t\tcolor: {argb: report.groups_row[level - 1].font_color ? report.groups_row[level - 1].font_color.replace('#', '') : '000000'},\n\t\t\tname: 'Arial',\n\t\t\tbold: true,\n\t\t\tsize: 14\n\t\t};\n\n\t\trow.getCell(2).value = report.groups_row[level - 1].columnName + ': ' + result._id['gr_' + level];\n\t\tws.mergeCells(row.getCell(2).$col$row + ':' + row.getCell(report.fields_selected.filter(a => a.show).length + 1).$col$row);\n\t\t\n\t\trow.getCell(2).border = {\n\t\t\ttop: {style:'thick'},\n\t\t\tleft: {style:'thick'},\n\t\t\tright: {style: 'thick'}\n\t\t};\n\n\t\tif (report.fields_total.length) {\n\t\t\treport.fields_total.forEach(total => {\n\t\t\t\tcurrentRow += 1;\n\t\t\t\trow = ws.getRow(currentRow);\n\n\t\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).value = field.columnName;\n\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\tsize: 10\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\n\t\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t\t\n\t\t// Totals\n\t\treport.fields_total.forEach(total => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[total.id + '_' + field.id];\n\n\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\tsize: 10\n\t\t\t\t\t};\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tleft: {style:'thick'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'},\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\t\n\t\tcurrentRow += 1;\n\n\t\tresult = result['gr_' + (level + 1)];\n\t\tresult.forEach((tDataRes, tIndex) => {\n\t\t\tcurrentRow = tabGroupExcelRecursive(report, ws, currentRow, level + 1, tDataRes);\n\t\t});\n\t}\n\telse {\n\t\trow.getCell(2).fill = {\n\t\t\tfgColor: {argb: report.groups_row[level - 1].fill_color ? report.groups_row[level - 1].fill_color.replace('#', '') : 'ffffff'},\n\t\t\ttype: 'pattern',\n\t\t\tpattern: 'solid'\n\t\t};\n\t\trow.getCell(2).font = {\n\t\t\tcolor: {argb: report.groups_row[level - 1].font_color ? report.groups_row[level - 1].font_color.replace('#', '') : '000000'},\n\t\t\tname: 'Arial',\n\t\t\tbold: true,\n\t\t\tsize: 12\n\t\t};\n\n\t\trow.getCell(2).value = report.groups_row[level - 1].columnName + ': ' + result._id['gr_' + level];\n\t\tws.mergeCells(row.getCell(2).$col$row + ':' + row.getCell(report.fields_selected.filter(a => a.show).length + 1).$col$row);\n\n\t\trow.getCell(2).border = {\n\t\t\ttop: {style:'thick'},\n\t\t\tleft: {style:'thick'},\n\t\t\tright: {style: 'thick'}\n\t\t};\n\n\t\tcurrentRow += 1;\n\t\trow = ws.getRow(currentRow);\n\t\t// Headers\n\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\trow.getCell(fieldIndex + 2).value = field.columnName;\n\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\tname: 'Arial',\n\t\t\t\tbold: true,\n\t\t\t\tsize: 10\n\t\t\t};\n\n\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t}\n\n\t\t\tif (fieldIndex === 0) {\n\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t};\n\t\t\t}\n\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t};\n\t\t\t}\n\t\t});\n\n\t\t// Data\n\t\tresult['f_0'].forEach((res, resIndex) => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (field.fieldType === 'Number' && typeof(result[field.id][resIndex]) === 'string' && result[field.id][resIndex]) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = parseFloat(result[field.id][resIndex].replace(new RegExp(/\\,/g), '').replace(new RegExp(/\\$/g), ''));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[field.id][resIndex];\n\t\t\t\t}\n\n\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t}\n\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t}\n\n\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\tname: 'Arial',\n\t\t\t\t\tsize: 10\n\t\t\t\t};\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\t\n\t\t// Totals\n\t\treport.fields_total.forEach(total => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[total.id + '_' + field.id];\n\n\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\tsize: 10\n\t\t\t\t\t};\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tleft: {style:'thick'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'},\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\treturn currentRow + 1;\n}\n\nfunction tabGroupExcelWidthRecursive(report, level, result, cols) {\n\tif (level < report.groups_row.length) {\n\t\tresult = result['gr_' + (level + 1)];\n\t\tresult.forEach((tDataRes, tIndex) => {\n\t\t\tcols = tabGroupExcelWidthRecursive(report, level + 1, tDataRes, cols);\n\t\t});\n\t}\n\telse {\n\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\tif (Array.isArray(result[field.id])) {\n\t\t\t\tresult[field.id].forEach(res => {\n\t\t\t\t\tlet length = 10;\n\n\t\t\t\t\tif (res) {\n\t\t\t\t\t\tlength = res.length + 3;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!cols[fieldIndex]) {\n\t\t\t\t\t\tcols[fieldIndex] = Math.max(10, field.columnName.length);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (length > cols[fieldIndex]) {\n\t\t\t\t\t\tcols[fieldIndex] = length;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlet res = result[field.id];\n\n\t\t\t\tif (res) {\n\t\t\t\t\tlength = res.length + 3;\n\t\t\t\t}\n\n\t\t\t\tif (!cols[fieldIndex]) {\n\t\t\t\t\tcols[fieldIndex] = Math.max(10, field.columnName.length);\n\t\t\t\t}\n\n\t\t\t\tif (length > cols[fieldIndex]) {\n\t\t\t\t\tcols[fieldIndex] = length;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\treturn cols;\n}"]}
1
+ {"version":3,"sources":["../../src/methods/cron-jobs.ts"],"names":["report_builder_report_collection_1","require","simpl_schema_1","common_1","moment","XLSX","Excel","file_collection_1","cron_job_collection_1","loadCronJobMethods","methodManager","methods","cronEmailMergedDocsCleanUp","function","_this","this","Promise","resolve","reject","__awaiter","Files","find","$and","type","createdAt","$lte","subtract","toDate","files","_a","sent","length","callMethod","deleteMany","_id","$in","map","a","stuckCronJob","fiveMin","CronJobs","running","updatedAt","cronJobs","updateMany","$set","reportbuilderCronJob","check","default","data","Object","blackbox","ReportBuilderReports","findById","report","fields_selected","forEach","field","fieldData","fieldPath","replace","split","fieldPathObj","i","_b","groups_row","fieldsObj_1","count_1","collection_name","collection_root","mergeDeep","sortIndex","fields_sort","findIndex","sortObj_1","sortField","startsWith","order","rootOptions_1","limit","skip","fields","sort","filters_1","fields_filter","filterAnd","ors","filter","includes","endDate","and","and_1","or_1","condition","value","Array","isArray","fieldType","is_rolling","startDate","rolling_interval","startOf","quarter","endOf","Date","setHours","setMinutes","setSeconds","setMilliseconds","push","$gte","_c","_d","highValue","_e","$exists","_f","$ne","_g","_h","$eq","filt","$or","_j","_k","errCollTree","collectionTree","allLeaves_1","filterArrayFields_1","filterArrays_1","layers","getTreeLeaves","children","and_2","or_2","filterLeaf","fields_custom","fields_total","fields_link","id_date_field","date_interval","group_type","err","res","results_1","results","reportTotals","totals","show","leafValueType","leafFormatType","id","undefined","result","format","getTime","round","toLocaleString","style","currency","lines_1","wb","group","columnName","header","utils","book_new","ws","tmp","join","treeItem","parseFloat","json_to_sheet","wbout_1","book_append_sheet","write","bookType","email","sendEmail","serverConfig","report_name","filename","content","encoding","modifyDataTypeField","ws_1","Workbook","addWorksheet","views","showGridLines","currentRow_1","properties","date1904","calcProperties","fullCalcOnLoad","row","getRow","copy","getCell","font","name","bold","size","deepCopy","widths_1","tabGroupExcelRecursive","tabGroupExcelWidthRecursive","columns","width","now_1","xlsx","writeBuffer","then","buffer","getFullYear","getMonth","getDate","catch","console","log","datedUniqueDates_1","datedUniqueGroups_1","datedData_1","reportTotalGroups_1","reportTotalDates_1","dataPt","month","tmpData_1","JSON","stringify","keys","key","splice","tmpResults","day","week","year","tmpGroup","tmpDate","date","tz","hour","minute","second","process","env","TZ_CLIENT","dateString","dateLast","toString","concat","b","tmpData","tmpTotalDated","tmpTotalCnt","tmpTotalType","match","totalKey","tmpTotalGroup","filteredData","total","reduce","currentRow","currentCol_1","row_1","toTitleCase","j","groupRow","k","items","resArray","allowLookups","item","isLeaf","lookup_collection","index","processFieldValue","array","groupKey","subResult","level","fill","fgColor","argb","fill_color","pattern","color","font_color","mergeCells","$col$row","border","top","left","right","fieldIndex","numFmt","bottom","tDataRes","tIndex","resIndex","RegExp","cols","Math","max","exports"],"mappings":"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","file":"cron-jobs.js","sourcesContent":["import { MethodManager } from '../managers/method.manager';\nimport { ReportBuilderReports } from '../collections/report-builder-report.collection';\nimport SimpleSchema from 'simpl-schema';\nimport { mergeDeep, deepCopy, toTitleCase, round } from '../util/common';\nimport { PaginationOptions } from '../models/pagination.model';\nimport * as moment from 'moment-timezone';\nimport * as XLSX from 'xlsx';\nimport * as Excel from 'exceljs';\nimport { Files } from '../collections/file.collection';\nimport { CronJobs } from '../collections/cron-job.collection';\n\nexport function loadCronJobMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tcronEmailMergedDocsCleanUp: {\n\t\t\tfunction: function() {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet files = await Files.find({$and: [{type: 'Email Merged Docs'}, {createdAt: {$lte: moment().subtract(1, 'day').toDate()}}]});\n\t\t\t\t\t\n\t\t\t\t\tif (files.length) {\n\t\t\t\t\t\tthis.callMethod('deleteFiles');\n\t\t\t\t\t\tFiles.deleteMany({_id: {$in: files.map(a => a._id)}});\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(true);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tstuckCronJob: {\n\t\t\tfunction: function() {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet fiveMin = moment().subtract(5, 'minutes').toDate();\n\t\t\t\t\tlet cronJobs = await CronJobs.find({running: true, updatedAt: {$lte: fiveMin}});\n\n\t\t\t\t\tif (cronJobs.length) {\n\t\t\t\t\t\tCronJobs.updateMany({_id: {$in: cronJobs.map(a => a._id)}}, {$set: {running: false}});\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(true);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportbuilderCronJob: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tdata: {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(data: Object) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet report = await ReportBuilderReports.findById(data['id_report']);\n\n\t\t\t\t\treport.fields_selected.forEach((field: any) => {\n\t\t\t\t\t\tlet dotPath = field.fieldPath.replace(/\\.\\$/g, '');\n\t\t\t\t\t\tlet fieldData = dotPath.split('.');\n\t\t\t\t\t\tfield.fieldPathObj = null;\n\t\t\t\t\t\tfor (let i = fieldData.length - 1; i >= 0; i--) {\n\t\t\t\t\t\t\tif (!field.fieldPathObj) {\n\t\t\t\t\t\t\t\tfield.fieldPathObj = {[fieldData[i]]: 1};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tfield.fieldPathObj = {[fieldData[i]]: field.fieldPathObj};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\n\t\t\t\t\tif ((report.fields_selected && report.fields_selected.length) || (report.groups_row && report.groups_row.length)) {\n\t\t\t\t\t\tlet fieldsObj = {};\n\n\t\t\t\t\t\tlet count = 0;\n\n\t\t\t\t\t\treport.fields_selected.forEach((field: any) => {\n\t\t\t\t\t\t\tif (field.collection_name === report.collection_root) {\n\t\t\t\t\t\t\t\tfieldsObj = mergeDeep(fieldsObj, field.fieldPathObj);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tlet sortIndex = report.fields_sort.findIndex(a => a.field === field['id']);\n\n\t\t\t\t\t\t\tif (sortIndex >= 0) {\n\t\t\t\t\t\t\t\treport.fields_sort[sortIndex].field = ('f_' + count);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tfield['id'] = 'f_' + count;\n\n\t\t\t\t\t\t\tcount += 1;\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tlet sortObj = {};\n\t\t\t\t\t\tif (report.fields_sort.length) {\n\t\t\t\t\t\t\treport.fields_sort.forEach(sortField => {\n\t\t\t\t\t\t\t\tif (sortField.field.startsWith('gr_')) {\n\t\t\t\t\t\t\t\t\tsortObj['_id.' + sortField.field] = (sortField.order === 'asc' ? 1 : -1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\tsortObj[sortField.field] = (sortField.order === 'asc' ? 1 : -1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tsortObj = null;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet rootOptions: PaginationOptions = {\n\t\t\t\t\t\t\tlimit: 0,\n\t\t\t\t\t\t\tskip: 0,\n\t\t\t\t\t\t\tfields: fieldsObj,\n\t\t\t\t\t\t\tsort: sortObj\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tlet filters = [];\n\t\t\t\t\t\treport.fields_filter.forEach(filterAnd => {\n\t\t\t\t\t\t\tlet ors = [];\n\t\t\t\t\t\t\tfilterAnd.ors.filter(a => !a.field.includes('.$.')).forEach(filter => {\n\t\t\t\t\t\t\t\tif (filter.condition && filter.field && ((filter.value !== null && (!Array.isArray(filter.value) || filter.value.length)) || filter.condition === 'null' || filter.condition === 'nnull')) {\n\t\t\t\t\t\t\t\t\tif (filter.condition === 'bw') {\n\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'Date' && filter.is_rolling) {\n\t\t\t\t\t\t\t\t\t\t\tlet startDate = null;\n\t\t\t\t\t\t\t\t\t\t\tlet endDate = null;\n\n\t\t\t\t\t\t\t\t\t\t\tif (filter.rolling_interval === 'Q1') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(2).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q2') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(2).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(3).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q3') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(3).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(4).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q4') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(4).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Today') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Yesterday') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(1, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Week') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Week') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('isoWeek').subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Month') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Month') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('month').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last 30 Days') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(30, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(moment().quarter()).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(moment().quarter()).subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('quarter').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Year') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Year') {\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'All') {\n\t\t\t\t\t\t\t\t\t\t\t\tstartDate = new Date(2017, 0, 1, 0, 0, 0, 0);\n\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\tendDate.setHours(23);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setMinutes(59);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setSeconds(59);\n\t\t\t\t\t\t\t\t\t\t\tendDate.setMilliseconds(999);\n\n\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field]: {'$gte': startDate}}, {[filter.field]: {'$lte': endDate}}]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field]: {'$gte': filter.value}}, {[filter.field]: {'$lte': filter.highValue}}]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (filter.condition === 'nnull') {\n\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$exists': true}});\n\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$ne': null}});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {'$ne': ''}});\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (filter.condition === 'null') {\n\t\t\t\t\t\t\t\t\t\tors.push({[filter.field]: {'$eq': null}});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\tif (Array.isArray(filter.value)) {\n\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'ne') {\n\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (and.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(and[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\tlet or = [];\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tor.push({[filter.field]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tif (or.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$or: or});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(or[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field]: {['$' + filter.condition]: filter.value}});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (ors.length) {\n\t\t\t\t\t\t\t\tfilters.push({$or: ors});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tthis.callMethod('reportBuilderBuildTree', report.collection_root, (errCollTree, collectionTree) => {\n\t\t\t\t\t\t\tif (collectionTree) {\n\t\t\t\t\t\t\t\tcollectionTree.layers = [collectionTree];\n\t\t\t\t\n\t\t\t\t\t\t\t\tlet treeLeaves = [];\n\t\t\t\t\t\t\t\tlet allLeaves = [];\n\t\t\t\t\t\t\t\tgetTreeLeaves(collectionTree.children, treeLeaves);\n\t\t\t\t\t\t\t\tgetTreeLeaves(collectionTree.children, allLeaves, true);\n\n\t\t\t\t\t\t\t\tlet filterArrayFields = [];\n\t\t\t\t\t\t\t\tlet filterArrays = [];\n\t\t\t\t\t\t\t\treport.fields_filter.forEach(filterAnd => {\n\t\t\t\t\t\t\t\t\tlet ors = [];\n\t\t\t\t\t\t\t\t\tfilterAnd.ors.filter(a => a.field.includes('.$.')).forEach(filter => {\n\t\t\t\t\t\t\t\t\t\tlet filterLeaf = allLeaves.find(a => a.fieldPath === filter.field);\n\t\t\t\t\t\t\t\t\t\tif (filterLeaf) {\n\t\t\t\t\t\t\t\t\t\t\tfilterArrayFields.push(filterLeaf);\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (filter.condition && filter.field && ((filter.value !== null && (!Array.isArray(filter.value) || filter.value.length)) || filter.condition === 'null' || filter.condition === 'nnull')) {\n\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'bw') {\n\t\t\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'Date' && filter.is_rolling) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet startDate = null;\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet endDate = null;\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (filter.rolling_interval === 'Q1') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(2).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q2') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(2).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(3).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q3') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(3).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(4).subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Q4') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(4).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Today') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Yesterday') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(1, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Week') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Week') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('isoWeek').subtract(1, 'days').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('isoWeek').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Month') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Month') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('month').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('month').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last 30 Days') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().subtract(30, 'days').startOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').quarter(moment().quarter()).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Quarter') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').quarter(moment().quarter()).subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('quarter').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Year') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment().startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'Last Year') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().startOf('year').subtract(1, 'days').endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = moment(endDate).startOf('year').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (filter.rolling_interval === 'All') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tstartDate = new Date(2017, 0, 1, 0, 0, 0, 0);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tendDate = moment().endOf('day').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setHours(23);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setMinutes(59);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setSeconds(59);\n\t\t\t\t\t\t\t\t\t\t\t\t\tendDate.setMilliseconds(999);\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: [{[filter.field.replace(/\\.\\$/g, '')]: {'$gte': startDate}}, {[filter.field.replace(/\\.\\$/g, '')]: {'$lte': endDate}}]});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tfilterArrays.push({$and: [{[filter.field.replace(/\\.\\$/g, '')]: {'$gte': filter.value}}, {[filter.field.replace(/\\.\\$/g, '')]: {'$lte': filter.highValue}}]});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.condition === 'nnull') {\n\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$exists': true}});\n\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$ne': null}});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tif (filter.fieldType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {'$ne': ''}});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse if (filter.condition === 'null') {\n\t\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field.replace(/\\.\\$/g, '')]: {'$eq': null}});\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(filter.value)) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (filter.condition === 'ne') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet and = [];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tand.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (and.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$and: and});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(and[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet or = [];\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilter.value.forEach(filt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tor.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: (Array.isArray(filt) ? filt[0] : filt)}});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (or.length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({$or: or});\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tors.push(or[0]);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tors.push({[filter.field.replace(/\\.\\$/g, '')]: {['$' + filter.condition]: filter.value}});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tif (ors.length) {\n\t\t\t\t\t\t\t\t\t\tfilterArrays.push({$or: ors});\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\tthis.callMethod('reportBuilderGetResults', report.type, report.collection_root, rootOptions, filters, filterArrays, filterArrayFields, report.fields_selected, report.fields_custom, report.groups_row, report.fields_total, report.fields_link, report.id_date_field || null, report.date_interval || null, report.group_type, (err, res) => {\n\t\t\t\t\t\t\t\t\tif (res && res[0]) {\n\t\t\t\t\t\t\t\t\t\tlet results = res[0].results;\n\t\t\t\t\t\t\t\t\t\tlet reportTotals = res[0].totals;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tif (report.type === 'List') {\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tif ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined ).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id].toLocaleString();\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id].toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if ((field.fieldType === 'Number' || field.leafValueType === 'Count') && field.leafFormatType === 'Currency') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = round(result[field.id], 2).toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && (!field.leafFormatType || field.leafFormatType === 'Boolean')) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 'True' : 'False';\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && field.leafFormatType === 'String') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 'Yes' : 'No';\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Boolean' && field.leafFormatType === 'Boolean_Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = result[field.id] === true ? 1 : 0;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && (field.leafFormatType === 'Date')) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('L');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Time') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LT');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'DateTime') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('MM/DD/YYYY h:mm A');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Date_long') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LL');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'DateTime_long') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).format('LLL');\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse if (field.fieldType === 'Date' && field.leafFormatType === 'Timestamp') {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresults.filter(a => a[field.id] !== null && a[field.id] !== undefined).forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult[field.id] = moment(result[field.id]).toDate().getTime();\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet lines: any = [];\n\n\t\t\t\t\t\t\t\t\t\t\tlet tmpHeaders = {};\n\n\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\ttmpHeaders[group.id] = group.columnName;\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(header => {\n\t\t\t\t\t\t\t\t\t\t\t\ttmpHeaders[header.columnName] = header.columnName;\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet wb = XLSX.utils.book_new();\n\n\t\t\t\t\t\t\t\t\t\t\tresults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmp = {};\n\t\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(result._id[group.id])) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id].join(',');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (group.treeItem.fieldType === 'Number') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id] ? (typeof(result._id[group.id]) === 'string' ? parseFloat(result._id[group.id].replace(/,/g, '').replace(/\\$/g, '')) : result._id[group.id]) : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[group.columnName] = result._id[group.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(header => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Array.isArray(result[header.id])) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id].join(',');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (header.fieldType === 'Number' || header.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id] ? (typeof(result[header.id]) === 'string' ? parseFloat(result[header.id].replace(/,/g, '').replace(/\\$/g, '')) : result[header.id]) : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmp[header.columnName] = result[header.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tlines.push(tmp);\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet ws = XLSX.utils.json_to_sheet(lines);\n\t\t\t\t\t\t\t\t\t\t\tXLSX.utils.book_append_sheet(wb, ws, 'RB Data');\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tlet wbout = XLSX.write(wb, {bookType: 'xlsx', type: 'base64'});\n\n\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(email,\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>` + this.serverConfig['CLIENT_NAME'] + ` Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>` + report.report_name + `<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>` + data['user'] + `<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: report.report_name + '-' + moment().format('MM-DD-YYYY-hh-mm-A') + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: wbout,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tencoding: 'base64'\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse if (report.type === 'Group') {\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tresults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tmodifyDataTypeField(report, result, field, 1);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tlet wb = new Excel.Workbook();\n\t\t\t\t\t\t\t\t\t\t\tlet ws = wb.addWorksheet('RB_1', {views: [{showGridLines: false}]});\n\t\t\t\t\t\t\t\t\t\t\twb.properties.date1904 = false;\n\t\t\t\t\t\t\t\t\t\t\twb.calcProperties.fullCalcOnLoad = true;\n\n\t\t\t\t\t\t\t\t\t\t\tlet currentRow = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet row = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Report Name:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = report.report_name;\n\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Run Date:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = moment().format('LLL');\n\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 2;\n\n\t\t\t\t\t\t\t\t\t\t\tlet copy = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\tlet widths = [];\n\t\t\t\t\t\t\t\t\t\t\tcopy.forEach(res => {\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow = tabGroupExcelRecursive(report, ws, currentRow, 1, res);\n\t\t\t\t\t\t\t\t\t\t\t\ttabGroupExcelWidthRecursive(report, 1, res, widths);\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tfor (let i = 1; i < ws.columns.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\tws.columns[i].width = widths[i - 1];\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\tlet now = new Date();\n\n\t\t\t\t\t\t\t\t\t\t\twb.xlsx.writeBuffer().then(buffer => {\n\t\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(email,\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>` + this.serverConfig['CLIENT_NAME'] + ` Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>` + report.report_name + `<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>` + data['user'] + `<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tHave a great day!<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: 'Group_Report_' + report.report_name + '_' + now.getFullYear() + '_' + (now.getMonth() + 1) + '_' + now.getDate() + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: buffer\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t}).catch(err => console.log('Error writing excel export', err));\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse if (report.type === 'Dated') {\n\t\t\t\t\t\t\t\t\t\t\tlet datedUniqueDates = [];\n\t\t\t\t\t\t\t\t\t\t\tlet datedUniqueGroups = [];\n\t\t\t\t\t\t\t\t\t\t\tlet datedData = [];\n\t\t\t\t\t\t\t\t\t\t\tlet reportTotalGroups = [];\n\t\t\t\t\t\t\t\t\t\t\tlet reportTotalDates = [];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 1: Handle quarterly dates if applicable\n\t\t\t\t\t\t\t\t\t\t\tif (report.date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\t\t\tresults.forEach(dataPt => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (dataPt._id.month < 4) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (dataPt._id.month < 7) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 2;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (dataPt._id.month < 10) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 3;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdataPt._id.quarter = 4;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tdelete dataPt._id.month;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Deduplicate quarterly data\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let i = results.length - 1; i >= 1; i--) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet dataPt = results[i];\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (results.filter(a => JSON.stringify(a._id) === JSON.stringify(dataPt._id)).length > 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet tmpData = results.find(a => JSON.stringify(a._id) === JSON.stringify(dataPt._id));\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(tmpData)\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.filter(a => a !== '_id')\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData[key] += dataPt[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresults.splice(i, 1); // Remove the duplicate entry\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t// Step 2: Prepare unique groups\n\t\t\t\t\t\t\t\t\t\t\tlet tmpResults = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\ttmpResults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.day;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.week;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.month;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.quarter;\n\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id.year;\n\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpGroup = {};\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpGroup[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (!datedUniqueGroups.find(a => JSON.stringify(a) === JSON.stringify(tmpGroup))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.push(tmpGroup);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t// Step 3: Prepare unique dates\n\t\t\t\t\t\t\t\t\t\t\ttmpResults = deepCopy(results);\n\t\t\t\t\t\t\t\t\t\t\ttmpResults.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id)\n\t\t\t\t\t\t\t\t\t\t\t\t\t.filter(a => a !== 'second' && a !== 'hour' && a !== 'minute' && a !== 'day' && a !== 'week' && a !== 'month' && a !== 'quarter' && a !== 'year')\n\t\t\t\t\t\t\t\t\t\t\t\t\t.forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tdelete result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpDate = {};\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpDate[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\tif (!datedUniqueDates.find(a => JSON.stringify(a) === JSON.stringify(tmpDate))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.push(tmpDate);\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t// Build the date strings\n\t\t\t\t\t\t\t\t\t\t\t// Ensure moment is using America/Chicago timezone for all date processing\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(result => {\n\t\t\t\t\t\t\t\t\t\t\t\tif (!result.year) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'No Date';\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.date_interval === 'Seconds') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1, // Use `month - 1` since months are zero-indexed in moment as well\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tminute: result.minute,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tsecond: result.second\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH:mm:ss');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Minutes') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tminute: result.minute\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH:mm');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Hours') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\thour: result.hour\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY HH');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Daily') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tday: result.day\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM DD YYYY');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Weekly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tweek: result.week\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).day('Monday').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateLast = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tweek: result.week\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).day('Sunday').toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'Week #' + result.week + ' ' + result.year + ' (' + moment(result.date).format('MM/DD/YY') + ' - ' + moment(result.dateLast).format('MM/DD/YY') + ')';\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Monthly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmonth: result.month - 1, // Months are zero-indexed in moment\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = moment(result.date).format('MMM YYYY');\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).quarter(result.quarter).toDate();;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = 'Q' + result.quarter + ' ' + result.year;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse if (report.date_interval === 'Yearly') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.date = moment.tz({\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tyear: result.year\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}, (process.env.TZ_CLIENT || 'America/Chicago')).toDate();\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tresult.dateString = result.year.toString();\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates = datedUniqueDates.filter(a => !a.date)\n\t\t\t\t\t\t\t\t\t\t\t\t.concat(datedUniqueDates.filter(a => a.date).sort((a, b) => a.date.getTime() - b.date.getTime()));\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 4: Build datedData and reportTotalGroups\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(date => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpData = [];\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalDated = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalCnt = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalType = {};\n\n\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet result = results.find(a => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet match = true;\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Match the group fields\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(group).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== group[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// Match the date fields\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(date).filter(key => key !== 'date' && key !== 'dateLast' && key !== 'dateString').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== date[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\treturn match;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (result) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData.push(result);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result._id).filter(a => a).forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.fields_total.filter(a => a.fields.includes(key)).length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalDated[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] = result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] += result._id[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalCnt[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalType[key] = report.fields_total.find(a => a.fields.includes(key)).type;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(result).filter(a => a && a !== '_id').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (report.fields_total.filter(a => a.fields.includes(key)).length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalDated[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] = result[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[key] += result[key];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (!tmpTotalCnt[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalCnt[key] += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalType[key] = report.fields_total.find(a => a.fields.includes(key)).type;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpData.push(null);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Handle averaging for totals\n\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(tmpTotalType).forEach(totalKey => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (tmpTotalType[totalKey] === 'avg') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[totalKey] = tmpTotalDated[totalKey] / tmpTotalCnt[totalKey];\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalDated[totalKey] = round(tmpTotalDated[totalKey], 2);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\treportTotalDates.push(tmpTotalDated);\n\t\t\t\t\t\t\t\t\t\t\t\tdatedData.push(tmpData);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Calculate group-level totals\n\t\t\t\t\t\t\t\t\t\t\tdatedUniqueGroups.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\tlet tmpTotalGroup = {};\n\t\t\t\t\t\t\t\t\t\t\t\tlet filteredData = results.filter(a => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet match = (!Object.keys(group).length || group._id === null) ? false : true;\n\t\t\t\t\t\t\t\t\t\t\t\t\tObject.keys(group).filter(a => a !== 'date' && a !== 'dateLast' && a !== 'dateString' && a !== 'second' && a !== 'minute' && a !== 'hour' && a !== 'day' && a !== 'week' && a !== 'month' && a !== 'quarter' && a !== 'year').forEach(key => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (a._id[key] !== group[key]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tmatch = false;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn match;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\treport.fields_total.forEach(total => {\n\t\t\t\t\t\t\t\t\t\t\t\t\ttotal.fields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (filteredData.length) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = filteredData.filter(a => a && a[field])\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.map(a => a[field])\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t.reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (total.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = round(tmpTotalGroup[field] / filteredData.length, 2);\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttmpTotalGroup[field] = 0;\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\treportTotalGroups.push(tmpTotalGroup);\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Step 5: Proceed with Excel generation using datedData and reportTotalGroups\n\t\t\t\t\t\t\t\t\t\t\tlet wb = new Excel.Workbook();\n\t\t\t\t\t\t\t\t\t\t\tlet ws = wb.addWorksheet('Dated_Report', {views: [{showGridLines: true}]});\n\t\t\t\t\t\t\t\t\t\t\twb.properties.date1904 = false;\n\t\t\t\t\t\t\t\t\t\t\twb.calcProperties.fullCalcOnLoad = true;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tlet currentRow = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet currentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\tlet row = ws.getRow(currentRow);\n\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Report Name:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = report.report_name;\n\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).font = {\n\t\t\t\t\t\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\t\t\t\t\t\tsize: 14\n\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(2).value = 'Run Date:';\n\t\t\t\t\t\t\t\t\t\t\trow.getCell(4).value = moment().format('LLL');\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 2;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add group column headers\n\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(group => {\n\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = group.columnName;\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add field headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(field => {\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add the date interval headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(date => {\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = date.dateString;\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add totals headers\n\t\t\t\t\t\t\t\t\t\t\treport.fields_total.forEach(total => {\n\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = 'Totals - ' + toTitleCase(total.type);\n\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\tcurrentRow += 1;\n\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Populate data for each group and field with date intervals\n\t\t\t\t\t\t\t\t\t\t\tfor (let i = 0; i < datedUniqueGroups.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\tlet group = datedUniqueGroups[i];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let j = 0; j < report.fields_selected.filter(a => a.show).length; j++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet field = report.fields_selected.filter(a => a.show)[j];\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate group data\n\t\t\t\t\t\t\t\t\t\t\t\t\treport.groups_row.forEach(groupRow => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = (j === 0) ? group[groupRow.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate field data\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = field.columnName;\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Populate date interval data for each field\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let k = 0; k < datedUniqueDates.length; k++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet result = datedData[k];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tif (result[i]) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = result[i][field.id] ? result[i][field.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Add totals for each field in the report\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let k = 0; k < report.fields_total.length; k++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet total = report.fields_total[k];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = reportTotalGroups[i][field.id] ? reportTotalGroups[i][field.id] : '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow++; // Move to the next row for the next field\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Add report totals at the bottom\n\t\t\t\t\t\t\t\t\t\t\tif (reportTotals) {\n\t\t\t\t\t\t\t\t\t\t\t\tfor (let i = 0; i < report.fields_total.length; i++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tlet total = report.fields_total[i];\n\t\t\t\t\t\t\t\t\t\t\t\t\trow = ws.getRow(currentRow);\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol = 1;\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = toTitleCase(total.type) + ' Totals';\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol += report.groups_row.length; // Skip group columns\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Skip the date columns for the totals row\n\t\t\t\t\t\t\t\t\t\t\t\t\treport.fields_selected.filter(a => a.show).forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol += 1;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\t\t\tdatedUniqueDates.forEach(() => {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\t// Set totals in the correct fields\n\t\t\t\t\t\t\t\t\t\t\t\t\tfor (let j = 0; j < report.fields_selected.filter(a => a.show).length; j++) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tlet field = report.fields_selected.filter(a => a.show)[j];\n\t\t\t\t\t\t\t\t\t\t\t\t\t\trow.getCell(currentCol).value = reportTotals[total.id + '_' + field.id] || '';\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentCol++;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tcurrentRow++; // Move to the next row for the next total\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t// Save the Excel file and send it via email\n\t\t\t\t\t\t\t\t\t\t\twb.xlsx.writeBuffer().then(buffer => {\n\t\t\t\t\t\t\t\t\t\t\t\tdata['emails'].forEach(email => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthis.sendEmail(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\temail,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['CLIENT_NAME'] + ' Scheduled Report - ' + report.report_name,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t'',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t`\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>${this.serverConfig['CLIENT_NAME']} Automated Report</b><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Report Name: </b>${report.report_name}<br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<b>Prepared By: </b>${data['user']}<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tAttached are the results of this automated report.<br><br>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tResolveIO<br><br>`,\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tfilename: report.report_name + '-' + moment().format('MM-DD-YYYY-hh-mm-A') + '.xlsx',\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tcontent: buffer\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tthis.serverConfig['MAIL_FROM_REPORTS'],\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t''\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t}).catch(err => console.log('Error writing excel export', err));\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse {\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\tthis.callMethod('insertErrorLog', 'Report Builder Cron Job - Report Builder Get Results', [\n\t\t\t\t\t\t\t\t\t\t\terr\n\t\t\t\t\t\t\t\t\t\t]);\n\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\treject(err);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction getTreeLeaves(items, resArray, allowLookups = false) {\n\titems.forEach(item => {\n\t\tif (item.isLeaf) {\n\t\t\tresArray.push(item);\n\t\t}\n\t\telse {\n\t\t\tif (!item.lookup_collection || allowLookups) {\n\t\t\t\tgetTreeLeaves(item.children, resArray, allowLookups);\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction modifyDataTypeField(report, result, field, index) {\n\tconst processFieldValue = (value, field) => {\n\t\tif (value === undefined || value === null) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (field.fieldType === 'Boolean') {\n\t\t\tif (!field.leafFormatType || field.leafFormatType === 'Boolean') {\n\t\t\t\treturn value === true ? 'True' : 'False';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'String') {\n\t\t\t\treturn value === true ? 'Yes' : 'No';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Boolean_Number') {\n\t\t\t\treturn value === true ? 1 : 0;\n\t\t\t}\n\t\t}\n\t\telse if (field.fieldType === 'Number' || field.leafValueType === 'Count') {\n\t\t\tif (field.leafFormatType === 'Number') {\n\t\t\t\treturn value.toLocaleString();\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'String') {\n\t\t\t\treturn value.toString();\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Currency') {\n\t\t\t\treturn round(value, 2).toLocaleString('en-US', { style: 'currency', currency: 'USD' });\n\t\t\t}\n\t\t}\n\t\telse if (field.fieldType === 'Date') {\n\t\t\tswitch (field.leafFormatType) {\n\t\t\t\tcase 'Date':\n\t\t\t\t\treturn moment(value).format('L');\n\t\t\t\tcase 'Time':\n\t\t\t\t\treturn moment(value).format('LT');\n\t\t\t\tcase 'DateTime':\n\t\t\t\t\treturn moment(value).format('MM/DD/YYYY h:mm A');\n\t\t\t\tcase 'Date_long':\n\t\t\t\t\treturn moment(value).format('LL');\n\t\t\t\tcase 'DateTime_long':\n\t\t\t\t\treturn moment(value).format('LLL');\n\t\t\t\tcase 'Timestamp':\n\t\t\t\t\treturn moment(value).toDate().getTime();\n\t\t\t\tdefault:\n\t\t\t\t\treturn value;\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t};\n\n\tconst processArrayField = (array, field) => {\n\t\treturn array.map(value => processFieldValue(value, field));\n\t};\n\n\tif (index < report.groups_row.length) {\n\t\t// Handle grouped data\n\t\tconst groupKey = 'gr_' + (index + 1);\n\t\tif (result[groupKey]) {\n\t\t\tresult[groupKey].forEach(subResult => {\n\t\t\t\tmodifyDataTypeField(report, subResult, field, index + 1);\n\t\t\t});\n\t\t}\n\t}\n\telse {\n\t\t// Process final-level fields\n\t\tif (Array.isArray(result[field.id])) {\n\t\t\tresult[field.id] = processArrayField(result[field.id], field);\n\t\t}\n\t\telse {\n\t\t\tresult[field.id] = processFieldValue(result[field.id], field);\n\t\t}\n\t}\n}\n\nfunction tabGroupExcelRecursive(report, ws: Excel.Worksheet, currentRow, level, result) {\n\tlet row = ws.getRow(currentRow);\n\n\tif (level < report.groups_row.length) {\n\t\trow.getCell(2).fill = {\n\t\t\tfgColor: {argb: report.groups_row[level - 1].fill_color ? report.groups_row[level - 1].fill_color.replace('#', '') : 'ffffff'},\n\t\t\ttype: 'pattern',\n\t\t\tpattern: 'solid'\n\t\t};\n\t\trow.getCell(2).font = {\n\t\t\tcolor: {argb: report.groups_row[level - 1].font_color ? report.groups_row[level - 1].font_color.replace('#', '') : '000000'},\n\t\t\tname: 'Arial',\n\t\t\tbold: true,\n\t\t\tsize: 14\n\t\t};\n\n\t\trow.getCell(2).value = report.groups_row[level - 1].columnName + ': ' + result._id['gr_' + level];\n\t\tws.mergeCells(row.getCell(2).$col$row + ':' + row.getCell(report.fields_selected.filter(a => a.show).length + 1).$col$row);\n\t\t\n\t\trow.getCell(2).border = {\n\t\t\ttop: {style:'thick'},\n\t\t\tleft: {style:'thick'},\n\t\t\tright: {style: 'thick'}\n\t\t};\n\n\t\tif (report.fields_total.length) {\n\t\t\treport.fields_total.forEach(total => {\n\t\t\t\tcurrentRow += 1;\n\t\t\t\trow = ws.getRow(currentRow);\n\n\t\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).value = field.columnName;\n\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\t\tsize: 10\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\n\t\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t\t\n\t\t// Totals\n\t\treport.fields_total.forEach(total => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[total.id + '_' + field.id];\n\n\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\tsize: 10\n\t\t\t\t\t};\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tleft: {style:'thick'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'},\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\t\n\t\tcurrentRow += 1;\n\n\t\tresult = result['gr_' + (level + 1)];\n\t\tresult.forEach((tDataRes, tIndex) => {\n\t\t\tcurrentRow = tabGroupExcelRecursive(report, ws, currentRow, level + 1, tDataRes);\n\t\t});\n\t}\n\telse {\n\t\trow.getCell(2).fill = {\n\t\t\tfgColor: {argb: report.groups_row[level - 1].fill_color ? report.groups_row[level - 1].fill_color.replace('#', '') : 'ffffff'},\n\t\t\ttype: 'pattern',\n\t\t\tpattern: 'solid'\n\t\t};\n\t\trow.getCell(2).font = {\n\t\t\tcolor: {argb: report.groups_row[level - 1].font_color ? report.groups_row[level - 1].font_color.replace('#', '') : '000000'},\n\t\t\tname: 'Arial',\n\t\t\tbold: true,\n\t\t\tsize: 12\n\t\t};\n\n\t\trow.getCell(2).value = report.groups_row[level - 1].columnName + ': ' + result._id['gr_' + level];\n\t\tws.mergeCells(row.getCell(2).$col$row + ':' + row.getCell(report.fields_selected.filter(a => a.show).length + 1).$col$row);\n\n\t\trow.getCell(2).border = {\n\t\t\ttop: {style:'thick'},\n\t\t\tleft: {style:'thick'},\n\t\t\tright: {style: 'thick'}\n\t\t};\n\n\t\tcurrentRow += 1;\n\t\trow = ws.getRow(currentRow);\n\t\t// Headers\n\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\trow.getCell(fieldIndex + 2).value = field.columnName;\n\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\tname: 'Arial',\n\t\t\t\tbold: true,\n\t\t\t\tsize: 10\n\t\t\t};\n\n\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t}\n\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t}\n\n\t\t\tif (fieldIndex === 0) {\n\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t};\n\t\t\t}\n\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t};\n\t\t\t}\n\t\t});\n\n\t\t// Data\n\t\tresult['f_0'].forEach((res, resIndex) => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (field.fieldType === 'Number' && typeof(result[field.id][resIndex]) === 'string' && result[field.id][resIndex]) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = parseFloat(result[field.id][resIndex].replace(new RegExp(/\\,/g), '').replace(new RegExp(/\\$/g), ''));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[field.id][resIndex];\n\t\t\t\t}\n\n\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t}\n\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t}\n\n\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\tname: 'Arial',\n\t\t\t\t\tsize: 10\n\t\t\t\t};\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\tleft: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t\t\n\t\t// Totals\n\t\treport.fields_total.forEach(total => {\n\t\t\tcurrentRow += 1;\n\t\t\trow = ws.getRow(currentRow);\n\n\t\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\t\tif (total.fields.includes(field.id)) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).value = result[total.id + '_' + field.id];\n\n\t\t\t\t\trow.getCell(fieldIndex + 2).font = {\n\t\t\t\t\t\tname: 'Arial',\n\t\t\t\t\t\tbold: true,\n\t\t\t\t\t\tsize: 10\n\t\t\t\t\t};\n\n\t\t\t\t\tif (field.leafFormatType === 'Currency') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '\"$\"#,##0.00';\n\t\t\t\t\t}\n\t\t\t\t\telse if (field.leafFormatType === 'Number') {\n\t\t\t\t\t\trow.getCell(fieldIndex + 2).numFmt = '#,##0';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (fieldIndex === 0) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tleft: {style:'thick'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse if (fieldIndex === report.fields_selected.filter(a => a.show).length - 1) {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'},\n\t\t\t\t\t\tright: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\trow.getCell(fieldIndex + 2).border = {\n\t\t\t\t\t\ttop: {style:'thin'},\n\t\t\t\t\t\tbottom: {style:'thick'}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\treturn currentRow + 1;\n}\n\nfunction tabGroupExcelWidthRecursive(report, level, result, cols) {\n\tif (level < report.groups_row.length) {\n\t\tresult = result['gr_' + (level + 1)];\n\t\tresult.forEach((tDataRes, tIndex) => {\n\t\t\tcols = tabGroupExcelWidthRecursive(report, level + 1, tDataRes, cols);\n\t\t});\n\t}\n\telse {\n\t\treport.fields_selected.filter(a => a.show).forEach((field, fieldIndex) => {\n\t\t\tif (Array.isArray(result[field.id])) {\n\t\t\t\tresult[field.id].forEach(res => {\n\t\t\t\t\tlet length = 10;\n\n\t\t\t\t\tif (res) {\n\t\t\t\t\t\tlength = res.length + 3;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!cols[fieldIndex]) {\n\t\t\t\t\t\tcols[fieldIndex] = Math.max(10, field.columnName.length);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (length > cols[fieldIndex]) {\n\t\t\t\t\t\tcols[fieldIndex] = length;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlet res = result[field.id];\n\n\t\t\t\tif (res) {\n\t\t\t\t\tlength = res.length + 3;\n\t\t\t\t}\n\n\t\t\t\tif (!cols[fieldIndex]) {\n\t\t\t\t\tcols[fieldIndex] = Math.max(10, field.columnName.length);\n\t\t\t\t}\n\n\t\t\t\tif (length > cols[fieldIndex]) {\n\t\t\t\t\tcols[fieldIndex] = length;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\treturn cols;\n}"]}