@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 +26 -1
- package/dist/index.d.ts +26 -1
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +24 -0
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
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
|
};
|
package/dist/index.mjs.map
CHANGED
|
@@ -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":"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","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.
|
|
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": {
|