@mody-park-cha-raja/finance_common 1.0.4 → 1.0.6-beta.1

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.
package/dist/index.d.mts CHANGED
@@ -29,8 +29,10 @@ interface IDonationHistoryEntity extends IBaseHistoryEntity {
29
29
 
30
30
  interface IDonationEntity extends IAuditColumnEntity {
31
31
  id: number;
32
+ receiptNumber: string;
32
33
  flatNo: string;
33
34
  amount: number;
35
+ mobileNumber?: string;
34
36
  }
35
37
 
36
38
  interface IExpenseHistoryEntity extends IBaseHistoryEntity {
@@ -42,6 +44,7 @@ interface IExpenseEntity extends IAuditColumnEntity {
42
44
  type: string;
43
45
  vendorName: string;
44
46
  amount: number;
47
+ billNumber?: string;
45
48
  }
46
49
 
47
50
  interface ISponsorHistoryEntity extends IBaseHistoryEntity {
@@ -49,6 +52,7 @@ interface ISponsorHistoryEntity extends IBaseHistoryEntity {
49
52
 
50
53
  interface ISponsorEntity extends IAuditColumnEntity {
51
54
  id: number;
55
+ sponsorName: string;
52
56
  contactName: string;
53
57
  contactNo: string;
54
58
  sponsorFor: SponsorFor;
@@ -136,14 +140,17 @@ declare abstract class BaseEntityModel {
136
140
 
137
141
  declare class DonationModel extends BaseEntityModel implements IDonationEntity {
138
142
  id: number;
143
+ receiptNumber: string;
139
144
  flatNo: string;
140
145
  amount: number;
146
+ mobileNumber?: string;
141
147
  createdOn: number;
142
148
  updatedOn: number;
143
149
  createdBy: number;
144
150
  updatedBy: number;
145
151
  protected constructor();
146
152
  static populateFromEntity(entity: IDonationEntity): DonationModel;
153
+ static generateReceiptNumber(flatNo: string, existingDonations: DonationModel[]): string;
147
154
  }
148
155
 
149
156
  declare class ExpenseHistoryModel extends BaseEntityModel implements IExpenseHistoryEntity {
@@ -166,6 +173,7 @@ declare class ExpenseModel extends BaseEntityModel implements IExpenseEntity {
166
173
  type: string;
167
174
  vendorName: string;
168
175
  amount: number;
176
+ billNumber?: string;
169
177
  createdOn: number;
170
178
  updatedOn: number;
171
179
  createdBy: number;
@@ -190,6 +198,7 @@ declare class SponsorHistoryModel extends BaseEntityModel implements ISponsorHis
190
198
 
191
199
  declare class SponsorModel extends BaseEntityModel implements ISponsorEntity {
192
200
  id: number;
201
+ sponsorName: string;
193
202
  contactName: string;
194
203
  contactNo: string;
195
204
  sponsorFor: SponsorFor;
@@ -386,6 +395,22 @@ declare function diffArrays<T>(arr1: T[], arr2: T[]): {
386
395
  */
387
396
  declare function groupBy<T>(items: T[], key: keyof T): Map<string, T[]>;
388
397
  declare function definedValues<T>(arr: Array<T | undefined | null>): T[];
398
+ /**
399
+ * Converts an epoch timestamp (milliseconds) into a human-readable date string.
400
+ *
401
+ * @param epoch - The epoch timestamp in milliseconds
402
+ * @param format - Optional output format:
403
+ * - `'short'` — locale-specific short date (e.g. "25/12/2026")
404
+ * - `'long'` — locale-specific long date (e.g. "25 December 2026")
405
+ * - `'iso'` — ISO 8601 string (default)
406
+ * @returns The formatted date string
407
+ *
408
+ * @example
409
+ * epochToReadableDate(1700000000000, 'long'); // "14 November 2023"
410
+ * epochToReadableDate(1700000000000, 'short'); // "14/11/2023"
411
+ * epochToReadableDate(1700000000000); // "2023-11-14T18:13:20.000Z"
412
+ */
413
+ declare function epochToReadableDate(epoch: number, format?: 'short' | 'long' | 'iso'): string;
389
414
 
390
415
  declare enum RelationType {
391
416
  ONE = "ONE",
@@ -504,4 +529,4 @@ interface IDtoValidationError {
504
529
 
505
530
  type Nullable<T> = T | null;
506
531
 
507
- export { BadRequestException, BaseEntityModel, DateCodeUtils, DateUtil, DonationHistoryModel, DonationModel, EntityFilterDataHelper, EntityHistoryOperation, EntityList, type EntityListEntityModelMap, type EntityModelType, type EntityType, ExpenseHistoryModel, ExpenseModel, ForbiddenException, HttpException, type IAuditColumnEntity, type IBaseHistoryEntity, type IDonationEntity, type IDonationHistoryEntity, type IDtoValidationError, type IEntityCreateDto, type IEntityFilterData, type IEntityFilterSearchData, type IEntityFilterSearchDataV2, type IEntityUpdateDto, type IExpenseEntity, type IExpenseHistoryEntity, type IModelRelationConfig, type ISearchV2Response, type ISponsorEntity, type ISponsorHistoryEntity, type ITransactionEntity, type ITransactionHistoryEntity, type IUserEntity, type IUserHistoryEntity, type IVendorEntity, type IVendorHistoryEntity, NotFoundException, type Nullable, OrderByDirection, RelationType, SponsorFor, SponsorHistoryModel, SponsorModel, TransactionHistoryModel, TransactionModel, type TransactionType, UnauthorizedException, UserHistoryModel, UserModel, VendorHistoryModel, VendorModel, definedValues, diffArrays, entityListEntityModelMap, getObjectDiffingKeys, groupBy };
532
+ export { BadRequestException, BaseEntityModel, DateCodeUtils, DateUtil, DonationHistoryModel, DonationModel, EntityFilterDataHelper, EntityHistoryOperation, EntityList, type EntityListEntityModelMap, type EntityModelType, type EntityType, ExpenseHistoryModel, ExpenseModel, ForbiddenException, HttpException, type IAuditColumnEntity, type IBaseHistoryEntity, type IDonationEntity, type IDonationHistoryEntity, type IDtoValidationError, type IEntityCreateDto, type IEntityFilterData, type IEntityFilterSearchData, type IEntityFilterSearchDataV2, type IEntityUpdateDto, type IExpenseEntity, type IExpenseHistoryEntity, type IModelRelationConfig, type ISearchV2Response, type ISponsorEntity, type ISponsorHistoryEntity, type ITransactionEntity, type ITransactionHistoryEntity, type IUserEntity, type IUserHistoryEntity, type IVendorEntity, type IVendorHistoryEntity, NotFoundException, type Nullable, OrderByDirection, RelationType, SponsorFor, SponsorHistoryModel, SponsorModel, TransactionHistoryModel, TransactionModel, type TransactionType, UnauthorizedException, UserHistoryModel, UserModel, VendorHistoryModel, VendorModel, definedValues, diffArrays, entityListEntityModelMap, epochToReadableDate, getObjectDiffingKeys, groupBy };
package/dist/index.d.ts CHANGED
@@ -29,8 +29,10 @@ interface IDonationHistoryEntity extends IBaseHistoryEntity {
29
29
 
30
30
  interface IDonationEntity extends IAuditColumnEntity {
31
31
  id: number;
32
+ receiptNumber: string;
32
33
  flatNo: string;
33
34
  amount: number;
35
+ mobileNumber?: string;
34
36
  }
35
37
 
36
38
  interface IExpenseHistoryEntity extends IBaseHistoryEntity {
@@ -42,6 +44,7 @@ interface IExpenseEntity extends IAuditColumnEntity {
42
44
  type: string;
43
45
  vendorName: string;
44
46
  amount: number;
47
+ billNumber?: string;
45
48
  }
46
49
 
47
50
  interface ISponsorHistoryEntity extends IBaseHistoryEntity {
@@ -49,6 +52,7 @@ interface ISponsorHistoryEntity extends IBaseHistoryEntity {
49
52
 
50
53
  interface ISponsorEntity extends IAuditColumnEntity {
51
54
  id: number;
55
+ sponsorName: string;
52
56
  contactName: string;
53
57
  contactNo: string;
54
58
  sponsorFor: SponsorFor;
@@ -136,14 +140,17 @@ declare abstract class BaseEntityModel {
136
140
 
137
141
  declare class DonationModel extends BaseEntityModel implements IDonationEntity {
138
142
  id: number;
143
+ receiptNumber: string;
139
144
  flatNo: string;
140
145
  amount: number;
146
+ mobileNumber?: string;
141
147
  createdOn: number;
142
148
  updatedOn: number;
143
149
  createdBy: number;
144
150
  updatedBy: number;
145
151
  protected constructor();
146
152
  static populateFromEntity(entity: IDonationEntity): DonationModel;
153
+ static generateReceiptNumber(flatNo: string, existingDonations: DonationModel[]): string;
147
154
  }
148
155
 
149
156
  declare class ExpenseHistoryModel extends BaseEntityModel implements IExpenseHistoryEntity {
@@ -166,6 +173,7 @@ declare class ExpenseModel extends BaseEntityModel implements IExpenseEntity {
166
173
  type: string;
167
174
  vendorName: string;
168
175
  amount: number;
176
+ billNumber?: string;
169
177
  createdOn: number;
170
178
  updatedOn: number;
171
179
  createdBy: number;
@@ -190,6 +198,7 @@ declare class SponsorHistoryModel extends BaseEntityModel implements ISponsorHis
190
198
 
191
199
  declare class SponsorModel extends BaseEntityModel implements ISponsorEntity {
192
200
  id: number;
201
+ sponsorName: string;
193
202
  contactName: string;
194
203
  contactNo: string;
195
204
  sponsorFor: SponsorFor;
@@ -386,6 +395,22 @@ declare function diffArrays<T>(arr1: T[], arr2: T[]): {
386
395
  */
387
396
  declare function groupBy<T>(items: T[], key: keyof T): Map<string, T[]>;
388
397
  declare function definedValues<T>(arr: Array<T | undefined | null>): T[];
398
+ /**
399
+ * Converts an epoch timestamp (milliseconds) into a human-readable date string.
400
+ *
401
+ * @param epoch - The epoch timestamp in milliseconds
402
+ * @param format - Optional output format:
403
+ * - `'short'` — locale-specific short date (e.g. "25/12/2026")
404
+ * - `'long'` — locale-specific long date (e.g. "25 December 2026")
405
+ * - `'iso'` — ISO 8601 string (default)
406
+ * @returns The formatted date string
407
+ *
408
+ * @example
409
+ * epochToReadableDate(1700000000000, 'long'); // "14 November 2023"
410
+ * epochToReadableDate(1700000000000, 'short'); // "14/11/2023"
411
+ * epochToReadableDate(1700000000000); // "2023-11-14T18:13:20.000Z"
412
+ */
413
+ declare function epochToReadableDate(epoch: number, format?: 'short' | 'long' | 'iso'): string;
389
414
 
390
415
  declare enum RelationType {
391
416
  ONE = "ONE",
@@ -504,4 +529,4 @@ interface IDtoValidationError {
504
529
 
505
530
  type Nullable<T> = T | null;
506
531
 
507
- export { BadRequestException, BaseEntityModel, DateCodeUtils, DateUtil, DonationHistoryModel, DonationModel, EntityFilterDataHelper, EntityHistoryOperation, EntityList, type EntityListEntityModelMap, type EntityModelType, type EntityType, ExpenseHistoryModel, ExpenseModel, ForbiddenException, HttpException, type IAuditColumnEntity, type IBaseHistoryEntity, type IDonationEntity, type IDonationHistoryEntity, type IDtoValidationError, type IEntityCreateDto, type IEntityFilterData, type IEntityFilterSearchData, type IEntityFilterSearchDataV2, type IEntityUpdateDto, type IExpenseEntity, type IExpenseHistoryEntity, type IModelRelationConfig, type ISearchV2Response, type ISponsorEntity, type ISponsorHistoryEntity, type ITransactionEntity, type ITransactionHistoryEntity, type IUserEntity, type IUserHistoryEntity, type IVendorEntity, type IVendorHistoryEntity, NotFoundException, type Nullable, OrderByDirection, RelationType, SponsorFor, SponsorHistoryModel, SponsorModel, TransactionHistoryModel, TransactionModel, type TransactionType, UnauthorizedException, UserHistoryModel, UserModel, VendorHistoryModel, VendorModel, definedValues, diffArrays, entityListEntityModelMap, getObjectDiffingKeys, groupBy };
532
+ export { BadRequestException, BaseEntityModel, DateCodeUtils, DateUtil, DonationHistoryModel, DonationModel, EntityFilterDataHelper, EntityHistoryOperation, EntityList, type EntityListEntityModelMap, type EntityModelType, type EntityType, ExpenseHistoryModel, ExpenseModel, ForbiddenException, HttpException, type IAuditColumnEntity, type IBaseHistoryEntity, type IDonationEntity, type IDonationHistoryEntity, type IDtoValidationError, type IEntityCreateDto, type IEntityFilterData, type IEntityFilterSearchData, type IEntityFilterSearchDataV2, type IEntityUpdateDto, type IExpenseEntity, type IExpenseHistoryEntity, type IModelRelationConfig, type ISearchV2Response, type ISponsorEntity, type ISponsorHistoryEntity, type ITransactionEntity, type ITransactionHistoryEntity, type IUserEntity, type IUserHistoryEntity, type IVendorEntity, type IVendorHistoryEntity, NotFoundException, type Nullable, OrderByDirection, RelationType, SponsorFor, SponsorHistoryModel, SponsorModel, TransactionHistoryModel, TransactionModel, type TransactionType, UnauthorizedException, UserHistoryModel, UserModel, VendorHistoryModel, VendorModel, definedValues, diffArrays, entityListEntityModelMap, epochToReadableDate, getObjectDiffingKeys, groupBy };
package/dist/index.js CHANGED
@@ -49,6 +49,7 @@ __export(index_exports, {
49
49
  definedValues: () => definedValues,
50
50
  diffArrays: () => diffArrays,
51
51
  entityListEntityModelMap: () => entityListEntityModelMap,
52
+ epochToReadableDate: () => epochToReadableDate,
52
53
  getObjectDiffingKeys: () => getObjectDiffingKeys,
53
54
  groupBy: () => groupBy
54
55
  });
@@ -309,6 +310,7 @@ var DonationModel = class _DonationModel extends BaseEntityModel {
309
310
  constructor() {
310
311
  super();
311
312
  this.id = 0;
313
+ this.receiptNumber = "";
312
314
  this.flatNo = "";
313
315
  this.amount = 0;
314
316
  this.createdOn = 0;
@@ -319,6 +321,11 @@ var DonationModel = class _DonationModel extends BaseEntityModel {
319
321
  static populateFromEntity(entity) {
320
322
  return Object.assign(new _DonationModel(), entity);
321
323
  }
324
+ static generateReceiptNumber(flatNo, existingDonations) {
325
+ const count = existingDonations.filter((d) => d.flatNo === flatNo).length + 1;
326
+ const seq = String(count).padStart(2, "0");
327
+ return `MPCR-2026-${flatNo}-${seq}`;
328
+ }
322
329
  };
323
330
 
324
331
  // src/models/expense-history.entity.model.ts
@@ -385,6 +392,7 @@ var SponsorModel = class _SponsorModel extends BaseEntityModel {
385
392
  constructor() {
386
393
  super();
387
394
  this.id = 0;
395
+ this.sponsorName = "";
388
396
  this.contactName = "";
389
397
  this.contactNo = "";
390
398
  this.sponsorFor = "ghee" /* GHEE */;
@@ -667,6 +675,22 @@ function groupBy(items, key) {
667
675
  function definedValues(arr) {
668
676
  return arr.filter((value) => value != null);
669
677
  }
678
+ function epochToReadableDate(epoch, format = "iso") {
679
+ const date = new Date(epoch);
680
+ switch (format) {
681
+ case "short":
682
+ return date.toLocaleDateString("en-IN");
683
+ case "long":
684
+ return date.toLocaleDateString("en-IN", {
685
+ year: "numeric",
686
+ month: "long",
687
+ day: "numeric"
688
+ });
689
+ case "iso":
690
+ default:
691
+ return date.toISOString();
692
+ }
693
+ }
670
694
 
671
695
  // src/utils/relation-config.utils.ts
672
696
  var RelationType = /* @__PURE__ */ ((RelationType2) => {
@@ -807,6 +831,7 @@ var EntityFilterDataHelper = class {
807
831
  definedValues,
808
832
  diffArrays,
809
833
  entityListEntityModelMap,
834
+ epochToReadableDate,
810
835
  getObjectDiffingKeys,
811
836
  groupBy
812
837
  });
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/enums/entity-history-operation.enum.ts","../src/enums/sponsor-for.enum.ts","../src/utils/date-code.utils.ts","../src/utils/date.utils.ts","../src/models/base.entity.model.ts","../src/models/donation-history.entity.model.ts","../src/models/donation.entity.model.ts","../src/models/expense-history.entity.model.ts","../src/models/expense.entity.model.ts","../src/models/sponsor-history.entity.model.ts","../src/models/sponsor.entity.model.ts","../src/models/transaction-history.entity.model.ts","../src/models/transaction.entity.model.ts","../src/models/user-history.entity.model.ts","../src/models/user.entity.model.ts","../src/models/vendor-history.entity.model.ts","../src/models/vendor.entity.model.ts","../src/utils/entity.utils.ts","../src/utils/entitiy-list-entity-model-map.ts","../src/utils/error.utils.ts","../src/utils/helper.fns.ts","../src/utils/relation-config.utils.ts","../src/utils/sql-utils.ts","../src/helpers/entity-filter-data.helper.ts"],"sourcesContent":["export * from \"./enums/index\";\r\nexport * from \"./helpers/index\";\r\nexport * from \"./interfaces/index\";\r\nexport * from \"./models/index\";\r\nexport * from \"./types/index\";\r\nexport * from \"./utils/index\";\r\n","export enum EntityHistoryOperation {\r\n CREATE = 'CREATE',\r\n UPDATE = 'UPDATE',\r\n DELETE = 'DELETE',\r\n}\r\n","export enum SponsorFor {\n GHEE = 'ghee',\n PRASAD = 'prasad',\n BANNER = 'banner',\n}\n","/**\r\n * Utility class for validating date codes in `YYYYMMDD` format.\r\n *\r\n * @example new DateCodeUtils(20240315)\r\n *\r\n * @methods\r\n * - `isValidYYYYMMDD()` — checks if the date code is a real calendar date. e.g. `new DateCodeUtils(20240315).isValidYYYYMMDD() // true`\r\n */\r\nexport class DateCodeUtils {\r\n stringifiedDateCode: string;\r\n constructor(private readonly dateCode: string | number) {\r\n this.stringifiedDateCode = String(this.dateCode);\r\n if (!this.isValidYYYYMMDD()) {\r\n throw new Error(\r\n `Invalid date code: \"${this.stringifiedDateCode}\". Expected format: YYYYMMDD.`,\r\n );\r\n }\r\n }\r\n\r\n isValidYYYYMMDD(): boolean {\r\n if (!/^\\d{8}$/.test(this.stringifiedDateCode)) return false;\r\n\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n if (month < 1 || month > 12) return false;\r\n if (day < 1 || day > 31) return false;\r\n\r\n const date = new Date(year, month - 1, day);\r\n return (\r\n date.getFullYear() === year &&\r\n date.getMonth() === month - 1 &&\r\n date.getDate() === day\r\n );\r\n }\r\n\r\n toLongDateString(): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n return new Date(year, month - 1, day).toLocaleDateString(\"en-US\", {\r\n year: \"numeric\",\r\n month: \"long\",\r\n day: \"numeric\",\r\n });\r\n }\r\n\r\n addMonths(months: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1 + months, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addDays(days: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1, day);\r\n date.setDate(date.getDate() + days);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addWeeks(weeks: number): string {\r\n return this.addDays(weeks * 7);\r\n }\r\n\r\n addYears(years: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year + years, month - 1, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n private parseDateParts(): { year: number; month: number; day: number } {\r\n return {\r\n year: parseInt(this.stringifiedDateCode.substring(0, 4), 10),\r\n month: parseInt(this.stringifiedDateCode.substring(4, 6), 10),\r\n day: parseInt(this.stringifiedDateCode.substring(6, 8), 10),\r\n };\r\n }\r\n\r\n static getCurrentYear(): number {\r\n return new Date().getFullYear();\r\n }\r\n\r\n static daysDiff(dateCode: string | number): number {\r\n const { year, month, day } = new DateCodeUtils(dateCode).parseDateParts();\r\n const target = new Date(year, month - 1, day);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n\r\n const diffMs = target.getTime() - today.getTime();\r\n return Math.round(diffMs / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n static getCurrentDateCode(): string {\r\n const today = new Date();\r\n const year = today.getFullYear();\r\n const month = String(today.getMonth() + 1).padStart(2, \"0\");\r\n const day = String(today.getDate()).padStart(2, \"0\");\r\n return `${year}${month}${day}`;\r\n }\r\n}\r\n","// src/common/helpers/date.util.ts\r\nexport class DateUtil {\r\n // Current time as epoch milliseconds\r\n static now(): number {\r\n return Date.now();\r\n }\r\n\r\n // Date object → epoch milliseconds\r\n static toEpoch(date: Date): number {\r\n return date.getTime();\r\n }\r\n\r\n // Epoch milliseconds → Date object\r\n static toDate(epoch: number): Date {\r\n return new Date(epoch);\r\n }\r\n\r\n // Epoch milliseconds → readable string\r\n static toReadable(epoch: number): string {\r\n return new Date(epoch).toISOString();\r\n }\r\n\r\n // Add days to epoch → returns epoch\r\n static addDays(epoch: number, days: number): number {\r\n return epoch + days * 24 * 60 * 60 * 1000;\r\n }\r\n\r\n // Add months to epoch → returns epoch\r\n static addMonths(epoch: number, months: number): number {\r\n const date = new Date(epoch);\r\n date.setMonth(date.getMonth() + months);\r\n return date.getTime();\r\n }\r\n\r\n // Add weeks to epoch → returns epoch\r\n static addWeeks(epoch: number, weeks: number): number {\r\n return this.addDays(epoch, weeks * 7);\r\n }\r\n\r\n // Add years to epoch → returns epoch\r\n static addYears(epoch: number, years: number): number {\r\n const date = new Date(epoch);\r\n date.setFullYear(date.getFullYear() + years);\r\n return date.getTime();\r\n }\r\n\r\n // Difference in days between two epochs\r\n static daysDifference(epoch1: number, epoch2: number): number {\r\n return Math.ceil((epoch2 - epoch1) / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n // Check if epoch is today\r\n static isToday(epoch: number): boolean {\r\n const date = new Date(epoch);\r\n const today = new Date();\r\n return (\r\n date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear()\r\n );\r\n }\r\n\r\n // Check if epoch is in the past\r\n static isPast(epoch: number): boolean {\r\n return epoch < Date.now();\r\n }\r\n\r\n // Check if epoch is in the future\r\n static isFuture(epoch: number): boolean {\r\n return epoch > Date.now();\r\n }\r\n}\r\n\r\n","import { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport {\r\n entityListEntityModelMap,\r\n IModelRelationConfig,\r\n RelationType,\r\n} from \"../utils\";\r\nimport { EntityList, EntityType } from \"../utils/entity.utils\";\r\n\r\nexport abstract class BaseEntityModel {\r\n static relations: Partial<\r\n Record<EntityList, IModelRelationConfig<EntityList>>\r\n > = {};\r\n\r\n // populateRelations(searchResponse: ISearchV2Response): this {\r\n // const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n // for (const [prop, config] of Object.entries(relations)) {\r\n // const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // // @ts-ignore\r\n // const fkValue = this[mappingProperty];\r\n // const bucket = searchResponse[entity] ?? [];\r\n // if (!bucket.length) continue;\r\n\r\n // if (relationType === RelationType.ONE) {\r\n // // @ts-ignore\r\n // const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n // if (match) {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(match);\r\n // // recursively populate relations on the hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // this[prop as keyof this] = hydrated;\r\n // }\r\n // } else {\r\n // const matches = bucket.filter(\r\n // (e: any) => e[searchProperty] === fkValue,\r\n // );\r\n // this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(e);\r\n // // recursively populate relations on each hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // return hydrated;\r\n // }) as this[keyof this];\r\n // }\r\n // }\r\n // return this;\r\n // }\r\n\r\n populateRelations(\r\n searchResponse: ISearchV2Response,\r\n visited = new Set<string>(),\r\n ): this {\r\n const selfKey = `${this.constructor.name}:${(this as any).id}`;\r\n if (visited.has(selfKey)) return this;\r\n visited.add(selfKey);\r\n\r\n const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n for (const [prop, config] of Object.entries(relations)) {\r\n const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // @ts-ignore\r\n const fkValue = this[mappingProperty];\r\n const bucket = searchResponse[entity] ?? [];\r\n if (!bucket.length) continue;\r\n\r\n if (relationType === RelationType.ONE) {\r\n // @ts-ignore\r\n const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n if (match) {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(match);\r\n hydrated.populateRelations(searchResponse, visited);\r\n this[prop as keyof this] = hydrated;\r\n }\r\n } else {\r\n const matches = bucket.filter(\r\n (e: any) => e[searchProperty] === fkValue,\r\n );\r\n this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(e);\r\n hydrated.populateRelations(searchResponse, visited);\r\n return hydrated;\r\n }) as this[keyof this];\r\n }\r\n }\r\n return this;\r\n }\r\n}\r\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IDonationHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationHistoryModel\n extends BaseEntityModel\n implements IDonationHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.DONATION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IDonationHistoryEntity,\n ): DonationHistoryModel {\n return Object.assign(new DonationHistoryModel(), entity);\n }\n}\n","import { IDonationEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationModel extends BaseEntityModel implements IDonationEntity {\n id: number = 0;\n flatNo: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IDonationEntity): DonationModel {\n return Object.assign(new DonationModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IExpenseHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseHistoryModel\n extends BaseEntityModel\n implements IExpenseHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.EXPENSE_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IExpenseHistoryEntity,\n ): ExpenseHistoryModel {\n return Object.assign(new ExpenseHistoryModel(), entity);\n }\n}\n","import { IExpenseEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseModel extends BaseEntityModel implements IExpenseEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n vendorName: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IExpenseEntity): ExpenseModel {\n return Object.assign(new ExpenseModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ISponsorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorHistoryModel\n extends BaseEntityModel\n implements ISponsorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.SPONSOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ISponsorHistoryEntity,\n ): SponsorHistoryModel {\n return Object.assign(new SponsorHistoryModel(), entity);\n }\n}\n","import { SponsorFor } from \"../enums\";\nimport { ISponsorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorModel extends BaseEntityModel implements ISponsorEntity {\n id: number = 0;\n contactName: string = \"\";\n contactNo: string = \"\";\n sponsorFor: SponsorFor = SponsorFor.GHEE;\n size: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ISponsorEntity): SponsorModel {\n return Object.assign(new SponsorModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ITransactionHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionHistoryModel\n extends BaseEntityModel\n implements ITransactionHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.TRANSACTION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ITransactionHistoryEntity,\n ): TransactionHistoryModel {\n return Object.assign(new TransactionHistoryModel(), entity);\n }\n}\n","import { ITransactionEntity, TransactionType } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionModel\n extends BaseEntityModel\n implements ITransactionEntity\n{\n id: number = 0;\n date: string = \"\";\n type: TransactionType = \"Income\";\n particulars: string = \"\";\n amount: number = 0;\n balanceAfter: number = 0;\n referenceId: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ITransactionEntity): TransactionModel {\n return Object.assign(new TransactionModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IUserHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserHistoryModel\n extends BaseEntityModel\n implements IUserHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.USER_HISTORY>>\n > = {};\n\n static populateFromEntity(entity: IUserHistoryEntity): UserHistoryModel {\n return Object.assign(new UserHistoryModel(), entity);\n }\n}\n","import { IUserEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserModel extends BaseEntityModel implements IUserEntity {\n id: number = 0;\n name: string = \"\";\n password: string = \"\";\n email: string = \"\";\n phone: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IUserEntity): UserModel {\n return Object.assign(new UserModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IVendorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorHistoryModel\n extends BaseEntityModel\n implements IVendorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.VENDOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IVendorHistoryEntity,\n ): VendorHistoryModel {\n return Object.assign(new VendorHistoryModel(), entity);\n }\n}\n","import { IVendorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorModel extends BaseEntityModel implements IVendorEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IVendorEntity): VendorModel {\n return Object.assign(new VendorModel(), entity);\n }\n}\n","import { IDonationHistoryEntity } from \"../interfaces/entities/donation-history.entity.interface\";\nimport { IDonationEntity } from \"../interfaces/entities/donation.entity.interface\";\nimport { IExpenseHistoryEntity } from \"../interfaces/entities/expense-history.entity.interface\";\nimport { IExpenseEntity } from \"../interfaces/entities/expense.entity.interface\";\nimport { ISponsorHistoryEntity } from \"../interfaces/entities/sponsor-history.entity.interface\";\nimport { ISponsorEntity } from \"../interfaces/entities/sponsor.entity.interface\";\nimport { ITransactionHistoryEntity } from \"../interfaces/entities/transaction-history.entity.interface\";\nimport { ITransactionEntity } from \"../interfaces/entities/transaction.entity.interface\";\nimport { IUserHistoryEntity } from \"../interfaces/entities/user-history.entity.interface\";\nimport { IUserEntity } from \"../interfaces/entities/user.entity.interface\";\nimport { IVendorHistoryEntity } from \"../interfaces/entities/vendor-history.entity.interface\";\nimport { IVendorEntity } from \"../interfaces/entities/vendor.entity.interface\";\nimport { DonationHistoryModel } from \"../models/donation-history.entity.model\";\nimport { DonationModel } from \"../models/donation.entity.model\";\nimport { ExpenseHistoryModel } from \"../models/expense-history.entity.model\";\nimport { ExpenseModel } from \"../models/expense.entity.model\";\nimport { SponsorHistoryModel } from \"../models/sponsor-history.entity.model\";\nimport { SponsorModel } from \"../models/sponsor.entity.model\";\nimport { TransactionHistoryModel } from \"../models/transaction-history.entity.model\";\nimport { TransactionModel } from \"../models/transaction.entity.model\";\nimport { UserHistoryModel } from \"../models/user-history.entity.model\";\nimport { UserModel } from \"../models/user.entity.model\";\nimport { VendorHistoryModel } from \"../models/vendor-history.entity.model\";\nimport { VendorModel } from \"../models/vendor.entity.model\";\n\nexport enum EntityList {\n DONATION = \"donation\",\n DONATION_HISTORY = \"donation_history\",\n USER = \"user\",\n USER_HISTORY = \"user_history\",\n EXPENSE = \"expense\",\n EXPENSE_HISTORY = \"expense_history\",\n VENDOR = \"vendor\",\n VENDOR_HISTORY = \"vendor_history\",\n TRANSACTION = \"transaction\",\n TRANSACTION_HISTORY = \"transaction_history\",\n SPONSOR = \"sponsor\",\n SPONSOR_HISTORY = \"sponsor_history\",\n}\n\nexport type EntityType<T extends EntityList> = T extends EntityList.DONATION\n ? IDonationEntity\n : T extends EntityList.DONATION_HISTORY\n ? IDonationHistoryEntity\n : T extends EntityList.USER\n ? IUserEntity\n : T extends EntityList.USER_HISTORY\n ? IUserHistoryEntity\n : T extends EntityList.EXPENSE\n ? IExpenseEntity\n : T extends EntityList.EXPENSE_HISTORY\n ? IExpenseHistoryEntity\n : T extends EntityList.VENDOR\n ? IVendorEntity\n : T extends EntityList.VENDOR_HISTORY\n ? IVendorHistoryEntity\n : T extends EntityList.TRANSACTION\n ? ITransactionEntity\n : T extends EntityList.TRANSACTION_HISTORY\n ? ITransactionHistoryEntity\n : T extends EntityList.SPONSOR\n ? ISponsorEntity\n : T extends EntityList.SPONSOR_HISTORY\n ? ISponsorHistoryEntity\n : never;\n\nexport type EntityModelType<T extends EntityList> =\n T extends EntityList.DONATION\n ? DonationModel\n : T extends EntityList.DONATION_HISTORY\n ? DonationHistoryModel\n : T extends EntityList.USER\n ? UserModel\n : T extends EntityList.USER_HISTORY\n ? UserHistoryModel\n : T extends EntityList.EXPENSE\n ? ExpenseModel\n : T extends EntityList.EXPENSE_HISTORY\n ? ExpenseHistoryModel\n : T extends EntityList.VENDOR\n ? VendorModel\n : T extends EntityList.VENDOR_HISTORY\n ? VendorHistoryModel\n : T extends EntityList.TRANSACTION\n ? TransactionModel\n : T extends EntityList.TRANSACTION_HISTORY\n ? TransactionHistoryModel\n : T extends EntityList.SPONSOR\n ? SponsorModel\n : T extends EntityList.SPONSOR_HISTORY\n ? SponsorHistoryModel\n : never;\n\nexport type EntityListEntityModelMap = {\n [T in EntityList]: EntityModelType<T>[];\n};\n","import {\n DonationHistoryModel,\n DonationModel,\n ExpenseHistoryModel,\n ExpenseModel,\n SponsorHistoryModel,\n SponsorModel,\n TransactionHistoryModel,\n TransactionModel,\n UserHistoryModel,\n UserModel,\n VendorHistoryModel,\n VendorModel,\n} from \"../models\";\nimport { EntityList } from \"./entity.utils\";\n\nexport const entityListEntityModelMap = {\n [EntityList.DONATION]: DonationModel.populateFromEntity,\n [EntityList.DONATION_HISTORY]: DonationHistoryModel.populateFromEntity,\n [EntityList.USER]: UserModel.populateFromEntity,\n [EntityList.USER_HISTORY]: UserHistoryModel.populateFromEntity,\n [EntityList.EXPENSE]: ExpenseModel.populateFromEntity,\n [EntityList.EXPENSE_HISTORY]: ExpenseHistoryModel.populateFromEntity,\n [EntityList.VENDOR]: VendorModel.populateFromEntity,\n [EntityList.VENDOR_HISTORY]: VendorHistoryModel.populateFromEntity,\n [EntityList.TRANSACTION]: TransactionModel.populateFromEntity,\n [EntityList.TRANSACTION_HISTORY]: TransactionHistoryModel.populateFromEntity,\n [EntityList.SPONSOR]: SponsorModel.populateFromEntity,\n [EntityList.SPONSOR_HISTORY]: SponsorHistoryModel.populateFromEntity,\n};\n","export class HttpException extends Error {\r\n constructor(\r\n public readonly message: string,\r\n public readonly statusCode: number,\r\n public readonly key?: string,\r\n public readonly errors?: any,\r\n ) {\r\n super(message);\r\n this.name = this.constructor.name;\r\n if ((Error as any).captureStackTrace) {\r\n (Error as any).captureStackTrace(this, this.constructor);\r\n }\r\n }\r\n\r\n getResponse() {\r\n return {\r\n statusCode: this.statusCode,\r\n message: this.message,\r\n key: this.key,\r\n errors: this.errors,\r\n };\r\n }\r\n\r\n getStatus() {\r\n return this.statusCode;\r\n }\r\n}\r\n\r\nexport class BadRequestException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string | string[],\r\n errors?: any,\r\n ) {\r\n if (typeof input === \"object\" && !Array.isArray(input)) {\r\n super(input.message, 400, input.key, errors);\r\n } else {\r\n super(\r\n Array.isArray(input) ? input.join(\", \") : input,\r\n 400,\r\n undefined,\r\n errors,\r\n );\r\n }\r\n }\r\n}\r\n\r\nexport class NotFoundException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Not Found\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 404, input.key);\r\n } else {\r\n super(input, 404);\r\n }\r\n }\r\n}\r\n\r\nexport class UnauthorizedException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string = \"Unauthorized\",\r\n ) {\r\n if (typeof input === \"object\") {\r\n super(input.message, 401, input.key);\r\n } else {\r\n super(input, 401);\r\n }\r\n }\r\n}\r\n\r\nexport class ForbiddenException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Forbidden\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 403, input.key);\r\n } else {\r\n super(input, 403);\r\n }\r\n }\r\n}\r\n","import { IAuditColumnEntity } from \"../helpers/audit-column.entity.interface\";\r\nimport { BadRequestException } from \"./error.utils\";\r\n\r\nexport function getObjectDiffingKeys<T extends Record<string, any>>(\r\n oldObject: T,\r\n newObject: T,\r\n): Partial<T> {\r\n const keysToExclude: (keyof IAuditColumnEntity)[] = [\r\n \"createdOn\",\r\n \"createdBy\",\r\n ];\r\n const keysOfOldObject = Object.keys(oldObject);\r\n const keysOfNewObject = Object.keys(newObject);\r\n\r\n if (keysOfOldObject.length !== keysOfNewObject.length) {\r\n throw new BadRequestException({\r\n key: \"objects\",\r\n message: `Different objects recieved for diffing. Please check & try again.`,\r\n });\r\n }\r\n\r\n const oldDiffingKeys = {} as T;\r\n const newDiffingKeys = {} as Partial<T>;\r\n\r\n for (const key of keysOfOldObject as Array<keyof T>) {\r\n if (keysToExclude.includes(key as keyof IAuditColumnEntity)) continue;\r\n\r\n const oldVal = oldObject[key];\r\n const newVal = newObject[key];\r\n\r\n if (JSON.stringify(oldVal) !== JSON.stringify(newVal)) {\r\n oldDiffingKeys[key] = oldVal;\r\n newDiffingKeys[key] = newVal;\r\n }\r\n }\r\n\r\n return newDiffingKeys;\r\n}\r\n\r\n/**\r\n * Compares two arrays and returns the difference between them.\r\n *\r\n * @template T - The type of elements in the arrays\r\n * @param {T[]} arr1 - The original array\r\n * @param {T[]} arr2 - The new array to compare against\r\n * @returns {{ present: T[], deleted: T[], added: T[] }} An object containing:\r\n * - `present` — items found in both arrays (intersection)\r\n * - `deleted` — items in `arr1` but not in `arr2`\r\n * - `added` — items in `arr2` but not in `arr1`\r\n *\r\n * @example\r\n * const arr1 = [1, 2, 3, 4];\r\n * const arr2 = [3, 4, 5, 6];\r\n *\r\n * diffArrays(arr1, arr2);\r\n * // {\r\n * // present: [3, 4],\r\n * // deleted: [1, 2],\r\n * // added: [5, 6]\r\n * // }\r\n */\r\nexport function diffArrays<T>(arr1: T[], arr2: T[]) {\r\n const set1 = new Set(arr1);\r\n const set2 = new Set(arr2);\r\n\r\n return {\r\n present: arr1.filter((item) => set2.has(item)),\r\n deleted: arr1.filter((item) => !set2.has(item)),\r\n added: arr2.filter((item) => !set1.has(item)),\r\n };\r\n}\r\n\r\n/**\r\n * Groups an array of objects by a specified key, returning a `Map` where each\r\n * unique value of the key becomes an entry containing all items that share that value.\r\n * Use this as a fallback if `Object.groupBy` (ES2024) is not available in your environment.\r\n *\r\n * @template T - The type of objects in the array\r\n * @param items - The array of objects to group\r\n * @param key - A key of `T` whose value will be used as the group identifier\r\n * @returns A `Map` where each key maps to an array of items belonging to that group\r\n *\r\n * @example\r\n * const grouped = groupBy(items, 'someKey');\r\n * grouped.get('keyValue1'); // [item1, item2]\r\n * grouped.get('keyValue2'); // [item3]\r\n */\r\nexport function groupBy<T>(items: T[], key: keyof T): Map<string, T[]> {\r\n const result = new Map<string, T[]>();\r\n for (const item of items) {\r\n const groupKey = String(item[key]);\r\n if (!result.has(groupKey)) {\r\n result.set(groupKey, []);\r\n }\r\n result.get(groupKey)!.push(item);\r\n }\r\n return result;\r\n}\r\n\r\nexport function definedValues<T>(arr: Array<T | undefined | null>): T[] {\r\n return arr.filter((value): value is T => value != null);\r\n}\r\n","import { EntityList, EntityType } from \".\";\r\n\r\nexport enum RelationType {\r\n ONE = \"ONE\",\r\n MANY = \"MANY\",\r\n}\r\n\r\nexport interface IModelRelationConfig<T extends EntityList> {\r\n relationType: RelationType;\r\n mappingProperty: keyof EntityType<T> & string;\r\n searchProperty: string;\r\n entity: EntityList;\r\n}\r\n","export enum OrderByDirection {\r\n ASC = \"ASC\",\r\n DESC = \"DESC\",\r\n}\r\n\r\n// export type IOrderByFilter<T> = {\r\n// column: keyof T;\r\n// direction: OrderByDirection;\r\n// };\r\n","import { BaseEntityModel } from \"../models\";\r\nimport { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport { BadRequestException, entityListEntityModelMap } from \"../utils\";\r\nimport {\r\n EntityList,\r\n EntityListEntityModelMap,\r\n EntityModelType,\r\n EntityType,\r\n} from \"../utils/entity.utils\";\r\n\r\n/**\r\n * Helper class for extracting typed entities from a `searchV2` response.\r\n *\r\n * @example new EntityFilterDataHelper(searchV2Response)\r\n *\r\n * @methods\r\n * - `getEntityFromList(name)` — returns typed entity array for the given `EntityList` key. e.g. `helper.getEntityFromList(EntityList.USER) // IUserEntity[]`\r\n */\r\nexport class EntityFilterDataHelper {\r\n entityModelsMap: EntityListEntityModelMap = {} as EntityListEntityModelMap;\r\n\r\n constructor(private readonly searchResponse: ISearchV2Response) {\r\n this.entityModelsMap = this.populateEntityModelsMap();\r\n }\r\n\r\n getEntityFromList<T extends EntityList>(name: T): EntityModelType<T>[] {\r\n const populateFn = entityListEntityModelMap[name];\r\n const data = this.searchResponse[name] ?? [];\r\n return data.map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof name>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n // getEntityModelsMap(): EntityListEntityModelMap {\r\n private populateEntityModelsMap(): EntityListEntityModelMap {\r\n const responseObj: EntityListEntityModelMap =\r\n {} as EntityListEntityModelMap;\r\n\r\n for (const key of Object.keys(this.searchResponse) as EntityList[]) {\r\n const populateFn = entityListEntityModelMap[key];\r\n if (!populateFn) continue;\r\n\r\n const raw = this.searchResponse[key];\r\n if (!Array.isArray(raw)) continue;\r\n\r\n // @ts-expect-error - conditional type EntityModelType<T> cannot be resolved in loop context\r\n (responseObj[key] as EntityModelType<typeof key>[]) = this.searchResponse[\r\n key\r\n ].map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof key>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n return responseObj;\r\n }\r\n\r\n getEntityModelsByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any[] },\r\n ): EntityModelType<T>[] {\r\n const filteredModels = this.entityModelsMap[entityName].filter((model) =>\r\n filter.value.includes(model[filter.key]),\r\n );\r\n\r\n if (filteredModels.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value.join(\", \")} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n return filteredModels;\r\n }\r\n\r\n getEntityModelByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any },\r\n ) {\r\n const filteredModel = this.entityModelsMap[entityName].filter(\r\n (model) => model[filter.key] === filter.value,\r\n );\r\n if (filteredModel.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n // console.log(\"filteredModel\", filteredModel);\r\n return filteredModel[0];\r\n }\r\n\r\n // populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n // for (const entityName of entityNames) {\r\n // const models = this.entityModelsMap[entityName];\r\n // if (!models) continue;\r\n // for (const model of models) {\r\n // (model as unknown as BaseEntityModel).populateRelations(\r\n // this.searchResponse,\r\n // );\r\n // }\r\n // }\r\n // return this.entityModelsMap;\r\n // }\r\n\r\n populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n for (const entityName of entityNames) {\r\n const models = this.entityModelsMap[entityName];\r\n if (!models) continue;\r\n for (const model of models) {\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(), // fresh set per top-level model\r\n );\r\n }\r\n }\r\n return this.entityModelsMap;\r\n }\r\n\r\n mergeEntity<T extends EntityList>(\r\n entityName: T,\r\n savedEntity: EntityType<T>,\r\n ): EntityModelType<T> {\r\n const populateFn = entityListEntityModelMap[entityName];\r\n const model = (populateFn as (e: EntityType<T>) => EntityModelType<T>)(\r\n savedEntity,\r\n );\r\n\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(),\r\n );\r\n\r\n return model;\r\n }\r\n}\r\n"],"mappings":"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","names":["EntityHistoryOperation","SponsorFor","EntityList","RelationType","OrderByDirection"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/enums/entity-history-operation.enum.ts","../src/enums/sponsor-for.enum.ts","../src/utils/date-code.utils.ts","../src/utils/date.utils.ts","../src/models/base.entity.model.ts","../src/models/donation-history.entity.model.ts","../src/models/donation.entity.model.ts","../src/models/expense-history.entity.model.ts","../src/models/expense.entity.model.ts","../src/models/sponsor-history.entity.model.ts","../src/models/sponsor.entity.model.ts","../src/models/transaction-history.entity.model.ts","../src/models/transaction.entity.model.ts","../src/models/user-history.entity.model.ts","../src/models/user.entity.model.ts","../src/models/vendor-history.entity.model.ts","../src/models/vendor.entity.model.ts","../src/utils/entity.utils.ts","../src/utils/entitiy-list-entity-model-map.ts","../src/utils/error.utils.ts","../src/utils/helper.fns.ts","../src/utils/relation-config.utils.ts","../src/utils/sql-utils.ts","../src/helpers/entity-filter-data.helper.ts"],"sourcesContent":["export * from \"./enums/index\";\r\nexport * from \"./helpers/index\";\r\nexport * from \"./interfaces/index\";\r\nexport * from \"./models/index\";\r\nexport * from \"./types/index\";\r\nexport * from \"./utils/index\";\r\n","export enum EntityHistoryOperation {\r\n CREATE = 'CREATE',\r\n UPDATE = 'UPDATE',\r\n DELETE = 'DELETE',\r\n}\r\n","export enum SponsorFor {\n GHEE = 'ghee',\n PRASAD = 'prasad',\n BANNER = 'banner',\n}\n","/**\r\n * Utility class for validating date codes in `YYYYMMDD` format.\r\n *\r\n * @example new DateCodeUtils(20240315)\r\n *\r\n * @methods\r\n * - `isValidYYYYMMDD()` — checks if the date code is a real calendar date. e.g. `new DateCodeUtils(20240315).isValidYYYYMMDD() // true`\r\n */\r\nexport class DateCodeUtils {\r\n stringifiedDateCode: string;\r\n constructor(private readonly dateCode: string | number) {\r\n this.stringifiedDateCode = String(this.dateCode);\r\n if (!this.isValidYYYYMMDD()) {\r\n throw new Error(\r\n `Invalid date code: \"${this.stringifiedDateCode}\". Expected format: YYYYMMDD.`,\r\n );\r\n }\r\n }\r\n\r\n isValidYYYYMMDD(): boolean {\r\n if (!/^\\d{8}$/.test(this.stringifiedDateCode)) return false;\r\n\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n if (month < 1 || month > 12) return false;\r\n if (day < 1 || day > 31) return false;\r\n\r\n const date = new Date(year, month - 1, day);\r\n return (\r\n date.getFullYear() === year &&\r\n date.getMonth() === month - 1 &&\r\n date.getDate() === day\r\n );\r\n }\r\n\r\n toLongDateString(): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n return new Date(year, month - 1, day).toLocaleDateString(\"en-US\", {\r\n year: \"numeric\",\r\n month: \"long\",\r\n day: \"numeric\",\r\n });\r\n }\r\n\r\n addMonths(months: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1 + months, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addDays(days: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1, day);\r\n date.setDate(date.getDate() + days);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addWeeks(weeks: number): string {\r\n return this.addDays(weeks * 7);\r\n }\r\n\r\n addYears(years: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year + years, month - 1, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n private parseDateParts(): { year: number; month: number; day: number } {\r\n return {\r\n year: parseInt(this.stringifiedDateCode.substring(0, 4), 10),\r\n month: parseInt(this.stringifiedDateCode.substring(4, 6), 10),\r\n day: parseInt(this.stringifiedDateCode.substring(6, 8), 10),\r\n };\r\n }\r\n\r\n static getCurrentYear(): number {\r\n return new Date().getFullYear();\r\n }\r\n\r\n static daysDiff(dateCode: string | number): number {\r\n const { year, month, day } = new DateCodeUtils(dateCode).parseDateParts();\r\n const target = new Date(year, month - 1, day);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n\r\n const diffMs = target.getTime() - today.getTime();\r\n return Math.round(diffMs / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n static getCurrentDateCode(): string {\r\n const today = new Date();\r\n const year = today.getFullYear();\r\n const month = String(today.getMonth() + 1).padStart(2, \"0\");\r\n const day = String(today.getDate()).padStart(2, \"0\");\r\n return `${year}${month}${day}`;\r\n }\r\n}\r\n","// src/common/helpers/date.util.ts\r\nexport class DateUtil {\r\n // Current time as epoch milliseconds\r\n static now(): number {\r\n return Date.now();\r\n }\r\n\r\n // Date object → epoch milliseconds\r\n static toEpoch(date: Date): number {\r\n return date.getTime();\r\n }\r\n\r\n // Epoch milliseconds → Date object\r\n static toDate(epoch: number): Date {\r\n return new Date(epoch);\r\n }\r\n\r\n // Epoch milliseconds → readable string\r\n static toReadable(epoch: number): string {\r\n return new Date(epoch).toISOString();\r\n }\r\n\r\n // Add days to epoch → returns epoch\r\n static addDays(epoch: number, days: number): number {\r\n return epoch + days * 24 * 60 * 60 * 1000;\r\n }\r\n\r\n // Add months to epoch → returns epoch\r\n static addMonths(epoch: number, months: number): number {\r\n const date = new Date(epoch);\r\n date.setMonth(date.getMonth() + months);\r\n return date.getTime();\r\n }\r\n\r\n // Add weeks to epoch → returns epoch\r\n static addWeeks(epoch: number, weeks: number): number {\r\n return this.addDays(epoch, weeks * 7);\r\n }\r\n\r\n // Add years to epoch → returns epoch\r\n static addYears(epoch: number, years: number): number {\r\n const date = new Date(epoch);\r\n date.setFullYear(date.getFullYear() + years);\r\n return date.getTime();\r\n }\r\n\r\n // Difference in days between two epochs\r\n static daysDifference(epoch1: number, epoch2: number): number {\r\n return Math.ceil((epoch2 - epoch1) / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n // Check if epoch is today\r\n static isToday(epoch: number): boolean {\r\n const date = new Date(epoch);\r\n const today = new Date();\r\n return (\r\n date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear()\r\n );\r\n }\r\n\r\n // Check if epoch is in the past\r\n static isPast(epoch: number): boolean {\r\n return epoch < Date.now();\r\n }\r\n\r\n // Check if epoch is in the future\r\n static isFuture(epoch: number): boolean {\r\n return epoch > Date.now();\r\n }\r\n}\r\n\r\n","import { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport {\r\n entityListEntityModelMap,\r\n IModelRelationConfig,\r\n RelationType,\r\n} from \"../utils\";\r\nimport { EntityList, EntityType } from \"../utils/entity.utils\";\r\n\r\nexport abstract class BaseEntityModel {\r\n static relations: Partial<\r\n Record<EntityList, IModelRelationConfig<EntityList>>\r\n > = {};\r\n\r\n // populateRelations(searchResponse: ISearchV2Response): this {\r\n // const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n // for (const [prop, config] of Object.entries(relations)) {\r\n // const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // // @ts-ignore\r\n // const fkValue = this[mappingProperty];\r\n // const bucket = searchResponse[entity] ?? [];\r\n // if (!bucket.length) continue;\r\n\r\n // if (relationType === RelationType.ONE) {\r\n // // @ts-ignore\r\n // const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n // if (match) {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(match);\r\n // // recursively populate relations on the hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // this[prop as keyof this] = hydrated;\r\n // }\r\n // } else {\r\n // const matches = bucket.filter(\r\n // (e: any) => e[searchProperty] === fkValue,\r\n // );\r\n // this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(e);\r\n // // recursively populate relations on each hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // return hydrated;\r\n // }) as this[keyof this];\r\n // }\r\n // }\r\n // return this;\r\n // }\r\n\r\n populateRelations(\r\n searchResponse: ISearchV2Response,\r\n visited = new Set<string>(),\r\n ): this {\r\n const selfKey = `${this.constructor.name}:${(this as any).id}`;\r\n if (visited.has(selfKey)) return this;\r\n visited.add(selfKey);\r\n\r\n const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n for (const [prop, config] of Object.entries(relations)) {\r\n const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // @ts-ignore\r\n const fkValue = this[mappingProperty];\r\n const bucket = searchResponse[entity] ?? [];\r\n if (!bucket.length) continue;\r\n\r\n if (relationType === RelationType.ONE) {\r\n // @ts-ignore\r\n const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n if (match) {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(match);\r\n hydrated.populateRelations(searchResponse, visited);\r\n this[prop as keyof this] = hydrated;\r\n }\r\n } else {\r\n const matches = bucket.filter(\r\n (e: any) => e[searchProperty] === fkValue,\r\n );\r\n this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(e);\r\n hydrated.populateRelations(searchResponse, visited);\r\n return hydrated;\r\n }) as this[keyof this];\r\n }\r\n }\r\n return this;\r\n }\r\n}\r\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IDonationHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationHistoryModel\n extends BaseEntityModel\n implements IDonationHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.DONATION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IDonationHistoryEntity,\n ): DonationHistoryModel {\n return Object.assign(new DonationHistoryModel(), entity);\n }\n}\n","import { IDonationEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationModel extends BaseEntityModel implements IDonationEntity {\n id: number = 0;\n receiptNumber: string = \"\";\n flatNo: string = \"\";\n amount: number = 0;\n mobileNumber?: string;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IDonationEntity): DonationModel {\n return Object.assign(new DonationModel(), entity);\n }\n\n static generateReceiptNumber(flatNo: string, existingDonations: DonationModel[]): string {\n const count = existingDonations.filter(d => d.flatNo === flatNo).length + 1;\n const seq = String(count).padStart(2, '0');\n return `MPCR-2026-${flatNo}-${seq}`;\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IExpenseHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseHistoryModel\n extends BaseEntityModel\n implements IExpenseHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.EXPENSE_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IExpenseHistoryEntity,\n ): ExpenseHistoryModel {\n return Object.assign(new ExpenseHistoryModel(), entity);\n }\n}\n","import { IExpenseEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseModel extends BaseEntityModel implements IExpenseEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n vendorName: string = \"\";\n amount: number = 0;\n billNumber?: string;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IExpenseEntity): ExpenseModel {\n return Object.assign(new ExpenseModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ISponsorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorHistoryModel\n extends BaseEntityModel\n implements ISponsorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.SPONSOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ISponsorHistoryEntity,\n ): SponsorHistoryModel {\n return Object.assign(new SponsorHistoryModel(), entity);\n }\n}\n","import { SponsorFor } from \"../enums\";\nimport { ISponsorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorModel extends BaseEntityModel implements ISponsorEntity {\n id: number = 0;\n sponsorName: string = \"\";\n contactName: string = \"\";\n contactNo: string = \"\";\n sponsorFor: SponsorFor = SponsorFor.GHEE;\n size: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ISponsorEntity): SponsorModel {\n return Object.assign(new SponsorModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ITransactionHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionHistoryModel\n extends BaseEntityModel\n implements ITransactionHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.TRANSACTION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ITransactionHistoryEntity,\n ): TransactionHistoryModel {\n return Object.assign(new TransactionHistoryModel(), entity);\n }\n}\n","import { ITransactionEntity, TransactionType } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionModel\n extends BaseEntityModel\n implements ITransactionEntity\n{\n id: number = 0;\n date: string = \"\";\n type: TransactionType = \"Income\";\n particulars: string = \"\";\n amount: number = 0;\n balanceAfter: number = 0;\n referenceId: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ITransactionEntity): TransactionModel {\n return Object.assign(new TransactionModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IUserHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserHistoryModel\n extends BaseEntityModel\n implements IUserHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.USER_HISTORY>>\n > = {};\n\n static populateFromEntity(entity: IUserHistoryEntity): UserHistoryModel {\n return Object.assign(new UserHistoryModel(), entity);\n }\n}\n","import { IUserEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserModel extends BaseEntityModel implements IUserEntity {\n id: number = 0;\n name: string = \"\";\n password: string = \"\";\n email: string = \"\";\n phone: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IUserEntity): UserModel {\n return Object.assign(new UserModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IVendorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorHistoryModel\n extends BaseEntityModel\n implements IVendorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.VENDOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IVendorHistoryEntity,\n ): VendorHistoryModel {\n return Object.assign(new VendorHistoryModel(), entity);\n }\n}\n","import { IVendorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorModel extends BaseEntityModel implements IVendorEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IVendorEntity): VendorModel {\n return Object.assign(new VendorModel(), entity);\n }\n}\n","import { IDonationHistoryEntity } from \"../interfaces/entities/donation-history.entity.interface\";\nimport { IDonationEntity } from \"../interfaces/entities/donation.entity.interface\";\nimport { IExpenseHistoryEntity } from \"../interfaces/entities/expense-history.entity.interface\";\nimport { IExpenseEntity } from \"../interfaces/entities/expense.entity.interface\";\nimport { ISponsorHistoryEntity } from \"../interfaces/entities/sponsor-history.entity.interface\";\nimport { ISponsorEntity } from \"../interfaces/entities/sponsor.entity.interface\";\nimport { ITransactionHistoryEntity } from \"../interfaces/entities/transaction-history.entity.interface\";\nimport { ITransactionEntity } from \"../interfaces/entities/transaction.entity.interface\";\nimport { IUserHistoryEntity } from \"../interfaces/entities/user-history.entity.interface\";\nimport { IUserEntity } from \"../interfaces/entities/user.entity.interface\";\nimport { IVendorHistoryEntity } from \"../interfaces/entities/vendor-history.entity.interface\";\nimport { IVendorEntity } from \"../interfaces/entities/vendor.entity.interface\";\nimport { DonationHistoryModel } from \"../models/donation-history.entity.model\";\nimport { DonationModel } from \"../models/donation.entity.model\";\nimport { ExpenseHistoryModel } from \"../models/expense-history.entity.model\";\nimport { ExpenseModel } from \"../models/expense.entity.model\";\nimport { SponsorHistoryModel } from \"../models/sponsor-history.entity.model\";\nimport { SponsorModel } from \"../models/sponsor.entity.model\";\nimport { TransactionHistoryModel } from \"../models/transaction-history.entity.model\";\nimport { TransactionModel } from \"../models/transaction.entity.model\";\nimport { UserHistoryModel } from \"../models/user-history.entity.model\";\nimport { UserModel } from \"../models/user.entity.model\";\nimport { VendorHistoryModel } from \"../models/vendor-history.entity.model\";\nimport { VendorModel } from \"../models/vendor.entity.model\";\n\nexport enum EntityList {\n DONATION = \"donation\",\n DONATION_HISTORY = \"donation_history\",\n USER = \"user\",\n USER_HISTORY = \"user_history\",\n EXPENSE = \"expense\",\n EXPENSE_HISTORY = \"expense_history\",\n VENDOR = \"vendor\",\n VENDOR_HISTORY = \"vendor_history\",\n TRANSACTION = \"transaction\",\n TRANSACTION_HISTORY = \"transaction_history\",\n SPONSOR = \"sponsor\",\n SPONSOR_HISTORY = \"sponsor_history\",\n}\n\nexport type EntityType<T extends EntityList> = T extends EntityList.DONATION\n ? IDonationEntity\n : T extends EntityList.DONATION_HISTORY\n ? IDonationHistoryEntity\n : T extends EntityList.USER\n ? IUserEntity\n : T extends EntityList.USER_HISTORY\n ? IUserHistoryEntity\n : T extends EntityList.EXPENSE\n ? IExpenseEntity\n : T extends EntityList.EXPENSE_HISTORY\n ? IExpenseHistoryEntity\n : T extends EntityList.VENDOR\n ? IVendorEntity\n : T extends EntityList.VENDOR_HISTORY\n ? IVendorHistoryEntity\n : T extends EntityList.TRANSACTION\n ? ITransactionEntity\n : T extends EntityList.TRANSACTION_HISTORY\n ? ITransactionHistoryEntity\n : T extends EntityList.SPONSOR\n ? ISponsorEntity\n : T extends EntityList.SPONSOR_HISTORY\n ? ISponsorHistoryEntity\n : never;\n\nexport type EntityModelType<T extends EntityList> =\n T extends EntityList.DONATION\n ? DonationModel\n : T extends EntityList.DONATION_HISTORY\n ? DonationHistoryModel\n : T extends EntityList.USER\n ? UserModel\n : T extends EntityList.USER_HISTORY\n ? UserHistoryModel\n : T extends EntityList.EXPENSE\n ? ExpenseModel\n : T extends EntityList.EXPENSE_HISTORY\n ? ExpenseHistoryModel\n : T extends EntityList.VENDOR\n ? VendorModel\n : T extends EntityList.VENDOR_HISTORY\n ? VendorHistoryModel\n : T extends EntityList.TRANSACTION\n ? TransactionModel\n : T extends EntityList.TRANSACTION_HISTORY\n ? TransactionHistoryModel\n : T extends EntityList.SPONSOR\n ? SponsorModel\n : T extends EntityList.SPONSOR_HISTORY\n ? SponsorHistoryModel\n : never;\n\nexport type EntityListEntityModelMap = {\n [T in EntityList]: EntityModelType<T>[];\n};\n","import {\n DonationHistoryModel,\n DonationModel,\n ExpenseHistoryModel,\n ExpenseModel,\n SponsorHistoryModel,\n SponsorModel,\n TransactionHistoryModel,\n TransactionModel,\n UserHistoryModel,\n UserModel,\n VendorHistoryModel,\n VendorModel,\n} from \"../models\";\nimport { EntityList } from \"./entity.utils\";\n\nexport const entityListEntityModelMap = {\n [EntityList.DONATION]: DonationModel.populateFromEntity,\n [EntityList.DONATION_HISTORY]: DonationHistoryModel.populateFromEntity,\n [EntityList.USER]: UserModel.populateFromEntity,\n [EntityList.USER_HISTORY]: UserHistoryModel.populateFromEntity,\n [EntityList.EXPENSE]: ExpenseModel.populateFromEntity,\n [EntityList.EXPENSE_HISTORY]: ExpenseHistoryModel.populateFromEntity,\n [EntityList.VENDOR]: VendorModel.populateFromEntity,\n [EntityList.VENDOR_HISTORY]: VendorHistoryModel.populateFromEntity,\n [EntityList.TRANSACTION]: TransactionModel.populateFromEntity,\n [EntityList.TRANSACTION_HISTORY]: TransactionHistoryModel.populateFromEntity,\n [EntityList.SPONSOR]: SponsorModel.populateFromEntity,\n [EntityList.SPONSOR_HISTORY]: SponsorHistoryModel.populateFromEntity,\n};\n","export class HttpException extends Error {\r\n constructor(\r\n public readonly message: string,\r\n public readonly statusCode: number,\r\n public readonly key?: string,\r\n public readonly errors?: any,\r\n ) {\r\n super(message);\r\n this.name = this.constructor.name;\r\n if ((Error as any).captureStackTrace) {\r\n (Error as any).captureStackTrace(this, this.constructor);\r\n }\r\n }\r\n\r\n getResponse() {\r\n return {\r\n statusCode: this.statusCode,\r\n message: this.message,\r\n key: this.key,\r\n errors: this.errors,\r\n };\r\n }\r\n\r\n getStatus() {\r\n return this.statusCode;\r\n }\r\n}\r\n\r\nexport class BadRequestException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string | string[],\r\n errors?: any,\r\n ) {\r\n if (typeof input === \"object\" && !Array.isArray(input)) {\r\n super(input.message, 400, input.key, errors);\r\n } else {\r\n super(\r\n Array.isArray(input) ? input.join(\", \") : input,\r\n 400,\r\n undefined,\r\n errors,\r\n );\r\n }\r\n }\r\n}\r\n\r\nexport class NotFoundException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Not Found\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 404, input.key);\r\n } else {\r\n super(input, 404);\r\n }\r\n }\r\n}\r\n\r\nexport class UnauthorizedException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string = \"Unauthorized\",\r\n ) {\r\n if (typeof input === \"object\") {\r\n super(input.message, 401, input.key);\r\n } else {\r\n super(input, 401);\r\n }\r\n }\r\n}\r\n\r\nexport class ForbiddenException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Forbidden\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 403, input.key);\r\n } else {\r\n super(input, 403);\r\n }\r\n }\r\n}\r\n","import { IAuditColumnEntity } from \"../helpers/audit-column.entity.interface\";\r\nimport { BadRequestException } from \"./error.utils\";\r\n\r\nexport function getObjectDiffingKeys<T extends Record<string, any>>(\r\n oldObject: T,\r\n newObject: T,\r\n): Partial<T> {\r\n const keysToExclude: (keyof IAuditColumnEntity)[] = [\r\n \"createdOn\",\r\n \"createdBy\",\r\n ];\r\n const keysOfOldObject = Object.keys(oldObject);\r\n const keysOfNewObject = Object.keys(newObject);\r\n\r\n if (keysOfOldObject.length !== keysOfNewObject.length) {\r\n throw new BadRequestException({\r\n key: \"objects\",\r\n message: `Different objects recieved for diffing. Please check & try again.`,\r\n });\r\n }\r\n\r\n const oldDiffingKeys = {} as T;\r\n const newDiffingKeys = {} as Partial<T>;\r\n\r\n for (const key of keysOfOldObject as Array<keyof T>) {\r\n if (keysToExclude.includes(key as keyof IAuditColumnEntity)) continue;\r\n\r\n const oldVal = oldObject[key];\r\n const newVal = newObject[key];\r\n\r\n if (JSON.stringify(oldVal) !== JSON.stringify(newVal)) {\r\n oldDiffingKeys[key] = oldVal;\r\n newDiffingKeys[key] = newVal;\r\n }\r\n }\r\n\r\n return newDiffingKeys;\r\n}\r\n\r\n/**\r\n * Compares two arrays and returns the difference between them.\r\n *\r\n * @template T - The type of elements in the arrays\r\n * @param {T[]} arr1 - The original array\r\n * @param {T[]} arr2 - The new array to compare against\r\n * @returns {{ present: T[], deleted: T[], added: T[] }} An object containing:\r\n * - `present` — items found in both arrays (intersection)\r\n * - `deleted` — items in `arr1` but not in `arr2`\r\n * - `added` — items in `arr2` but not in `arr1`\r\n *\r\n * @example\r\n * const arr1 = [1, 2, 3, 4];\r\n * const arr2 = [3, 4, 5, 6];\r\n *\r\n * diffArrays(arr1, arr2);\r\n * // {\r\n * // present: [3, 4],\r\n * // deleted: [1, 2],\r\n * // added: [5, 6]\r\n * // }\r\n */\r\nexport function diffArrays<T>(arr1: T[], arr2: T[]) {\r\n const set1 = new Set(arr1);\r\n const set2 = new Set(arr2);\r\n\r\n return {\r\n present: arr1.filter((item) => set2.has(item)),\r\n deleted: arr1.filter((item) => !set2.has(item)),\r\n added: arr2.filter((item) => !set1.has(item)),\r\n };\r\n}\r\n\r\n/**\r\n * Groups an array of objects by a specified key, returning a `Map` where each\r\n * unique value of the key becomes an entry containing all items that share that value.\r\n * Use this as a fallback if `Object.groupBy` (ES2024) is not available in your environment.\r\n *\r\n * @template T - The type of objects in the array\r\n * @param items - The array of objects to group\r\n * @param key - A key of `T` whose value will be used as the group identifier\r\n * @returns A `Map` where each key maps to an array of items belonging to that group\r\n *\r\n * @example\r\n * const grouped = groupBy(items, 'someKey');\r\n * grouped.get('keyValue1'); // [item1, item2]\r\n * grouped.get('keyValue2'); // [item3]\r\n */\r\nexport function groupBy<T>(items: T[], key: keyof T): Map<string, T[]> {\r\n const result = new Map<string, T[]>();\r\n for (const item of items) {\r\n const groupKey = String(item[key]);\r\n if (!result.has(groupKey)) {\r\n result.set(groupKey, []);\r\n }\r\n result.get(groupKey)!.push(item);\r\n }\r\n return result;\r\n}\r\n\r\nexport function definedValues<T>(arr: Array<T | undefined | null>): T[] {\r\n return arr.filter((value): value is T => value != null);\r\n}\r\n\r\n/**\r\n * Converts an epoch timestamp (milliseconds) into a human-readable date string.\r\n *\r\n * @param epoch - The epoch timestamp in milliseconds\r\n * @param format - Optional output format:\r\n * - `'short'` — locale-specific short date (e.g. \"25/12/2026\")\r\n * - `'long'` — locale-specific long date (e.g. \"25 December 2026\")\r\n * - `'iso'` — ISO 8601 string (default)\r\n * @returns The formatted date string\r\n *\r\n * @example\r\n * epochToReadableDate(1700000000000, 'long'); // \"14 November 2023\"\r\n * epochToReadableDate(1700000000000, 'short'); // \"14/11/2023\"\r\n * epochToReadableDate(1700000000000); // \"2023-11-14T18:13:20.000Z\"\r\n */\r\nexport function epochToReadableDate(\r\n epoch: number,\r\n format: 'short' | 'long' | 'iso' = 'iso',\r\n): string {\r\n const date = new Date(epoch);\r\n switch (format) {\r\n case 'short':\r\n return date.toLocaleDateString('en-IN');\r\n case 'long':\r\n return date.toLocaleDateString('en-IN', {\r\n year: 'numeric',\r\n month: 'long',\r\n day: 'numeric',\r\n });\r\n case 'iso':\r\n default:\r\n return date.toISOString();\r\n }\r\n}\r\n","import { EntityList, EntityType } from \".\";\r\n\r\nexport enum RelationType {\r\n ONE = \"ONE\",\r\n MANY = \"MANY\",\r\n}\r\n\r\nexport interface IModelRelationConfig<T extends EntityList> {\r\n relationType: RelationType;\r\n mappingProperty: keyof EntityType<T> & string;\r\n searchProperty: string;\r\n entity: EntityList;\r\n}\r\n","export enum OrderByDirection {\r\n ASC = \"ASC\",\r\n DESC = \"DESC\",\r\n}\r\n\r\n// export type IOrderByFilter<T> = {\r\n// column: keyof T;\r\n// direction: OrderByDirection;\r\n// };\r\n","import { BaseEntityModel } from \"../models\";\r\nimport { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport { BadRequestException, entityListEntityModelMap } from \"../utils\";\r\nimport {\r\n EntityList,\r\n EntityListEntityModelMap,\r\n EntityModelType,\r\n EntityType,\r\n} from \"../utils/entity.utils\";\r\n\r\n/**\r\n * Helper class for extracting typed entities from a `searchV2` response.\r\n *\r\n * @example new EntityFilterDataHelper(searchV2Response)\r\n *\r\n * @methods\r\n * - `getEntityFromList(name)` — returns typed entity array for the given `EntityList` key. e.g. `helper.getEntityFromList(EntityList.USER) // IUserEntity[]`\r\n */\r\nexport class EntityFilterDataHelper {\r\n entityModelsMap: EntityListEntityModelMap = {} as EntityListEntityModelMap;\r\n\r\n constructor(private readonly searchResponse: ISearchV2Response) {\r\n this.entityModelsMap = this.populateEntityModelsMap();\r\n }\r\n\r\n getEntityFromList<T extends EntityList>(name: T): EntityModelType<T>[] {\r\n const populateFn = entityListEntityModelMap[name];\r\n const data = this.searchResponse[name] ?? [];\r\n return data.map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof name>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n // getEntityModelsMap(): EntityListEntityModelMap {\r\n private populateEntityModelsMap(): EntityListEntityModelMap {\r\n const responseObj: EntityListEntityModelMap =\r\n {} as EntityListEntityModelMap;\r\n\r\n for (const key of Object.keys(this.searchResponse) as EntityList[]) {\r\n const populateFn = entityListEntityModelMap[key];\r\n if (!populateFn) continue;\r\n\r\n const raw = this.searchResponse[key];\r\n if (!Array.isArray(raw)) continue;\r\n\r\n // @ts-expect-error - conditional type EntityModelType<T> cannot be resolved in loop context\r\n (responseObj[key] as EntityModelType<typeof key>[]) = this.searchResponse[\r\n key\r\n ].map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof key>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n return responseObj;\r\n }\r\n\r\n getEntityModelsByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any[] },\r\n ): EntityModelType<T>[] {\r\n const filteredModels = this.entityModelsMap[entityName].filter((model) =>\r\n filter.value.includes(model[filter.key]),\r\n );\r\n\r\n if (filteredModels.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value.join(\", \")} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n return filteredModels;\r\n }\r\n\r\n getEntityModelByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any },\r\n ) {\r\n const filteredModel = this.entityModelsMap[entityName].filter(\r\n (model) => model[filter.key] === filter.value,\r\n );\r\n if (filteredModel.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n // console.log(\"filteredModel\", filteredModel);\r\n return filteredModel[0];\r\n }\r\n\r\n // populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n // for (const entityName of entityNames) {\r\n // const models = this.entityModelsMap[entityName];\r\n // if (!models) continue;\r\n // for (const model of models) {\r\n // (model as unknown as BaseEntityModel).populateRelations(\r\n // this.searchResponse,\r\n // );\r\n // }\r\n // }\r\n // return this.entityModelsMap;\r\n // }\r\n\r\n populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n for (const entityName of entityNames) {\r\n const models = this.entityModelsMap[entityName];\r\n if (!models) continue;\r\n for (const model of models) {\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(), // fresh set per top-level model\r\n );\r\n }\r\n }\r\n return this.entityModelsMap;\r\n }\r\n\r\n mergeEntity<T extends EntityList>(\r\n entityName: T,\r\n savedEntity: EntityType<T>,\r\n ): EntityModelType<T> {\r\n const populateFn = entityListEntityModelMap[entityName];\r\n const model = (populateFn as (e: EntityType<T>) => EntityModelType<T>)(\r\n savedEntity,\r\n );\r\n\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(),\r\n );\r\n\r\n return model;\r\n }\r\n}\r\n"],"mappings":"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","names":["EntityHistoryOperation","SponsorFor","EntityList","RelationType","OrderByDirection"]}
package/dist/index.mjs CHANGED
@@ -253,6 +253,7 @@ var DonationModel = class _DonationModel extends BaseEntityModel {
253
253
  constructor() {
254
254
  super();
255
255
  this.id = 0;
256
+ this.receiptNumber = "";
256
257
  this.flatNo = "";
257
258
  this.amount = 0;
258
259
  this.createdOn = 0;
@@ -263,6 +264,11 @@ var DonationModel = class _DonationModel extends BaseEntityModel {
263
264
  static populateFromEntity(entity) {
264
265
  return Object.assign(new _DonationModel(), entity);
265
266
  }
267
+ static generateReceiptNumber(flatNo, existingDonations) {
268
+ const count = existingDonations.filter((d) => d.flatNo === flatNo).length + 1;
269
+ const seq = String(count).padStart(2, "0");
270
+ return `MPCR-2026-${flatNo}-${seq}`;
271
+ }
266
272
  };
267
273
 
268
274
  // src/models/expense-history.entity.model.ts
@@ -329,6 +335,7 @@ var SponsorModel = class _SponsorModel extends BaseEntityModel {
329
335
  constructor() {
330
336
  super();
331
337
  this.id = 0;
338
+ this.sponsorName = "";
332
339
  this.contactName = "";
333
340
  this.contactNo = "";
334
341
  this.sponsorFor = "ghee" /* GHEE */;
@@ -611,6 +618,22 @@ function groupBy(items, key) {
611
618
  function definedValues(arr) {
612
619
  return arr.filter((value) => value != null);
613
620
  }
621
+ function epochToReadableDate(epoch, format = "iso") {
622
+ const date = new Date(epoch);
623
+ switch (format) {
624
+ case "short":
625
+ return date.toLocaleDateString("en-IN");
626
+ case "long":
627
+ return date.toLocaleDateString("en-IN", {
628
+ year: "numeric",
629
+ month: "long",
630
+ day: "numeric"
631
+ });
632
+ case "iso":
633
+ default:
634
+ return date.toISOString();
635
+ }
636
+ }
614
637
 
615
638
  // src/utils/relation-config.utils.ts
616
639
  var RelationType = /* @__PURE__ */ ((RelationType2) => {
@@ -750,6 +773,7 @@ export {
750
773
  definedValues,
751
774
  diffArrays,
752
775
  entityListEntityModelMap,
776
+ epochToReadableDate,
753
777
  getObjectDiffingKeys,
754
778
  groupBy
755
779
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/enums/entity-history-operation.enum.ts","../src/enums/sponsor-for.enum.ts","../src/utils/date-code.utils.ts","../src/utils/date.utils.ts","../src/models/base.entity.model.ts","../src/models/donation-history.entity.model.ts","../src/models/donation.entity.model.ts","../src/models/expense-history.entity.model.ts","../src/models/expense.entity.model.ts","../src/models/sponsor-history.entity.model.ts","../src/models/sponsor.entity.model.ts","../src/models/transaction-history.entity.model.ts","../src/models/transaction.entity.model.ts","../src/models/user-history.entity.model.ts","../src/models/user.entity.model.ts","../src/models/vendor-history.entity.model.ts","../src/models/vendor.entity.model.ts","../src/utils/entity.utils.ts","../src/utils/entitiy-list-entity-model-map.ts","../src/utils/error.utils.ts","../src/utils/helper.fns.ts","../src/utils/relation-config.utils.ts","../src/utils/sql-utils.ts","../src/helpers/entity-filter-data.helper.ts"],"sourcesContent":["export enum EntityHistoryOperation {\r\n CREATE = 'CREATE',\r\n UPDATE = 'UPDATE',\r\n DELETE = 'DELETE',\r\n}\r\n","export enum SponsorFor {\n GHEE = 'ghee',\n PRASAD = 'prasad',\n BANNER = 'banner',\n}\n","/**\r\n * Utility class for validating date codes in `YYYYMMDD` format.\r\n *\r\n * @example new DateCodeUtils(20240315)\r\n *\r\n * @methods\r\n * - `isValidYYYYMMDD()` — checks if the date code is a real calendar date. e.g. `new DateCodeUtils(20240315).isValidYYYYMMDD() // true`\r\n */\r\nexport class DateCodeUtils {\r\n stringifiedDateCode: string;\r\n constructor(private readonly dateCode: string | number) {\r\n this.stringifiedDateCode = String(this.dateCode);\r\n if (!this.isValidYYYYMMDD()) {\r\n throw new Error(\r\n `Invalid date code: \"${this.stringifiedDateCode}\". Expected format: YYYYMMDD.`,\r\n );\r\n }\r\n }\r\n\r\n isValidYYYYMMDD(): boolean {\r\n if (!/^\\d{8}$/.test(this.stringifiedDateCode)) return false;\r\n\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n if (month < 1 || month > 12) return false;\r\n if (day < 1 || day > 31) return false;\r\n\r\n const date = new Date(year, month - 1, day);\r\n return (\r\n date.getFullYear() === year &&\r\n date.getMonth() === month - 1 &&\r\n date.getDate() === day\r\n );\r\n }\r\n\r\n toLongDateString(): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n return new Date(year, month - 1, day).toLocaleDateString(\"en-US\", {\r\n year: \"numeric\",\r\n month: \"long\",\r\n day: \"numeric\",\r\n });\r\n }\r\n\r\n addMonths(months: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1 + months, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addDays(days: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1, day);\r\n date.setDate(date.getDate() + days);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addWeeks(weeks: number): string {\r\n return this.addDays(weeks * 7);\r\n }\r\n\r\n addYears(years: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year + years, month - 1, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n private parseDateParts(): { year: number; month: number; day: number } {\r\n return {\r\n year: parseInt(this.stringifiedDateCode.substring(0, 4), 10),\r\n month: parseInt(this.stringifiedDateCode.substring(4, 6), 10),\r\n day: parseInt(this.stringifiedDateCode.substring(6, 8), 10),\r\n };\r\n }\r\n\r\n static getCurrentYear(): number {\r\n return new Date().getFullYear();\r\n }\r\n\r\n static daysDiff(dateCode: string | number): number {\r\n const { year, month, day } = new DateCodeUtils(dateCode).parseDateParts();\r\n const target = new Date(year, month - 1, day);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n\r\n const diffMs = target.getTime() - today.getTime();\r\n return Math.round(diffMs / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n static getCurrentDateCode(): string {\r\n const today = new Date();\r\n const year = today.getFullYear();\r\n const month = String(today.getMonth() + 1).padStart(2, \"0\");\r\n const day = String(today.getDate()).padStart(2, \"0\");\r\n return `${year}${month}${day}`;\r\n }\r\n}\r\n","// src/common/helpers/date.util.ts\r\nexport class DateUtil {\r\n // Current time as epoch milliseconds\r\n static now(): number {\r\n return Date.now();\r\n }\r\n\r\n // Date object → epoch milliseconds\r\n static toEpoch(date: Date): number {\r\n return date.getTime();\r\n }\r\n\r\n // Epoch milliseconds → Date object\r\n static toDate(epoch: number): Date {\r\n return new Date(epoch);\r\n }\r\n\r\n // Epoch milliseconds → readable string\r\n static toReadable(epoch: number): string {\r\n return new Date(epoch).toISOString();\r\n }\r\n\r\n // Add days to epoch → returns epoch\r\n static addDays(epoch: number, days: number): number {\r\n return epoch + days * 24 * 60 * 60 * 1000;\r\n }\r\n\r\n // Add months to epoch → returns epoch\r\n static addMonths(epoch: number, months: number): number {\r\n const date = new Date(epoch);\r\n date.setMonth(date.getMonth() + months);\r\n return date.getTime();\r\n }\r\n\r\n // Add weeks to epoch → returns epoch\r\n static addWeeks(epoch: number, weeks: number): number {\r\n return this.addDays(epoch, weeks * 7);\r\n }\r\n\r\n // Add years to epoch → returns epoch\r\n static addYears(epoch: number, years: number): number {\r\n const date = new Date(epoch);\r\n date.setFullYear(date.getFullYear() + years);\r\n return date.getTime();\r\n }\r\n\r\n // Difference in days between two epochs\r\n static daysDifference(epoch1: number, epoch2: number): number {\r\n return Math.ceil((epoch2 - epoch1) / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n // Check if epoch is today\r\n static isToday(epoch: number): boolean {\r\n const date = new Date(epoch);\r\n const today = new Date();\r\n return (\r\n date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear()\r\n );\r\n }\r\n\r\n // Check if epoch is in the past\r\n static isPast(epoch: number): boolean {\r\n return epoch < Date.now();\r\n }\r\n\r\n // Check if epoch is in the future\r\n static isFuture(epoch: number): boolean {\r\n return epoch > Date.now();\r\n }\r\n}\r\n\r\n","import { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport {\r\n entityListEntityModelMap,\r\n IModelRelationConfig,\r\n RelationType,\r\n} from \"../utils\";\r\nimport { EntityList, EntityType } from \"../utils/entity.utils\";\r\n\r\nexport abstract class BaseEntityModel {\r\n static relations: Partial<\r\n Record<EntityList, IModelRelationConfig<EntityList>>\r\n > = {};\r\n\r\n // populateRelations(searchResponse: ISearchV2Response): this {\r\n // const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n // for (const [prop, config] of Object.entries(relations)) {\r\n // const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // // @ts-ignore\r\n // const fkValue = this[mappingProperty];\r\n // const bucket = searchResponse[entity] ?? [];\r\n // if (!bucket.length) continue;\r\n\r\n // if (relationType === RelationType.ONE) {\r\n // // @ts-ignore\r\n // const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n // if (match) {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(match);\r\n // // recursively populate relations on the hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // this[prop as keyof this] = hydrated;\r\n // }\r\n // } else {\r\n // const matches = bucket.filter(\r\n // (e: any) => e[searchProperty] === fkValue,\r\n // );\r\n // this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(e);\r\n // // recursively populate relations on each hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // return hydrated;\r\n // }) as this[keyof this];\r\n // }\r\n // }\r\n // return this;\r\n // }\r\n\r\n populateRelations(\r\n searchResponse: ISearchV2Response,\r\n visited = new Set<string>(),\r\n ): this {\r\n const selfKey = `${this.constructor.name}:${(this as any).id}`;\r\n if (visited.has(selfKey)) return this;\r\n visited.add(selfKey);\r\n\r\n const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n for (const [prop, config] of Object.entries(relations)) {\r\n const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // @ts-ignore\r\n const fkValue = this[mappingProperty];\r\n const bucket = searchResponse[entity] ?? [];\r\n if (!bucket.length) continue;\r\n\r\n if (relationType === RelationType.ONE) {\r\n // @ts-ignore\r\n const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n if (match) {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(match);\r\n hydrated.populateRelations(searchResponse, visited);\r\n this[prop as keyof this] = hydrated;\r\n }\r\n } else {\r\n const matches = bucket.filter(\r\n (e: any) => e[searchProperty] === fkValue,\r\n );\r\n this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(e);\r\n hydrated.populateRelations(searchResponse, visited);\r\n return hydrated;\r\n }) as this[keyof this];\r\n }\r\n }\r\n return this;\r\n }\r\n}\r\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IDonationHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationHistoryModel\n extends BaseEntityModel\n implements IDonationHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.DONATION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IDonationHistoryEntity,\n ): DonationHistoryModel {\n return Object.assign(new DonationHistoryModel(), entity);\n }\n}\n","import { IDonationEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationModel extends BaseEntityModel implements IDonationEntity {\n id: number = 0;\n flatNo: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IDonationEntity): DonationModel {\n return Object.assign(new DonationModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IExpenseHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseHistoryModel\n extends BaseEntityModel\n implements IExpenseHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.EXPENSE_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IExpenseHistoryEntity,\n ): ExpenseHistoryModel {\n return Object.assign(new ExpenseHistoryModel(), entity);\n }\n}\n","import { IExpenseEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseModel extends BaseEntityModel implements IExpenseEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n vendorName: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IExpenseEntity): ExpenseModel {\n return Object.assign(new ExpenseModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ISponsorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorHistoryModel\n extends BaseEntityModel\n implements ISponsorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.SPONSOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ISponsorHistoryEntity,\n ): SponsorHistoryModel {\n return Object.assign(new SponsorHistoryModel(), entity);\n }\n}\n","import { SponsorFor } from \"../enums\";\nimport { ISponsorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorModel extends BaseEntityModel implements ISponsorEntity {\n id: number = 0;\n contactName: string = \"\";\n contactNo: string = \"\";\n sponsorFor: SponsorFor = SponsorFor.GHEE;\n size: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ISponsorEntity): SponsorModel {\n return Object.assign(new SponsorModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ITransactionHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionHistoryModel\n extends BaseEntityModel\n implements ITransactionHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.TRANSACTION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ITransactionHistoryEntity,\n ): TransactionHistoryModel {\n return Object.assign(new TransactionHistoryModel(), entity);\n }\n}\n","import { ITransactionEntity, TransactionType } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionModel\n extends BaseEntityModel\n implements ITransactionEntity\n{\n id: number = 0;\n date: string = \"\";\n type: TransactionType = \"Income\";\n particulars: string = \"\";\n amount: number = 0;\n balanceAfter: number = 0;\n referenceId: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ITransactionEntity): TransactionModel {\n return Object.assign(new TransactionModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IUserHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserHistoryModel\n extends BaseEntityModel\n implements IUserHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.USER_HISTORY>>\n > = {};\n\n static populateFromEntity(entity: IUserHistoryEntity): UserHistoryModel {\n return Object.assign(new UserHistoryModel(), entity);\n }\n}\n","import { IUserEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserModel extends BaseEntityModel implements IUserEntity {\n id: number = 0;\n name: string = \"\";\n password: string = \"\";\n email: string = \"\";\n phone: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IUserEntity): UserModel {\n return Object.assign(new UserModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IVendorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorHistoryModel\n extends BaseEntityModel\n implements IVendorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.VENDOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IVendorHistoryEntity,\n ): VendorHistoryModel {\n return Object.assign(new VendorHistoryModel(), entity);\n }\n}\n","import { IVendorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorModel extends BaseEntityModel implements IVendorEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IVendorEntity): VendorModel {\n return Object.assign(new VendorModel(), entity);\n }\n}\n","import { IDonationHistoryEntity } from \"../interfaces/entities/donation-history.entity.interface\";\nimport { IDonationEntity } from \"../interfaces/entities/donation.entity.interface\";\nimport { IExpenseHistoryEntity } from \"../interfaces/entities/expense-history.entity.interface\";\nimport { IExpenseEntity } from \"../interfaces/entities/expense.entity.interface\";\nimport { ISponsorHistoryEntity } from \"../interfaces/entities/sponsor-history.entity.interface\";\nimport { ISponsorEntity } from \"../interfaces/entities/sponsor.entity.interface\";\nimport { ITransactionHistoryEntity } from \"../interfaces/entities/transaction-history.entity.interface\";\nimport { ITransactionEntity } from \"../interfaces/entities/transaction.entity.interface\";\nimport { IUserHistoryEntity } from \"../interfaces/entities/user-history.entity.interface\";\nimport { IUserEntity } from \"../interfaces/entities/user.entity.interface\";\nimport { IVendorHistoryEntity } from \"../interfaces/entities/vendor-history.entity.interface\";\nimport { IVendorEntity } from \"../interfaces/entities/vendor.entity.interface\";\nimport { DonationHistoryModel } from \"../models/donation-history.entity.model\";\nimport { DonationModel } from \"../models/donation.entity.model\";\nimport { ExpenseHistoryModel } from \"../models/expense-history.entity.model\";\nimport { ExpenseModel } from \"../models/expense.entity.model\";\nimport { SponsorHistoryModel } from \"../models/sponsor-history.entity.model\";\nimport { SponsorModel } from \"../models/sponsor.entity.model\";\nimport { TransactionHistoryModel } from \"../models/transaction-history.entity.model\";\nimport { TransactionModel } from \"../models/transaction.entity.model\";\nimport { UserHistoryModel } from \"../models/user-history.entity.model\";\nimport { UserModel } from \"../models/user.entity.model\";\nimport { VendorHistoryModel } from \"../models/vendor-history.entity.model\";\nimport { VendorModel } from \"../models/vendor.entity.model\";\n\nexport enum EntityList {\n DONATION = \"donation\",\n DONATION_HISTORY = \"donation_history\",\n USER = \"user\",\n USER_HISTORY = \"user_history\",\n EXPENSE = \"expense\",\n EXPENSE_HISTORY = \"expense_history\",\n VENDOR = \"vendor\",\n VENDOR_HISTORY = \"vendor_history\",\n TRANSACTION = \"transaction\",\n TRANSACTION_HISTORY = \"transaction_history\",\n SPONSOR = \"sponsor\",\n SPONSOR_HISTORY = \"sponsor_history\",\n}\n\nexport type EntityType<T extends EntityList> = T extends EntityList.DONATION\n ? IDonationEntity\n : T extends EntityList.DONATION_HISTORY\n ? IDonationHistoryEntity\n : T extends EntityList.USER\n ? IUserEntity\n : T extends EntityList.USER_HISTORY\n ? IUserHistoryEntity\n : T extends EntityList.EXPENSE\n ? IExpenseEntity\n : T extends EntityList.EXPENSE_HISTORY\n ? IExpenseHistoryEntity\n : T extends EntityList.VENDOR\n ? IVendorEntity\n : T extends EntityList.VENDOR_HISTORY\n ? IVendorHistoryEntity\n : T extends EntityList.TRANSACTION\n ? ITransactionEntity\n : T extends EntityList.TRANSACTION_HISTORY\n ? ITransactionHistoryEntity\n : T extends EntityList.SPONSOR\n ? ISponsorEntity\n : T extends EntityList.SPONSOR_HISTORY\n ? ISponsorHistoryEntity\n : never;\n\nexport type EntityModelType<T extends EntityList> =\n T extends EntityList.DONATION\n ? DonationModel\n : T extends EntityList.DONATION_HISTORY\n ? DonationHistoryModel\n : T extends EntityList.USER\n ? UserModel\n : T extends EntityList.USER_HISTORY\n ? UserHistoryModel\n : T extends EntityList.EXPENSE\n ? ExpenseModel\n : T extends EntityList.EXPENSE_HISTORY\n ? ExpenseHistoryModel\n : T extends EntityList.VENDOR\n ? VendorModel\n : T extends EntityList.VENDOR_HISTORY\n ? VendorHistoryModel\n : T extends EntityList.TRANSACTION\n ? TransactionModel\n : T extends EntityList.TRANSACTION_HISTORY\n ? TransactionHistoryModel\n : T extends EntityList.SPONSOR\n ? SponsorModel\n : T extends EntityList.SPONSOR_HISTORY\n ? SponsorHistoryModel\n : never;\n\nexport type EntityListEntityModelMap = {\n [T in EntityList]: EntityModelType<T>[];\n};\n","import {\n DonationHistoryModel,\n DonationModel,\n ExpenseHistoryModel,\n ExpenseModel,\n SponsorHistoryModel,\n SponsorModel,\n TransactionHistoryModel,\n TransactionModel,\n UserHistoryModel,\n UserModel,\n VendorHistoryModel,\n VendorModel,\n} from \"../models\";\nimport { EntityList } from \"./entity.utils\";\n\nexport const entityListEntityModelMap = {\n [EntityList.DONATION]: DonationModel.populateFromEntity,\n [EntityList.DONATION_HISTORY]: DonationHistoryModel.populateFromEntity,\n [EntityList.USER]: UserModel.populateFromEntity,\n [EntityList.USER_HISTORY]: UserHistoryModel.populateFromEntity,\n [EntityList.EXPENSE]: ExpenseModel.populateFromEntity,\n [EntityList.EXPENSE_HISTORY]: ExpenseHistoryModel.populateFromEntity,\n [EntityList.VENDOR]: VendorModel.populateFromEntity,\n [EntityList.VENDOR_HISTORY]: VendorHistoryModel.populateFromEntity,\n [EntityList.TRANSACTION]: TransactionModel.populateFromEntity,\n [EntityList.TRANSACTION_HISTORY]: TransactionHistoryModel.populateFromEntity,\n [EntityList.SPONSOR]: SponsorModel.populateFromEntity,\n [EntityList.SPONSOR_HISTORY]: SponsorHistoryModel.populateFromEntity,\n};\n","export class HttpException extends Error {\r\n constructor(\r\n public readonly message: string,\r\n public readonly statusCode: number,\r\n public readonly key?: string,\r\n public readonly errors?: any,\r\n ) {\r\n super(message);\r\n this.name = this.constructor.name;\r\n if ((Error as any).captureStackTrace) {\r\n (Error as any).captureStackTrace(this, this.constructor);\r\n }\r\n }\r\n\r\n getResponse() {\r\n return {\r\n statusCode: this.statusCode,\r\n message: this.message,\r\n key: this.key,\r\n errors: this.errors,\r\n };\r\n }\r\n\r\n getStatus() {\r\n return this.statusCode;\r\n }\r\n}\r\n\r\nexport class BadRequestException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string | string[],\r\n errors?: any,\r\n ) {\r\n if (typeof input === \"object\" && !Array.isArray(input)) {\r\n super(input.message, 400, input.key, errors);\r\n } else {\r\n super(\r\n Array.isArray(input) ? input.join(\", \") : input,\r\n 400,\r\n undefined,\r\n errors,\r\n );\r\n }\r\n }\r\n}\r\n\r\nexport class NotFoundException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Not Found\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 404, input.key);\r\n } else {\r\n super(input, 404);\r\n }\r\n }\r\n}\r\n\r\nexport class UnauthorizedException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string = \"Unauthorized\",\r\n ) {\r\n if (typeof input === \"object\") {\r\n super(input.message, 401, input.key);\r\n } else {\r\n super(input, 401);\r\n }\r\n }\r\n}\r\n\r\nexport class ForbiddenException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Forbidden\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 403, input.key);\r\n } else {\r\n super(input, 403);\r\n }\r\n }\r\n}\r\n","import { IAuditColumnEntity } from \"../helpers/audit-column.entity.interface\";\r\nimport { BadRequestException } from \"./error.utils\";\r\n\r\nexport function getObjectDiffingKeys<T extends Record<string, any>>(\r\n oldObject: T,\r\n newObject: T,\r\n): Partial<T> {\r\n const keysToExclude: (keyof IAuditColumnEntity)[] = [\r\n \"createdOn\",\r\n \"createdBy\",\r\n ];\r\n const keysOfOldObject = Object.keys(oldObject);\r\n const keysOfNewObject = Object.keys(newObject);\r\n\r\n if (keysOfOldObject.length !== keysOfNewObject.length) {\r\n throw new BadRequestException({\r\n key: \"objects\",\r\n message: `Different objects recieved for diffing. Please check & try again.`,\r\n });\r\n }\r\n\r\n const oldDiffingKeys = {} as T;\r\n const newDiffingKeys = {} as Partial<T>;\r\n\r\n for (const key of keysOfOldObject as Array<keyof T>) {\r\n if (keysToExclude.includes(key as keyof IAuditColumnEntity)) continue;\r\n\r\n const oldVal = oldObject[key];\r\n const newVal = newObject[key];\r\n\r\n if (JSON.stringify(oldVal) !== JSON.stringify(newVal)) {\r\n oldDiffingKeys[key] = oldVal;\r\n newDiffingKeys[key] = newVal;\r\n }\r\n }\r\n\r\n return newDiffingKeys;\r\n}\r\n\r\n/**\r\n * Compares two arrays and returns the difference between them.\r\n *\r\n * @template T - The type of elements in the arrays\r\n * @param {T[]} arr1 - The original array\r\n * @param {T[]} arr2 - The new array to compare against\r\n * @returns {{ present: T[], deleted: T[], added: T[] }} An object containing:\r\n * - `present` — items found in both arrays (intersection)\r\n * - `deleted` — items in `arr1` but not in `arr2`\r\n * - `added` — items in `arr2` but not in `arr1`\r\n *\r\n * @example\r\n * const arr1 = [1, 2, 3, 4];\r\n * const arr2 = [3, 4, 5, 6];\r\n *\r\n * diffArrays(arr1, arr2);\r\n * // {\r\n * // present: [3, 4],\r\n * // deleted: [1, 2],\r\n * // added: [5, 6]\r\n * // }\r\n */\r\nexport function diffArrays<T>(arr1: T[], arr2: T[]) {\r\n const set1 = new Set(arr1);\r\n const set2 = new Set(arr2);\r\n\r\n return {\r\n present: arr1.filter((item) => set2.has(item)),\r\n deleted: arr1.filter((item) => !set2.has(item)),\r\n added: arr2.filter((item) => !set1.has(item)),\r\n };\r\n}\r\n\r\n/**\r\n * Groups an array of objects by a specified key, returning a `Map` where each\r\n * unique value of the key becomes an entry containing all items that share that value.\r\n * Use this as a fallback if `Object.groupBy` (ES2024) is not available in your environment.\r\n *\r\n * @template T - The type of objects in the array\r\n * @param items - The array of objects to group\r\n * @param key - A key of `T` whose value will be used as the group identifier\r\n * @returns A `Map` where each key maps to an array of items belonging to that group\r\n *\r\n * @example\r\n * const grouped = groupBy(items, 'someKey');\r\n * grouped.get('keyValue1'); // [item1, item2]\r\n * grouped.get('keyValue2'); // [item3]\r\n */\r\nexport function groupBy<T>(items: T[], key: keyof T): Map<string, T[]> {\r\n const result = new Map<string, T[]>();\r\n for (const item of items) {\r\n const groupKey = String(item[key]);\r\n if (!result.has(groupKey)) {\r\n result.set(groupKey, []);\r\n }\r\n result.get(groupKey)!.push(item);\r\n }\r\n return result;\r\n}\r\n\r\nexport function definedValues<T>(arr: Array<T | undefined | null>): T[] {\r\n return arr.filter((value): value is T => value != null);\r\n}\r\n","import { EntityList, EntityType } from \".\";\r\n\r\nexport enum RelationType {\r\n ONE = \"ONE\",\r\n MANY = \"MANY\",\r\n}\r\n\r\nexport interface IModelRelationConfig<T extends EntityList> {\r\n relationType: RelationType;\r\n mappingProperty: keyof EntityType<T> & string;\r\n searchProperty: string;\r\n entity: EntityList;\r\n}\r\n","export enum OrderByDirection {\r\n ASC = \"ASC\",\r\n DESC = \"DESC\",\r\n}\r\n\r\n// export type IOrderByFilter<T> = {\r\n// column: keyof T;\r\n// direction: OrderByDirection;\r\n// };\r\n","import { BaseEntityModel } from \"../models\";\r\nimport { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport { BadRequestException, entityListEntityModelMap } from \"../utils\";\r\nimport {\r\n EntityList,\r\n EntityListEntityModelMap,\r\n EntityModelType,\r\n EntityType,\r\n} from \"../utils/entity.utils\";\r\n\r\n/**\r\n * Helper class for extracting typed entities from a `searchV2` response.\r\n *\r\n * @example new EntityFilterDataHelper(searchV2Response)\r\n *\r\n * @methods\r\n * - `getEntityFromList(name)` — returns typed entity array for the given `EntityList` key. e.g. `helper.getEntityFromList(EntityList.USER) // IUserEntity[]`\r\n */\r\nexport class EntityFilterDataHelper {\r\n entityModelsMap: EntityListEntityModelMap = {} as EntityListEntityModelMap;\r\n\r\n constructor(private readonly searchResponse: ISearchV2Response) {\r\n this.entityModelsMap = this.populateEntityModelsMap();\r\n }\r\n\r\n getEntityFromList<T extends EntityList>(name: T): EntityModelType<T>[] {\r\n const populateFn = entityListEntityModelMap[name];\r\n const data = this.searchResponse[name] ?? [];\r\n return data.map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof name>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n // getEntityModelsMap(): EntityListEntityModelMap {\r\n private populateEntityModelsMap(): EntityListEntityModelMap {\r\n const responseObj: EntityListEntityModelMap =\r\n {} as EntityListEntityModelMap;\r\n\r\n for (const key of Object.keys(this.searchResponse) as EntityList[]) {\r\n const populateFn = entityListEntityModelMap[key];\r\n if (!populateFn) continue;\r\n\r\n const raw = this.searchResponse[key];\r\n if (!Array.isArray(raw)) continue;\r\n\r\n // @ts-expect-error - conditional type EntityModelType<T> cannot be resolved in loop context\r\n (responseObj[key] as EntityModelType<typeof key>[]) = this.searchResponse[\r\n key\r\n ].map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof key>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n return responseObj;\r\n }\r\n\r\n getEntityModelsByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any[] },\r\n ): EntityModelType<T>[] {\r\n const filteredModels = this.entityModelsMap[entityName].filter((model) =>\r\n filter.value.includes(model[filter.key]),\r\n );\r\n\r\n if (filteredModels.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value.join(\", \")} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n return filteredModels;\r\n }\r\n\r\n getEntityModelByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any },\r\n ) {\r\n const filteredModel = this.entityModelsMap[entityName].filter(\r\n (model) => model[filter.key] === filter.value,\r\n );\r\n if (filteredModel.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n // console.log(\"filteredModel\", filteredModel);\r\n return filteredModel[0];\r\n }\r\n\r\n // populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n // for (const entityName of entityNames) {\r\n // const models = this.entityModelsMap[entityName];\r\n // if (!models) continue;\r\n // for (const model of models) {\r\n // (model as unknown as BaseEntityModel).populateRelations(\r\n // this.searchResponse,\r\n // );\r\n // }\r\n // }\r\n // return this.entityModelsMap;\r\n // }\r\n\r\n populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n for (const entityName of entityNames) {\r\n const models = this.entityModelsMap[entityName];\r\n if (!models) continue;\r\n for (const model of models) {\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(), // fresh set per top-level model\r\n );\r\n }\r\n }\r\n return this.entityModelsMap;\r\n }\r\n\r\n mergeEntity<T extends EntityList>(\r\n entityName: T,\r\n savedEntity: EntityType<T>,\r\n ): EntityModelType<T> {\r\n const populateFn = entityListEntityModelMap[entityName];\r\n const model = (populateFn as (e: EntityType<T>) => EntityModelType<T>)(\r\n savedEntity,\r\n );\r\n\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(),\r\n );\r\n\r\n return model;\r\n }\r\n}\r\n"],"mappings":"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","names":["EntityHistoryOperation","SponsorFor","EntityList","RelationType","OrderByDirection"]}
1
+ {"version":3,"sources":["../src/enums/entity-history-operation.enum.ts","../src/enums/sponsor-for.enum.ts","../src/utils/date-code.utils.ts","../src/utils/date.utils.ts","../src/models/base.entity.model.ts","../src/models/donation-history.entity.model.ts","../src/models/donation.entity.model.ts","../src/models/expense-history.entity.model.ts","../src/models/expense.entity.model.ts","../src/models/sponsor-history.entity.model.ts","../src/models/sponsor.entity.model.ts","../src/models/transaction-history.entity.model.ts","../src/models/transaction.entity.model.ts","../src/models/user-history.entity.model.ts","../src/models/user.entity.model.ts","../src/models/vendor-history.entity.model.ts","../src/models/vendor.entity.model.ts","../src/utils/entity.utils.ts","../src/utils/entitiy-list-entity-model-map.ts","../src/utils/error.utils.ts","../src/utils/helper.fns.ts","../src/utils/relation-config.utils.ts","../src/utils/sql-utils.ts","../src/helpers/entity-filter-data.helper.ts"],"sourcesContent":["export enum EntityHistoryOperation {\r\n CREATE = 'CREATE',\r\n UPDATE = 'UPDATE',\r\n DELETE = 'DELETE',\r\n}\r\n","export enum SponsorFor {\n GHEE = 'ghee',\n PRASAD = 'prasad',\n BANNER = 'banner',\n}\n","/**\r\n * Utility class for validating date codes in `YYYYMMDD` format.\r\n *\r\n * @example new DateCodeUtils(20240315)\r\n *\r\n * @methods\r\n * - `isValidYYYYMMDD()` — checks if the date code is a real calendar date. e.g. `new DateCodeUtils(20240315).isValidYYYYMMDD() // true`\r\n */\r\nexport class DateCodeUtils {\r\n stringifiedDateCode: string;\r\n constructor(private readonly dateCode: string | number) {\r\n this.stringifiedDateCode = String(this.dateCode);\r\n if (!this.isValidYYYYMMDD()) {\r\n throw new Error(\r\n `Invalid date code: \"${this.stringifiedDateCode}\". Expected format: YYYYMMDD.`,\r\n );\r\n }\r\n }\r\n\r\n isValidYYYYMMDD(): boolean {\r\n if (!/^\\d{8}$/.test(this.stringifiedDateCode)) return false;\r\n\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n if (month < 1 || month > 12) return false;\r\n if (day < 1 || day > 31) return false;\r\n\r\n const date = new Date(year, month - 1, day);\r\n return (\r\n date.getFullYear() === year &&\r\n date.getMonth() === month - 1 &&\r\n date.getDate() === day\r\n );\r\n }\r\n\r\n toLongDateString(): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n return new Date(year, month - 1, day).toLocaleDateString(\"en-US\", {\r\n year: \"numeric\",\r\n month: \"long\",\r\n day: \"numeric\",\r\n });\r\n }\r\n\r\n addMonths(months: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1 + months, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addDays(days: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year, month - 1, day);\r\n date.setDate(date.getDate() + days);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n addWeeks(weeks: number): string {\r\n return this.addDays(weeks * 7);\r\n }\r\n\r\n addYears(years: number): string {\r\n const { year, month, day } = this.parseDateParts();\r\n\r\n const date = new Date(year + years, month - 1, day);\r\n\r\n const newYear = date.getFullYear();\r\n const newMonth = String(date.getMonth() + 1).padStart(2, \"0\");\r\n const newDay = String(date.getDate()).padStart(2, \"0\");\r\n\r\n return `${newYear}${newMonth}${newDay}`;\r\n }\r\n\r\n private parseDateParts(): { year: number; month: number; day: number } {\r\n return {\r\n year: parseInt(this.stringifiedDateCode.substring(0, 4), 10),\r\n month: parseInt(this.stringifiedDateCode.substring(4, 6), 10),\r\n day: parseInt(this.stringifiedDateCode.substring(6, 8), 10),\r\n };\r\n }\r\n\r\n static getCurrentYear(): number {\r\n return new Date().getFullYear();\r\n }\r\n\r\n static daysDiff(dateCode: string | number): number {\r\n const { year, month, day } = new DateCodeUtils(dateCode).parseDateParts();\r\n const target = new Date(year, month - 1, day);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n\r\n const diffMs = target.getTime() - today.getTime();\r\n return Math.round(diffMs / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n static getCurrentDateCode(): string {\r\n const today = new Date();\r\n const year = today.getFullYear();\r\n const month = String(today.getMonth() + 1).padStart(2, \"0\");\r\n const day = String(today.getDate()).padStart(2, \"0\");\r\n return `${year}${month}${day}`;\r\n }\r\n}\r\n","// src/common/helpers/date.util.ts\r\nexport class DateUtil {\r\n // Current time as epoch milliseconds\r\n static now(): number {\r\n return Date.now();\r\n }\r\n\r\n // Date object → epoch milliseconds\r\n static toEpoch(date: Date): number {\r\n return date.getTime();\r\n }\r\n\r\n // Epoch milliseconds → Date object\r\n static toDate(epoch: number): Date {\r\n return new Date(epoch);\r\n }\r\n\r\n // Epoch milliseconds → readable string\r\n static toReadable(epoch: number): string {\r\n return new Date(epoch).toISOString();\r\n }\r\n\r\n // Add days to epoch → returns epoch\r\n static addDays(epoch: number, days: number): number {\r\n return epoch + days * 24 * 60 * 60 * 1000;\r\n }\r\n\r\n // Add months to epoch → returns epoch\r\n static addMonths(epoch: number, months: number): number {\r\n const date = new Date(epoch);\r\n date.setMonth(date.getMonth() + months);\r\n return date.getTime();\r\n }\r\n\r\n // Add weeks to epoch → returns epoch\r\n static addWeeks(epoch: number, weeks: number): number {\r\n return this.addDays(epoch, weeks * 7);\r\n }\r\n\r\n // Add years to epoch → returns epoch\r\n static addYears(epoch: number, years: number): number {\r\n const date = new Date(epoch);\r\n date.setFullYear(date.getFullYear() + years);\r\n return date.getTime();\r\n }\r\n\r\n // Difference in days between two epochs\r\n static daysDifference(epoch1: number, epoch2: number): number {\r\n return Math.ceil((epoch2 - epoch1) / (1000 * 60 * 60 * 24));\r\n }\r\n\r\n // Check if epoch is today\r\n static isToday(epoch: number): boolean {\r\n const date = new Date(epoch);\r\n const today = new Date();\r\n return (\r\n date.getDate() === today.getDate() &&\r\n date.getMonth() === today.getMonth() &&\r\n date.getFullYear() === today.getFullYear()\r\n );\r\n }\r\n\r\n // Check if epoch is in the past\r\n static isPast(epoch: number): boolean {\r\n return epoch < Date.now();\r\n }\r\n\r\n // Check if epoch is in the future\r\n static isFuture(epoch: number): boolean {\r\n return epoch > Date.now();\r\n }\r\n}\r\n\r\n","import { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport {\r\n entityListEntityModelMap,\r\n IModelRelationConfig,\r\n RelationType,\r\n} from \"../utils\";\r\nimport { EntityList, EntityType } from \"../utils/entity.utils\";\r\n\r\nexport abstract class BaseEntityModel {\r\n static relations: Partial<\r\n Record<EntityList, IModelRelationConfig<EntityList>>\r\n > = {};\r\n\r\n // populateRelations(searchResponse: ISearchV2Response): this {\r\n // const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n // for (const [prop, config] of Object.entries(relations)) {\r\n // const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // // @ts-ignore\r\n // const fkValue = this[mappingProperty];\r\n // const bucket = searchResponse[entity] ?? [];\r\n // if (!bucket.length) continue;\r\n\r\n // if (relationType === RelationType.ONE) {\r\n // // @ts-ignore\r\n // const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n // if (match) {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(match);\r\n // // recursively populate relations on the hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // this[prop as keyof this] = hydrated;\r\n // }\r\n // } else {\r\n // const matches = bucket.filter(\r\n // (e: any) => e[searchProperty] === fkValue,\r\n // );\r\n // this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n // const hydrated = (\r\n // entityListEntityModelMap[entity] as (\r\n // e: EntityType<EntityList>,\r\n // ) => any\r\n // )(e);\r\n // // recursively populate relations on each hydrated model\r\n // hydrated.populateRelations(searchResponse);\r\n // return hydrated;\r\n // }) as this[keyof this];\r\n // }\r\n // }\r\n // return this;\r\n // }\r\n\r\n populateRelations(\r\n searchResponse: ISearchV2Response,\r\n visited = new Set<string>(),\r\n ): this {\r\n const selfKey = `${this.constructor.name}:${(this as any).id}`;\r\n if (visited.has(selfKey)) return this;\r\n visited.add(selfKey);\r\n\r\n const relations = (this.constructor as typeof BaseEntityModel).relations;\r\n for (const [prop, config] of Object.entries(relations)) {\r\n const { relationType, mappingProperty, searchProperty, entity } = config!;\r\n // @ts-ignore\r\n const fkValue = this[mappingProperty];\r\n const bucket = searchResponse[entity] ?? [];\r\n if (!bucket.length) continue;\r\n\r\n if (relationType === RelationType.ONE) {\r\n // @ts-ignore\r\n const match = bucket.find((e) => e[searchProperty] === fkValue);\r\n if (match) {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(match);\r\n hydrated.populateRelations(searchResponse, visited);\r\n this[prop as keyof this] = hydrated;\r\n }\r\n } else {\r\n const matches = bucket.filter(\r\n (e: any) => e[searchProperty] === fkValue,\r\n );\r\n this[prop as keyof this] = matches.map((e: EntityType<EntityList>) => {\r\n const hydrated = (\r\n entityListEntityModelMap[entity] as (\r\n e: EntityType<EntityList>,\r\n ) => any\r\n )(e);\r\n hydrated.populateRelations(searchResponse, visited);\r\n return hydrated;\r\n }) as this[keyof this];\r\n }\r\n }\r\n return this;\r\n }\r\n}\r\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IDonationHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationHistoryModel\n extends BaseEntityModel\n implements IDonationHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.DONATION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IDonationHistoryEntity,\n ): DonationHistoryModel {\n return Object.assign(new DonationHistoryModel(), entity);\n }\n}\n","import { IDonationEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class DonationModel extends BaseEntityModel implements IDonationEntity {\n id: number = 0;\n receiptNumber: string = \"\";\n flatNo: string = \"\";\n amount: number = 0;\n mobileNumber?: string;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IDonationEntity): DonationModel {\n return Object.assign(new DonationModel(), entity);\n }\n\n static generateReceiptNumber(flatNo: string, existingDonations: DonationModel[]): string {\n const count = existingDonations.filter(d => d.flatNo === flatNo).length + 1;\n const seq = String(count).padStart(2, '0');\n return `MPCR-2026-${flatNo}-${seq}`;\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IExpenseHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseHistoryModel\n extends BaseEntityModel\n implements IExpenseHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.EXPENSE_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IExpenseHistoryEntity,\n ): ExpenseHistoryModel {\n return Object.assign(new ExpenseHistoryModel(), entity);\n }\n}\n","import { IExpenseEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class ExpenseModel extends BaseEntityModel implements IExpenseEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n vendorName: string = \"\";\n amount: number = 0;\n billNumber?: string;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IExpenseEntity): ExpenseModel {\n return Object.assign(new ExpenseModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ISponsorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorHistoryModel\n extends BaseEntityModel\n implements ISponsorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.SPONSOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ISponsorHistoryEntity,\n ): SponsorHistoryModel {\n return Object.assign(new SponsorHistoryModel(), entity);\n }\n}\n","import { SponsorFor } from \"../enums\";\nimport { ISponsorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class SponsorModel extends BaseEntityModel implements ISponsorEntity {\n id: number = 0;\n sponsorName: string = \"\";\n contactName: string = \"\";\n contactNo: string = \"\";\n sponsorFor: SponsorFor = SponsorFor.GHEE;\n size: string = \"\";\n amount: number = 0;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ISponsorEntity): SponsorModel {\n return Object.assign(new SponsorModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { ITransactionHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionHistoryModel\n extends BaseEntityModel\n implements ITransactionHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.TRANSACTION_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: ITransactionHistoryEntity,\n ): TransactionHistoryModel {\n return Object.assign(new TransactionHistoryModel(), entity);\n }\n}\n","import { ITransactionEntity, TransactionType } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class TransactionModel\n extends BaseEntityModel\n implements ITransactionEntity\n{\n id: number = 0;\n date: string = \"\";\n type: TransactionType = \"Income\";\n particulars: string = \"\";\n amount: number = 0;\n balanceAfter: number = 0;\n referenceId: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: ITransactionEntity): TransactionModel {\n return Object.assign(new TransactionModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IUserHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserHistoryModel\n extends BaseEntityModel\n implements IUserHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.USER_HISTORY>>\n > = {};\n\n static populateFromEntity(entity: IUserHistoryEntity): UserHistoryModel {\n return Object.assign(new UserHistoryModel(), entity);\n }\n}\n","import { IUserEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class UserModel extends BaseEntityModel implements IUserEntity {\n id: number = 0;\n name: string = \"\";\n password: string = \"\";\n email: string = \"\";\n phone: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IUserEntity): UserModel {\n return Object.assign(new UserModel(), entity);\n }\n}\n","import { EntityHistoryOperation } from \"../enums\";\nimport { IVendorHistoryEntity } from \"../interfaces\";\nimport { EntityList, IModelRelationConfig } from \"../utils\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorHistoryModel\n extends BaseEntityModel\n implements IVendorHistoryEntity\n{\n id: number = 0;\n entityId: number = 0;\n data: string = \"\";\n operation: EntityHistoryOperation = EntityHistoryOperation.CREATE;\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static relations: Partial<\n Record<EntityList, IModelRelationConfig<EntityList.VENDOR_HISTORY>>\n > = {};\n\n static populateFromEntity(\n entity: IVendorHistoryEntity,\n ): VendorHistoryModel {\n return Object.assign(new VendorHistoryModel(), entity);\n }\n}\n","import { IVendorEntity } from \"../interfaces\";\nimport { BaseEntityModel } from \"./base.entity.model\";\n\nexport class VendorModel extends BaseEntityModel implements IVendorEntity {\n id: number = 0;\n name: string = \"\";\n type: string = \"\";\n\n createdOn: number = 0;\n updatedOn: number = 0;\n createdBy: number = 0;\n updatedBy: number = 0;\n\n protected constructor() {\n super();\n }\n\n static populateFromEntity(entity: IVendorEntity): VendorModel {\n return Object.assign(new VendorModel(), entity);\n }\n}\n","import { IDonationHistoryEntity } from \"../interfaces/entities/donation-history.entity.interface\";\nimport { IDonationEntity } from \"../interfaces/entities/donation.entity.interface\";\nimport { IExpenseHistoryEntity } from \"../interfaces/entities/expense-history.entity.interface\";\nimport { IExpenseEntity } from \"../interfaces/entities/expense.entity.interface\";\nimport { ISponsorHistoryEntity } from \"../interfaces/entities/sponsor-history.entity.interface\";\nimport { ISponsorEntity } from \"../interfaces/entities/sponsor.entity.interface\";\nimport { ITransactionHistoryEntity } from \"../interfaces/entities/transaction-history.entity.interface\";\nimport { ITransactionEntity } from \"../interfaces/entities/transaction.entity.interface\";\nimport { IUserHistoryEntity } from \"../interfaces/entities/user-history.entity.interface\";\nimport { IUserEntity } from \"../interfaces/entities/user.entity.interface\";\nimport { IVendorHistoryEntity } from \"../interfaces/entities/vendor-history.entity.interface\";\nimport { IVendorEntity } from \"../interfaces/entities/vendor.entity.interface\";\nimport { DonationHistoryModel } from \"../models/donation-history.entity.model\";\nimport { DonationModel } from \"../models/donation.entity.model\";\nimport { ExpenseHistoryModel } from \"../models/expense-history.entity.model\";\nimport { ExpenseModel } from \"../models/expense.entity.model\";\nimport { SponsorHistoryModel } from \"../models/sponsor-history.entity.model\";\nimport { SponsorModel } from \"../models/sponsor.entity.model\";\nimport { TransactionHistoryModel } from \"../models/transaction-history.entity.model\";\nimport { TransactionModel } from \"../models/transaction.entity.model\";\nimport { UserHistoryModel } from \"../models/user-history.entity.model\";\nimport { UserModel } from \"../models/user.entity.model\";\nimport { VendorHistoryModel } from \"../models/vendor-history.entity.model\";\nimport { VendorModel } from \"../models/vendor.entity.model\";\n\nexport enum EntityList {\n DONATION = \"donation\",\n DONATION_HISTORY = \"donation_history\",\n USER = \"user\",\n USER_HISTORY = \"user_history\",\n EXPENSE = \"expense\",\n EXPENSE_HISTORY = \"expense_history\",\n VENDOR = \"vendor\",\n VENDOR_HISTORY = \"vendor_history\",\n TRANSACTION = \"transaction\",\n TRANSACTION_HISTORY = \"transaction_history\",\n SPONSOR = \"sponsor\",\n SPONSOR_HISTORY = \"sponsor_history\",\n}\n\nexport type EntityType<T extends EntityList> = T extends EntityList.DONATION\n ? IDonationEntity\n : T extends EntityList.DONATION_HISTORY\n ? IDonationHistoryEntity\n : T extends EntityList.USER\n ? IUserEntity\n : T extends EntityList.USER_HISTORY\n ? IUserHistoryEntity\n : T extends EntityList.EXPENSE\n ? IExpenseEntity\n : T extends EntityList.EXPENSE_HISTORY\n ? IExpenseHistoryEntity\n : T extends EntityList.VENDOR\n ? IVendorEntity\n : T extends EntityList.VENDOR_HISTORY\n ? IVendorHistoryEntity\n : T extends EntityList.TRANSACTION\n ? ITransactionEntity\n : T extends EntityList.TRANSACTION_HISTORY\n ? ITransactionHistoryEntity\n : T extends EntityList.SPONSOR\n ? ISponsorEntity\n : T extends EntityList.SPONSOR_HISTORY\n ? ISponsorHistoryEntity\n : never;\n\nexport type EntityModelType<T extends EntityList> =\n T extends EntityList.DONATION\n ? DonationModel\n : T extends EntityList.DONATION_HISTORY\n ? DonationHistoryModel\n : T extends EntityList.USER\n ? UserModel\n : T extends EntityList.USER_HISTORY\n ? UserHistoryModel\n : T extends EntityList.EXPENSE\n ? ExpenseModel\n : T extends EntityList.EXPENSE_HISTORY\n ? ExpenseHistoryModel\n : T extends EntityList.VENDOR\n ? VendorModel\n : T extends EntityList.VENDOR_HISTORY\n ? VendorHistoryModel\n : T extends EntityList.TRANSACTION\n ? TransactionModel\n : T extends EntityList.TRANSACTION_HISTORY\n ? TransactionHistoryModel\n : T extends EntityList.SPONSOR\n ? SponsorModel\n : T extends EntityList.SPONSOR_HISTORY\n ? SponsorHistoryModel\n : never;\n\nexport type EntityListEntityModelMap = {\n [T in EntityList]: EntityModelType<T>[];\n};\n","import {\n DonationHistoryModel,\n DonationModel,\n ExpenseHistoryModel,\n ExpenseModel,\n SponsorHistoryModel,\n SponsorModel,\n TransactionHistoryModel,\n TransactionModel,\n UserHistoryModel,\n UserModel,\n VendorHistoryModel,\n VendorModel,\n} from \"../models\";\nimport { EntityList } from \"./entity.utils\";\n\nexport const entityListEntityModelMap = {\n [EntityList.DONATION]: DonationModel.populateFromEntity,\n [EntityList.DONATION_HISTORY]: DonationHistoryModel.populateFromEntity,\n [EntityList.USER]: UserModel.populateFromEntity,\n [EntityList.USER_HISTORY]: UserHistoryModel.populateFromEntity,\n [EntityList.EXPENSE]: ExpenseModel.populateFromEntity,\n [EntityList.EXPENSE_HISTORY]: ExpenseHistoryModel.populateFromEntity,\n [EntityList.VENDOR]: VendorModel.populateFromEntity,\n [EntityList.VENDOR_HISTORY]: VendorHistoryModel.populateFromEntity,\n [EntityList.TRANSACTION]: TransactionModel.populateFromEntity,\n [EntityList.TRANSACTION_HISTORY]: TransactionHistoryModel.populateFromEntity,\n [EntityList.SPONSOR]: SponsorModel.populateFromEntity,\n [EntityList.SPONSOR_HISTORY]: SponsorHistoryModel.populateFromEntity,\n};\n","export class HttpException extends Error {\r\n constructor(\r\n public readonly message: string,\r\n public readonly statusCode: number,\r\n public readonly key?: string,\r\n public readonly errors?: any,\r\n ) {\r\n super(message);\r\n this.name = this.constructor.name;\r\n if ((Error as any).captureStackTrace) {\r\n (Error as any).captureStackTrace(this, this.constructor);\r\n }\r\n }\r\n\r\n getResponse() {\r\n return {\r\n statusCode: this.statusCode,\r\n message: this.message,\r\n key: this.key,\r\n errors: this.errors,\r\n };\r\n }\r\n\r\n getStatus() {\r\n return this.statusCode;\r\n }\r\n}\r\n\r\nexport class BadRequestException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string | string[],\r\n errors?: any,\r\n ) {\r\n if (typeof input === \"object\" && !Array.isArray(input)) {\r\n super(input.message, 400, input.key, errors);\r\n } else {\r\n super(\r\n Array.isArray(input) ? input.join(\", \") : input,\r\n 400,\r\n undefined,\r\n errors,\r\n );\r\n }\r\n }\r\n}\r\n\r\nexport class NotFoundException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Not Found\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 404, input.key);\r\n } else {\r\n super(input, 404);\r\n }\r\n }\r\n}\r\n\r\nexport class UnauthorizedException extends HttpException {\r\n constructor(\r\n input: { key: string; message: string } | string = \"Unauthorized\",\r\n ) {\r\n if (typeof input === \"object\") {\r\n super(input.message, 401, input.key);\r\n } else {\r\n super(input, 401);\r\n }\r\n }\r\n}\r\n\r\nexport class ForbiddenException extends HttpException {\r\n constructor(input: { key: string; message: string } | string = \"Forbidden\") {\r\n if (typeof input === \"object\") {\r\n super(input.message, 403, input.key);\r\n } else {\r\n super(input, 403);\r\n }\r\n }\r\n}\r\n","import { IAuditColumnEntity } from \"../helpers/audit-column.entity.interface\";\r\nimport { BadRequestException } from \"./error.utils\";\r\n\r\nexport function getObjectDiffingKeys<T extends Record<string, any>>(\r\n oldObject: T,\r\n newObject: T,\r\n): Partial<T> {\r\n const keysToExclude: (keyof IAuditColumnEntity)[] = [\r\n \"createdOn\",\r\n \"createdBy\",\r\n ];\r\n const keysOfOldObject = Object.keys(oldObject);\r\n const keysOfNewObject = Object.keys(newObject);\r\n\r\n if (keysOfOldObject.length !== keysOfNewObject.length) {\r\n throw new BadRequestException({\r\n key: \"objects\",\r\n message: `Different objects recieved for diffing. Please check & try again.`,\r\n });\r\n }\r\n\r\n const oldDiffingKeys = {} as T;\r\n const newDiffingKeys = {} as Partial<T>;\r\n\r\n for (const key of keysOfOldObject as Array<keyof T>) {\r\n if (keysToExclude.includes(key as keyof IAuditColumnEntity)) continue;\r\n\r\n const oldVal = oldObject[key];\r\n const newVal = newObject[key];\r\n\r\n if (JSON.stringify(oldVal) !== JSON.stringify(newVal)) {\r\n oldDiffingKeys[key] = oldVal;\r\n newDiffingKeys[key] = newVal;\r\n }\r\n }\r\n\r\n return newDiffingKeys;\r\n}\r\n\r\n/**\r\n * Compares two arrays and returns the difference between them.\r\n *\r\n * @template T - The type of elements in the arrays\r\n * @param {T[]} arr1 - The original array\r\n * @param {T[]} arr2 - The new array to compare against\r\n * @returns {{ present: T[], deleted: T[], added: T[] }} An object containing:\r\n * - `present` — items found in both arrays (intersection)\r\n * - `deleted` — items in `arr1` but not in `arr2`\r\n * - `added` — items in `arr2` but not in `arr1`\r\n *\r\n * @example\r\n * const arr1 = [1, 2, 3, 4];\r\n * const arr2 = [3, 4, 5, 6];\r\n *\r\n * diffArrays(arr1, arr2);\r\n * // {\r\n * // present: [3, 4],\r\n * // deleted: [1, 2],\r\n * // added: [5, 6]\r\n * // }\r\n */\r\nexport function diffArrays<T>(arr1: T[], arr2: T[]) {\r\n const set1 = new Set(arr1);\r\n const set2 = new Set(arr2);\r\n\r\n return {\r\n present: arr1.filter((item) => set2.has(item)),\r\n deleted: arr1.filter((item) => !set2.has(item)),\r\n added: arr2.filter((item) => !set1.has(item)),\r\n };\r\n}\r\n\r\n/**\r\n * Groups an array of objects by a specified key, returning a `Map` where each\r\n * unique value of the key becomes an entry containing all items that share that value.\r\n * Use this as a fallback if `Object.groupBy` (ES2024) is not available in your environment.\r\n *\r\n * @template T - The type of objects in the array\r\n * @param items - The array of objects to group\r\n * @param key - A key of `T` whose value will be used as the group identifier\r\n * @returns A `Map` where each key maps to an array of items belonging to that group\r\n *\r\n * @example\r\n * const grouped = groupBy(items, 'someKey');\r\n * grouped.get('keyValue1'); // [item1, item2]\r\n * grouped.get('keyValue2'); // [item3]\r\n */\r\nexport function groupBy<T>(items: T[], key: keyof T): Map<string, T[]> {\r\n const result = new Map<string, T[]>();\r\n for (const item of items) {\r\n const groupKey = String(item[key]);\r\n if (!result.has(groupKey)) {\r\n result.set(groupKey, []);\r\n }\r\n result.get(groupKey)!.push(item);\r\n }\r\n return result;\r\n}\r\n\r\nexport function definedValues<T>(arr: Array<T | undefined | null>): T[] {\r\n return arr.filter((value): value is T => value != null);\r\n}\r\n\r\n/**\r\n * Converts an epoch timestamp (milliseconds) into a human-readable date string.\r\n *\r\n * @param epoch - The epoch timestamp in milliseconds\r\n * @param format - Optional output format:\r\n * - `'short'` — locale-specific short date (e.g. \"25/12/2026\")\r\n * - `'long'` — locale-specific long date (e.g. \"25 December 2026\")\r\n * - `'iso'` — ISO 8601 string (default)\r\n * @returns The formatted date string\r\n *\r\n * @example\r\n * epochToReadableDate(1700000000000, 'long'); // \"14 November 2023\"\r\n * epochToReadableDate(1700000000000, 'short'); // \"14/11/2023\"\r\n * epochToReadableDate(1700000000000); // \"2023-11-14T18:13:20.000Z\"\r\n */\r\nexport function epochToReadableDate(\r\n epoch: number,\r\n format: 'short' | 'long' | 'iso' = 'iso',\r\n): string {\r\n const date = new Date(epoch);\r\n switch (format) {\r\n case 'short':\r\n return date.toLocaleDateString('en-IN');\r\n case 'long':\r\n return date.toLocaleDateString('en-IN', {\r\n year: 'numeric',\r\n month: 'long',\r\n day: 'numeric',\r\n });\r\n case 'iso':\r\n default:\r\n return date.toISOString();\r\n }\r\n}\r\n","import { EntityList, EntityType } from \".\";\r\n\r\nexport enum RelationType {\r\n ONE = \"ONE\",\r\n MANY = \"MANY\",\r\n}\r\n\r\nexport interface IModelRelationConfig<T extends EntityList> {\r\n relationType: RelationType;\r\n mappingProperty: keyof EntityType<T> & string;\r\n searchProperty: string;\r\n entity: EntityList;\r\n}\r\n","export enum OrderByDirection {\r\n ASC = \"ASC\",\r\n DESC = \"DESC\",\r\n}\r\n\r\n// export type IOrderByFilter<T> = {\r\n// column: keyof T;\r\n// direction: OrderByDirection;\r\n// };\r\n","import { BaseEntityModel } from \"../models\";\r\nimport { ISearchV2Response } from \"../types/generic.dto.types\";\r\nimport { BadRequestException, entityListEntityModelMap } from \"../utils\";\r\nimport {\r\n EntityList,\r\n EntityListEntityModelMap,\r\n EntityModelType,\r\n EntityType,\r\n} from \"../utils/entity.utils\";\r\n\r\n/**\r\n * Helper class for extracting typed entities from a `searchV2` response.\r\n *\r\n * @example new EntityFilterDataHelper(searchV2Response)\r\n *\r\n * @methods\r\n * - `getEntityFromList(name)` — returns typed entity array for the given `EntityList` key. e.g. `helper.getEntityFromList(EntityList.USER) // IUserEntity[]`\r\n */\r\nexport class EntityFilterDataHelper {\r\n entityModelsMap: EntityListEntityModelMap = {} as EntityListEntityModelMap;\r\n\r\n constructor(private readonly searchResponse: ISearchV2Response) {\r\n this.entityModelsMap = this.populateEntityModelsMap();\r\n }\r\n\r\n getEntityFromList<T extends EntityList>(name: T): EntityModelType<T>[] {\r\n const populateFn = entityListEntityModelMap[name];\r\n const data = this.searchResponse[name] ?? [];\r\n return data.map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof name>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n // getEntityModelsMap(): EntityListEntityModelMap {\r\n private populateEntityModelsMap(): EntityListEntityModelMap {\r\n const responseObj: EntityListEntityModelMap =\r\n {} as EntityListEntityModelMap;\r\n\r\n for (const key of Object.keys(this.searchResponse) as EntityList[]) {\r\n const populateFn = entityListEntityModelMap[key];\r\n if (!populateFn) continue;\r\n\r\n const raw = this.searchResponse[key];\r\n if (!Array.isArray(raw)) continue;\r\n\r\n // @ts-expect-error - conditional type EntityModelType<T> cannot be resolved in loop context\r\n (responseObj[key] as EntityModelType<typeof key>[]) = this.searchResponse[\r\n key\r\n ].map((entity) =>\r\n (populateFn as (e: typeof entity) => EntityModelType<typeof key>)(\r\n entity,\r\n ),\r\n );\r\n }\r\n\r\n return responseObj;\r\n }\r\n\r\n getEntityModelsByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any[] },\r\n ): EntityModelType<T>[] {\r\n const filteredModels = this.entityModelsMap[entityName].filter((model) =>\r\n filter.value.includes(model[filter.key]),\r\n );\r\n\r\n if (filteredModels.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value.join(\", \")} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n return filteredModels;\r\n }\r\n\r\n getEntityModelByFilter<T extends EntityList>(\r\n entityName: T,\r\n filter: { key: keyof EntityType<T> & string; value: any },\r\n ) {\r\n const filteredModel = this.entityModelsMap[entityName].filter(\r\n (model) => model[filter.key] === filter.value,\r\n );\r\n if (filteredModel.length === 0) {\r\n throw new BadRequestException({\r\n key: `${filter.key}`,\r\n message: `${entityName} with values: ${filter.value} not found. Please try with valid values.`,\r\n });\r\n }\r\n\r\n // console.log(\"filteredModel\", filteredModel);\r\n return filteredModel[0];\r\n }\r\n\r\n // populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n // for (const entityName of entityNames) {\r\n // const models = this.entityModelsMap[entityName];\r\n // if (!models) continue;\r\n // for (const model of models) {\r\n // (model as unknown as BaseEntityModel).populateRelations(\r\n // this.searchResponse,\r\n // );\r\n // }\r\n // }\r\n // return this.entityModelsMap;\r\n // }\r\n\r\n populateRelationsFor(entityNames: EntityList[]): EntityListEntityModelMap {\r\n for (const entityName of entityNames) {\r\n const models = this.entityModelsMap[entityName];\r\n if (!models) continue;\r\n for (const model of models) {\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(), // fresh set per top-level model\r\n );\r\n }\r\n }\r\n return this.entityModelsMap;\r\n }\r\n\r\n mergeEntity<T extends EntityList>(\r\n entityName: T,\r\n savedEntity: EntityType<T>,\r\n ): EntityModelType<T> {\r\n const populateFn = entityListEntityModelMap[entityName];\r\n const model = (populateFn as (e: EntityType<T>) => EntityModelType<T>)(\r\n savedEntity,\r\n );\r\n\r\n (model as unknown as BaseEntityModel).populateRelations(\r\n this.searchResponse,\r\n new Set<string>(),\r\n );\r\n\r\n return model;\r\n }\r\n}\r\n"],"mappings":";AAAO,IAAK,yBAAL,kBAAKA,4BAAL;AACL,EAAAA,wBAAA,YAAS;AACT,EAAAA,wBAAA,YAAS;AACT,EAAAA,wBAAA,YAAS;AAHC,SAAAA;AAAA,GAAA;;;ACAL,IAAK,aAAL,kBAAKC,gBAAL;AACL,EAAAA,YAAA,UAAO;AACP,EAAAA,YAAA,YAAS;AACT,EAAAA,YAAA,YAAS;AAHC,SAAAA;AAAA,GAAA;;;ACQL,IAAM,gBAAN,MAAM,eAAc;AAAA,EAEzB,YAA6B,UAA2B;AAA3B;AAC3B,SAAK,sBAAsB,OAAO,KAAK,QAAQ;AAC/C,QAAI,CAAC,KAAK,gBAAgB,GAAG;AAC3B,YAAM,IAAI;AAAA,QACR,uBAAuB,KAAK,mBAAmB;AAAA,MACjD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,kBAA2B;AACzB,QAAI,CAAC,UAAU,KAAK,KAAK,mBAAmB,EAAG,QAAO;AAEtD,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,KAAK,eAAe;AAEjD,QAAI,QAAQ,KAAK,QAAQ,GAAI,QAAO;AACpC,QAAI,MAAM,KAAK,MAAM,GAAI,QAAO;AAEhC,UAAM,OAAO,IAAI,KAAK,MAAM,QAAQ,GAAG,GAAG;AAC1C,WACE,KAAK,YAAY,MAAM,QACvB,KAAK,SAAS,MAAM,QAAQ,KAC5B,KAAK,QAAQ,MAAM;AAAA,EAEvB;AAAA,EAEA,mBAA2B;AACzB,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,KAAK,eAAe;AAEjD,WAAO,IAAI,KAAK,MAAM,QAAQ,GAAG,GAAG,EAAE,mBAAmB,SAAS;AAAA,MAChE,MAAM;AAAA,MACN,OAAO;AAAA,MACP,KAAK;AAAA,IACP,CAAC;AAAA,EACH;AAAA,EAEA,UAAU,QAAwB;AAChC,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,KAAK,eAAe;AAEjD,UAAM,OAAO,IAAI,KAAK,MAAM,QAAQ,IAAI,QAAQ,GAAG;AAEnD,UAAM,UAAU,KAAK,YAAY;AACjC,UAAM,WAAW,OAAO,KAAK,SAAS,IAAI,CAAC,EAAE,SAAS,GAAG,GAAG;AAC5D,UAAM,SAAS,OAAO,KAAK,QAAQ,CAAC,EAAE,SAAS,GAAG,GAAG;AAErD,WAAO,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM;AAAA,EACvC;AAAA,EAEA,QAAQ,MAAsB;AAC5B,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,KAAK,eAAe;AAEjD,UAAM,OAAO,IAAI,KAAK,MAAM,QAAQ,GAAG,GAAG;AAC1C,SAAK,QAAQ,KAAK,QAAQ,IAAI,IAAI;AAElC,UAAM,UAAU,KAAK,YAAY;AACjC,UAAM,WAAW,OAAO,KAAK,SAAS,IAAI,CAAC,EAAE,SAAS,GAAG,GAAG;AAC5D,UAAM,SAAS,OAAO,KAAK,QAAQ,CAAC,EAAE,SAAS,GAAG,GAAG;AAErD,WAAO,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM;AAAA,EACvC;AAAA,EAEA,SAAS,OAAuB;AAC9B,WAAO,KAAK,QAAQ,QAAQ,CAAC;AAAA,EAC/B;AAAA,EAEA,SAAS,OAAuB;AAC9B,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,KAAK,eAAe;AAEjD,UAAM,OAAO,IAAI,KAAK,OAAO,OAAO,QAAQ,GAAG,GAAG;AAElD,UAAM,UAAU,KAAK,YAAY;AACjC,UAAM,WAAW,OAAO,KAAK,SAAS,IAAI,CAAC,EAAE,SAAS,GAAG,GAAG;AAC5D,UAAM,SAAS,OAAO,KAAK,QAAQ,CAAC,EAAE,SAAS,GAAG,GAAG;AAErD,WAAO,GAAG,OAAO,GAAG,QAAQ,GAAG,MAAM;AAAA,EACvC;AAAA,EAEQ,iBAA+D;AACrE,WAAO;AAAA,MACL,MAAM,SAAS,KAAK,oBAAoB,UAAU,GAAG,CAAC,GAAG,EAAE;AAAA,MAC3D,OAAO,SAAS,KAAK,oBAAoB,UAAU,GAAG,CAAC,GAAG,EAAE;AAAA,MAC5D,KAAK,SAAS,KAAK,oBAAoB,UAAU,GAAG,CAAC,GAAG,EAAE;AAAA,IAC5D;AAAA,EACF;AAAA,EAEA,OAAO,iBAAyB;AAC9B,YAAO,oBAAI,KAAK,GAAE,YAAY;AAAA,EAChC;AAAA,EAEA,OAAO,SAAS,UAAmC;AACjD,UAAM,EAAE,MAAM,OAAO,IAAI,IAAI,IAAI,eAAc,QAAQ,EAAE,eAAe;AACxE,UAAM,SAAS,IAAI,KAAK,MAAM,QAAQ,GAAG,GAAG;AAC5C,UAAM,QAAQ,oBAAI,KAAK;AACvB,UAAM,SAAS,GAAG,GAAG,GAAG,CAAC;AAEzB,UAAM,SAAS,OAAO,QAAQ,IAAI,MAAM,QAAQ;AAChD,WAAO,KAAK,MAAM,UAAU,MAAO,KAAK,KAAK,GAAG;AAAA,EAClD;AAAA,EAEA,OAAO,qBAA6B;AAClC,UAAM,QAAQ,oBAAI,KAAK;AACvB,UAAM,OAAO,MAAM,YAAY;AAC/B,UAAM,QAAQ,OAAO,MAAM,SAAS,IAAI,CAAC,EAAE,SAAS,GAAG,GAAG;AAC1D,UAAM,MAAM,OAAO,MAAM,QAAQ,CAAC,EAAE,SAAS,GAAG,GAAG;AACnD,WAAO,GAAG,IAAI,GAAG,KAAK,GAAG,GAAG;AAAA,EAC9B;AACF;;;AClHO,IAAM,WAAN,MAAe;AAAA;AAAA,EAEpB,OAAO,MAAc;AACnB,WAAO,KAAK,IAAI;AAAA,EAClB;AAAA;AAAA,EAGA,OAAO,QAAQ,MAAoB;AACjC,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA;AAAA,EAGA,OAAO,OAAO,OAAqB;AACjC,WAAO,IAAI,KAAK,KAAK;AAAA,EACvB;AAAA;AAAA,EAGA,OAAO,WAAW,OAAuB;AACvC,WAAO,IAAI,KAAK,KAAK,EAAE,YAAY;AAAA,EACrC;AAAA;AAAA,EAGA,OAAO,QAAQ,OAAe,MAAsB;AAClD,WAAO,QAAQ,OAAO,KAAK,KAAK,KAAK;AAAA,EACvC;AAAA;AAAA,EAGA,OAAO,UAAU,OAAe,QAAwB;AACtD,UAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,SAAK,SAAS,KAAK,SAAS,IAAI,MAAM;AACtC,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA;AAAA,EAGA,OAAO,SAAS,OAAe,OAAuB;AACpD,WAAO,KAAK,QAAQ,OAAO,QAAQ,CAAC;AAAA,EACtC;AAAA;AAAA,EAGA,OAAO,SAAS,OAAe,OAAuB;AACpD,UAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,SAAK,YAAY,KAAK,YAAY,IAAI,KAAK;AAC3C,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA;AAAA,EAGA,OAAO,eAAe,QAAgB,QAAwB;AAC5D,WAAO,KAAK,MAAM,SAAS,WAAW,MAAO,KAAK,KAAK,GAAG;AAAA,EAC5D;AAAA;AAAA,EAGA,OAAO,QAAQ,OAAwB;AACrC,UAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,UAAM,QAAQ,oBAAI,KAAK;AACvB,WACE,KAAK,QAAQ,MAAM,MAAM,QAAQ,KACjC,KAAK,SAAS,MAAM,MAAM,SAAS,KACnC,KAAK,YAAY,MAAM,MAAM,YAAY;AAAA,EAE7C;AAAA;AAAA,EAGA,OAAO,OAAO,OAAwB;AACpC,WAAO,QAAQ,KAAK,IAAI;AAAA,EAC1B;AAAA;AAAA,EAGA,OAAO,SAAS,OAAwB;AACtC,WAAO,QAAQ,KAAK,IAAI;AAAA,EAC1B;AACF;;;AC/DO,IAAe,kBAAf,MAA+B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA8CpC,kBACE,gBACA,UAAU,oBAAI,IAAY,GACpB;AACN,UAAM,UAAU,GAAG,KAAK,YAAY,IAAI,IAAK,KAAa,EAAE;AAC5D,QAAI,QAAQ,IAAI,OAAO,EAAG,QAAO;AACjC,YAAQ,IAAI,OAAO;AAEnB,UAAM,YAAa,KAAK,YAAuC;AAC/D,eAAW,CAAC,MAAM,MAAM,KAAK,OAAO,QAAQ,SAAS,GAAG;AACtD,YAAM,EAAE,cAAc,iBAAiB,gBAAgB,OAAO,IAAI;AAElE,YAAM,UAAU,KAAK,eAAe;AACpC,YAAM,SAAS,eAAe,MAAM,KAAK,CAAC;AAC1C,UAAI,CAAC,OAAO,OAAQ;AAEpB,UAAI,kCAAmC;AAErC,cAAM,QAAQ,OAAO,KAAK,CAAC,MAAM,EAAE,cAAc,MAAM,OAAO;AAC9D,YAAI,OAAO;AACT,gBAAM,WACJ,yBAAyB,MAAM,EAG/B,KAAK;AACP,mBAAS,kBAAkB,gBAAgB,OAAO;AAClD,eAAK,IAAkB,IAAI;AAAA,QAC7B;AAAA,MACF,OAAO;AACL,cAAM,UAAU,OAAO;AAAA,UACrB,CAAC,MAAW,EAAE,cAAc,MAAM;AAAA,QACpC;AACA,aAAK,IAAkB,IAAI,QAAQ,IAAI,CAAC,MAA8B;AACpE,gBAAM,WACJ,yBAAyB,MAAM,EAG/B,CAAC;AACH,mBAAS,kBAAkB,gBAAgB,OAAO;AAClD,iBAAO;AAAA,QACT,CAAC;AAAA,MACH;AAAA,IACF;AACA,WAAO;AAAA,EACT;AACF;AA3FsB,gBACb,YAEH,CAAC;;;ACNA,IAAM,wBAAN,MAAM,8BACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBACL,QACsB;AACtB,WAAO,OAAO,OAAO,IAAI,sBAAqB,GAAG,MAAM;AAAA,EACzD;AACF;AA3Ba,sBAkBJ,YAEH,CAAC;AApBA,IAAM,uBAAN;;;ACFA,IAAM,gBAAN,MAAM,uBAAsB,gBAA2C;AAAA,EAYlE,cAAc;AACtB,UAAM;AAZR,cAAa;AACb,yBAAwB;AACxB,kBAAiB;AACjB,kBAAiB;AAGjB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAAwC;AAChE,WAAO,OAAO,OAAO,IAAI,eAAc,GAAG,MAAM;AAAA,EAClD;AAAA,EAEA,OAAO,sBAAsB,QAAgB,mBAA4C;AACvF,UAAM,QAAQ,kBAAkB,OAAO,OAAK,EAAE,WAAW,MAAM,EAAE,SAAS;AAC1E,UAAM,MAAM,OAAO,KAAK,EAAE,SAAS,GAAG,GAAG;AACzC,WAAO,aAAa,MAAM,IAAI,GAAG;AAAA,EACnC;AACF;;;ACvBO,IAAM,uBAAN,MAAM,6BACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBACL,QACqB;AACrB,WAAO,OAAO,OAAO,IAAI,qBAAoB,GAAG,MAAM;AAAA,EACxD;AACF;AA3Ba,qBAkBJ,YAEH,CAAC;AApBA,IAAM,sBAAN;;;ACFA,IAAM,eAAN,MAAM,sBAAqB,gBAA0C;AAAA,EAahE,cAAc;AACtB,UAAM;AAbR,cAAa;AACb,gBAAe;AACf,gBAAe;AACf,sBAAqB;AACrB,kBAAiB;AAGjB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAAsC;AAC9D,WAAO,OAAO,OAAO,IAAI,cAAa,GAAG,MAAM;AAAA,EACjD;AACF;;;AClBO,IAAM,uBAAN,MAAM,6BACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBACL,QACqB;AACrB,WAAO,OAAO,OAAO,IAAI,qBAAoB,GAAG,MAAM;AAAA,EACxD;AACF;AA3Ba,qBAkBJ,YAEH,CAAC;AApBA,IAAM,sBAAN;;;ACDA,IAAM,eAAN,MAAM,sBAAqB,gBAA0C;AAAA,EAchE,cAAc;AACtB,UAAM;AAdR,cAAa;AACb,uBAAsB;AACtB,uBAAsB;AACtB,qBAAoB;AACpB;AACA,gBAAe;AACf,kBAAiB;AAEjB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAAsC;AAC9D,WAAO,OAAO,OAAO,IAAI,cAAa,GAAG,MAAM;AAAA,EACjD;AACF;;;ACpBO,IAAM,2BAAN,MAAM,iCACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBACL,QACyB;AACzB,WAAO,OAAO,OAAO,IAAI,yBAAwB,GAAG,MAAM;AAAA,EAC5D;AACF;AA3Ba,yBAkBJ,YAEH,CAAC;AApBA,IAAM,0BAAN;;;ACFA,IAAM,mBAAN,MAAM,0BACH,gBAEV;AAAA,EAcY,cAAc;AACtB,UAAM;AAdR,cAAa;AACb,gBAAe;AACf,gBAAwB;AACxB,uBAAsB;AACtB,kBAAiB;AACjB,wBAAuB;AACvB,uBAAsB;AAEtB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAA8C;AACtE,WAAO,OAAO,OAAO,IAAI,kBAAiB,GAAG,MAAM;AAAA,EACrD;AACF;;;ACtBO,IAAM,oBAAN,MAAM,0BACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBAAmB,QAA8C;AACtE,WAAO,OAAO,OAAO,IAAI,kBAAiB,GAAG,MAAM;AAAA,EACrD;AACF;AAzBa,kBAkBJ,YAEH,CAAC;AApBA,IAAM,mBAAN;;;ACFA,IAAM,YAAN,MAAM,mBAAkB,gBAAuC;AAAA,EAY1D,cAAc;AACtB,UAAM;AAZR,cAAa;AACb,gBAAe;AACf,oBAAmB;AACnB,iBAAgB;AAChB,iBAAgB;AAEhB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAAgC;AACxD,WAAO,OAAO,OAAO,IAAI,WAAU,GAAG,MAAM;AAAA,EAC9C;AACF;;;ACjBO,IAAM,sBAAN,MAAM,4BACH,gBAEV;AAAA,EAWY,cAAc;AACtB,UAAM;AAXR,cAAa;AACb,oBAAmB;AACnB,gBAAe;AACf;AAEA,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAMA,OAAO,mBACL,QACoB;AACpB,WAAO,OAAO,OAAO,IAAI,oBAAmB,GAAG,MAAM;AAAA,EACvD;AACF;AA3Ba,oBAkBJ,YAEH,CAAC;AApBA,IAAM,qBAAN;;;ACFA,IAAM,cAAN,MAAM,qBAAoB,gBAAyC;AAAA,EAU9D,cAAc;AACtB,UAAM;AAVR,cAAa;AACb,gBAAe;AACf,gBAAe;AAEf,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AACpB,qBAAoB;AAAA,EAIpB;AAAA,EAEA,OAAO,mBAAmB,QAAoC;AAC5D,WAAO,OAAO,OAAO,IAAI,aAAY,GAAG,MAAM;AAAA,EAChD;AACF;;;ACKO,IAAK,aAAL,kBAAKC,gBAAL;AACL,EAAAA,YAAA,cAAW;AACX,EAAAA,YAAA,sBAAmB;AACnB,EAAAA,YAAA,UAAO;AACP,EAAAA,YAAA,kBAAe;AACf,EAAAA,YAAA,aAAU;AACV,EAAAA,YAAA,qBAAkB;AAClB,EAAAA,YAAA,YAAS;AACT,EAAAA,YAAA,oBAAiB;AACjB,EAAAA,YAAA,iBAAc;AACd,EAAAA,YAAA,yBAAsB;AACtB,EAAAA,YAAA,aAAU;AACV,EAAAA,YAAA,qBAAkB;AAZR,SAAAA;AAAA,GAAA;;;ACTL,IAAM,2BAA2B;AAAA,EACtC,0BAAoB,GAAG,cAAc;AAAA,EACrC,0CAA4B,GAAG,qBAAqB;AAAA,EACpD,kBAAgB,GAAG,UAAU;AAAA,EAC7B,kCAAwB,GAAG,iBAAiB;AAAA,EAC5C,wBAAmB,GAAG,aAAa;AAAA,EACnC,wCAA2B,GAAG,oBAAoB;AAAA,EAClD,sBAAkB,GAAG,YAAY;AAAA,EACjC,sCAA0B,GAAG,mBAAmB;AAAA,EAChD,gCAAuB,GAAG,iBAAiB;AAAA,EAC3C,gDAA+B,GAAG,wBAAwB;AAAA,EAC1D,wBAAmB,GAAG,aAAa;AAAA,EACnC,wCAA2B,GAAG,oBAAoB;AACpD;;;AC7BO,IAAM,gBAAN,cAA4B,MAAM;AAAA,EACvC,YACkB,SACA,YACA,KACA,QAChB;AACA,UAAM,OAAO;AALG;AACA;AACA;AACA;AAGhB,SAAK,OAAO,KAAK,YAAY;AAC7B,QAAK,MAAc,mBAAmB;AACpC,MAAC,MAAc,kBAAkB,MAAM,KAAK,WAAW;AAAA,IACzD;AAAA,EACF;AAAA,EAEA,cAAc;AACZ,WAAO;AAAA,MACL,YAAY,KAAK;AAAA,MACjB,SAAS,KAAK;AAAA,MACd,KAAK,KAAK;AAAA,MACV,QAAQ,KAAK;AAAA,IACf;AAAA,EACF;AAAA,EAEA,YAAY;AACV,WAAO,KAAK;AAAA,EACd;AACF;AAEO,IAAM,sBAAN,cAAkC,cAAc;AAAA,EACrD,YACE,OACA,QACA;AACA,QAAI,OAAO,UAAU,YAAY,CAAC,MAAM,QAAQ,KAAK,GAAG;AACtD,YAAM,MAAM,SAAS,KAAK,MAAM,KAAK,MAAM;AAAA,IAC7C,OAAO;AACL;AAAA,QACE,MAAM,QAAQ,KAAK,IAAI,MAAM,KAAK,IAAI,IAAI;AAAA,QAC1C;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;AAEO,IAAM,oBAAN,cAAgC,cAAc;AAAA,EACnD,YAAY,QAAmD,aAAa;AAC1E,QAAI,OAAO,UAAU,UAAU;AAC7B,YAAM,MAAM,SAAS,KAAK,MAAM,GAAG;AAAA,IACrC,OAAO;AACL,YAAM,OAAO,GAAG;AAAA,IAClB;AAAA,EACF;AACF;AAEO,IAAM,wBAAN,cAAoC,cAAc;AAAA,EACvD,YACE,QAAmD,gBACnD;AACA,QAAI,OAAO,UAAU,UAAU;AAC7B,YAAM,MAAM,SAAS,KAAK,MAAM,GAAG;AAAA,IACrC,OAAO;AACL,YAAM,OAAO,GAAG;AAAA,IAClB;AAAA,EACF;AACF;AAEO,IAAM,qBAAN,cAAiC,cAAc;AAAA,EACpD,YAAY,QAAmD,aAAa;AAC1E,QAAI,OAAO,UAAU,UAAU;AAC7B,YAAM,MAAM,SAAS,KAAK,MAAM,GAAG;AAAA,IACrC,OAAO;AACL,YAAM,OAAO,GAAG;AAAA,IAClB;AAAA,EACF;AACF;;;ACzEO,SAAS,qBACd,WACA,WACY;AACZ,QAAM,gBAA8C;AAAA,IAClD;AAAA,IACA;AAAA,EACF;AACA,QAAM,kBAAkB,OAAO,KAAK,SAAS;AAC7C,QAAM,kBAAkB,OAAO,KAAK,SAAS;AAE7C,MAAI,gBAAgB,WAAW,gBAAgB,QAAQ;AACrD,UAAM,IAAI,oBAAoB;AAAA,MAC5B,KAAK;AAAA,MACL,SAAS;AAAA,IACX,CAAC;AAAA,EACH;AAEA,QAAM,iBAAiB,CAAC;AACxB,QAAM,iBAAiB,CAAC;AAExB,aAAW,OAAO,iBAAmC;AACnD,QAAI,cAAc,SAAS,GAA+B,EAAG;AAE7D,UAAM,SAAS,UAAU,GAAG;AAC5B,UAAM,SAAS,UAAU,GAAG;AAE5B,QAAI,KAAK,UAAU,MAAM,MAAM,KAAK,UAAU,MAAM,GAAG;AACrD,qBAAe,GAAG,IAAI;AACtB,qBAAe,GAAG,IAAI;AAAA,IACxB;AAAA,EACF;AAEA,SAAO;AACT;AAwBO,SAAS,WAAc,MAAW,MAAW;AAClD,QAAM,OAAO,IAAI,IAAI,IAAI;AACzB,QAAM,OAAO,IAAI,IAAI,IAAI;AAEzB,SAAO;AAAA,IACL,SAAS,KAAK,OAAO,CAAC,SAAS,KAAK,IAAI,IAAI,CAAC;AAAA,IAC7C,SAAS,KAAK,OAAO,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,CAAC;AAAA,IAC9C,OAAO,KAAK,OAAO,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,CAAC;AAAA,EAC9C;AACF;AAiBO,SAAS,QAAW,OAAY,KAAgC;AACrE,QAAM,SAAS,oBAAI,IAAiB;AACpC,aAAW,QAAQ,OAAO;AACxB,UAAM,WAAW,OAAO,KAAK,GAAG,CAAC;AACjC,QAAI,CAAC,OAAO,IAAI,QAAQ,GAAG;AACzB,aAAO,IAAI,UAAU,CAAC,CAAC;AAAA,IACzB;AACA,WAAO,IAAI,QAAQ,EAAG,KAAK,IAAI;AAAA,EACjC;AACA,SAAO;AACT;AAEO,SAAS,cAAiB,KAAuC;AACtE,SAAO,IAAI,OAAO,CAAC,UAAsB,SAAS,IAAI;AACxD;AAiBO,SAAS,oBACd,OACA,SAAmC,OAC3B;AACR,QAAM,OAAO,IAAI,KAAK,KAAK;AAC3B,UAAQ,QAAQ;AAAA,IACd,KAAK;AACH,aAAO,KAAK,mBAAmB,OAAO;AAAA,IACxC,KAAK;AACH,aAAO,KAAK,mBAAmB,SAAS;AAAA,QACtC,MAAM;AAAA,QACN,OAAO;AAAA,QACP,KAAK;AAAA,MACP,CAAC;AAAA,IACH,KAAK;AAAA,IACL;AACE,aAAO,KAAK,YAAY;AAAA,EAC5B;AACF;;;ACtIO,IAAK,eAAL,kBAAKC,kBAAL;AACL,EAAAA,cAAA,SAAM;AACN,EAAAA,cAAA,UAAO;AAFG,SAAAA;AAAA,GAAA;;;ACFL,IAAK,mBAAL,kBAAKC,sBAAL;AACL,EAAAA,kBAAA,SAAM;AACN,EAAAA,kBAAA,UAAO;AAFG,SAAAA;AAAA,GAAA;;;ACkBL,IAAM,yBAAN,MAA6B;AAAA,EAGlC,YAA6B,gBAAmC;AAAnC;AAF7B,2BAA4C,CAAC;AAG3C,SAAK,kBAAkB,KAAK,wBAAwB;AAAA,EACtD;AAAA,EAEA,kBAAwC,MAA+B;AACrE,UAAM,aAAa,yBAAyB,IAAI;AAChD,UAAM,OAAO,KAAK,eAAe,IAAI,KAAK,CAAC;AAC3C,WAAO,KAAK;AAAA,MAAI,CAAC,WACd;AAAA,QACC;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA,EAGQ,0BAAoD;AAC1D,UAAM,cACJ,CAAC;AAEH,eAAW,OAAO,OAAO,KAAK,KAAK,cAAc,GAAmB;AAClE,YAAM,aAAa,yBAAyB,GAAG;AAC/C,UAAI,CAAC,WAAY;AAEjB,YAAM,MAAM,KAAK,eAAe,GAAG;AACnC,UAAI,CAAC,MAAM,QAAQ,GAAG,EAAG;AAGzB,MAAC,YAAY,GAAG,IAAsC,KAAK,eACzD,GACF,EAAE;AAAA,QAAI,CAAC,WACJ;AAAA,UACC;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,wBACE,YACA,QACsB;AACtB,UAAM,iBAAiB,KAAK,gBAAgB,UAAU,EAAE;AAAA,MAAO,CAAC,UAC9D,OAAO,MAAM,SAAS,MAAM,OAAO,GAAG,CAAC;AAAA,IACzC;AAEA,QAAI,eAAe,WAAW,GAAG;AAC/B,YAAM,IAAI,oBAAoB;AAAA,QAC5B,KAAK,GAAG,OAAO,GAAG;AAAA,QAClB,SAAS,GAAG,UAAU,iBAAiB,OAAO,MAAM,KAAK,IAAI,CAAC;AAAA,MAChE,CAAC;AAAA,IACH;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,uBACE,YACA,QACA;AACA,UAAM,gBAAgB,KAAK,gBAAgB,UAAU,EAAE;AAAA,MACrD,CAAC,UAAU,MAAM,OAAO,GAAG,MAAM,OAAO;AAAA,IAC1C;AACA,QAAI,cAAc,WAAW,GAAG;AAC9B,YAAM,IAAI,oBAAoB;AAAA,QAC5B,KAAK,GAAG,OAAO,GAAG;AAAA,QAClB,SAAS,GAAG,UAAU,iBAAiB,OAAO,KAAK;AAAA,MACrD,CAAC;AAAA,IACH;AAGA,WAAO,cAAc,CAAC;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeA,qBAAqB,aAAqD;AACxE,eAAW,cAAc,aAAa;AACpC,YAAM,SAAS,KAAK,gBAAgB,UAAU;AAC9C,UAAI,CAAC,OAAQ;AACb,iBAAW,SAAS,QAAQ;AAC1B,QAAC,MAAqC;AAAA,UACpC,KAAK;AAAA,UACL,oBAAI,IAAY;AAAA;AAAA,QAClB;AAAA,MACF;AAAA,IACF;AACA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,YACE,YACA,aACoB;AACpB,UAAM,aAAa,yBAAyB,UAAU;AACtD,UAAM,QAAS;AAAA,MACb;AAAA,IACF;AAEA,IAAC,MAAqC;AAAA,MACpC,KAAK;AAAA,MACL,oBAAI,IAAY;AAAA,IAClB;AAEA,WAAO;AAAA,EACT;AACF;","names":["EntityHistoryOperation","SponsorFor","EntityList","RelationType","OrderByDirection"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mody-park-cha-raja/finance_common",
3
- "version": "1.0.4",
3
+ "version": "1.0.6-beta.1",
4
4
  "description": "Common interfaces, models, enums, and utilities for the Mody Park Cha Raja finance ecosystem",
5
5
  "homepage": "https://github.com/mody-park-cha-raja/finance-common#readme",
6
6
  "bugs": {