@resolveio/server-lib 20.5.0 → 20.5.3

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 (113) hide show
  1. package/collections/app-status.collection.js +1 -1
  2. package/collections/app-status.collection.js.map +1 -1
  3. package/collections/counter.collection.js +1 -1
  4. package/collections/counter.collection.js.map +1 -1
  5. package/collections/cron-job-history.collection.js +1 -1
  6. package/collections/cron-job-history.collection.js.map +1 -1
  7. package/collections/cron-job.collection.js +1 -1
  8. package/collections/cron-job.collection.js.map +1 -1
  9. package/collections/email-history.collection.js +1 -1
  10. package/collections/email-history.collection.js.map +1 -1
  11. package/collections/email-verified.collection.js +1 -1
  12. package/collections/email-verified.collection.js.map +1 -1
  13. package/collections/file.collection.js +1 -1
  14. package/collections/file.collection.js.map +1 -1
  15. package/collections/flag-update.collection.js +1 -1
  16. package/collections/flag-update.collection.js.map +1 -1
  17. package/collections/flag.collection.js +1 -1
  18. package/collections/flag.collection.js.map +1 -1
  19. package/collections/log-method-latency.collection.js +1 -1
  20. package/collections/log-method-latency.collection.js.map +1 -1
  21. package/collections/log-subscription.collection.js +1 -1
  22. package/collections/log-subscription.collection.js.map +1 -1
  23. package/collections/log.collection.js +1 -1
  24. package/collections/log.collection.js.map +1 -1
  25. package/collections/logged-in-users.collection.js +1 -1
  26. package/collections/logged-in-users.collection.js.map +1 -1
  27. package/collections/method-response.collection.js +1 -1
  28. package/collections/method-response.collection.js.map +1 -1
  29. package/collections/monitor-cpu.collection.js +1 -1
  30. package/collections/monitor-cpu.collection.js.map +1 -1
  31. package/collections/monitor-memory.collection.js +1 -1
  32. package/collections/monitor-memory.collection.js.map +1 -1
  33. package/collections/monitor-mongo.collection.js +1 -1
  34. package/collections/monitor-mongo.collection.js.map +1 -1
  35. package/collections/notification.collection.js +1 -1
  36. package/collections/notification.collection.js.map +1 -1
  37. package/collections/report-builder-dashboard-builder.collection.js +1 -1
  38. package/collections/report-builder-dashboard-builder.collection.js.map +1 -1
  39. package/collections/report-builder-library.collection.js +1 -1
  40. package/collections/report-builder-library.collection.js.map +1 -1
  41. package/collections/report-builder-report.collection.js +1 -1
  42. package/collections/report-builder-report.collection.js.map +1 -1
  43. package/collections/user-group.collection.js +1 -1
  44. package/collections/user-group.collection.js.map +1 -1
  45. package/collections/user-guide.collection.js +1 -1
  46. package/collections/user-guide.collection.js.map +1 -1
  47. package/collections/user.collection.js +1 -1
  48. package/collections/user.collection.js.map +1 -1
  49. package/collections/worker-task-request.collection.js +1 -1
  50. package/collections/worker-task-request.collection.js.map +1 -1
  51. package/collections/worker-task-response.collection.js +1 -1
  52. package/collections/worker-task-response.collection.js.map +1 -1
  53. package/fixtures/cron-jobs.js +1 -1
  54. package/fixtures/cron-jobs.js.map +1 -1
  55. package/fixtures/init.js +1 -1
  56. package/fixtures/init.js.map +1 -1
  57. package/http/auth.d.ts +1 -2
  58. package/http/auth.js +1 -1
  59. package/http/auth.js.map +1 -1
  60. package/http/home.d.ts +1 -2
  61. package/http/home.js +1 -1
  62. package/http/home.js.map +1 -1
  63. package/index.d.ts +0 -30
  64. package/index.js +1 -1
  65. package/index.js.map +1 -1
  66. package/managers/cron.manager.js +1 -1
  67. package/managers/cron.manager.js.map +1 -1
  68. package/managers/local-log.manager.js +1 -1
  69. package/managers/local-log.manager.js.map +1 -1
  70. package/managers/method.manager.js +1 -1
  71. package/managers/method.manager.js.map +1 -1
  72. package/managers/mongo.manager.d.ts +1 -2
  73. package/managers/mongo.manager.js +1 -1
  74. package/managers/mongo.manager.js.map +1 -1
  75. package/managers/monitor.manager.d.ts +0 -1
  76. package/managers/monitor.manager.js +1 -1
  77. package/managers/monitor.manager.js.map +1 -1
  78. package/managers/subscription.manager.js +1 -1
  79. package/managers/subscription.manager.js.map +1 -1
  80. package/managers/websocket.manager.d.ts +1 -2
  81. package/managers/websocket.manager.js.map +1 -1
  82. package/methods/accounts.js +1 -1
  83. package/methods/accounts.js.map +1 -1
  84. package/methods/aws.js +1 -1
  85. package/methods/aws.js.map +1 -1
  86. package/methods/collections.js +1 -1
  87. package/methods/collections.js.map +1 -1
  88. package/methods/counters.js +1 -1
  89. package/methods/counters.js.map +1 -1
  90. package/methods/logs.js +1 -1
  91. package/methods/logs.js.map +1 -1
  92. package/methods/monitor.js +1 -1
  93. package/methods/monitor.js.map +1 -1
  94. package/methods/report-builder.js +1 -1
  95. package/methods/report-builder.js.map +1 -1
  96. package/package.json +1 -1
  97. package/public_api.d.ts +1 -0
  98. package/public_api.js +1 -1
  99. package/public_api.js.map +1 -1
  100. package/resolveio-server-app.d.ts +31 -0
  101. package/resolveio-server-app.js +2 -0
  102. package/resolveio-server-app.js.map +1 -0
  103. package/server-app.d.ts +2 -1
  104. package/server-app.js +1 -1
  105. package/server-app.js.map +1 -1
  106. package/util/common.d.ts +1 -0
  107. package/util/common.js +1 -1
  108. package/util/common.js.map +1 -1
  109. package/util/schema-report-builder.js +1 -1
  110. package/util/schema-report-builder.js.map +1 -1
  111. package/client-server-app.d.ts +0 -1
  112. package/client-server-app.js +0 -2
  113. package/client-server-app.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/methods/report-builder.ts"],"names":["simpl_schema_1","require","pagination_model_1","index_1","schema_report_builder_1","common_1","loadReportBuilderMethods","methodManager","methods","reportBuilderBuildTree","check","default","collection_root","type","String","function","_this","this","Promise","resolve","reject","__awaiter","lookupSchemaData","getReportLookupSchemas","sort","a","b","collection_name","localeCompare","lookupSchemaTree","find","is_root","tree","treeItems","buildTree","Object","keys","filter","endsWith","forEach","lookup","fieldPath","split","field","path","children","fieldName","lookup_collection","isLeaf","reportBuilderGetDistinctValue","treeLeaf","blackbox","fieldType","includes","_a","mongoCommand","replace","apply","_c","sent","_b","reportBuilderGetResults","reportType","rootCollectionName","options","PaginationOptionsSchema","filters","Array","optional","filters.$","filterArrays","filterArrays.$","filterArrayFields","filterArrayFields.$","selectedFields","selectedFields.$","customFields","customFields.$","groupsRow","groupsRow.$","fieldsTotal","fieldsTotal.$","fieldsLink","fieldsLink.$","date_field","date_interval","displayType","rootOptions","modelCollection","ResolveIOServer","getMongoManager","collection","query_1","initialQueryMatchCondition_1","$and","some","c","length","push","$match","$addFields","count","$sum","sizes_1","filterField","fieldData","i","$lookup","as","lookup_as","from","localField","lookup_local_key","foreignField","lookup_foreign_key","$size","$ifNull","$unwind","preserveNullAndEmptyArrays","row","fieldPath_1","treeItem","fieldPath_2","leafValueType","divFields_1","total","multFields","field_first","field_second","size","$cond","if","$gt","then","else","id","$divide","$multiply","link","$cmp","cust","operations","operation","fields","value","opIndex","condCheck_1","tmpOperationFields_1","condOr_1","custFieldGroup","$eq","selFieldId","$or","queryMatchConditionLookup_1","queryGroup_1","_id","groupedSorts_1","sortField","selField","$sort","$second","date","timezone","process","env","TZ_CLIENT","$minute","$hour","$dayOfMonth","$month","$year","$isoWeek","$isoWeekYear","$avg","$min","$max","$first","$last","$addToSet","$push","$group","queryProjection_1","$project","sortKeys_1","sort_1","groupString_1","projQuery","grQuery","totField","j","groupIndex","startsWith","key","res_1","aggregate","allowDiskUse","readPreference","serverConfig","console","log","err_1","tmpTotals_1","map","reduce","round","custField","tmpRes","results","limit","splice","totals","exports"],"mappings":"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","file":"report-builder.js","sourcesContent":["import SimpleSchema from 'simpl-schema';\nimport { MethodManager } from '../managers/method.manager';\nimport { PaginationOptions, PaginationOptionsSchema } from '../models/pagination.model';\nimport { ResolveIOServer } from '../index';\nimport { getReportLookupSchemas, buildTree, mongoCommand } from '../util/schema-report-builder';\nimport { round } from '../util/common';\n\nexport function loadReportBuilderMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\treportBuilderBuildTree: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tcollection_root: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(collection_root: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet lookupSchemaData = getReportLookupSchemas(collection_root).sort((a, b) => a.collection_name.localeCompare(b.collection_name));\n\t\t\t\t\tlet lookupSchemaTree = lookupSchemaData.find(a => a.is_root === true).tree;\n\n\t\t\t\t\tlet treeItems = buildTree(collection_root, lookupSchemaTree);\n\n\t\t\t\t\tObject.keys(lookupSchemaTree).filter(a => a.endsWith('(Lookup)')).forEach(lookup => {\n\t\t\t\t\t\tlet fieldPath = lookup.split('.');\n\t\t\t\t\t\tlet field = null;\n\t\t\t\t\t\tfieldPath.forEach(path => {\n\t\t\t\t\t\t\tif (!field) {\n\t\t\t\t\t\t\t\tfield = treeItems.find(a => a.fieldName === path);\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 = field.children.find(a => a.fieldName === path);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t\tfield.children = buildTree(lookupSchemaTree[lookup].lookup_collection, lookupSchemaData.find(a => a.collection_name === lookupSchemaTree[lookup].lookup_collection).tree, field);\n\t\t\t\t\t});\n\n\t\t\t\t\t// console.log('----------- Tree Items -----------', treeItems);\n\n\t\t\t\t\tresolve({isLeaf: false, children: treeItems});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportBuilderGetDistinctValue: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\ttreeLeaf: {\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(treeLeaf) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tif (treeLeaf.fieldType === 'String') {\n\t\t\t\t\t\tif (treeLeaf.fieldPath.includes('(Lookup)')) {\n\t\t\t\t\t\t\tresolve(await mongoCommand('distinct', treeLeaf.collection_name, treeLeaf.fieldPath.replace(/^.+\\(.+\\) \\(Lookup\\)\\.\\$\\./g, '').replace(/\\.\\$/g, '')));\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tresolve(await mongoCommand('distinct', treeLeaf.collection_name, treeLeaf.fieldPath.replace(/\\.\\$/g, '')));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tresolve([]);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportBuilderGetResults: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\treportType: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\trootCollectionName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\toptions: {\n\t\t\t\t\ttype: PaginationOptionsSchema\n\t\t\t\t},\n\t\t\t\tfilters: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filters.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfilterArrays: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filterArrays.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfilterArrayFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filterArrayFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tselectedFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'selectedFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\toptional: true,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tcustomFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'customFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\toptional: true,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tgroupsRow: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'groupsRow.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tfieldsTotal: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fieldsTotal.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tfieldsLink: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fieldsLink.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tdate_field: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tdate_interval: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tdisplayType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(reportType: string, rootCollectionName: string, rootOptions: PaginationOptions, filters: any[] = [], filterArrays: any[] = [], filterArrayFields: any[] = [], selectedFields: any[] = [], customFields: any[] = [], groupsRow: any[] = [], fieldsTotal: any[] = [], fieldsLink: any[] = [], date_field = '', date_interval = '', displayType = '') {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\n\t\t\t\t\tlet modelCollection = ResolveIOServer.getMongoManager().collection(rootCollectionName);\n\n\t\t\t\t\tif (!modelCollection) {\n\t\t\t\t\t\treject('Invalid collection');\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\t// Query\n\t\t\t\t\t\tlet query = [];\n\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t// Non-Lookup Match Filters\n\t\t\t\t\t\tlet initialQueryMatchCondition = {\n\t\t\t\t\t\t\t$and: []\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// selectedFields.filter(a => a.collection_name === rootCollectionName).forEach(field => {\n\t\t\t\t\t\t// \tinitialQueryMatchCondition['$and'].push({\n\t\t\t\t\t\t// \t\t$and: [\n\t\t\t\t\t\t// \t\t\t{[field.fieldPath.replace(/\\.\\$/g, '')]: {$exists: 1}},\n\t\t\t\t\t\t// \t\t\t// {[field.fieldPath.replace(/\\.\\$/g, '')]: {$ne: ''}},\n\t\t\t\t\t\t// \t\t\t{[field.fieldPath.replace(/\\.\\$/g, '')]: {$ne: null}},\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\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tfilters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).forEach(filter => {\n\t\t\t\t\t\t\t\tinitialQueryMatchCondition['$and'].push(filter);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Add filter to query\n\t\t\t\t\t\t// if (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length || selectedFields.filter(a => !a.fieldPath.includes('(Lookup')).length) {\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t$match: initialQueryMatchCondition\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Add count\n\t\t\t\t\t\tquery.push({ $addFields: { count: { $sum: 1} } });\n\n\t\t\t\t\t\tlet sizes = [];\n\n\t\t\t\t\t\tfilterArrayFields.filter(a => a.fieldPath).forEach(filterField => {\n\t\t\t\t\t\t\tlet fieldData = filterField.fieldPath.split('.$');\n\n\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === filterField.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\tfrom: filterField.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\tlocalField: filterField.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\tforeignField: filterField.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\tas: filterField.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\tsizes.push(filterField.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + filterField.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + filterField.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + filterField.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: true}});\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\telse {\n\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: true}});\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\n\t\t\t\t\t\t// Groups - Lookups / Sizes / Unwinds\n\t\t\t\t\t\tgroupsRow.forEach(row => {\n\t\t\t\t\t\t\tif (row.field.includes('$')) {\n\t\t\t\t\t\t\t\tlet fieldData = row.field.split('.$');\n\n\t\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === row.treeItem.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\t\tfrom: row.treeItem.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\t\tlocalField: row.treeItem.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\t\tforeignField: row.treeItem.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\t\tas: row.treeItem.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(row.treeItem.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + row.treeItem.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + row.treeItem.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + row.treeItem.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: 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 {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath.replace(/\\.\\$\\./g, '.'), []]}}}});\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath.replace(/\\.\\$\\./g, '.'), preserveNullAndEmptyArrays: true}});\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\tfieldPath += '.$';\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\n\t\t\t\t\t\t// Selected Fields - Lookups / Sizes / Unwinds\n\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\tif (field.fieldPath.includes('$')) {\n\t\t\t\t\t\t\t\tlet fieldData = field.fieldPath.split('.$');\n\n\t\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === field.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\t\tfrom: field.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\t\tlocalField: field.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\t\tforeignField: field.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\t\tas: field.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(field.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + field.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + field.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + field.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: true}});\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\tif (!fieldData[i].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: true}});\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\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (field.leafValueType !== 'Count' && !query.some(a => a.$unwind && a.$unwind.path === '$' + fieldPath)) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: 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}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// Divide all number fields by sizes\n\t\t\t\t\t\tlet divFields = {$addFields: {}};\n\n\t\t\t\t\t\tfieldsTotal.filter(a => a.type === 'sum').forEach(total => {\n\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\tlet multFields = [];\n\n\t\t\t\t\t\t\t\tif (!field.fieldPath.includes('.$')) {\n\t\t\t\t\t\t\t\t\tsizes.forEach(size => {\n\t\t\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\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\telse {\n\t\t\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\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\tif (multFields.length) {\n\t\t\t\t\t\t\t\t\tif (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = {\n\t\t\t\t\t\t\t\t\t\t\t$divide: ['$count', {$multiply: multFields}]\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 {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = {\n\t\t\t\t\t\t\t\t\t\t\t$divide: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), {$multiply: multFields}]\n\t\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\telse {\n\t\t\t\t\t\t\t\t\tif (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = '$count';\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\tdivFields.$addFields[total.id + '_' + field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\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\n\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' && a.leafValueType === 'Sum').forEach(field => {\n\t\t\t\t\t\t\tlet multFields = [];\n\n\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !groupsRow.some(b => b.field.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (multFields.length) {\n\t\t\t\t\t\t\t\tdivFields.$addFields[field.fieldPath.replace(/\\.\\$/g, '')] = {\n\t\t\t\t\t\t\t\t\t$divide: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), {$multiply: multFields}]\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\n\t\t\t\t\t\tselectedFields.filter(a => a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\tlet multFields = [];\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !groupsRow.some(b => b.field.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (multFields.length) {\n\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = {\n\t\t\t\t\t\t\t\t\t$divide: ['$count', {$multiply: multFields}]\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tif (reportType !== 'Dated' && sizes.filter(a => field.fieldPath.replace(/\\.\\$\\./g, '_').includes(a)).length) {\n\t\t\t\t\t\t\t\t\tsizes.filter(a => field.fieldPath.replace(/\\.\\$\\./g, '_').includes(a)).forEach(size => {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = '$size_' + size;\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\telse {\n\t\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = '$count';\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\n\t\t\t\t\t\tfieldsTotal.filter(a => a.type === 'avg').forEach(total => {\n\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (Object.keys(divFields.$addFields).length > 0) {\n\t\t\t\t\t\t\tquery.push(divFields);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfieldsLink.filter(a => a.field_first && a.field_second).forEach(link => {\n\t\t\t\t\t\t\tquery.push({$addFields: {[link.id]: {$cmp: ['$' + link.field_first.replace(/\\.\\$/g, ''), '$' + link.field_second.replace(/\\.\\$/g, '')]}}});\n\t\t\t\t\t\t\tquery.push({$match: {[link.id]: 0}});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\tcust.operations.filter(a => a.operation && !a.fields.some(b => (b.field === null || b.field === '') && b.value === null)).forEach((operation, opIndex) => {\n\t\t\t\t\t\t\t\tlet custFieldGroup = {};\n\n\t\t\t\t\t\t\t\tif (operation.operation === 'divide') {\n\t\t\t\t\t\t\t\t\tlet condCheck = [];\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), 0]});\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), null]});\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\tcondCheck.push({$eq: [field.value, 0]});\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: [field.value, null]});\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 (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + cust.selFieldId, 0]});\n\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + cust.selFieldId, null]});\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tlet tmpOperationFields = [];\n\n\t\t\t\t\t\t\t\t\tif (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\ttmpOperationFields.push('$' + cust.selFieldId);\n\t\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\ttmpOperationFields.push('$' + field.field.replace(/\\.\\$/g, ''));\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\ttmpOperationFields.push(field.value);\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\tcustFieldGroup[cust.selFieldId] = {\n\t\t\t\t\t\t\t\t\t\t$cond: { if: { $or: condCheck }, then: 0, else: {['$' + operation.operation]: tmpOperationFields} }\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\telse {\n\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId] = {\n\t\t\t\t\t\t\t\t\t\t['$' + operation.operation]: []\n\t\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\t\tif (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $eq: ['$' + cust.selFieldId, null] }, then: 0, else: '$' + cust.selFieldId}});\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tlet condOr = [];\n\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcondOr.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), null]});\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\tcondOr.push({$eq: [field.value, null]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t});\n\t\t\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $or: condOr }, then: 0, else: '$' + field.field.replace(/\\.\\$/g, '')}});\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\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $or: condOr }, then: 0, else: field.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\n\t\t\t\t\t\t\t\tquery.push({$addFields: custFieldGroup});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\tquery.push({$addFields:{[total.id + '_' + field.selFieldId]: '$' + field.selFieldId}});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// Filters - Lookups / Arrays\n\t\t\t\t\t\tlet queryMatchConditionLookup = {\n\t\t\t\t\t\t\t$and: []\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tfilters.filter(a => (!a['$or'] && Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).forEach(filter => {\n\t\t\t\t\t\t\t\tqueryMatchConditionLookup['$and'].push(filter);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfilterArrays.forEach(filter => {\n\t\t\t\t\t\t\tqueryMatchConditionLookup['$and'].push(filter);\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (queryMatchConditionLookup.$and.length) {\n\t\t\t\t\t\t\tquery.push({$match: queryMatchConditionLookup});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Group\n\t\t\t\t\t\tlet queryGroup = {\n\t\t\t\t\t\t\t_id: {}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (groupsRow.length || !displayType || displayType === 'grouped') {\n\t\t\t\t\t\t\tif (!groupsRow.length) {\n\t\t\t\t\t\t\t\tqueryGroup._id = '$_id';\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tif (rootOptions.sort) { \n\t\t\t\t\t\t\t\t\tlet groupedSorts = {};\n\t\t\t\t\t\t\t\t\tObject.keys(rootOptions.sort).forEach(sortField => {\n\t\t\t\t\t\t\t\t\t\tlet selField = selectedFields.find(a => a.id === sortField);\n\n\t\t\t\t\t\t\t\t\t\tif (selField) {\n\t\t\t\t\t\t\t\t\t\t\tgroupedSorts[selField.fieldPath.replace(/\\.\\$/g, '')] = rootOptions.sort[sortField];\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\tif (Object.keys(groupedSorts).length > 0) {\n\t\t\t\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t\t\t\t$sort: groupedSorts\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\tgroupsRow.forEach(row => {\n\t\t\t\t\t\t\t\tqueryGroup._id[row.id] = '$' + row.field.replace(/\\.\\$/g, '');\n\n\t\t\t\t\t\t\t\tif (date_field && date_interval) {\n\t\t\t\t\t\t\t\t\tif (date_interval === 'Seconds') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['second'] = {'$second' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['minute'] = {'$minute' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Minutes') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['minute'] = {'$minute' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Hours') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Daily') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Weekly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['week'] = {'$isoWeek' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$isoWeekYear' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Monthly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Yearly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\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\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\tif (field.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$avg': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$sum': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = { '$sum': '$count_' + field.fieldPath.replace(/\\.\\$/g, '') };\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$min': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$max': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'First') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$first': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Last') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$last': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Unique') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$addToSet': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\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\tqueryGroup[field.id] = {'$push': {$ifNull: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), null]}};\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\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\t\tif (cust.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$avg': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$sum': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tif (reportType === 'Dated') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = { '$sum': '$count_' + cust.selFieldId };\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\tqueryGroup[cust.selFieldId] = { '$push': '$count_' + cust.selFieldId };\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\telse if (cust.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$min': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$max': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'First') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$first': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Last') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$last': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Unique') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$addToSet': '$' + cust.selFieldId};\t\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\tqueryGroup[cust.selFieldId] = {'$push': {$ifNull: ['$' + cust.selFieldId, null]}};\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\t// Totals\n\t\t\t\t\t\t\tif (fieldsTotal.length) {\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[total.id + '_' + field.id] = {['$' + total.type] : '$' + total.id + '_' + field.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[total.id + '_' + field.selFieldId] = {['$' + total.type]: '$' + total.id + '_' + field.selFieldId};\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\tquery.push({$group: queryGroup});\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t//Projection\n\t\t\t\t\t\t\tlet queryProjection = {\n\t\t\t\t\t\t\t\t_id: 1\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\tif (field.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$avg: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$sum: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$sum: 1};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$min: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$max: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\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\tqueryProjection[field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\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\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\t\tif (cust === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$avg: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$sum: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$sum: 1};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$min: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$max: '$' + cust.selFieldId};\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\tqueryProjection[cust.selFieldId] = '$' + cust.selFieldId;\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\t//Totals\n\t\t\t\t\t\t\tif (fieldsTotal.length && (reportType === 'List' || reportType === 'Dated')) {\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryProjection[total.id + '_' + field.id] = {['$' + total.type]: '$' + total.id + '_' + field.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryProjection[total.id + '_' + field.selFieldId] = {['$' + total.type]: '$' + total.id + '_' + field.selFieldId};\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\tquery.push({$project: queryProjection});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// SORT\n\t\t\t\t\t\tif (rootOptions.sort) {\n\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t$sort: rootOptions.sort\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (reportType === 'Group' && groupsRow.length > 1) {\n\t\t\t\t\t\t\tfor (let i = groupsRow.length - 1; i >= 1; i--) {\n\t\t\t\t\t\t\t\tlet projQuery = {_id: 1};\n\n\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id] = {\n\t\t\t\t\t\t\t\t\t_id: {[groupsRow[i].id]: '$_id.' + groupsRow[i].id}\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tif (i === groupsRow.length - 1) {\n\t\t\t\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][field.id] = '$' + field.id;\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][field.selFieldId] = '$' + field.selFieldId;\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\telse {\n\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][groupsRow[i + 1].id] = '$' + groupsRow[i + 1].id;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[totField.id + '_' + selField.id] = 1;\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][totField.id + '_' + selField.id] = '$' + totField.id + '_' + selField.id;\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][totField.id + '_' + field.selFieldId] = '$' + totField.id + '_' + field.selFieldId;\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\tquery.push({$project: projQuery});\n\n\t\t\t\t\t\t\t\tlet grQuery = {\n\t\t\t\t\t\t\t\t\t_id: {}\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tfor (let j = 0; j < i; j++) {\n\t\t\t\t\t\t\t\t\tgrQuery._id[groupsRow[j].id] = '$_id.' + groupsRow[j].id;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tgrQuery[groupsRow[i].id] = {\n\t\t\t\t\t\t\t\t\t$push: '$' + groupsRow[i].id\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\t\tgrQuery[totField.id + '_' + selField.id] = {['$' + totField.type]: '$' + totField.id + '_' + selField.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tgrQuery[totField.id + '_' + field.selFieldId] = {['$' + totField.type]: '$' + totField.id + '_' + field.selFieldId};\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\tquery.push({$group: grQuery});\n\n\t\t\t\t\t\t\t\tif (rootOptions.sort) {\n\t\t\t\t\t\t\t\t\tlet sortKeys = Object.keys(rootOptions.sort);\n\t\t\t\t\t\t\t\t\tlet sort = {};\n\n\t\t\t\t\t\t\t\t\tlet groupString = '';\n\t\t\t\t\t\t\t\t\tgroupsRow.forEach((row, groupIndex) => {\n\t\t\t\t\t\t\t\t\t\tif (groupIndex > 0) {\n\t\t\t\t\t\t\t\t\t\t\tgroupString += 'gr_' + (groupIndex + 1) + '.';\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (sortKeys.includes('_id.gr_' + (groupIndex + 1))) {\n\t\t\t\t\t\t\t\t\t\t\tsort[groupString + '_id.gr_' + (groupIndex + 1)] = rootOptions.sort['_id.gr_' + (groupIndex + 1)];\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\tsort[groupString + '_id.gr_' + (groupIndex + 1)] = 1;\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\tsortKeys.filter(a => !a.startsWith('_id.gr_')).forEach(key => {\n\t\t\t\t\t\t\t\t\t\tsort[groupString + key] = rootOptions.sort[key];\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tquery.push({$sort: sort});\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\n\t\t\t\t\t\t// console.log('_____________ query __________'); console.log(query); console.log(JSON.stringify(query, null, 2));\n\n\t\t\t\t\t\tlet res = null;\n\t\t\t\t\t\t\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tres = await modelCollection.aggregate(query, {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\t\tconsole.log(err);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet tmpTotals = {};\n\n\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\tif (totField.type === 'sum') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + selField.id] = res.map(a => a[totField.id + '_' + selField.id] || 0).reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (totField.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + selField.id] = round(res.map(a => a[totField.id + '_' + selField.id] || 0).reduce((a, b) => a + b, 0) / res.length);\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\tcustomFields.forEach(custField => {\n\t\t\t\t\t\t\t\t\tif (totField.type === 'sum') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + custField.selFieldId] = res.map(a => a[totField.id + '_' + custField.selFieldId] || 0).reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (totField.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + custField.selFieldId] = round(res.map(a => a[totField.id + '_' + custField.selFieldId] || 0).reduce((a, b) => a + b, 0) / res.length);\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\n\t\t\t\t\t\tlet tmpRes = [{\n\t\t\t\t\t\t\tcount: res ? res.length : 0,\n\t\t\t\t\t\t\tresults: res ? (rootOptions.limit ? res.splice(0, rootOptions.limit) : res) : [],\n\t\t\t\t\t\t\ttotals: tmpTotals\n\t\t\t\t\t\t}];\n\n\t\t\t\t\t\tresolve(tmpRes);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t}\n\t});\n}"]}
1
+ {"version":3,"sources":["../../src/methods/report-builder.ts"],"names":["simpl_schema_1","require","pagination_model_1","resolveio_server_app_1","schema_report_builder_1","common_1","loadReportBuilderMethods","methodManager","methods","reportBuilderBuildTree","check","default","collection_root","type","String","function","_this","this","Promise","resolve","reject","__awaiter","lookupSchemaData","getReportLookupSchemas","sort","a","b","collection_name","localeCompare","lookupSchemaTree","find","is_root","tree","treeItems","buildTree","Object","keys","filter","endsWith","forEach","lookup","fieldPath","split","field","path","children","fieldName","lookup_collection","isLeaf","reportBuilderGetDistinctValue","treeLeaf","blackbox","fieldType","includes","_a","mongoCommand","replace","apply","_c","sent","_b","reportBuilderGetResults","reportType","rootCollectionName","options","PaginationOptionsSchema","filters","Array","optional","filters.$","filterArrays","filterArrays.$","filterArrayFields","filterArrayFields.$","selectedFields","selectedFields.$","customFields","customFields.$","groupsRow","groupsRow.$","fieldsTotal","fieldsTotal.$","fieldsLink","fieldsLink.$","date_field","date_interval","displayType","rootOptions","modelCollection","ResolveIOServer","getMongoManager","collection","query_1","initialQueryMatchCondition_1","$and","some","c","length","push","$match","$addFields","count","$sum","sizes_1","filterField","fieldData","i","$lookup","as","lookup_as","from","localField","lookup_local_key","foreignField","lookup_foreign_key","$size","$ifNull","$unwind","preserveNullAndEmptyArrays","row","fieldPath_1","treeItem","fieldPath_2","leafValueType","divFields_1","total","multFields","field_first","field_second","size","$cond","if","$gt","then","else","id","$divide","$multiply","link","$cmp","cust","operations","operation","fields","value","opIndex","condCheck_1","tmpOperationFields_1","condOr_1","custFieldGroup","$eq","selFieldId","$or","queryMatchConditionLookup_1","queryGroup_1","_id","groupedSorts_1","sortField","selField","$sort","$second","date","timezone","process","env","TZ_CLIENT","$minute","$hour","$dayOfMonth","$month","$year","$isoWeek","$isoWeekYear","$avg","$min","$max","$first","$last","$addToSet","$push","$group","queryProjection_1","$project","sortKeys_1","sort_1","groupString_1","projQuery","grQuery","totField","j","groupIndex","startsWith","key","res_1","aggregate","allowDiskUse","readPreference","serverConfig","console","log","err_1","tmpTotals_1","map","reduce","round","custField","tmpRes","results","limit","splice","totals","exports"],"mappings":"k8CAAAA,gB,+FAAAC,QAAA,cAAA,GAEAC,mBAAAD,QAAA,4BAAA,EACAE,uBAAAF,QAAA,yBAAA,EACAG,wBAAAH,QAAA,+BAAA,EACAI,SAAAJ,QAAA,gBAAA,EAEA,SAAgBK,yBAAyBC,GACxCA,EAAcC,QAAQ,CACrBC,uBAAwB,CACvBC,MAAO,IAAIV,eAAAW,QAAa,CACvBC,gBAAiB,CAChBC,KAAMC,M,EAEP,EACDC,SAAU,SAASH,GAAT,IAAAI,EAAAC,KACT,OAAO,IAAIC,QAAQ,SAAOC,EAASC,GAAM,OAAAC,UAAAL,EAAA,KAAA,EAAA,KAAA,EAAA,W,qDACpCM,GAAmB,EAAAlB,wBAAAmB,wBAAuBX,CAAe,EAAEY,KAAK,SAACC,EAAGC,GAAM,OAAAD,EAAEE,gBAAgBC,cAAcF,EAAEC,eAAe,CAAjD,CAAkD,EAC5HE,EAAmBP,EAAiBQ,KAAK,SAAAL,GAAK,MAAc,CAAA,IAAdA,EAAEM,OAAF,CAAkB,EAAEC,KAElEC,GAAY,EAAA7B,wBAAA8B,WAAUtB,EAAiBiB,CAAgB,EAE3DM,OAAOC,KAAKP,CAAgB,EAAEQ,OAAO,SAAAZ,GAAK,OAAAA,EAAEa,SAAS,UAAU,CAArB,CAAsB,EAAEC,QAAQ,SAAAC,GACzE,IAAIC,EAAYD,EAAOE,MAAM,GAAG,EAC5BC,EAAQ,KACZF,EAAUF,QAAQ,SAAAK,GAKhBD,EAJIA,EAIIA,EAAME,SAASf,KAAK,SAAAL,GAAK,OAAAA,EAAEqB,YAAcF,CAAhB,CAAoB,EAH7CX,EAAUH,KAAK,SAAAL,GAAK,OAAAA,EAAEqB,YAAcF,CAAhB,CAAoB,CAKlD,CAAC,EACDD,EAAME,UAAW,EAAAzC,wBAAA8B,WAAUL,EAAiBW,GAAQO,kBAAmBzB,EAAiBQ,KAAK,SAAAL,GAAK,OAAAA,EAAEE,kBAAoBE,EAAiBW,GAAQO,iBAA/C,CAAgE,EAAEf,KAAMW,CAAK,CAChL,CAAC,EAIDxB,EAAQ,CAAC6B,OAAQ,CAAA,EAAOH,SAAUZ,CAAS,CAAC,E,QAC5C,CACF,C,EAEDgB,8BAA+B,CAC9BvC,MAAO,IAAIV,eAAAW,QAAa,CACvBuC,SAAU,CACTrC,KAAMsB,OACNgB,SAAU,CAAA,C,EAEX,EACDpC,SAAU,SAASmC,GAAT,IAAAlC,EAAAC,KACT,OAAO,IAAIC,QAAQ,SAAOC,EAASC,GAAM,OAAAC,UAAAL,EAAA,KAAA,EAAA,KAAA,EAAA,W,yEACb,WAAvBkC,EAASE,UAAT,CAAA,EAAA,GACCF,EAAST,UAAUY,SAAS,UAAU,GACzCC,EAAAnC,EAAQ,CAAA,GAAM,EAAAf,wBAAAmD,cAAa,WAAYL,EAASvB,gBAAiBuB,EAAST,UAAUe,QAAQ,8BAA+B,EAAE,EAAEA,QAAQ,QAAS,EAAE,CAAC,IADhJ,CAAA,EAAA,G,cACHF,EAAAG,MAAA,KAAA,EAAA,CAAQC,EAAAC,KAAA,EAA4I,E,aAG5I,OAARC,EAAAzC,EAAQ,CAAA,GAAM,EAAAf,wBAAAmD,cAAa,WAAYL,EAASvB,gBAAiBuB,EAAST,UAAUe,QAAQ,QAAS,EAAE,CAAC,G,OAAxGI,EAAAH,MAAA,KAAA,EAAA,CAAQC,EAAAC,KAAA,EAAiG,E,oCAI1GxC,EAAQ,EAAE,E,gCAEX,CACF,C,EAED0C,wBAAyB,CACxBnD,MAAO,IAAIV,eAAAW,QAAa,CACvBmD,WAAY,CACXjD,KAAMC,M,EAEPiD,mBAAoB,CACnBlD,KAAMC,M,EAEPkD,QAAS,CACRnD,KAAMX,mBAAA+D,uB,EAEPC,QAAS,CACRrD,KAAMsD,MACNC,SAAU,CAAA,C,EAEXC,YAAa,CACZxD,KAAMsB,OACNgB,SAAU,CAAA,EACViB,SAAU,CAAA,C,EAEXE,aAAc,CACbzD,KAAMsD,MACNC,SAAU,CAAA,C,EAEXG,iBAAkB,CACjB1D,KAAMsB,OACNgB,SAAU,CAAA,EACViB,SAAU,CAAA,C,EAEXI,kBAAmB,CAClB3D,KAAMsD,MACNC,SAAU,CAAA,C,EAEXK,sBAAuB,CACtB5D,KAAMsB,OACNgB,SAAU,CAAA,EACViB,SAAU,CAAA,C,EAEXM,eAAgB,CACf7D,KAAMsD,MACNC,SAAU,CAAA,C,EAEXO,mBAAoB,CACnB9D,KAAMsB,OACNiC,SAAU,CAAA,EACVjB,SAAU,CAAA,C,EAEXyB,aAAc,CACb/D,KAAMsD,MACNC,SAAU,CAAA,C,EAEXS,iBAAkB,CACjBhE,KAAMsB,OACNiC,SAAU,CAAA,EACVjB,SAAU,CAAA,C,EAEX2B,UAAW,CACVjE,KAAMsD,K,EAEPY,cAAe,CACdlE,KAAMsB,OACNgB,SAAU,CAAA,C,EAEX6B,YAAa,CACZnE,KAAMsD,K,EAEPc,gBAAiB,CAChBpE,KAAMsB,OACNgB,SAAU,CAAA,C,EAEX+B,WAAY,CACXrE,KAAMsD,K,EAEPgB,eAAgB,CACftE,KAAMsB,OACNgB,SAAU,CAAA,C,EAEXiC,WAAY,CACXvE,KAAMC,OACNsD,SAAU,CAAA,C,EAEXiB,cAAe,CACdxE,KAAMC,OACNsD,SAAU,CAAA,C,EAEXkB,YAAa,CACZzE,KAAMC,OACNsD,SAAU,CAAA,C,EAEX,EACDrD,SAAU,SAAS+C,EAAoBC,EAA4BwB,EAAgCrB,EAAqBI,EAA0BE,EAA+BE,EAA4BE,EAA0BE,EAAuBE,EAAyBE,EAAwBE,EAAiBC,EAAoBC,GAA1U,IAAAtE,EAAAC,KACT,OADkG,KAAA,IAAAiD,IAAAA,EAAA,IAAqB,KAAA,IAAAI,IAAAA,EAAA,IAA0B,KAAA,IAAAE,IAAAA,EAAA,IAA+B,KAAA,IAAAE,IAAAA,EAAA,IAA4B,KAAA,IAAAE,IAAAA,EAAA,IAA0B,KAAA,IAAAE,IAAAA,EAAA,IAAuB,KAAA,IAAAE,IAAAA,EAAA,IAAyB,KAAA,IAAAE,IAAAA,EAAA,IAAwB,KAAA,IAAAE,IAAAA,EAAA,IAAiB,KAAA,IAAAC,IAAAA,EAAA,IAAoB,KAAA,IAAAC,IAAAA,EAAA,IAC5U,IAAIpE,QAAQ,SAAOC,EAASC,GAAM,OAAAC,UAAAL,EAAA,KAAA,EAAA,KAAA,EAAA,W,kGAEpCwE,EAAkBrF,uBAAAsF,gBAAgBC,gBAAe,EAAGC,WAAW5B,CAAkB,GAEjF,CAAA,EAAA,IACH3C,EAAO,oBAAoB,E,cAukB3B,GAnkBIwE,EAAQ,GAGRC,EAA6B,CAChCC,KAAM,E,EAaH5B,EAAQ7B,OAAO,SAAAZ,GAAK,MAAC,CAACA,EAAO,KAAK,CAACU,OAAOC,KAAKX,CAAC,EAAEsE,KAAK,SAAArE,GAAK,OAAAA,EAAE2B,SAAS,UAAU,CAArB,CAAsB,GAAO5B,EAAO,KAAK,CAACA,EAAO,IAAEsE,KAAK,SAAArE,GAAK,OAAAS,OAAOC,KAAKV,CAAC,EAAEqE,KAAK,SAAAC,GAAK,OAAAA,EAAE3C,SAAS,UAAU,CAArB,CAAsB,CAA/C,CAAgD,CAArJ,CAAuJ,EAAE4C,QAChL/B,EAAQ7B,OAAO,SAAAZ,GAAK,MAAC,CAACA,EAAO,KAAK,CAACU,OAAOC,KAAKX,CAAC,EAAEsE,KAAK,SAAArE,GAAK,OAAAA,EAAE2B,SAAS,UAAU,CAArB,CAAsB,GAAO5B,EAAO,KAAK,CAACA,EAAO,IAAEsE,KAAK,SAAArE,GAAK,OAAAS,OAAOC,KAAKV,CAAC,EAAEqE,KAAK,SAAAC,GAAK,OAAAA,EAAE3C,SAAS,UAAU,CAArB,CAAsB,CAA/C,CAAgD,CAArJ,CAAuJ,EAAEd,QAAQ,SAAAF,GACpLwD,EAAiC,KAAEK,KAAK7D,CAAM,CAC/C,CAAC,EAKE6B,EAAQ7B,OAAO,SAAAZ,GAAK,MAAC,CAACA,EAAO,KAAK,CAACU,OAAOC,KAAKX,CAAC,EAAEsE,KAAK,SAAArE,GAAK,OAAAA,EAAE2B,SAAS,UAAU,CAArB,CAAsB,GAAO5B,EAAO,KAAK,CAACA,EAAO,IAAEsE,KAAK,SAAArE,GAAK,OAAAS,OAAOC,KAAKV,CAAC,EAAEqE,KAAK,SAAAC,GAAK,OAAAA,EAAE3C,SAAS,UAAU,CAArB,CAAsB,CAA/C,CAAgD,CAArJ,CAAuJ,EAAE4C,QAChLL,EAAMM,KAAK,CACVC,OAAQN,C,CACR,EAIFD,EAAMM,KAAK,CAAEE,WAAY,CAAEC,MAAO,CAAEC,KAAM,CAAC,CAAC,CAAE,CAAE,EAE5CC,EAAQ,GAEZ/B,EAAkBnC,OAAO,SAAAZ,GAAK,OAAAA,EAAEgB,SAAF,CAAW,EAAEF,QAAQ,SAAAiE,GAKlD,I,MAJIC,EAAYD,EAAY/D,UAAUC,MAAM,IAAI,EAE5CD,EAAY,GAEPiE,EAAI,EAAGA,EAAID,EAAUR,OAAS,EAAGS,CAAC,IAE1CjE,GAAagE,EAAUC,IAEThE,MAAM,IAAI,EAAED,EAAUC,MAAM,IAAI,EAAEuD,OAAS,GAAG5C,SAAS,UAAU,EACzEuC,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAEkF,SAAWlF,EAAEkF,QAAQC,KAAOJ,EAAYK,UAAUrD,QAAQ,QAAS,EAAE,CAAvE,CAAwE,IAC5FoC,EAAMM,KAAK,CAACS,QAAS,CACpBG,KAAMN,EAAYzD,kBAClBgE,WAAYP,EAAYQ,iBACxBC,aAAcT,EAAYU,mBAC1BN,GAAIJ,EAAYK,UAAUrD,QAAQ,QAAS,EAAE,C,CAC7C,CAAC,EAEF+C,EAAML,KAAKM,EAAYK,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,CAAC,EAC5EoC,EAAMM,KAAK,CAACE,aAAU9C,EAAA,IAAI,QAAUkD,EAAYK,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMZ,EAAYK,UAAUrD,QAAQ,QAAS,EAAE,EAAEA,QAAQ,MAAO,GAAG,EAAG,GAAG,CAAC,EAACF,EAAC,CAAC,EAExMsC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAM4D,EAAYK,UAAUrD,QAAQ,QAAS,EAAE,EAAG8D,2BAA4B,CAAA,CAAI,CAAC,CAAC,GAI9G1B,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAE2E,YAAcjE,OAAOC,KAAKX,EAAE2E,UAAU,EAAE/C,SAAS,QAAUZ,EAAUe,QAAQ,MAAO,GAAG,CAAC,CAA1F,CAA2F,IAC/G+C,EAAML,KAAKzD,EAAUe,QAAQ,MAAO,GAAG,CAAC,EACxCoC,EAAMM,KAAK,CAACE,aAAUxC,EAAA,IAAI,QAAUnB,EAAUe,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAM3E,EAAW,GAAG,CAAC,EAACmB,EAAC,CAAC,EAE/GgC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAMH,EAAW6E,2BAA4B,CAAA,CAAI,CAAC,CAAC,EAIrF,CAAC,EAGDxC,EAAUvC,QAAQ,SAAAgF,G,MACjB,GAAIA,EAAI5E,MAAMU,SAAS,GAAG,EAKzB,IAJA,IAAIoD,EAAYc,EAAI5E,MAAMD,MAAM,IAAI,EAEhC8E,EAAY,GAEPd,EAAI,EAAGA,EAAID,EAAUR,OAAS,EAAGS,CAAC,IAC1Cc,GAAaf,EAAUC,IAEThE,MAAM,IAAI,EAAE8E,EAAU9E,MAAM,IAAI,EAAEuD,OAAS,GAAG5C,SAAS,UAAU,EACzEuC,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAEkF,SAAWlF,EAAEkF,QAAQC,KAAOW,EAAIE,SAASZ,UAAUrD,QAAQ,QAAS,EAAE,CAAxE,CAAyE,IAC7FoC,EAAMM,KAAK,CAACS,QAAS,CACpBG,KAAMS,EAAIE,SAAS1E,kBACnBgE,WAAYQ,EAAIE,SAAST,iBACzBC,aAAcM,EAAIE,SAASP,mBAC3BN,GAAIW,EAAIE,SAASZ,UAAUrD,QAAQ,QAAS,EAAE,C,CAC9C,CAAC,EAEF+C,EAAML,KAAKqB,EAAIE,SAASZ,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,CAAC,EAC7EoC,EAAMM,KAAK,CAACE,aAAU9C,EAAA,IAAI,QAAUiE,EAAIE,SAASZ,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMG,EAAIE,SAASZ,UAAUrD,QAAQ,QAAS,EAAE,EAAEA,QAAQ,MAAO,GAAG,EAAG,GAAG,CAAC,EAACF,EAAC,CAAC,EAE1MsC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAM2E,EAAIE,SAASZ,UAAUrD,QAAQ,QAAS,EAAE,EAAG8D,2BAA4B,CAAA,CAAI,CAAC,CAAC,GAI/G1B,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAE2E,YAAcjE,OAAOC,KAAKX,EAAE2E,UAAU,EAAE/C,SAAS,QAAUmE,EAAUhE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,CAAC,CAAlH,CAAmH,IACvI+C,EAAML,KAAKsB,EAAUhE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,CAAC,EAChEoC,EAAMM,KAAK,CAACE,aAAUxC,EAAA,IAAI,QAAU4D,EAAUhE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMI,EAAUhE,QAAQ,UAAW,GAAG,EAAG,GAAG,CAAC,EAACI,EAAC,CAAC,EAC/JgC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAM4E,EAAUhE,QAAQ,UAAW,GAAG,EAAG8D,2BAA4B,CAAA,CAAI,CAAC,CAAC,GAI3GE,GAAa,IAGhB,CAAC,EAGD9C,EAAenC,QAAQ,SAAAI,G,QACtB,GAAIA,EAAMF,UAAUY,SAAS,GAAG,EAK/B,IAJA,IAAIoD,EAAY9D,EAAMF,UAAUC,MAAM,IAAI,EAEtCgF,EAAY,GAEPhB,EAAI,EAAGA,EAAID,EAAUR,OAAS,EAAGS,CAAC,IAE1CgB,GAAajB,EAAUC,IAEThE,MAAM,IAAI,EAAEgF,EAAUhF,MAAM,IAAI,EAAEuD,OAAS,GAAG5C,SAAS,UAAU,EACzEuC,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAEkF,SAAWlF,EAAEkF,QAAQC,KAAOjE,EAAMkE,UAAUrD,QAAQ,QAAS,EAAE,CAAjE,CAAkE,EAcjFiD,EAAUC,GAAGrD,SAAS,UAAU,GAC/BuC,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAE2E,YAAcjE,OAAOC,KAAKX,EAAE2E,UAAU,EAAE/C,SAAS,QAAUqE,EAAUlE,QAAQ,MAAO,GAAG,CAAC,CAA1F,CAA2F,IAC/G+C,EAAML,KAAKwB,EAAUlE,QAAQ,MAAO,GAAG,CAAC,EACxCoC,EAAMM,KAAK,CAACE,aAAUxC,EAAA,IAAI,QAAU8D,EAAUlE,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMM,EAAW,GAAG,CAAC,EAAC9D,EAAC,CAAC,EAE/GgC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAM8E,EAAWJ,2BAA4B,CAAA,CAAI,CAAC,CAAC,IAlBnF1B,EAAMM,KAAK,CAACS,QAAS,CACpBG,KAAMnE,EAAMI,kBACZgE,WAAYpE,EAAMqE,iBAClBC,aAActE,EAAMuE,mBACpBN,GAAIjE,EAAMkE,UAAUrD,QAAQ,QAAS,EAAE,C,CACvC,CAAC,EAEF+C,EAAML,KAAKvD,EAAMkE,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,CAAC,EACtEoC,EAAMM,KAAK,CAACE,aAAU9C,EAAA,IAAI,QAAUX,EAAMkE,UAAUrD,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMzE,EAAMkE,UAAUrD,QAAQ,QAAS,EAAE,EAAEA,QAAQ,MAAO,GAAG,EAAG,GAAG,CAAC,EAACF,EAAC,CAAC,EAE5LsC,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAMD,EAAMkE,UAAUrD,QAAQ,QAAS,EAAE,EAAG8D,2BAA4B,CAAA,CAAI,CAAC,CAAC,IAcxG1B,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAE2E,YAAcjE,OAAOC,KAAKX,EAAE2E,UAAU,EAAE/C,SAAS,QAAUqE,EAAUlE,QAAQ,MAAO,GAAG,CAAC,CAA1F,CAA2F,IAC/G+C,EAAML,KAAKwB,EAAUlE,QAAQ,MAAO,GAAG,CAAC,EACxCoC,EAAMM,KAAK,CAACE,aAAU1C,EAAA,IAAI,QAAUgE,EAAUlE,QAAQ,MAAO,GAAG,GAAI,CAAC2D,MAAO,CAACC,QAAS,CAAC,IAAMM,EAAW,GAAG,CAAC,EAAChE,EAAC,CAAC,GAGpF,UAAxBf,EAAMgF,eAA8B/B,EAAMG,KAAK,SAAAtE,GAAK,OAAAA,EAAE4F,SAAW5F,EAAE4F,QAAQzE,OAAS,IAAM8E,CAAtC,CAA+C,GACtG9B,EAAMM,KAAK,CAACmB,QAAW,CAACzE,KAAM,IAAM8E,EAAWJ,2BAA4B,CAAA,CAAI,CAAC,CAAC,EAKtF,CAAC,EAGGM,EAAY,CAACxB,WAAY,EAAE,EAE/BpB,EAAY3C,OAAO,SAAAZ,GAAK,MAAW,QAAXA,EAAEZ,IAAF,CAAgB,EAAE0B,QAAQ,SAAAsF,GACjDnD,EAAerC,OAAO,SAAAZ,GAAK,MAAgB,WAAhBA,EAAE2B,WAA8C,UAApB3B,EAAEkG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAI,GAC3F,IAAImF,EAAa,GAEZnF,EAAMF,UAAUY,SAAS,IAAI,EAMjCkD,EAAMlE,OAAO,SAAAZ,GAAK,MAAA,CAACkB,EAAMF,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAK,CAAC+C,EAAkBnC,OAAO,SAAAZ,GAAK,OAAAA,EAAEgB,SAAF,CAAW,EAAEsD,KAAK,SAAArE,GAAK,OAAAA,EAAEe,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAAlE,CAAmE,GAAK,CAACyD,EAAWa,KAAK,SAAArE,GAAK,OAAAA,EAAEqG,YAAYvE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAKC,EAAEsG,aAAaxE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAA9I,CAA+I,CAA/W,CAAgX,EAAEc,QAAQ,SAAA0F,GAC3YH,EAAW5B,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEC,IAAK,CAAC,SAAWH,EAAM,EAAG,EAAII,KAAM,SAAWJ,EAAMK,KAAM,CAAC,CAAE,CAAC,CAChG,CAAC,EAPD/B,EAAMhE,QAAQ,SAAA0F,GACbH,EAAW5B,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEC,IAAK,CAAC,SAAWH,EAAM,EAAG,EAAII,KAAM,SAAWJ,EAAMK,KAAM,CAAC,CAAE,CAAC,CAChG,CAAC,EAQER,EAAW7B,OACc,UAAxBtD,EAAMgF,cACTC,EAAUxB,WAAWyB,EAAMU,GAAK,IAAM5F,EAAM4F,IAAM,CACjDC,QAAS,CAAC,SAAU,CAACC,UAAWX,CAAU,E,EAI3CF,EAAUxB,WAAWyB,EAAMU,GAAK,IAAM5F,EAAM4F,IAAM,CACjDC,QAAS,CAAC,IAAM7F,EAAMF,UAAUe,QAAQ,QAAS,EAAE,EAAG,CAACiF,UAAWX,CAAU,E,EAKlD,UAAxBnF,EAAMgF,cACTC,EAAUxB,WAAWyB,EAAMU,GAAK,IAAM5F,EAAM4F,IAAM,SAGlDX,EAAUxB,WAAWyB,EAAMU,GAAK,IAAM5F,EAAM4F,IAAM,IAAM5F,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAG9F,CAAC,CACF,CAAC,EAEDkB,EAAerC,OAAO,SAAAZ,GAAK,MAAgB,WAAhBA,EAAE2B,WAA8C,QAApB3B,EAAEkG,aAA9B,CAAqD,EAAEpF,QAAQ,SAAAI,GACzF,IAAImF,EAAa,GAEjBvB,EAAMlE,OAAO,SAAAZ,GAAK,MAAA,EAACkB,EAAMF,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAMqD,EAAUiB,KAAK,SAAArE,GAAK,OAAAA,EAAEiB,MAAMa,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAA9D,CAA+D,GAAM+C,EAAkBnC,OAAO,SAAAZ,GAAK,OAAAA,EAAEgB,SAAF,CAAW,EAAEsD,KAAK,SAAArE,GAAK,OAAAA,EAAEe,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAAlE,CAAmE,GAAMyD,EAAWa,KAAK,SAAArE,GAAK,OAAAA,EAAEqG,YAAYvE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAKC,EAAEsG,aAAaxE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAA9I,CAA+I,EAAxc,CAAyc,EAAEc,QAAQ,SAAA0F,GACpeH,EAAW5B,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEC,IAAK,CAAC,SAAWH,EAAM,EAAG,EAAII,KAAM,SAAWJ,EAAMK,KAAM,CAAC,CAAE,CAAC,CAChG,CAAC,EAEGR,EAAW7B,SACd2B,EAAUxB,WAAWzD,EAAMF,UAAUe,QAAQ,QAAS,EAAE,GAAK,CAC5DgF,QAAS,CAAC,IAAM7F,EAAMF,UAAUe,QAAQ,QAAS,EAAE,EAAG,CAACiF,UAAWX,CAAU,E,EAG/E,CAAC,EAEDpD,EAAerC,OAAO,SAAAZ,GAAK,MAAoB,UAApBA,EAAEkG,aAAF,CAA2B,EAAEpF,QAAQ,SAAAI,GAC/D,IAAImF,EAAa,GAEjBvB,EAAMlE,OAAO,SAAAZ,GAAK,MAAA,EAACkB,EAAMF,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAMqD,EAAUiB,KAAK,SAAArE,GAAK,OAAAA,EAAEiB,MAAMa,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAA9D,CAA+D,GAAM+C,EAAkBnC,OAAO,SAAAZ,GAAK,OAAAA,EAAEgB,SAAF,CAAW,EAAEsD,KAAK,SAAArE,GAAK,OAAAA,EAAEe,UAAUe,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAAlE,CAAmE,GAAMyD,EAAWa,KAAK,SAAArE,GAAK,OAAAA,EAAEqG,YAAYvE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,GAAKC,EAAEsG,aAAaxE,QAAQ,UAAW,GAAG,EAAEA,QAAQ,MAAO,GAAG,EAAEH,SAAS5B,CAAC,CAA9I,CAA+I,EAAxc,CAAyc,EAAEc,QAAQ,SAAA0F,GACpeH,EAAW5B,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEC,IAAK,CAAC,SAAWH,EAAM,EAAG,EAAII,KAAM,SAAWJ,EAAMK,KAAM,CAAC,CAAE,CAAC,CAChG,CAAC,EAEGR,EAAW7B,OACd2B,EAAUxB,WAAW,SAAWzD,EAAMF,UAAUe,QAAQ,QAAS,EAAE,GAAK,CACvEgF,QAAS,CAAC,SAAU,CAACC,UAAWX,CAAU,E,EAIxB,UAAfhE,GAA0ByC,EAAMlE,OAAO,SAAAZ,GAAK,OAAAkB,EAAMF,UAAUe,QAAQ,UAAW,GAAG,EAAEH,SAAS5B,CAAC,CAAlD,CAAmD,EAAEwE,OACpGM,EAAMlE,OAAO,SAAAZ,GAAK,OAAAkB,EAAMF,UAAUe,QAAQ,UAAW,GAAG,EAAEH,SAAS5B,CAAC,CAAlD,CAAmD,EAAEc,QAAQ,SAAA0F,GAC9EL,EAAUxB,WAAW,SAAWzD,EAAMF,UAAUe,QAAQ,QAAS,EAAE,GAAK,SAAWyE,CACpF,CAAC,EAGDL,EAAUxB,WAAW,SAAWzD,EAAMF,UAAUe,QAAQ,QAAS,EAAE,GAAK,QAG3E,CAAC,EAEDwB,EAAY3C,OAAO,SAAAZ,GAAK,MAAW,QAAXA,EAAEZ,IAAF,CAAgB,EAAE0B,QAAQ,SAAAsF,GACjDnD,EAAerC,OAAO,SAAAZ,GAAK,MAAgB,WAAhBA,EAAE2B,WAA8C,UAApB3B,EAAEkG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAI,GAC3FiF,EAAUxB,WAAWyB,EAAMU,GAAK,IAAM5F,EAAM4F,IAAM,IAAM5F,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAC5F,CAAC,CACF,CAAC,EAE8C,EAA3CrB,OAAOC,KAAKwF,EAAUxB,UAAU,EAAEH,QACrCL,EAAMM,KAAK0B,CAAS,EAGrB1C,EAAW7C,OAAO,SAAAZ,GAAK,OAAAA,EAAEsG,aAAetG,EAAEuG,YAAnB,CAA+B,EAAEzF,QAAQ,SAAAmG,G,MAC/D9C,EAAMM,KAAK,CAACE,aAAU9C,EAAA,IAAIoF,EAAKH,IAAK,CAACI,KAAM,CAAC,IAAMD,EAAKX,YAAYvE,QAAQ,QAAS,EAAE,EAAG,IAAMkF,EAAKV,aAAaxE,QAAQ,QAAS,EAAE,EAAE,EAACF,EAAC,CAAC,EACzIsC,EAAMM,KAAK,CAACC,SAAMvC,EAAA,IAAI8E,EAAKH,IAAK,EAAC3E,EAAC,CAAC,CACpC,CAAC,EAEDgB,EAAarC,QAAQ,SAAAqG,GACpBA,EAAKC,WAAWxG,OAAO,SAAAZ,GAAK,OAAAA,EAAEqH,WAAa,CAACrH,EAAEsH,OAAOhD,KAAK,SAAArE,GAAK,OAAa,OAAZA,EAAEiB,OAA8B,KAAZjB,EAAEiB,QAA6B,OAAZjB,EAAEsH,KAA1C,CAAwD,CAA3F,CAA4F,EAAEzG,QAAQ,SAACuG,EAAWG,G,MAIxIC,EAiBAC,EA4BAC,EAhDDC,EAAiB,GAEO,WAAxBP,EAAUA,WACTI,EAAY,GAChBJ,EAAUC,OAAO1G,OAAO,SAAAZ,GAAK,OAAAA,EAAEkB,OAAqB,OAAZlB,EAAEuH,KAAb,CAA2B,EAAEzG,QAAQ,SAAAI,GAC7DA,EAAMA,OACTuG,EAAUhD,KAAK,CAACoD,IAAK,CAAC,IAAM3G,EAAMA,MAAMa,QAAQ,QAAS,EAAE,EAAG,EAAE,CAAC,EACjE0F,EAAUhD,KAAK,CAACoD,IAAK,CAAC,IAAM3G,EAAMA,MAAMa,QAAQ,QAAS,EAAE,EAAG,KAAK,CAAC,IAGpE0F,EAAUhD,KAAK,CAACoD,IAAK,CAAC3G,EAAMqG,MAAO,EAAE,CAAC,EACtCE,EAAUhD,KAAK,CAACoD,IAAK,CAAC3G,EAAMqG,MAAO,KAAK,CAAC,EAE3C,CAAC,EAEa,EAAVC,IACHC,EAAUhD,KAAK,CAACoD,IAAK,CAAC,IAAMV,EAAKW,WAAY,EAAE,CAAC,EAChDL,EAAUhD,KAAK,CAACoD,IAAK,CAAC,IAAMV,EAAKW,WAAY,KAAK,CAAC,GAGhDJ,EAAqB,GAEX,EAAVF,GACHE,EAAmBjD,KAAK,IAAM0C,EAAKW,UAAU,EAG9CT,EAAUC,OAAO1G,OAAO,SAAAZ,GAAK,OAAAA,EAAEkB,OAAqB,OAAZlB,EAAEuH,KAAb,CAA2B,EAAEzG,QAAQ,SAAAI,GAC7DA,EAAMA,MACTwG,EAAmBjD,KAAK,IAAMvD,EAAMA,MAAMa,QAAQ,QAAS,EAAE,CAAC,EAG9D2F,EAAmBjD,KAAKvD,EAAMqG,KAAK,CAErC,CAAC,EAEDK,EAAeT,EAAKW,YAAc,CACjCrB,MAAO,CAAEC,GAAI,CAAEqB,IAAKN,CAAS,EAAIb,KAAM,EAAGC,OAAIhF,EAAA,IAAI,IAAMwF,EAAUA,WAAYK,EAAkB7F,EAAC,C,IAIlG+F,EAAeT,EAAKW,cAAW3F,EAAA,IAC7B,IAAMkF,EAAUA,WAAY,G,GAGhB,EAAVG,GACHI,EAAeT,EAAKW,YAAY,IAAMT,EAAUA,WAAW5C,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEmB,IAAK,CAAC,IAAMV,EAAKW,WAAY,KAAK,EAAIlB,KAAM,EAAGC,KAAM,IAAMM,EAAKW,UAAU,CAAC,CAAC,EAGzJH,EAAS,GAEbN,EAAUC,OAAO1G,OAAO,SAAAZ,GAAK,OAAAA,EAAEkB,OAAqB,OAAZlB,EAAEuH,KAAb,CAA2B,EAAEzG,QAAQ,SAAAI,GAC7DA,EAAMA,MACTyG,EAAOlD,KAAK,CAACoD,IAAK,CAAC,IAAM3G,EAAMA,MAAMa,QAAQ,QAAS,EAAE,EAAG,KAAK,CAAC,EAGjE4F,EAAOlD,KAAK,CAACoD,IAAK,CAAC3G,EAAMqG,MAAO,KAAK,CAAC,CAExC,CAAC,EAEDF,EAAUC,OAAO1G,OAAO,SAAAZ,GAAK,OAAAA,EAAEkB,OAAqB,OAAZlB,EAAEuH,KAAb,CAA2B,EAAEzG,QAAQ,SAAAI,GAC7DA,EAAMA,MACT0G,EAAeT,EAAKW,YAAY,IAAMT,EAAUA,WAAW5C,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEqB,IAAKJ,CAAM,EAAIf,KAAM,EAAGC,KAAM,IAAM3F,EAAMA,MAAMa,QAAQ,QAAS,EAAE,CAAC,CAAC,CAAC,EAGtJ6F,EAAeT,EAAKW,YAAY,IAAMT,EAAUA,WAAW5C,KAAK,CAACgC,MAAO,CAAEC,GAAI,CAAEqB,IAAKJ,CAAM,EAAIf,KAAM,EAAGC,KAAM3F,EAAMqG,KAAK,CAAC,CAAC,CAE7H,CAAC,GAGFpD,EAAMM,KAAK,CAACE,WAAYiD,CAAc,CAAC,CACxC,CAAC,CACF,CAAC,EAEDrE,EAAYzC,QAAQ,SAAAsF,GACnBjD,EAAarC,QAAQ,SAAAI,G,MACpBiD,EAAMM,KAAK,CAACE,aAAU9C,EAAA,IAAGuE,EAAMU,GAAK,IAAM5F,EAAM4G,YAAa,IAAM5G,EAAM4G,WAAUjG,EAAC,CAAC,CACtF,CAAC,CACF,CAAC,EAGGmG,EAA4B,CAC/B3D,KAAM,E,EAGH5B,EAAQ7B,OAAO,SAAAZ,GAAK,MAAC,CAACA,EAAO,KAAKU,OAAOC,KAAKX,CAAC,EAAEsE,KAAK,SAAArE,GAAK,OAAAA,EAAE2B,SAAS,UAAU,CAArB,CAAsB,GAAO5B,EAAO,KAAKA,EAAO,IAAEsE,KAAK,SAAArE,GAAK,OAAAS,OAAOC,KAAKV,CAAC,EAAEqE,KAAK,SAAAC,GAAK,OAAAA,EAAE3C,SAAS,UAAU,CAArB,CAAsB,CAA/C,CAAgD,CAAnJ,CAAqJ,EAAE4C,QAC9K/B,EAAQ7B,OAAO,SAAAZ,GAAK,MAAC,CAACA,EAAO,KAAKU,OAAOC,KAAKX,CAAC,EAAEsE,KAAK,SAAArE,GAAK,OAAAA,EAAE2B,SAAS,UAAU,CAArB,CAAsB,GAAO5B,EAAO,KAAKA,EAAO,IAAEsE,KAAK,SAAArE,GAAK,OAAAS,OAAOC,KAAKV,CAAC,EAAEqE,KAAK,SAAAC,GAAK,OAAAA,EAAE3C,SAAS,UAAU,CAArB,CAAsB,CAA/C,CAAgD,CAAnJ,CAAqJ,EAAEd,QAAQ,SAAAF,GAClLoH,EAAgC,KAAEvD,KAAK7D,CAAM,CAC9C,CAAC,EAGFiC,EAAa/B,QAAQ,SAAAF,GACpBoH,EAAgC,KAAEvD,KAAK7D,CAAM,CAC9C,CAAC,EAEGoH,EAA0B3D,KAAKG,QAClCL,EAAMM,KAAK,CAACC,OAAQsD,CAAyB,CAAC,EAI3CC,EAAa,CAChBC,IAAK,E,EAGF7E,EAAUmB,QAAU,CAACX,GAA+B,YAAhBA,GAClCR,EAAUmB,OAIVV,EAAY/D,OACXoI,EAAe,GACnBzH,OAAOC,KAAKmD,EAAY/D,IAAI,EAAEe,QAAQ,SAAAsH,GACrC,IAAIC,EAAWpF,EAAe5C,KAAK,SAAAL,GAAK,OAAAA,EAAE8G,KAAOsB,CAAT,CAAkB,EAEtDC,IACHF,EAAaE,EAASrH,UAAUe,QAAQ,QAAS,EAAE,GAAK+B,EAAY/D,KAAKqI,GAE3E,CAAC,EACsC,EAAnC1H,OAAOC,KAAKwH,CAAY,EAAE3D,SAC7BL,EAAMM,KAAK,CACV6D,MAAOH,C,CACP,EAfHF,EAAWC,IAAM,OAoBlB7E,EAAUvC,QAAQ,SAAAgF,GACjBmC,EAAWC,IAAIpC,EAAIgB,IAAM,IAAMhB,EAAI5E,MAAMa,QAAQ,QAAS,EAAE,EAExD4B,GAAcC,IACK,YAAlBA,GACHqE,EAAWC,IAAY,OAAI,CAACK,QAAY,CAACC,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC/IX,EAAWC,IAAY,OAAI,CAACW,QAAY,CAACL,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC/IX,EAAWC,IAAU,KAAI,CAACY,MAAU,CAACN,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC3IX,EAAWC,IAAS,IAAI,CAACa,YAAgB,CAACP,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAChJX,EAAWC,IAAW,MAAI,CAACc,OAAW,CAACR,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC7IX,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAEjH,YAAlBhF,GACRqE,EAAWC,IAAY,OAAI,CAACW,QAAY,CAACL,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC/IX,EAAWC,IAAU,KAAI,CAACY,MAAU,CAACN,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC3IX,EAAWC,IAAS,IAAI,CAACa,YAAgB,CAACP,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAChJX,EAAWC,IAAW,MAAI,CAACc,OAAW,CAACR,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC7IX,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAEjH,UAAlBhF,GACRqE,EAAWC,IAAU,KAAI,CAACY,MAAU,CAACN,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC3IX,EAAWC,IAAS,IAAI,CAACa,YAAgB,CAACP,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAChJX,EAAWC,IAAW,MAAI,CAACc,OAAW,CAACR,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC7IX,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAEjH,UAAlBhF,GACRqE,EAAWC,IAAS,IAAI,CAACa,YAAgB,CAACP,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAChJX,EAAWC,IAAW,MAAI,CAACc,OAAW,CAACR,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC7IX,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAEjH,WAAlBhF,GACRqE,EAAWC,IAAU,KAAI,CAACgB,SAAa,CAACV,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC9IX,EAAWC,IAAU,KAAI,CAACiB,aAAiB,CAACX,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAExH,YAAlBhF,GAIkB,cAAlBA,GACRqE,EAAWC,IAAW,MAAI,CAACc,OAAW,CAACR,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,EAC7IX,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAEjH,WAAlBhF,IACRqE,EAAWC,IAAU,KAAI,CAACe,MAAU,CAACT,KAAQ,IAAM7E,EAAW5B,QAAQ,QAAS,EAAE,EAAG0G,SAAYC,QAAQC,IAAIC,WAAa,iBAAiB,CAAC,GAG9I,CAAC,EAED3F,EAAenC,QAAQ,SAAAI,GACM,YAAxBA,EAAMgF,cACT+B,EAAW/G,EAAM4F,IAAM,CAACsC,KAAQ,IAAMlI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE1C,QAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAACjC,KAAQ,IAAM3D,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE1C,UAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAAEjC,KAAQ,UAAY3D,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAEjD,YAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAACuC,KAAQ,IAAMnI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE1C,YAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAACwC,KAAQ,IAAMpI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE1C,UAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAACyC,OAAU,IAAMrI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE5C,SAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAAC0C,MAAS,IAAMtI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE3C,WAAxBb,EAAMgF,cACd+B,EAAW/G,EAAM4F,IAAM,CAAC2C,UAAa,IAAMvI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAG/EkG,EAAW/G,EAAM4F,IAAM,CAAC4C,MAAS,CAAC/D,QAAS,CAAC,IAAMzE,EAAMF,UAAUe,QAAQ,QAAS,EAAE,EAAG,KAAK,CAAC,CAEhG,CAAC,EAEDoB,EAAarC,QAAQ,SAAAqG,GACO,YAAvBA,EAAKjB,cACR+B,EAAWd,EAAKW,YAAc,CAACsB,KAAQ,IAAOjC,EAAKW,UAAU,EAE9B,QAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAACjD,KAAQ,IAAOsC,EAAKW,UAAU,EAE9B,UAAvBX,EAAKjB,cAEZ+B,EAAWd,EAAKW,YADE,UAAfzF,EAC2B,CAAEwC,KAAQ,UAAasC,EAAKW,UAAU,EAGtC,CAAE4B,MAAS,UAAavC,EAAKW,UAAU,EAGvC,YAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAACuB,KAAQ,IAAOlC,EAAKW,UAAU,EAE9B,YAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAACwB,KAAQ,IAAOnC,EAAKW,UAAU,EAE9B,UAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAACyB,OAAU,IAAOpC,EAAKW,UAAU,EAEhC,SAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAAC0B,MAAS,IAAOrC,EAAKW,UAAU,EAE/B,WAAvBX,EAAKjB,cACb+B,EAAWd,EAAKW,YAAc,CAAC2B,UAAa,IAAOtC,EAAKW,UAAU,EAGlEG,EAAWd,EAAKW,YAAc,CAAC4B,MAAS,CAAC/D,QAAS,CAAC,IAAOwB,EAAKW,WAAY,KAAK,CAAC,CAEnF,CAAC,EAGGvE,EAAYiB,QACfjB,EAAYzC,QAAQ,SAAAsF,GACnBnD,EAAerC,OAAO,SAAAZ,GAAK,MAAgB,WAAhBA,EAAE2B,WAA8C,UAApB3B,EAAEkG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAI,G,MAC3F+G,EAAW7B,EAAMU,GAAK,IAAM5F,EAAM4F,MAAGjF,EAAA,IAAK,IAAMuE,EAAMhH,MAAQ,IAAMgH,EAAMU,GAAK,IAAM5F,EAAM4F,GAAEjF,EAC9F,CAAC,EAEDsB,EAAarC,QAAQ,SAAAI,G,MACpB+G,EAAW7B,EAAMU,GAAK,IAAM5F,EAAM4G,cAAWjG,EAAA,IAAK,IAAMuE,EAAMhH,MAAO,IAAMgH,EAAMU,GAAK,IAAM5F,EAAM4G,WAAUjG,EAC7G,CAAC,CACF,CAAC,EAGFsC,EAAMM,KAAK,CAACkF,OAAQ1B,CAAU,CAAC,IAI3B2B,EAAkB,CACrB1B,IAAK,C,EAGNjF,EAAenC,QAAQ,SAAAI,GACM,YAAxBA,EAAMgF,cACT0D,EAAgB1I,EAAM4F,IAAM,CAACsC,KAAM,IAAMlI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE7C,QAAxBb,EAAMgF,cACd0D,EAAgB1I,EAAM4F,IAAM,CAACjC,KAAM,IAAM3D,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE7C,UAAxBb,EAAMgF,cACd0D,EAAgB1I,EAAM4F,IAAM,CAACjC,KAAM,CAAC,EAEJ,YAAxB3D,EAAMgF,cACd0D,EAAgB1I,EAAM4F,IAAM,CAACuC,KAAM,IAAMnI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAE7C,YAAxBb,EAAMgF,cACd0D,EAAgB1I,EAAM4F,IAAM,CAACwC,KAAM,IAAMpI,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAAC,EAG7E6H,EAAgB1I,EAAM4F,IAAM,IAAM5F,EAAMF,UAAUe,QAAQ,QAAS,EAAE,CAEvE,CAAC,EAEDoB,EAAarC,QAAQ,SAAAqG,GAEnByC,EAAgBzC,EAAKW,YADT,YAATX,EACgC,CAACiC,KAAM,IAAOjC,EAAKW,UAAU,EAE/C,QAATX,EAC2B,CAACtC,KAAM,IAAOsC,EAAKW,UAAU,EAE/C,UAATX,EAC2B,CAACtC,KAAM,CAAC,EAE1B,YAATsC,EAC2B,CAACkC,KAAM,IAAOlC,EAAKW,UAAU,EAE/C,YAATX,EAC2B,CAACmC,KAAM,IAAOnC,EAAKW,UAAU,EAG7B,IAAMX,EAAKW,UAEhD,CAAC,EAGGvE,CAAAA,EAAYiB,QAA0B,SAAfnC,GAAwC,UAAfA,GACnDkB,EAAYzC,QAAQ,SAAAsF,GACnBnD,EAAerC,OAAO,SAAAZ,GAAK,MAAgB,WAAhBA,EAAE2B,WAA8C,UAApB3B,EAAEkG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAI,G,MAC3F0I,EAAgBxD,EAAMU,GAAK,IAAM5F,EAAM4F,MAAGjF,EAAA,IAAK,IAAMuE,EAAMhH,MAAO,IAAMgH,EAAMU,GAAK,IAAM5F,EAAM4F,GAAEjF,EAClG,CAAC,EAEDsB,EAAarC,QAAQ,SAAAI,G,MACpB0I,EAAgBxD,EAAMU,GAAK,IAAM5F,EAAM4G,cAAWjG,EAAA,IAAK,IAAMuE,EAAMhH,MAAO,IAAMgH,EAAMU,GAAK,IAAM5F,EAAM4G,WAAUjG,EAClH,CAAC,CACF,CAAC,EAGFsC,EAAMM,KAAK,CAACoF,SAAUD,CAAe,CAAC,GAInC9F,EAAY/D,MACfoE,EAAMM,KAAK,CACV6D,MAAOxE,EAAY/D,I,CACnB,EAGiB,UAAfsC,GAA6C,EAAnBgB,EAAUmB,OACvC,I,WAASS,GAqCR,I,MAqBK6E,EACAC,EAEAC,EA5DDC,EAAY,CAAC/B,IAAK,CAAC,EAgCnBgC,GA9BJD,EAAU5G,EAAU4B,GAAG6B,IAAM,CAC5BoB,MAAG/F,EAAA,IAAIkB,EAAU4B,GAAG6B,IAAK,QAAUzD,EAAU4B,GAAG6B,GAAE3E,E,EAG/C8C,IAAM5B,EAAUmB,OAAS,GAC5BvB,EAAenC,QAAQ,SAAAI,GACtB+I,EAAU5G,EAAU4B,GAAG6B,IAAI5F,EAAM4F,IAAM,IAAM5F,EAAM4F,EACpD,CAAC,EAED3D,EAAarC,QAAQ,SAAAI,GACpB+I,EAAU5G,EAAU4B,GAAG6B,IAAI5F,EAAM4G,YAAc,IAAM5G,EAAM4G,UAC5D,CAAC,GAGDmC,EAAU5G,EAAU4B,GAAG6B,IAAIzD,EAAU4B,EAAI,GAAG6B,IAAM,IAAMzD,EAAU4B,EAAI,GAAG6B,GAG1EvD,EAAYzC,QAAQ,SAAAqJ,GACnBlH,EAAerC,OAAO,SAAAX,GAAK,MAAgB,WAAhBA,EAAE0B,WAA8C,UAApB1B,EAAEiG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAuH,GAC3F4B,EAAUE,EAASrD,GAAK,IAAMuB,EAASvB,IAAM,EAC7CmD,EAAU5G,EAAU4B,GAAG6B,IAAIqD,EAASrD,GAAK,IAAMuB,EAASvB,IAAM,IAAMqD,EAASrD,GAAK,IAAMuB,EAASvB,EAClG,CAAC,EAED3D,EAAarC,QAAQ,SAAAI,GACpB+I,EAAU5G,EAAU4B,GAAG6B,IAAIqD,EAASrD,GAAK,IAAM5F,EAAM4G,YAAc,IAAMqC,EAASrD,GAAK,IAAM5F,EAAM4G,UACpG,CAAC,CACF,CAAC,EAED3D,EAAMM,KAAK,CAACoF,SAAUI,CAAS,CAAC,EAElB,CACb/B,IAAK,E,GAGGkC,EAAI,EAAGA,EAAInF,EAAGmF,CAAC,GACvBF,EAAQhC,IAAI7E,EAAU+G,GAAGtD,IAAM,QAAUzD,EAAU+G,GAAGtD,GAGvDoD,EAAQ7G,EAAU4B,GAAG6B,IAAM,CAC1B4C,MAAO,IAAMrG,EAAU4B,GAAG6B,E,EAG3BvD,EAAYzC,QAAQ,SAAAqJ,GACnBlH,EAAerC,OAAO,SAAAX,GAAK,MAAgB,WAAhBA,EAAE0B,WAA8C,UAApB1B,EAAEiG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAuH,G,MAC3F6B,EAAQC,EAASrD,GAAK,IAAMuB,EAASvB,MAAGjF,EAAA,IAAK,IAAMsI,EAAS/K,MAAO,IAAM+K,EAASrD,GAAK,IAAMuB,EAASvB,GAAEjF,EACzG,CAAC,EAEDsB,EAAarC,QAAQ,SAAAI,G,MACpBgJ,EAAQC,EAASrD,GAAK,IAAM5F,EAAM4G,cAAWjG,EAAA,IAAK,IAAMsI,EAAS/K,MAAO,IAAM+K,EAASrD,GAAK,IAAM5F,EAAM4G,WAAUjG,EACnH,CAAC,CACF,CAAC,EAEDsC,EAAMM,KAAK,CAACkF,OAAQO,CAAO,CAAC,EAExBpG,EAAY/D,OACX+J,EAAWpJ,OAAOC,KAAKmD,EAAY/D,IAAI,EACvCgK,EAAO,GAEPC,EAAc,GAClB3G,EAAUvC,QAAQ,SAACgF,EAAKuE,GACN,EAAbA,IACHL,GAAe,OAASK,EAAa,GAAK,KAGvCP,EAASlI,SAAS,WAAayI,EAAa,EAAE,EACjDN,EAAKC,EAAc,WAAaK,EAAa,IAAMvG,EAAY/D,KAAK,WAAasK,EAAa,IAG9FN,EAAKC,EAAc,WAAaK,EAAa,IAAM,CAErD,CAAC,EAEDP,EAASlJ,OAAO,SAAAZ,GAAK,MAAA,CAACA,EAAEsK,WAAW,SAAS,CAAvB,CAAwB,EAAExJ,QAAQ,SAAAyJ,GACtDR,EAAKC,EAAcO,GAAOzG,EAAY/D,KAAKwK,EAC5C,CAAC,EAEDpG,EAAMM,KAAK,CAAC6D,MAAOyB,CAAI,CAAC,E,EA/EjB9E,EAAI5B,EAAUmB,OAAS,EAAQ,GAALS,EAAQA,CAAC,G,EAAnCA,CAAC,EAsFPuF,EAAM,K,iBAGH,O,sBAAA,CAAA,EAAMzG,EAAgB0G,UAAUtG,EAAO,CAACuG,aAAc,CAAA,EAAMC,eAAkD,0BAAlCnL,KAAKoL,aAAuB,SAAgC,YAAc,SAAS,EAAG,CAAA,CAAI,G,cAA5KJ,EAAM3I,EAAAK,KAAA,E,+BAGN2I,QAAQC,IAAIC,CAAG,E,aAGZC,EAAY,GAEZR,GACHjH,EAAYzC,QAAQ,SAAAqJ,GACnBlH,EAAerC,OAAO,SAAAX,GAAK,MAAgB,WAAhBA,EAAE0B,WAA8C,UAApB1B,EAAEiG,aAA9B,CAAuD,EAAEpF,QAAQ,SAAAuH,GACrE,QAAlB8B,EAAS/K,KACZ4L,EAAUb,EAASrD,GAAK,IAAMuB,EAASvB,IAAM0D,EAAIS,IAAI,SAAAjL,GAAK,OAAAA,EAAEmK,EAASrD,GAAK,IAAMuB,EAASvB,KAAO,CAAtC,CAAuC,EAAEoE,OAAO,SAAClL,EAAGC,GAAM,OAAAD,EAAIC,CAAJ,EAAO,CAAC,EAElG,QAAlBkK,EAAS/K,OACjB4L,EAAUb,EAASrD,GAAK,IAAMuB,EAASvB,KAAM,EAAAlI,SAAAuM,OAAMX,EAAIS,IAAI,SAAAjL,GAAK,OAAAA,EAAEmK,EAASrD,GAAK,IAAMuB,EAASvB,KAAO,CAAtC,CAAuC,EAAEoE,OAAO,SAAClL,EAAGC,GAAM,OAAAD,EAAIC,CAAJ,EAAO,CAAC,EAAIuK,EAAIhG,MAAM,EAElJ,CAAC,EAEDrB,EAAarC,QAAQ,SAAAsK,GACE,QAAlBjB,EAAS/K,KACZ4L,EAAUb,EAASrD,GAAK,IAAMsE,EAAUtD,YAAc0C,EAAIS,IAAI,SAAAjL,GAAK,OAAAA,EAAEmK,EAASrD,GAAK,IAAMsE,EAAUtD,aAAe,CAA/C,CAAgD,EAAEoD,OAAO,SAAClL,EAAGC,GAAM,OAAAD,EAAIC,CAAJ,EAAO,CAAC,EAEpH,QAAlBkK,EAAS/K,OACjB4L,EAAUb,EAASrD,GAAK,IAAMsE,EAAUtD,aAAc,EAAAlJ,SAAAuM,OAAMX,EAAIS,IAAI,SAAAjL,GAAK,OAAAA,EAAEmK,EAASrD,GAAK,IAAMsE,EAAUtD,aAAe,CAA/C,CAAgD,EAAEoD,OAAO,SAAClL,EAAGC,GAAM,OAAAD,EAAIC,CAAJ,EAAO,CAAC,EAAIuK,EAAIhG,MAAM,EAEpK,CAAC,CACF,CAAC,EAGE6G,EAAS,CAAC,CACbzG,MAAO4F,EAAMA,EAAIhG,OAAS,EAC1B8G,QAASd,EAAO1G,EAAYyH,MAAQf,EAAIgB,OAAO,EAAG1H,EAAYyH,KAAK,EAAIf,EAAO,GAC9EiB,OAAQT,C,GAGTtL,EAAQ2L,CAAM,E,gCAEf,CACF,C,EAED,CACF,CAr2BAK,QAAA7M,yBAAAA","file":"report-builder.js","sourcesContent":["import SimpleSchema from 'simpl-schema';\nimport { MethodManager } from '../managers/method.manager';\nimport { PaginationOptions, PaginationOptionsSchema } from '../models/pagination.model';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { getReportLookupSchemas, buildTree, mongoCommand } from '../util/schema-report-builder';\nimport { round } from '../util/common';\n\nexport function loadReportBuilderMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\treportBuilderBuildTree: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tcollection_root: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(collection_root: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet lookupSchemaData = getReportLookupSchemas(collection_root).sort((a, b) => a.collection_name.localeCompare(b.collection_name));\n\t\t\t\t\tlet lookupSchemaTree = lookupSchemaData.find(a => a.is_root === true).tree;\n\n\t\t\t\t\tlet treeItems = buildTree(collection_root, lookupSchemaTree);\n\n\t\t\t\t\tObject.keys(lookupSchemaTree).filter(a => a.endsWith('(Lookup)')).forEach(lookup => {\n\t\t\t\t\t\tlet fieldPath = lookup.split('.');\n\t\t\t\t\t\tlet field = null;\n\t\t\t\t\t\tfieldPath.forEach(path => {\n\t\t\t\t\t\t\tif (!field) {\n\t\t\t\t\t\t\t\tfield = treeItems.find(a => a.fieldName === path);\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 = field.children.find(a => a.fieldName === path);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t\tfield.children = buildTree(lookupSchemaTree[lookup].lookup_collection, lookupSchemaData.find(a => a.collection_name === lookupSchemaTree[lookup].lookup_collection).tree, field);\n\t\t\t\t\t});\n\n\t\t\t\t\t// console.log('----------- Tree Items -----------', treeItems);\n\n\t\t\t\t\tresolve({isLeaf: false, children: treeItems});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportBuilderGetDistinctValue: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\ttreeLeaf: {\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(treeLeaf) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tif (treeLeaf.fieldType === 'String') {\n\t\t\t\t\t\tif (treeLeaf.fieldPath.includes('(Lookup)')) {\n\t\t\t\t\t\t\tresolve(await mongoCommand('distinct', treeLeaf.collection_name, treeLeaf.fieldPath.replace(/^.+\\(.+\\) \\(Lookup\\)\\.\\$\\./g, '').replace(/\\.\\$/g, '')));\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tresolve(await mongoCommand('distinct', treeLeaf.collection_name, treeLeaf.fieldPath.replace(/\\.\\$/g, '')));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tresolve([]);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\treportBuilderGetResults: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\treportType: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\trootCollectionName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\toptions: {\n\t\t\t\t\ttype: PaginationOptionsSchema\n\t\t\t\t},\n\t\t\t\tfilters: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filters.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfilterArrays: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filterArrays.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfilterArrayFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'filterArrayFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tselectedFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'selectedFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\toptional: true,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tcustomFields: {\n\t\t\t\t\ttype: Array,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\t'customFields.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\toptional: true,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tgroupsRow: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'groupsRow.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tfieldsTotal: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fieldsTotal.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tfieldsLink: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fieldsLink.$': {\n\t\t\t\t\ttype: Object,\n\t\t\t\t\tblackbox: true\n\t\t\t\t},\n\t\t\t\tdate_field: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tdate_interval: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tdisplayType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(reportType: string, rootCollectionName: string, rootOptions: PaginationOptions, filters: any[] = [], filterArrays: any[] = [], filterArrayFields: any[] = [], selectedFields: any[] = [], customFields: any[] = [], groupsRow: any[] = [], fieldsTotal: any[] = [], fieldsLink: any[] = [], date_field = '', date_interval = '', displayType = '') {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\n\t\t\t\t\tlet modelCollection = ResolveIOServer.getMongoManager().collection(rootCollectionName);\n\n\t\t\t\t\tif (!modelCollection) {\n\t\t\t\t\t\treject('Invalid collection');\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\t// Query\n\t\t\t\t\t\tlet query = [];\n\t\t\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t// Non-Lookup Match Filters\n\t\t\t\t\t\tlet initialQueryMatchCondition = {\n\t\t\t\t\t\t\t$and: []\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\t// selectedFields.filter(a => a.collection_name === rootCollectionName).forEach(field => {\n\t\t\t\t\t\t// \tinitialQueryMatchCondition['$and'].push({\n\t\t\t\t\t\t// \t\t$and: [\n\t\t\t\t\t\t// \t\t\t{[field.fieldPath.replace(/\\.\\$/g, '')]: {$exists: 1}},\n\t\t\t\t\t\t// \t\t\t// {[field.fieldPath.replace(/\\.\\$/g, '')]: {$ne: ''}},\n\t\t\t\t\t\t// \t\t\t{[field.fieldPath.replace(/\\.\\$/g, '')]: {$ne: null}},\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\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tfilters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).forEach(filter => {\n\t\t\t\t\t\t\t\tinitialQueryMatchCondition['$and'].push(filter);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Add filter to query\n\t\t\t\t\t\t// if (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length || selectedFields.filter(a => !a.fieldPath.includes('(Lookup')).length) {\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && !Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && !a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t$match: initialQueryMatchCondition\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Add count\n\t\t\t\t\t\tquery.push({ $addFields: { count: { $sum: 1} } });\n\n\t\t\t\t\t\tlet sizes = [];\n\n\t\t\t\t\t\tfilterArrayFields.filter(a => a.fieldPath).forEach(filterField => {\n\t\t\t\t\t\t\tlet fieldData = filterField.fieldPath.split('.$');\n\n\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === filterField.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\tfrom: filterField.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\tlocalField: filterField.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\tforeignField: filterField.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\tas: filterField.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\tsizes.push(filterField.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + filterField.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + filterField.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + filterField.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: true}});\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\telse {\n\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: true}});\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\n\t\t\t\t\t\t// Groups - Lookups / Sizes / Unwinds\n\t\t\t\t\t\tgroupsRow.forEach(row => {\n\t\t\t\t\t\t\tif (row.field.includes('$')) {\n\t\t\t\t\t\t\t\tlet fieldData = row.field.split('.$');\n\n\t\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === row.treeItem.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\t\tfrom: row.treeItem.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\t\tlocalField: row.treeItem.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\t\tforeignField: row.treeItem.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\t\tas: row.treeItem.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(row.treeItem.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + row.treeItem.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + row.treeItem.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + row.treeItem.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: 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 {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\.\\$\\./g, '.').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath.replace(/\\.\\$\\./g, '.'), []]}}}});\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath.replace(/\\.\\$\\./g, '.'), preserveNullAndEmptyArrays: true}});\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\tfieldPath += '.$';\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\n\t\t\t\t\t\t// Selected Fields - Lookups / Sizes / Unwinds\n\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\tif (field.fieldPath.includes('$')) {\n\t\t\t\t\t\t\t\tlet fieldData = field.fieldPath.split('.$');\n\n\t\t\t\t\t\t\t\tlet fieldPath = '';\n\n\t\t\t\t\t\t\t\tfor (let i = 0; i < fieldData.length - 1; i++) {\n\t\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\tfieldPath += fieldData[i];\n\n\t\t\t\t\t\t\t\t\tif (fieldPath.split('.$')[fieldPath.split('.$').length - 1].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$lookup && a.$lookup.as === field.lookup_as.replace(/\\.\\$/g, ''))) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$lookup: {\n\t\t\t\t\t\t\t\t\t\t\t\tfrom: field.lookup_collection,\n\t\t\t\t\t\t\t\t\t\t\t\tlocalField: field.lookup_local_key,\n\t\t\t\t\t\t\t\t\t\t\t\tforeignField: field.lookup_foreign_key,\n\t\t\t\t\t\t\t\t\t\t\t\tas: field.lookup_as.replace(/\\.\\$/g, '')\n\t\t\t\t\t\t\t\t\t\t\t}});\n\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(field.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + field.lookup_as.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + field.lookup_as.replace(/\\.\\$/g, '').replace(/\\./g, '_'), []]}}}});\n\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + field.lookup_as.replace(/\\.\\$/g, ''), preserveNullAndEmptyArrays: true}});\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\tif (!fieldData[i].includes('(Lookup)')) {\n\t\t\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\t\t\t\n\t\t\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: true}});\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\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\tif (!query.some(a => a.$addFields && Object.keys(a.$addFields).includes('size_' + fieldPath.replace(/\\./g, '_')))) {\n\t\t\t\t\t\t\t\t\t\t\tsizes.push(fieldPath.replace(/\\./g, '_'));\n\t\t\t\t\t\t\t\t\t\t\tquery.push({$addFields: {['size_' + fieldPath.replace(/\\./g, '_')]: {$size: {$ifNull: ['$' + fieldPath, []]}}}});\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (field.leafValueType !== 'Count' && !query.some(a => a.$unwind && a.$unwind.path === '$' + fieldPath)) {\n\t\t\t\t\t\t\t\t\t\t\tquery.push({'$unwind': {path: '$' + fieldPath, preserveNullAndEmptyArrays: 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}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// Divide all number fields by sizes\n\t\t\t\t\t\tlet divFields = {$addFields: {}};\n\n\t\t\t\t\t\tfieldsTotal.filter(a => a.type === 'sum').forEach(total => {\n\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\tlet multFields = [];\n\n\t\t\t\t\t\t\t\tif (!field.fieldPath.includes('.$')) {\n\t\t\t\t\t\t\t\t\tsizes.forEach(size => {\n\t\t\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\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\telse {\n\t\t\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\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\tif (multFields.length) {\n\t\t\t\t\t\t\t\t\tif (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = {\n\t\t\t\t\t\t\t\t\t\t\t$divide: ['$count', {$multiply: multFields}]\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 {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = {\n\t\t\t\t\t\t\t\t\t\t\t$divide: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), {$multiply: multFields}]\n\t\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\telse {\n\t\t\t\t\t\t\t\t\tif (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = '$count';\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\tdivFields.$addFields[total.id + '_' + field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\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\n\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' && a.leafValueType === 'Sum').forEach(field => {\n\t\t\t\t\t\t\tlet multFields = [];\n\n\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !groupsRow.some(b => b.field.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (multFields.length) {\n\t\t\t\t\t\t\t\tdivFields.$addFields[field.fieldPath.replace(/\\.\\$/g, '')] = {\n\t\t\t\t\t\t\t\t\t$divide: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), {$multiply: multFields}]\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\n\t\t\t\t\t\tselectedFields.filter(a => a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\tlet multFields = [];\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tsizes.filter(a => !field.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) && !groupsRow.some(b => b.field.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !filterArrayFields.filter(a => a.fieldPath).some(b => b.fieldPath.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a)) && !fieldsLink.some(b => b.field_first.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a) || b.field_second.replace(/\\.\\$\\./g, '_').replace(/\\./g, '_').includes(a))).forEach(size => {\n\t\t\t\t\t\t\t\tmultFields.push({$cond: { if: { $gt: ['$size_' + size, 0 ] }, then: '$size_' + size, else: 1 }});\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\tif (multFields.length) {\n\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = {\n\t\t\t\t\t\t\t\t\t$divide: ['$count', {$multiply: multFields}]\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tif (reportType !== 'Dated' && sizes.filter(a => field.fieldPath.replace(/\\.\\$\\./g, '_').includes(a)).length) {\n\t\t\t\t\t\t\t\t\tsizes.filter(a => field.fieldPath.replace(/\\.\\$\\./g, '_').includes(a)).forEach(size => {\n\t\t\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = '$size_' + size;\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\telse {\n\t\t\t\t\t\t\t\t\tdivFields.$addFields['count_' + field.fieldPath.replace(/\\.\\$/g, '')] = '$count';\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\n\t\t\t\t\t\tfieldsTotal.filter(a => a.type === 'avg').forEach(total => {\n\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\tdivFields.$addFields[total.id + '_' + field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (Object.keys(divFields.$addFields).length > 0) {\n\t\t\t\t\t\t\tquery.push(divFields);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfieldsLink.filter(a => a.field_first && a.field_second).forEach(link => {\n\t\t\t\t\t\t\tquery.push({$addFields: {[link.id]: {$cmp: ['$' + link.field_first.replace(/\\.\\$/g, ''), '$' + link.field_second.replace(/\\.\\$/g, '')]}}});\n\t\t\t\t\t\t\tquery.push({$match: {[link.id]: 0}});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\tcust.operations.filter(a => a.operation && !a.fields.some(b => (b.field === null || b.field === '') && b.value === null)).forEach((operation, opIndex) => {\n\t\t\t\t\t\t\t\tlet custFieldGroup = {};\n\n\t\t\t\t\t\t\t\tif (operation.operation === 'divide') {\n\t\t\t\t\t\t\t\t\tlet condCheck = [];\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), 0]});\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), null]});\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\tcondCheck.push({$eq: [field.value, 0]});\n\t\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: [field.value, null]});\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 (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + cust.selFieldId, 0]});\n\t\t\t\t\t\t\t\t\t\tcondCheck.push({$eq: ['$' + cust.selFieldId, null]});\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tlet tmpOperationFields = [];\n\n\t\t\t\t\t\t\t\t\tif (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\ttmpOperationFields.push('$' + cust.selFieldId);\n\t\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\ttmpOperationFields.push('$' + field.field.replace(/\\.\\$/g, ''));\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\ttmpOperationFields.push(field.value);\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\tcustFieldGroup[cust.selFieldId] = {\n\t\t\t\t\t\t\t\t\t\t$cond: { if: { $or: condCheck }, then: 0, else: {['$' + operation.operation]: tmpOperationFields} }\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\telse {\n\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId] = {\n\t\t\t\t\t\t\t\t\t\t['$' + operation.operation]: []\n\t\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\t\tif (opIndex > 0) {\n\t\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $eq: ['$' + cust.selFieldId, null] }, then: 0, else: '$' + cust.selFieldId}});\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tlet condOr = [];\n\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcondOr.push({$eq: ['$' + field.field.replace(/\\.\\$/g, ''), null]});\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\tcondOr.push({$eq: [field.value, null]});\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t});\n\t\t\n\t\t\t\t\t\t\t\t\toperation.fields.filter(a => a.field || a.value !== null).forEach(field => {\n\t\t\t\t\t\t\t\t\t\tif (field.field) {\n\t\t\t\t\t\t\t\t\t\t\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $or: condOr }, then: 0, else: '$' + field.field.replace(/\\.\\$/g, '')}});\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\tcustFieldGroup[cust.selFieldId]['$' + operation.operation].push({$cond: { if: { $or: condOr }, then: 0, else: field.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\n\t\t\t\t\t\t\t\tquery.push({$addFields: custFieldGroup});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\tquery.push({$addFields:{[total.id + '_' + field.selFieldId]: '$' + field.selFieldId}});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\t// Filters - Lookups / Arrays\n\t\t\t\t\t\tlet queryMatchConditionLookup = {\n\t\t\t\t\t\t\t$and: []\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (filters.filter(a => (!a['$or'] && Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).length) {\n\t\t\t\t\t\t\tfilters.filter(a => (!a['$or'] && Object.keys(a).some(b => b.includes('(Lookup)'))) || (a['$or'] && a['$or'].some(b => Object.keys(b).some(c => c.includes('(Lookup)'))))).forEach(filter => {\n\t\t\t\t\t\t\t\tqueryMatchConditionLookup['$and'].push(filter);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfilterArrays.forEach(filter => {\n\t\t\t\t\t\t\tqueryMatchConditionLookup['$and'].push(filter);\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif (queryMatchConditionLookup.$and.length) {\n\t\t\t\t\t\t\tquery.push({$match: queryMatchConditionLookup});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Group\n\t\t\t\t\t\tlet queryGroup = {\n\t\t\t\t\t\t\t_id: {}\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (groupsRow.length || !displayType || displayType === 'grouped') {\n\t\t\t\t\t\t\tif (!groupsRow.length) {\n\t\t\t\t\t\t\t\tqueryGroup._id = '$_id';\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tif (rootOptions.sort) { \n\t\t\t\t\t\t\t\t\tlet groupedSorts = {};\n\t\t\t\t\t\t\t\t\tObject.keys(rootOptions.sort).forEach(sortField => {\n\t\t\t\t\t\t\t\t\t\tlet selField = selectedFields.find(a => a.id === sortField);\n\n\t\t\t\t\t\t\t\t\t\tif (selField) {\n\t\t\t\t\t\t\t\t\t\t\tgroupedSorts[selField.fieldPath.replace(/\\.\\$/g, '')] = rootOptions.sort[sortField];\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\tif (Object.keys(groupedSorts).length > 0) {\n\t\t\t\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t\t\t\t$sort: groupedSorts\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\tgroupsRow.forEach(row => {\n\t\t\t\t\t\t\t\tqueryGroup._id[row.id] = '$' + row.field.replace(/\\.\\$/g, '');\n\n\t\t\t\t\t\t\t\tif (date_field && date_interval) {\n\t\t\t\t\t\t\t\t\tif (date_interval === 'Seconds') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['second'] = {'$second' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['minute'] = {'$minute' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Minutes') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['minute'] = {'$minute' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Hours') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['hour'] = {'$hour' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Daily') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['day'] = {'$dayOfMonth' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Weekly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['week'] = {'$isoWeek' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$isoWeekYear' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Monthly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Quarterly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['month'] = {'$month' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (date_interval === 'Yearly') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup._id['year'] = {'$year' : {'date': '$' + date_field.replace(/\\.\\$/g, ''), 'timezone': process.env.TZ_CLIENT || 'America/Chicago'}};\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\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\tif (field.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$avg': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$sum': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = { '$sum': '$count_' + field.fieldPath.replace(/\\.\\$/g, '') };\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$min': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$max': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'First') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$first': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Last') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$last': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Unique') {\n\t\t\t\t\t\t\t\t\tqueryGroup[field.id] = {'$addToSet': '$' + field.fieldPath.replace(/\\.\\$/g, '')};\t\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\tqueryGroup[field.id] = {'$push': {$ifNull: ['$' + field.fieldPath.replace(/\\.\\$/g, ''), null]}};\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\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\t\tif (cust.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$avg': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$sum': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tif (reportType === 'Dated') {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = { '$sum': '$count_' + cust.selFieldId };\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\tqueryGroup[cust.selFieldId] = { '$push': '$count_' + cust.selFieldId };\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\telse if (cust.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$min': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$max': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'First') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$first': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Last') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$last': '$' + cust.selFieldId};\t\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust.leafValueType === 'Unique') {\n\t\t\t\t\t\t\t\t\tqueryGroup[cust.selFieldId] = {'$addToSet': '$' + cust.selFieldId};\t\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\tqueryGroup[cust.selFieldId] = {'$push': {$ifNull: ['$' + cust.selFieldId, null]}};\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\t// Totals\n\t\t\t\t\t\t\tif (fieldsTotal.length) {\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[total.id + '_' + field.id] = {['$' + total.type] : '$' + total.id + '_' + field.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryGroup[total.id + '_' + field.selFieldId] = {['$' + total.type]: '$' + total.id + '_' + field.selFieldId};\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\tquery.push({$group: queryGroup});\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t//Projection\n\t\t\t\t\t\t\tlet queryProjection = {\n\t\t\t\t\t\t\t\t_id: 1\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\tif (field.leafValueType === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$avg: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$sum: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$sum: 1};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$min: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (field.leafValueType === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[field.id] = {$max: '$' + field.fieldPath.replace(/\\.\\$/g, '')};\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\tqueryProjection[field.id] = '$' + field.fieldPath.replace(/\\.\\$/g, '');\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\tcustomFields.forEach(cust => {\n\t\t\t\t\t\t\t\tif (cust === 'Average') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$avg: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Sum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$sum: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Count') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$sum: 1};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Minimum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$min: '$' + cust.selFieldId};\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse if (cust === 'Maximum') {\n\t\t\t\t\t\t\t\t\tqueryProjection[cust.selFieldId] = {$max: '$' + cust.selFieldId};\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\tqueryProjection[cust.selFieldId] = '$' + cust.selFieldId;\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\t//Totals\n\t\t\t\t\t\t\tif (fieldsTotal.length && (reportType === 'List' || reportType === 'Dated')) {\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(total => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(a => a.fieldType === 'Number' || a.leafValueType === 'Count').forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryProjection[total.id + '_' + field.id] = {['$' + total.type]: '$' + total.id + '_' + field.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tqueryProjection[total.id + '_' + field.selFieldId] = {['$' + total.type]: '$' + total.id + '_' + field.selFieldId};\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\tquery.push({$project: queryProjection});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// SORT\n\t\t\t\t\t\tif (rootOptions.sort) {\n\t\t\t\t\t\t\tquery.push({\n\t\t\t\t\t\t\t\t$sort: rootOptions.sort\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (reportType === 'Group' && groupsRow.length > 1) {\n\t\t\t\t\t\t\tfor (let i = groupsRow.length - 1; i >= 1; i--) {\n\t\t\t\t\t\t\t\tlet projQuery = {_id: 1};\n\n\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id] = {\n\t\t\t\t\t\t\t\t\t_id: {[groupsRow[i].id]: '$_id.' + groupsRow[i].id}\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tif (i === groupsRow.length - 1) {\n\t\t\t\t\t\t\t\t\tselectedFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][field.id] = '$' + field.id;\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][field.selFieldId] = '$' + field.selFieldId;\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\telse {\n\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][groupsRow[i + 1].id] = '$' + groupsRow[i + 1].id;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[totField.id + '_' + selField.id] = 1;\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][totField.id + '_' + selField.id] = '$' + totField.id + '_' + selField.id;\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tprojQuery[groupsRow[i].id][totField.id + '_' + field.selFieldId] = '$' + totField.id + '_' + field.selFieldId;\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\tquery.push({$project: projQuery});\n\n\t\t\t\t\t\t\t\tlet grQuery = {\n\t\t\t\t\t\t\t\t\t_id: {}\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tfor (let j = 0; j < i; j++) {\n\t\t\t\t\t\t\t\t\tgrQuery._id[groupsRow[j].id] = '$_id.' + groupsRow[j].id;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tgrQuery[groupsRow[i].id] = {\n\t\t\t\t\t\t\t\t\t$push: '$' + groupsRow[i].id\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\t\tgrQuery[totField.id + '_' + selField.id] = {['$' + totField.type]: '$' + totField.id + '_' + selField.id};\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tcustomFields.forEach(field => {\n\t\t\t\t\t\t\t\t\t\tgrQuery[totField.id + '_' + field.selFieldId] = {['$' + totField.type]: '$' + totField.id + '_' + field.selFieldId};\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\tquery.push({$group: grQuery});\n\n\t\t\t\t\t\t\t\tif (rootOptions.sort) {\n\t\t\t\t\t\t\t\t\tlet sortKeys = Object.keys(rootOptions.sort);\n\t\t\t\t\t\t\t\t\tlet sort = {};\n\n\t\t\t\t\t\t\t\t\tlet groupString = '';\n\t\t\t\t\t\t\t\t\tgroupsRow.forEach((row, groupIndex) => {\n\t\t\t\t\t\t\t\t\t\tif (groupIndex > 0) {\n\t\t\t\t\t\t\t\t\t\t\tgroupString += 'gr_' + (groupIndex + 1) + '.';\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif (sortKeys.includes('_id.gr_' + (groupIndex + 1))) {\n\t\t\t\t\t\t\t\t\t\t\tsort[groupString + '_id.gr_' + (groupIndex + 1)] = rootOptions.sort['_id.gr_' + (groupIndex + 1)];\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\tsort[groupString + '_id.gr_' + (groupIndex + 1)] = 1;\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\tsortKeys.filter(a => !a.startsWith('_id.gr_')).forEach(key => {\n\t\t\t\t\t\t\t\t\t\tsort[groupString + key] = rootOptions.sort[key];\n\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\tquery.push({$sort: sort});\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\n\t\t\t\t\t\t// console.log('_____________ query __________'); console.log(query); console.log(JSON.stringify(query, null, 2));\n\n\t\t\t\t\t\tlet res = null;\n\t\t\t\t\t\t\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tres = await modelCollection.aggregate(query, {allowDiskUse: true, readPreference: this.serverConfig['ROOT_URL'] !== 'http://localhost:4200' ? 'secondary' : 'primary'}, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\t\tconsole.log(err);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet tmpTotals = {};\n\n\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\tfieldsTotal.forEach(totField => {\n\t\t\t\t\t\t\t\tselectedFields.filter(b => b.fieldType === 'Number' || b.leafValueType === 'Count').forEach(selField => {\n\t\t\t\t\t\t\t\t\tif (totField.type === 'sum') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + selField.id] = res.map(a => a[totField.id + '_' + selField.id] || 0).reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (totField.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + selField.id] = round(res.map(a => a[totField.id + '_' + selField.id] || 0).reduce((a, b) => a + b, 0) / res.length);\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\tcustomFields.forEach(custField => {\n\t\t\t\t\t\t\t\t\tif (totField.type === 'sum') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + custField.selFieldId] = res.map(a => a[totField.id + '_' + custField.selFieldId] || 0).reduce((a, b) => a + b, 0);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse if (totField.type === 'avg') {\n\t\t\t\t\t\t\t\t\t\ttmpTotals[totField.id + '_' + custField.selFieldId] = round(res.map(a => a[totField.id + '_' + custField.selFieldId] || 0).reduce((a, b) => a + b, 0) / res.length);\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\n\t\t\t\t\t\tlet tmpRes = [{\n\t\t\t\t\t\t\tcount: res ? res.length : 0,\n\t\t\t\t\t\t\tresults: res ? (rootOptions.limit ? res.splice(0, rootOptions.limit) : res) : [],\n\t\t\t\t\t\t\ttotals: tmpTotals\n\t\t\t\t\t\t}];\n\n\t\t\t\t\t\tresolve(tmpRes);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t}\n\t});\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@resolveio/server-lib",
3
- "version": "20.5.0",
3
+ "version": "20.5.3",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "package": "./build_package.sh",
package/public_api.d.ts CHANGED
@@ -57,3 +57,4 @@ export * from './models/user-guide.model';
57
57
  export * from './models/user.model';
58
58
  export * from './util/common';
59
59
  export * from './managers/mongo.manager';
60
+ export * from './resolveio-server-app';
package/public_api.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(e,r,o,t){void 0===t&&(t=o);var l=Object.getOwnPropertyDescriptor(r,o);l&&("get"in l?r.__esModule:!l.writable&&!l.configurable)||(l={enumerable:!0,get:function(){return r[o]}}),Object.defineProperty(e,t,l)}:function(e,r,o,t){e[t=void 0===t?o:t]=r[o]}),__exportStar=this&&this.__exportStar||function(e,r){for(var o in e)"default"===o||Object.prototype.hasOwnProperty.call(r,o)||__createBinding(r,e,o)};Object.defineProperty(exports,"__esModule",{value:!0}),__exportStar(require("./collections/app-status.collection"),exports),__exportStar(require("./collections/counter.collection"),exports),__exportStar(require("./collections/cron-job-history.collection"),exports),__exportStar(require("./collections/cron-job.collection"),exports),__exportStar(require("./collections/email-history.collection"),exports),__exportStar(require("./collections/email-verified.collection"),exports),__exportStar(require("./collections/file.collection"),exports),__exportStar(require("./collections/flag.collection"),exports),__exportStar(require("./collections/flag-update.collection"),exports),__exportStar(require("./collections/log-method-latency.collection"),exports),__exportStar(require("./collections/log-subscription.collection"),exports),__exportStar(require("./collections/log.collection"),exports),__exportStar(require("./collections/logged-in-users.collection"),exports),__exportStar(require("./collections/method-response.collection"),exports),__exportStar(require("./collections/monitor-cpu.collection"),exports),__exportStar(require("./collections/monitor-memory.collection"),exports),__exportStar(require("./collections/monitor-mongo.collection"),exports),__exportStar(require("./collections/notification.collection"),exports),__exportStar(require("./collections/report-builder-library.collection"),exports),__exportStar(require("./collections/report-builder-report.collection"),exports),__exportStar(require("./collections/user-group.collection"),exports),__exportStar(require("./collections/user-guide.collection"),exports),__exportStar(require("./collections/user.collection"),exports),__exportStar(require("./models/app-status.model"),exports),__exportStar(require("./models/billing-logged-in-users.model"),exports),__exportStar(require("./models/collection-document.model"),exports),__exportStar(require("./models/counter.model"),exports),__exportStar(require("./models/cron-job-history.model"),exports),__exportStar(require("./models/cron-job.model"),exports),__exportStar(require("./models/dialog.model"),exports),__exportStar(require("./models/email-history.model"),exports),__exportStar(require("./models/email-verified.model"),exports),__exportStar(require("./models/file.model"),exports),__exportStar(require("./models/flag.model"),exports),__exportStar(require("./models/flag-update.model"),exports),__exportStar(require("./models/log-method-latency.model"),exports),__exportStar(require("./models/log-subscription.model"),exports),__exportStar(require("./models/log.model"),exports),__exportStar(require("./models/logged-in-users.model"),exports),__exportStar(require("./models/method-response.model"),exports),__exportStar(require("./models/method.model"),exports),__exportStar(require("./models/monitor-cpu.model"),exports),__exportStar(require("./models/monitor-memory.model"),exports),__exportStar(require("./models/monitor-mongo.model"),exports),__exportStar(require("./models/notification.model"),exports),__exportStar(require("./models/pagination.model"),exports),__exportStar(require("./models/permission.model"),exports),__exportStar(require("./models/report-builder-library.model"),exports),__exportStar(require("./models/report-builder-report.model"),exports),__exportStar(require("./models/report-builder.model"),exports),__exportStar(require("./models/select-data-label.model"),exports),__exportStar(require("./models/server-response.model"),exports),__exportStar(require("./models/subscription.model"),exports),__exportStar(require("./models/support-ticket.model"),exports),__exportStar(require("./models/user-group.model"),exports),__exportStar(require("./models/user-guide.model"),exports),__exportStar(require("./models/user.model"),exports),__exportStar(require("./util/common"),exports),__exportStar(require("./managers/mongo.manager"),exports);
1
+ "use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(e,r,o,t){void 0===t&&(t=o);var l=Object.getOwnPropertyDescriptor(r,o);l&&("get"in l?r.__esModule:!l.writable&&!l.configurable)||(l={enumerable:!0,get:function(){return r[o]}}),Object.defineProperty(e,t,l)}:function(e,r,o,t){e[t=void 0===t?o:t]=r[o]}),__exportStar=this&&this.__exportStar||function(e,r){for(var o in e)"default"===o||Object.prototype.hasOwnProperty.call(r,o)||__createBinding(r,e,o)};Object.defineProperty(exports,"__esModule",{value:!0}),__exportStar(require("./collections/app-status.collection"),exports),__exportStar(require("./collections/counter.collection"),exports),__exportStar(require("./collections/cron-job-history.collection"),exports),__exportStar(require("./collections/cron-job.collection"),exports),__exportStar(require("./collections/email-history.collection"),exports),__exportStar(require("./collections/email-verified.collection"),exports),__exportStar(require("./collections/file.collection"),exports),__exportStar(require("./collections/flag.collection"),exports),__exportStar(require("./collections/flag-update.collection"),exports),__exportStar(require("./collections/log-method-latency.collection"),exports),__exportStar(require("./collections/log-subscription.collection"),exports),__exportStar(require("./collections/log.collection"),exports),__exportStar(require("./collections/logged-in-users.collection"),exports),__exportStar(require("./collections/method-response.collection"),exports),__exportStar(require("./collections/monitor-cpu.collection"),exports),__exportStar(require("./collections/monitor-memory.collection"),exports),__exportStar(require("./collections/monitor-mongo.collection"),exports),__exportStar(require("./collections/notification.collection"),exports),__exportStar(require("./collections/report-builder-library.collection"),exports),__exportStar(require("./collections/report-builder-report.collection"),exports),__exportStar(require("./collections/user-group.collection"),exports),__exportStar(require("./collections/user-guide.collection"),exports),__exportStar(require("./collections/user.collection"),exports),__exportStar(require("./models/app-status.model"),exports),__exportStar(require("./models/billing-logged-in-users.model"),exports),__exportStar(require("./models/collection-document.model"),exports),__exportStar(require("./models/counter.model"),exports),__exportStar(require("./models/cron-job-history.model"),exports),__exportStar(require("./models/cron-job.model"),exports),__exportStar(require("./models/dialog.model"),exports),__exportStar(require("./models/email-history.model"),exports),__exportStar(require("./models/email-verified.model"),exports),__exportStar(require("./models/file.model"),exports),__exportStar(require("./models/flag.model"),exports),__exportStar(require("./models/flag-update.model"),exports),__exportStar(require("./models/log-method-latency.model"),exports),__exportStar(require("./models/log-subscription.model"),exports),__exportStar(require("./models/log.model"),exports),__exportStar(require("./models/logged-in-users.model"),exports),__exportStar(require("./models/method-response.model"),exports),__exportStar(require("./models/method.model"),exports),__exportStar(require("./models/monitor-cpu.model"),exports),__exportStar(require("./models/monitor-memory.model"),exports),__exportStar(require("./models/monitor-mongo.model"),exports),__exportStar(require("./models/notification.model"),exports),__exportStar(require("./models/pagination.model"),exports),__exportStar(require("./models/permission.model"),exports),__exportStar(require("./models/report-builder-library.model"),exports),__exportStar(require("./models/report-builder-report.model"),exports),__exportStar(require("./models/report-builder.model"),exports),__exportStar(require("./models/select-data-label.model"),exports),__exportStar(require("./models/server-response.model"),exports),__exportStar(require("./models/subscription.model"),exports),__exportStar(require("./models/support-ticket.model"),exports),__exportStar(require("./models/user-group.model"),exports),__exportStar(require("./models/user-guide.model"),exports),__exportStar(require("./models/user.model"),exports),__exportStar(require("./util/common"),exports),__exportStar(require("./managers/mongo.manager"),exports),__exportStar(require("./resolveio-server-app"),exports);
2
2
  //# sourceMappingURL=public_api.js.map
package/public_api.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/public_api.ts"],"names":["__exportStar","require","exports"],"mappings":"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","file":"public_api.js","sourcesContent":["export * from './collections/app-status.collection';\nexport * from './collections/counter.collection';\nexport * from './collections/cron-job-history.collection';\nexport * from './collections/cron-job.collection';\nexport * from './collections/email-history.collection';\nexport * from './collections/email-verified.collection';\nexport * from './collections/file.collection';\nexport * from './collections/flag.collection';\nexport * from './collections/flag-update.collection';\nexport * from './collections/log-method-latency.collection';\nexport * from './collections/log-subscription.collection';\nexport * from './collections/log.collection';\nexport * from './collections/logged-in-users.collection';\nexport * from './collections/method-response.collection';\nexport * from './collections/monitor-cpu.collection';\nexport * from './collections/monitor-memory.collection';\nexport * from './collections/monitor-mongo.collection';\nexport * from './collections/notification.collection';\nexport * from './collections/report-builder-library.collection';\nexport * from './collections/report-builder-report.collection';\nexport * from './collections/user-group.collection';\nexport * from './collections/user-guide.collection';\nexport * from './collections/user.collection';\nexport * from './models/app-status.model';\nexport * from './models/billing-logged-in-users.model';\nexport * from './models/collection-document.model';\nexport * from './models/counter.model';\nexport * from './models/cron-job-history.model';\nexport * from './models/cron-job.model';\nexport * from './models/dialog.model';\nexport * from './models/email-history.model';\nexport * from './models/email-verified.model';\nexport * from './models/file.model';\nexport * from './models/flag.model';\nexport * from './models/flag-update.model';\nexport * from './models/log-method-latency.model';\nexport * from './models/log-subscription.model';\nexport * from './models/log.model';\nexport * from './models/logged-in-users.model';\nexport * from './models/method-response.model';\nexport * from './models/method.model';\nexport * from './models/monitor-cpu.model';\nexport * from './models/monitor-memory.model';\nexport * from './models/monitor-mongo.model';\nexport * from './models/notification.model';\nexport * from './models/pagination.model';\nexport * from './models/permission.model';\nexport * from './models/report-builder-library.model';\nexport * from './models/report-builder-report.model';\nexport * from './models/report-builder.model';\nexport * from './models/select-data-label.model';\nexport * from './models/server-response.model';\nexport * from './models/subscription.model';\nexport * from './models/support-ticket.model';\nexport * from './models/user-group.model';\nexport * from './models/user-guide.model';\nexport * from './models/user.model';\nexport * from './util/common';\nexport * from './managers/mongo.manager';"]}
1
+ {"version":3,"sources":["../../src/public_api.ts"],"names":["__exportStar","require","exports"],"mappings":"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","file":"public_api.js","sourcesContent":["export * from './collections/app-status.collection';\nexport * from './collections/counter.collection';\nexport * from './collections/cron-job-history.collection';\nexport * from './collections/cron-job.collection';\nexport * from './collections/email-history.collection';\nexport * from './collections/email-verified.collection';\nexport * from './collections/file.collection';\nexport * from './collections/flag.collection';\nexport * from './collections/flag-update.collection';\nexport * from './collections/log-method-latency.collection';\nexport * from './collections/log-subscription.collection';\nexport * from './collections/log.collection';\nexport * from './collections/logged-in-users.collection';\nexport * from './collections/method-response.collection';\nexport * from './collections/monitor-cpu.collection';\nexport * from './collections/monitor-memory.collection';\nexport * from './collections/monitor-mongo.collection';\nexport * from './collections/notification.collection';\nexport * from './collections/report-builder-library.collection';\nexport * from './collections/report-builder-report.collection';\nexport * from './collections/user-group.collection';\nexport * from './collections/user-guide.collection';\nexport * from './collections/user.collection';\nexport * from './models/app-status.model';\nexport * from './models/billing-logged-in-users.model';\nexport * from './models/collection-document.model';\nexport * from './models/counter.model';\nexport * from './models/cron-job-history.model';\nexport * from './models/cron-job.model';\nexport * from './models/dialog.model';\nexport * from './models/email-history.model';\nexport * from './models/email-verified.model';\nexport * from './models/file.model';\nexport * from './models/flag.model';\nexport * from './models/flag-update.model';\nexport * from './models/log-method-latency.model';\nexport * from './models/log-subscription.model';\nexport * from './models/log.model';\nexport * from './models/logged-in-users.model';\nexport * from './models/method-response.model';\nexport * from './models/method.model';\nexport * from './models/monitor-cpu.model';\nexport * from './models/monitor-memory.model';\nexport * from './models/monitor-mongo.model';\nexport * from './models/notification.model';\nexport * from './models/pagination.model';\nexport * from './models/permission.model';\nexport * from './models/report-builder-library.model';\nexport * from './models/report-builder-report.model';\nexport * from './models/report-builder.model';\nexport * from './models/select-data-label.model';\nexport * from './models/server-response.model';\nexport * from './models/subscription.model';\nexport * from './models/support-ticket.model';\nexport * from './models/user-group.model';\nexport * from './models/user-guide.model';\nexport * from './models/user.model';\nexport * from './util/common';\nexport * from './managers/mongo.manager';\nexport * from './resolveio-server-app';"]}
@@ -0,0 +1,31 @@
1
+ import { Db, MongoClient } from 'mongodb';
2
+ export declare class ResolveIOServer {
3
+ private static _serverConfig;
4
+ private static _clientRoutes;
5
+ private static _mongoConnection;
6
+ private static _mainDB;
7
+ private static _mainServer;
8
+ private static _localLogManager;
9
+ private static _mongoManager;
10
+ private static _client;
11
+ private static _clientDir;
12
+ private static _sesMail;
13
+ private static _standardProgram;
14
+ constructor(serverConfig: any, clientRoutes: string[], client: string, clientDir: any, sesMail?: boolean, standardProgram?: boolean);
15
+ static getClientName(): string;
16
+ static getMainServer(): any;
17
+ static setMainServer(mainServer: any): void;
18
+ static setMongoConnection(mongoConnection: any): void;
19
+ static getMongoConnection(): MongoClient;
20
+ static getMainDB(): Db;
21
+ static setMainDB(mainDB: any): void;
22
+ static getMongoManager(): any;
23
+ static setMongoManager(mongoManager: any): void;
24
+ static getLocalLogManager(): any;
25
+ static setLocalLogManager(localLogManager: any): void;
26
+ static getServerConfig(): any;
27
+ static getClientRoutes(): any[];
28
+ static getClientDir(): string;
29
+ static getSESMail(): boolean;
30
+ static getStandardProgram(): boolean;
31
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.ResolveIOServer=void 0;var ResolveIOServer=function(){function ResolveIOServer(e,r,o,v,n,l){void 0===n&&(n=!0),void 0===l&&(l=!1),ResolveIOServer._serverConfig=e,ResolveIOServer._clientRoutes=r,ResolveIOServer._client=o,ResolveIOServer._clientDir=v,ResolveIOServer._sesMail=n,ResolveIOServer._standardProgram=l}return ResolveIOServer.getClientName=function(){return this._client},ResolveIOServer.getMainServer=function(){return ResolveIOServer._mainServer},ResolveIOServer.setMainServer=function(e){ResolveIOServer._mainServer=e},ResolveIOServer.setMongoConnection=function(e){ResolveIOServer._mongoConnection=e},ResolveIOServer.getMongoConnection=function(){return ResolveIOServer._mongoConnection},ResolveIOServer.getMainDB=function(){return ResolveIOServer._mainDB},ResolveIOServer.setMainDB=function(e){ResolveIOServer._mainDB=e},ResolveIOServer.getMongoManager=function(){return ResolveIOServer._mongoManager},ResolveIOServer.setMongoManager=function(e){ResolveIOServer._mongoManager=e},ResolveIOServer.getLocalLogManager=function(){return ResolveIOServer._localLogManager},ResolveIOServer.setLocalLogManager=function(e){ResolveIOServer._localLogManager=e},ResolveIOServer.getServerConfig=function(){return ResolveIOServer._serverConfig},ResolveIOServer.getClientRoutes=function(){return ResolveIOServer._clientRoutes},ResolveIOServer.getClientDir=function(){return ResolveIOServer._clientDir},ResolveIOServer.getSESMail=function(){return ResolveIOServer._sesMail},ResolveIOServer.getStandardProgram=function(){return ResolveIOServer._standardProgram},ResolveIOServer._serverConfig=null,ResolveIOServer._clientRoutes=[],ResolveIOServer._mongoConnection=null,ResolveIOServer._mainDB=null,ResolveIOServer._mainServer=null,ResolveIOServer._localLogManager=null,ResolveIOServer._mongoManager=null,ResolveIOServer._client="",ResolveIOServer._clientDir="",ResolveIOServer._sesMail=!0,ResolveIOServer._standardProgram=!1,ResolveIOServer}();exports.ResolveIOServer=ResolveIOServer;
2
+ //# sourceMappingURL=resolveio-server-app.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/resolveio-server-app.ts"],"names":["ResolveIOServer","serverConfig","clientRoutes","client","clientDir","sesMail","standardProgram","_serverConfig","_clientRoutes","_client","_clientDir","_sesMail","_standardProgram","getClientName","this","getMainServer","_mainServer","setMainServer","mainServer","setMongoConnection","mongoConnection","_mongoConnection","getMongoConnection","getMainDB","_mainDB","setMainDB","mainDB","getMongoManager","_mongoManager","setMongoManager","mongoManager","getLocalLogManager","_localLogManager","setLocalLogManager","localLogManager","getServerConfig","getClientRoutes","getClientDir","getSESMail","getStandardProgram","exports"],"mappings":"mGAEA,IAAAA,gBAAA,WAaC,SAAAA,gBAAYC,EAAcC,EAAwBC,EAAgBC,EAAWC,EAAgBC,GAAhB,KAAA,IAAAD,IAAAA,EAAA,CAAA,GAAgB,KAAA,IAAAC,IAAAA,EAAA,CAAA,GAC5FN,gBAAgBO,cAAgBN,EAChCD,gBAAgBQ,cAAgBN,EAChCF,gBAAgBS,QAAUN,EAC1BH,gBAAgBU,WAAaN,EAC7BJ,gBAAgBW,SAAWN,EAC3BL,gBAAgBY,iBAAmBN,CACpC,CAiED,OA/DeN,gBAAAa,cAAd,WACC,OAAOC,KAAKL,OACb,EAEcT,gBAAAe,cAAd,WACC,OAAOf,gBAAgBgB,WACxB,EAEchB,gBAAAiB,cAAd,SAA4BC,GAC3BlB,gBAAgBgB,YAAcE,CAC/B,EAEclB,gBAAAmB,mBAAd,SAAiCC,GAChCpB,gBAAgBqB,iBAAmBD,CACpC,EAEcpB,gBAAAsB,mBAAd,WACC,OAAOtB,gBAAgBqB,gBACxB,EAEcrB,gBAAAuB,UAAd,WACC,OAAOvB,gBAAgBwB,OACxB,EAEcxB,gBAAAyB,UAAd,SAAwBC,GACvB1B,gBAAgBwB,QAAUE,CAC3B,EAEc1B,gBAAA2B,gBAAd,WACC,OAAO3B,gBAAgB4B,aACxB,EAEc5B,gBAAA6B,gBAAd,SAA8BC,GAC7B9B,gBAAgB4B,cAAgBE,CACjC,EAEc9B,gBAAA+B,mBAAd,WACC,OAAO/B,gBAAgBgC,gBACxB,EAEchC,gBAAAiC,mBAAd,SAAiCC,GAChClC,gBAAgBgC,iBAAmBE,CACpC,EAEclC,gBAAAmC,gBAAd,WACC,OAAOnC,gBAAgBO,aACxB,EAEcP,gBAAAoC,gBAAd,WACC,OAAOpC,gBAAgBQ,aACxB,EAEcR,gBAAAqC,aAAd,WACC,OAAOrC,gBAAgBU,UACxB,EAEcV,gBAAAsC,WAAd,WACC,OAAOtC,gBAAgBW,QACxB,EAEcX,gBAAAuC,mBAAd,WACC,OAAOvC,gBAAgBY,gBACxB,EAnFeZ,gBAAAO,cAAgB,KAChBP,gBAAAQ,cAAgB,GAChBR,gBAAAqB,iBAAgC,KAChCrB,gBAAAwB,QAAc,KACdxB,gBAAAgB,YAAc,KACdhB,gBAAAgC,iBAAmB,KACnBhC,gBAAA4B,cAAgB,KAChB5B,gBAAAS,QAAU,GACVT,gBAAAU,WAAa,GACbV,gBAAAW,SAAW,CAAA,EACXX,gBAAAY,iBAAmB,CAAA,EA0EnCZ,e,EAAC,EArFYwC,QAAAxC,gBAAAA","file":"resolveio-server-app.js","sourcesContent":["import { Db, MongoClient } from 'mongodb';\n\nexport class ResolveIOServer {\n\tprivate static _serverConfig = null;\n\tprivate static _clientRoutes = [];\n\tprivate static _mongoConnection: MongoClient = null;\n\tprivate static _mainDB: Db = null;\n\tprivate static _mainServer = null;\n\tprivate static _localLogManager = null;\n\tprivate static _mongoManager = null;\n\tprivate static _client = '';\n\tprivate static _clientDir = '';\n\tprivate static _sesMail = true;\n\tprivate static _standardProgram = false;\n\n\tconstructor(serverConfig, clientRoutes: string[], client: string, clientDir, sesMail = true, standardProgram = false) {\n\t\tResolveIOServer._serverConfig = serverConfig;\n\t\tResolveIOServer._clientRoutes = clientRoutes;\n\t\tResolveIOServer._client = client;\n\t\tResolveIOServer._clientDir = clientDir;\n\t\tResolveIOServer._sesMail = sesMail;\n\t\tResolveIOServer._standardProgram = standardProgram;\n\t}\n\n\tpublic static getClientName() {\n\t\treturn this._client;\n\t}\n\n\tpublic static getMainServer() {\n\t\treturn ResolveIOServer._mainServer;\n\t}\n\n\tpublic static setMainServer(mainServer) {\n\t\tResolveIOServer._mainServer = mainServer;\n\t}\n\n\tpublic static setMongoConnection(mongoConnection) {\n\t\tResolveIOServer._mongoConnection = mongoConnection;\n\t}\n\n\tpublic static getMongoConnection() {\n\t\treturn ResolveIOServer._mongoConnection;\n\t}\n\n\tpublic static getMainDB() {\n\t\treturn ResolveIOServer._mainDB;\n\t}\n\n\tpublic static setMainDB(mainDB) {\n\t\tResolveIOServer._mainDB = mainDB\n\t}\n\n\tpublic static getMongoManager() {\n\t\treturn ResolveIOServer._mongoManager;\n\t}\n\n\tpublic static setMongoManager(mongoManager) {\n\t\tResolveIOServer._mongoManager = mongoManager;\n\t}\n\n\tpublic static getLocalLogManager() {\n\t\treturn ResolveIOServer._localLogManager;\n\t}\n\n\tpublic static setLocalLogManager(localLogManager) {\n\t\tResolveIOServer._localLogManager = localLogManager;\n\t}\n\n\tpublic static getServerConfig() {\n\t\treturn ResolveIOServer._serverConfig;\n\t}\n\n\tpublic static getClientRoutes() {\n\t\treturn ResolveIOServer._clientRoutes;\n\t}\n\n\tpublic static getClientDir() {\n\t\treturn ResolveIOServer._clientDir;\n\t}\n\n\tpublic static getSESMail() {\n\t\treturn ResolveIOServer._sesMail;\n\t}\n\n\tpublic static getStandardProgram() {\n\t\treturn ResolveIOServer._standardProgram;\n\t}\n}"]}
package/server-app.d.ts CHANGED
@@ -7,7 +7,7 @@ import { MethodManager } from './managers/method.manager';
7
7
  import { SubscriptionManager } from './managers/subscription.manager';
8
8
  import { MonitorManager } from './managers/monitor.manager';
9
9
  import { WebSocketManager } from './managers/websocket.manager';
10
- export default class ResolveIOMainServer {
10
+ export declare class ResolveIOMainServer {
11
11
  private _app;
12
12
  private _serverHTTP;
13
13
  private _portHTTP;
@@ -35,6 +35,7 @@ export default class ResolveIOMainServer {
35
35
  private _workerTasks;
36
36
  private _safeShutdown;
37
37
  constructor();
38
+ initServerApp(): void;
38
39
  private startServerInstance;
39
40
  private startWorkerInstance;
40
41
  private processTask;