cmp-aws-database 1.7.1-dev.25 → 1.7.1-dev.27

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.
@@ -0,0 +1,57 @@
1
+ import { BaseDynamooseModel, AuthContext } from "./base-dynamoose-model";
2
+ type DynamoKeyValue = string | number | boolean | null;
3
+ export type DynamoKey = Record<string, DynamoKeyValue>;
4
+ type DynamooseModelLike = {
5
+ create: Function;
6
+ update: Function;
7
+ get: Function;
8
+ delete: Function;
9
+ batchPut: Function;
10
+ batchGet: Function;
11
+ };
12
+ export declare class GenericDynamooseDAO<T extends BaseDynamooseModel> {
13
+ protected readonly model: DynamooseModelLike;
14
+ protected readonly primaryKeyName: keyof T & string;
15
+ /**
16
+ * @param model Dynamoose model instance for the target table.
17
+ * @param primaryKeyName Attribute name used as the table hash key.
18
+ */
19
+ constructor(model: DynamooseModelLike, primaryKeyName: keyof T & string);
20
+ /**
21
+ * Builds a DynamoDB key object from a single primary key value.
22
+ */
23
+ protected getKeyObject(primaryKeyValue: string): DynamoKey;
24
+ /**
25
+ * Creates a new record and automatically stamps created audit fields.
26
+ */
27
+ save(item: T, authContext?: AuthContext): Promise<T>;
28
+ /**
29
+ * Updates an existing record and automatically stamps updated audit fields.
30
+ */
31
+ update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext): Promise<T>;
32
+ /**
33
+ * Deletes one record by primary key.
34
+ */
35
+ delete(primaryKeyValue: string): Promise<T | undefined>;
36
+ /**
37
+ * Fetches one record by primary key. Returns null when not found.
38
+ */
39
+ get(primaryKeyValue: string): Promise<T | null>;
40
+ /**
41
+ * Writes multiple records in a batch and throws if any item is left unprocessed.
42
+ */
43
+ batchSave(items: T[], authContext?: AuthContext): Promise<T[]>;
44
+ /**
45
+ * Fetches multiple records by primary keys.
46
+ */
47
+ batchGet(primaryKeyValues: string[]): Promise<T[]>;
48
+ /**
49
+ * Decodes a base64 continuation token into DynamoDB last evaluated key.
50
+ */
51
+ decode(continuationToken: string | undefined): DynamoKey | undefined;
52
+ /**
53
+ * Encodes DynamoDB last evaluated key into a base64 continuation token.
54
+ */
55
+ encode(lastEvaluatedKey: DynamoKey | undefined): Promise<string | undefined>;
56
+ }
57
+ export {};
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GenericDynamooseDAO = void 0;
4
+ class GenericDynamooseDAO {
5
+ /**
6
+ * @param model Dynamoose model instance for the target table.
7
+ * @param primaryKeyName Attribute name used as the table hash key.
8
+ */
9
+ constructor(model, primaryKeyName) {
10
+ this.model = model;
11
+ this.primaryKeyName = primaryKeyName;
12
+ }
13
+ /**
14
+ * Builds a DynamoDB key object from a single primary key value.
15
+ */
16
+ getKeyObject(primaryKeyValue) {
17
+ return { [this.primaryKeyName]: primaryKeyValue };
18
+ }
19
+ /**
20
+ * Creates a new record and automatically stamps created audit fields.
21
+ */
22
+ async save(item, authContext) {
23
+ const createFn = this.model.create;
24
+ const created = await createFn({
25
+ ...item,
26
+ created_time: new Date(),
27
+ created_user: authContext?.userSub
28
+ });
29
+ return created;
30
+ }
31
+ /**
32
+ * Updates an existing record and automatically stamps updated audit fields.
33
+ */
34
+ async update(primaryKeyValue, updates, authContext) {
35
+ const updateFn = this.model.update;
36
+ const updated = await updateFn(this.getKeyObject(primaryKeyValue), {
37
+ ...updates,
38
+ updated_time: new Date(),
39
+ updated_user: authContext?.userSub
40
+ });
41
+ return updated;
42
+ }
43
+ /**
44
+ * Deletes one record by primary key.
45
+ */
46
+ async delete(primaryKeyValue) {
47
+ const deleteFn = this.model.delete;
48
+ const deleted = await deleteFn(this.getKeyObject(primaryKeyValue));
49
+ return deleted;
50
+ }
51
+ /**
52
+ * Fetches one record by primary key. Returns null when not found.
53
+ */
54
+ async get(primaryKeyValue) {
55
+ const getFn = this.model.get;
56
+ const item = await getFn(this.getKeyObject(primaryKeyValue));
57
+ return item ?? null;
58
+ }
59
+ /**
60
+ * Writes multiple records in a batch and throws if any item is left unprocessed.
61
+ */
62
+ async batchSave(items, authContext) {
63
+ const now = new Date();
64
+ const inputItems = items.map((item) => ({
65
+ ...item,
66
+ created_time: now,
67
+ created_user: authContext?.userSub
68
+ }));
69
+ const batchPutFn = this.model.batchPut;
70
+ const result = await batchPutFn(inputItems);
71
+ if (result.unprocessedItems.length > 0) {
72
+ throw new Error(`Batch save partially failed. Unprocessed items: ${result.unprocessedItems.length}`);
73
+ }
74
+ return inputItems;
75
+ }
76
+ /**
77
+ * Fetches multiple records by primary keys.
78
+ */
79
+ async batchGet(primaryKeyValues) {
80
+ const keys = primaryKeyValues.map((value) => this.getKeyObject(value));
81
+ const batchGetFn = this.model.batchGet;
82
+ const items = await batchGetFn(keys);
83
+ return items;
84
+ }
85
+ /**
86
+ * Decodes a base64 continuation token into DynamoDB last evaluated key.
87
+ */
88
+ decode(continuationToken) {
89
+ if (!continuationToken) {
90
+ return undefined;
91
+ }
92
+ try {
93
+ return JSON.parse(Buffer.from(continuationToken, "base64").toString("utf8"));
94
+ }
95
+ catch (error) {
96
+ throw new Error("Invalid continuationToken");
97
+ }
98
+ }
99
+ /**
100
+ * Encodes DynamoDB last evaluated key into a base64 continuation token.
101
+ */
102
+ async encode(lastEvaluatedKey) {
103
+ if (!lastEvaluatedKey) {
104
+ return undefined;
105
+ }
106
+ return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString("base64");
107
+ }
108
+ }
109
+ exports.GenericDynamooseDAO = GenericDynamooseDAO;
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-dynamoose-dao.js","sourceRoot":"","sources":["../src/base-dynamoose-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseDynamooseModel, AuthContext } from \"./base-dynamoose-model\";\n\ntype DynamoKeyValue = string | number | boolean | null;\nexport type DynamoKey = Record<string, DynamoKeyValue>;\n\ntype BatchPutResponse<T> = {\n    unprocessedItems: Partial<T>[];\n};\n\ntype CreateFn<T> = (item: Partial<T>) => Promise<object>;\ntype UpdateFn<T> = (key: DynamoKey, update: Partial<T>) => Promise<object>;\ntype DeleteFn = (key: DynamoKey) => Promise<object | undefined>;\ntype GetFn = (key: DynamoKey) => Promise<object | undefined>;\ntype BatchPutFn<T> = (items: Partial<T>[]) => Promise<BatchPutResponse<T>>;\ntype BatchGetFn = (keys: DynamoKey[]) => Promise<object[]>;\n\ntype DynamooseModelLike = {\n    create: Function;\n    update: Function;\n    get: Function;\n    delete: Function;\n    batchPut: Function;\n    batchGet: Function;\n};\n\nexport class GenericDynamooseDAO<T extends BaseDynamooseModel> {\n    /**\n     * @param model Dynamoose model instance for the target table.\n     * @param primaryKeyName Attribute name used as the table hash key.\n     */\n    constructor(\n        protected readonly model: DynamooseModelLike,\n        protected readonly primaryKeyName: keyof T & string\n    ) { }\n\n    /**\n     * Builds a DynamoDB key object from a single primary key value.\n     */\n    protected getKeyObject(primaryKeyValue: string): DynamoKey {\n        return { [this.primaryKeyName]: primaryKeyValue };\n    }\n\n    /**\n     * Creates a new record and automatically stamps created audit fields.\n     */\n    async save(item: T, authContext?: AuthContext): Promise<T> {\n        const createFn = this.model.create as CreateFn<T>;\n        const created = await createFn({\n            ...item,\n            created_time: new Date(),\n            created_user: authContext?.userSub\n        });\n        return created as T;\n    }\n\n    /**\n     * Updates an existing record and automatically stamps updated audit fields.\n     */\n    async update(primaryKeyValue: string, updates: Partial<T>, authContext?: AuthContext): Promise<T> {\n        const updateFn = this.model.update as UpdateFn<T>;\n        const updated = await updateFn(\n            this.getKeyObject(primaryKeyValue),\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            }\n        );\n        return updated as T;\n    }\n\n    /**\n     * Deletes one record by primary key.\n     */\n    async delete(primaryKeyValue: string): Promise<T | undefined> {\n        const deleteFn = this.model.delete as DeleteFn;\n        const deleted = await deleteFn(this.getKeyObject(primaryKeyValue));\n        return deleted as T | undefined;\n    }\n\n    /**\n     * Fetches one record by primary key. Returns null when not found.\n     */\n    async get(primaryKeyValue: string): Promise<T | null> {\n        const getFn = this.model.get as GetFn;\n        const item = await getFn(this.getKeyObject(primaryKeyValue));\n        return (item as T | undefined) ?? null;\n    }\n\n    /**\n     * Writes multiple records in a batch and throws if any item is left unprocessed.\n     */\n    async batchSave(items: T[], authContext?: AuthContext): Promise<T[]> {\n        const now = new Date();\n        const inputItems = items.map((item) => ({\n            ...item,\n            created_time: now,\n            created_user: authContext?.userSub\n        })) as T[];\n\n        const batchPutFn = this.model.batchPut as BatchPutFn<T>;\n        const result = await batchPutFn(inputItems);\n        if (result.unprocessedItems.length > 0) {\n            throw new Error(`Batch save partially failed. Unprocessed items: ${result.unprocessedItems.length}`);\n        }\n\n        return inputItems;\n    }\n\n    /**\n     * Fetches multiple records by primary keys.\n     */\n    async batchGet(primaryKeyValues: string[]): Promise<T[]> {\n        const keys = primaryKeyValues.map((value) => this.getKeyObject(value));\n        const batchGetFn = this.model.batchGet as BatchGetFn;\n        const items = await batchGetFn(keys);\n        return items as T[];\n    }\n\n    /**\n     * Decodes a base64 continuation token into DynamoDB last evaluated key.\n     */\n    decode(continuationToken: string | undefined): DynamoKey | undefined {\n        if (!continuationToken) {\n            return undefined;\n        }\n\n        try {\n            return JSON.parse(Buffer.from(continuationToken, \"base64\").toString(\"utf8\")) as DynamoKey;\n        } catch (error) {\n            throw new Error(\"Invalid continuationToken\");\n        }\n    }\n\n    /**\n     * Encodes DynamoDB last evaluated key into a base64 continuation token.\n     */\n    async encode(lastEvaluatedKey: DynamoKey | undefined): Promise<string | undefined> {\n        if (!lastEvaluatedKey) {\n            return undefined;\n        }\n\n        return Buffer.from(JSON.stringify(lastEvaluatedKey)).toString(\"base64\");\n    }\n}\n"]}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Shared audit fields for Dynamoose entities.
3
+ * Extend this interface in module-specific model interfaces.
4
+ */
5
+ export interface BaseDynamooseModel {
6
+ created_time?: Date;
7
+ updated_time?: Date;
8
+ created_user?: string;
9
+ updated_user?: string;
10
+ }
11
+ /**
12
+ * Reusable runtime schema fragment for audit fields.
13
+ * Spread this into Dynamoose schema definitions to avoid duplication.
14
+ */
15
+ export declare const BASE_DYNAMOOSE_AUDIT_SCHEMA: {
16
+ readonly created_time: DateConstructor;
17
+ readonly updated_time: DateConstructor;
18
+ readonly created_user: StringConstructor;
19
+ readonly updated_user: StringConstructor;
20
+ };
21
+ /**
22
+ * Auth payload used by DAO methods for audit stamping.
23
+ */
24
+ export type AuthContext = {
25
+ userSub?: string;
26
+ };
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BASE_DYNAMOOSE_AUDIT_SCHEMA = void 0;
4
+ /**
5
+ * Reusable runtime schema fragment for audit fields.
6
+ * Spread this into Dynamoose schema definitions to avoid duplication.
7
+ */
8
+ exports.BASE_DYNAMOOSE_AUDIT_SCHEMA = {
9
+ created_time: Date,
10
+ updated_time: Date,
11
+ created_user: String,
12
+ updated_user: String
13
+ };
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1keW5hbW9vc2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvYmFzZS1keW5hbW9vc2UtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBV0E7OztHQUdHO0FBQ1UsUUFBQSwyQkFBMkIsR0FBRztJQUN2QyxZQUFZLEVBQUUsSUFBSTtJQUNsQixZQUFZLEVBQUUsSUFBSTtJQUNsQixZQUFZLEVBQUUsTUFBTTtJQUNwQixZQUFZLEVBQUUsTUFBTTtDQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNoYXJlZCBhdWRpdCBmaWVsZHMgZm9yIER5bmFtb29zZSBlbnRpdGllcy5cbiAqIEV4dGVuZCB0aGlzIGludGVyZmFjZSBpbiBtb2R1bGUtc3BlY2lmaWMgbW9kZWwgaW50ZXJmYWNlcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCYXNlRHluYW1vb3NlTW9kZWwge1xuICAgIGNyZWF0ZWRfdGltZT86IERhdGU7XG4gICAgdXBkYXRlZF90aW1lPzogRGF0ZTtcbiAgICBjcmVhdGVkX3VzZXI/OiBzdHJpbmc7XG4gICAgdXBkYXRlZF91c2VyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFJldXNhYmxlIHJ1bnRpbWUgc2NoZW1hIGZyYWdtZW50IGZvciBhdWRpdCBmaWVsZHMuXG4gKiBTcHJlYWQgdGhpcyBpbnRvIER5bmFtb29zZSBzY2hlbWEgZGVmaW5pdGlvbnMgdG8gYXZvaWQgZHVwbGljYXRpb24uXG4gKi9cbmV4cG9ydCBjb25zdCBCQVNFX0RZTkFNT09TRV9BVURJVF9TQ0hFTUEgPSB7XG4gICAgY3JlYXRlZF90aW1lOiBEYXRlLFxuICAgIHVwZGF0ZWRfdGltZTogRGF0ZSxcbiAgICBjcmVhdGVkX3VzZXI6IFN0cmluZyxcbiAgICB1cGRhdGVkX3VzZXI6IFN0cmluZ1xufSBhcyBjb25zdDtcblxuLyoqXG4gKiBBdXRoIHBheWxvYWQgdXNlZCBieSBEQU8gbWV0aG9kcyBmb3IgYXVkaXQgc3RhbXBpbmcuXG4gKi9cbmV4cG9ydCB0eXBlIEF1dGhDb250ZXh0ID0ge1xuICAgIHVzZXJTdWI/OiBzdHJpbmc7XG59O1xuIl19
@@ -16,6 +16,7 @@ export declare const BASE_TABLE_NAMES: {
16
16
  readonly ORDER_REVIEW_FEEDBACK: "OrderReviewFeedbackTable";
17
17
  readonly CATERING_REQUEST: "CateringRequestTable";
18
18
  readonly FMP_REQUEST_CALLBACK: "FmpRequestCallbackTable";
19
+ readonly PLATTER_FIT: "PlatterFitTable";
19
20
  readonly ORDER: "OrderTable";
20
21
  readonly ORDER_ADDRESS: "OrderAddressTable";
21
22
  readonly ORDER_REVIEW: "OrderReviewTable";
@@ -71,6 +72,7 @@ export declare const TABLE_NAMES: {
71
72
  readonly ORDER_REVIEW_FEEDBACK: string;
72
73
  readonly CATERING_REQUEST: string;
73
74
  readonly FMP_REQUEST_CALLBACK: string;
75
+ readonly PLATTER_FIT: string;
74
76
  readonly ORDER: string;
75
77
  readonly ORDER_ADDRESS: string;
76
78
  readonly ORDER_REVIEW: string;
@@ -22,6 +22,7 @@ exports.BASE_TABLE_NAMES = {
22
22
  ORDER_REVIEW_FEEDBACK: 'OrderReviewFeedbackTable',
23
23
  CATERING_REQUEST: 'CateringRequestTable',
24
24
  FMP_REQUEST_CALLBACK: 'FmpRequestCallbackTable',
25
+ PLATTER_FIT: 'PlatterFitTable',
25
26
  // Order Module Tables
26
27
  ORDER: 'OrderTable',
27
28
  ORDER_ADDRESS: 'OrderAddressTable',
@@ -92,6 +93,7 @@ exports.TABLE_NAMES = {
92
93
  ORDER_REVIEW_FEEDBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER_REVIEW_FEEDBACK),
93
94
  CATERING_REQUEST: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.CATERING_REQUEST),
94
95
  FMP_REQUEST_CALLBACK: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.FMP_REQUEST_CALLBACK),
96
+ PLATTER_FIT: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.PLATTER_FIT),
95
97
  // Order Module Tables
96
98
  ORDER: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER),
97
99
  ORDER_ADDRESS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ORDER_ADDRESS),
@@ -128,4 +130,4 @@ exports.TABLE_NAMES = {
128
130
  ACTIVITY_LOGS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.ACTIVITY_LOGS),
129
131
  QUOTATIONS: TableNameManager.getTableName(exports.BASE_TABLE_NAMES.QUOTATIONS),
130
132
  };
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-names.js","sourceRoot":"","sources":["../../src/config/table-names.ts"],"names":[],"mappings":";;;AAAA,yDAAqD;AAErD,gDAAgD;AACnC,QAAA,gBAAgB,GAAG;IAC5B,sBAAsB;IACtB,YAAY,EAAE,kBAAkB;IAChC,OAAO,EAAE,aAAa;IACtB,OAAO,EAAE,cAAc;IACvB,mBAAmB,EAAE,yBAAyB;IAC9C,OAAO,EAAE,cAAc;IACvB,YAAY,EAAE,kBAAkB;IAChC,kBAAkB,EAAE,uBAAuB;IAC3C,aAAa,EAAE,mBAAmB;IAClC,oBAAoB,EAAE,yBAAyB;IAC/C,eAAe,EAAE,qBAAqB;IACtC,cAAc,EAAE,oBAAoB;IACpC,OAAO,EAAE,cAAc;IACvB,eAAe,EAAE,qBAAqB;IACtC,qBAAqB,EAAE,0BAA0B;IACjD,qBAAqB,EAAE,0BAA0B;IACjD,gBAAgB,EAAE,sBAAsB;IACxC,oBAAoB,EAAE,yBAAyB;IAE/C,sBAAsB;IACtB,KAAK,EAAE,YAAY;IACnB,aAAa,EAAE,mBAAmB;IAClC,YAAY,EAAE,kBAAkB;IAChC,OAAO,EAAE,cAAc;IACvB,WAAW,EAAE,iBAAiB;IAC9B,QAAQ,EAAE,eAAe;IACzB,YAAY,EAAE,kBAAkB;IAChC,cAAc,EAAE,oBAAoB;IACpC,WAAW,EAAE,iBAAiB;IAE9B,wBAAwB;IACxB,OAAO,EAAE,aAAa;IACtB,YAAY,EAAE,kBAAkB;IAChC,IAAI,EAAE,WAAW;IACjB,eAAe,EAAE,qBAAqB;IACtC,QAAQ,EAAE,eAAe;IACzB,QAAQ,EAAE,eAAe;IACzB,OAAO,EAAE,cAAc;IACvB,OAAO,EAAE,cAAc;IACvB,eAAe,EAAE,qBAAqB;IACtC,0BAA0B,EAAE,+BAA+B;IAC3D,qBAAqB,EAAE,0BAA0B;IACjD,gBAAgB,EAAE,sBAAsB;IACxC,KAAK,EAAE,YAAY;IACnB,IAAI,EAAE,WAAW;IACjB,QAAQ,EAAE,eAAe;IACzB,gBAAgB,EAAE,sBAAsB;IACxC,IAAI,EAAE,WAAW;IACjB,MAAM,EAAE,aAAa;IACrB,kBAAkB,EAAE,wBAAwB;IAC5C,SAAS,EAAE,gBAAgB;IAE3B,uBAAuB;IACvB,aAAa,EAAE,mBAAmB;IAClC,aAAa,EAAE,mBAAmB;IAClC,UAAU,EAAE,iBAAiB;CACvB,CAAC;AAEX,sCAAsC;AACtC,MAAa,gBAAgB;IAClB,MAAM,CAAC,YAAY,CAAC,aAAqB;QAC5C,OAAO,kCAAe,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAEM,MAAM,CAAC,gBAAgB;QAC1B,MAAM,UAAU,GAA2B,EAAE,CAAC;QAE9C,MAAM,CAAC,OAAO,CAAC,wBAAgB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACtD,UAAU,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACtB,CAAC;CACJ;AAdD,4CAcC;AAED,uCAAuC;AAC1B,QAAA,WAAW,GAAG;IACvB,sBAAsB;IACtB,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,mBAAmB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,mBAAmB,CAAC;IACxF,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,kBAAkB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,kBAAkB,CAAC;IACtF,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,oBAAoB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,oBAAoB,CAAC;IAC1F,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,cAAc,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,cAAc,CAAC;IAC9E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAClF,oBAAoB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,oBAAoB,CAAC;IAE1F,sBAAsB;IACtB,KAAK,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,KAAK,CAAC;IAC5D,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,WAAW,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,WAAW,CAAC;IACxE,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,cAAc,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,cAAc,CAAC;IAC9E,WAAW,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,WAAW,CAAC;IAExE,wBAAwB;IACxB,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,YAAY,CAAC;IAC1E,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,OAAO,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,OAAO,CAAC;IAChE,eAAe,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,eAAe,CAAC;IAChF,0BAA0B,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,0BAA0B,CAAC;IACtG,qBAAqB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,qBAAqB,CAAC;IAC5F,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAClF,KAAK,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,KAAK,CAAC;IAC5D,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,QAAQ,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,QAAQ,CAAC;IAClE,gBAAgB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,gBAAgB,CAAC;IAClF,IAAI,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,IAAI,CAAC;IAC1D,MAAM,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,MAAM,CAAC;IAC9D,kBAAkB,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,kBAAkB,CAAC;IACtF,SAAS,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,SAAS,CAAC;IAEpE,uBAAuB;IACvB,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,aAAa,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,aAAa,CAAC;IAC5E,UAAU,EAAE,gBAAgB,CAAC,YAAY,CAAC,wBAAgB,CAAC,UAAU,CAAC;CAChE,CAAC","sourcesContent":["import { DatabaseFactory } from './database-factory';\n\n// Base table names (without environment prefix)\nexport const BASE_TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: 'AppFeedbackTable',\n    LSQ_CRM: 'LsqCrmTable',\n    CUTLERY: 'CutleryTable',\n    ITEM_ACCOMPANIMENTS: 'ItemAccompanimentsTable',\n    CUISINE: 'CuisineTable',\n    TIER_DETAILS: 'TierDetailsTable',\n    USER_ORDER_SUMMARY: 'UserOrderSummaryTable',\n    TIER_REFERRAL: 'TierReferralTable',\n    USER_ADDRESS_REQUEST: 'UserAddressRequestTable',\n    COMMON_FEEDBACK: 'CommonFeedbackTable',\n    GUEST_FEEDBACK: 'GuestFeedbackTable',\n    COUNTER: 'CounterTable',\n    REQUEST_INVOICE: 'RequestInvoiceTable',\n    PLATTER_SEARCH_EVENTS: 'PlatterSearchEventsTable',\n    ORDER_REVIEW_FEEDBACK: 'OrderReviewFeedbackTable',\n    CATERING_REQUEST: 'CateringRequestTable',\n    FMP_REQUEST_CALLBACK: 'FmpRequestCallbackTable',\n\n    // Order Module Tables\n    ORDER: 'OrderTable',\n    ORDER_ADDRESS: 'OrderAddressTable',\n    ORDER_REVIEW: 'OrderReviewTable',\n    PAYMENT: 'PaymentTable',\n    PLATE_ORDER: 'PlateOrderTable',\n    TRACKING: 'TrackingTable',\n    USER_ADDRESS: 'UserAddressTable',\n    USER_SPECIFICS: 'UserSpecificsTable',\n    BBQ_SKEWERS: 'BbqSkewersTable',\n\n    // Other Customer Tables\n    ADD_ONS: 'AddOnsTable',\n    BANK_DETAILS: 'BankDetailsTable',\n    CART: 'CartTable',\n    CART_CATEGORIES: 'CartCategoriesTable',\n    CATEGORY: 'CategoryTable',\n    CATERING: 'CateringTable',\n    CONTENT: 'ContentTable',\n    COUPONS: 'CouponsTable',\n    DEFAULT_PLATTER: 'DefaultPlatterTable',\n    DEFAULT_PLATTER_CATEGORIES: 'DefaultPlatterCategoriesTable',\n    DEFAULT_PLATTER_ITEMS: 'DefaultPlatterItemsTable',\n    EVENT_EXECUTIVES: 'EventExecutivesTable',\n    ITEMS: 'ItemsTable',\n    LEAD: 'LeadTable',\n    OCCASION: 'OccasionTable',\n    REFERRAL_CONTENT: 'ReferralContentTable',\n    USER: 'UserTable',\n    WALLET: 'WalletTable',\n    WALLET_TRANSACTION: 'WalletTransactionTable',\n    WITHDRAWN: 'WithdrawnTable',\n\n    // Internal User Tables\n    INTERNAL_USER: 'InternalUserTable',\n    ACTIVITY_LOGS: 'ActivityLogsTable',\n    QUOTATIONS: 'QuotationsTable',\n} as const;\n\n// Environment-aware table name getter\nexport class TableNameManager {\n    public static getTableName(baseTableName: string): string {\n        return DatabaseFactory.getTableName(baseTableName);\n    }\n\n    public static getAllTableNames(): Record<string, string> {\n        const tableNames: Record<string, string> = {};\n\n        Object.entries(BASE_TABLE_NAMES).forEach(([key, value]) => {\n            tableNames[key] = this.getTableName(value);\n        });\n\n        return tableNames;\n    }\n}\n\n// Export environment-aware table names\nexport const TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.APP_FEEDBACK),\n    LSQ_CRM: TableNameManager.getTableName(BASE_TABLE_NAMES.LSQ_CRM),\n    CUTLERY: TableNameManager.getTableName(BASE_TABLE_NAMES.CUTLERY),\n    ITEM_ACCOMPANIMENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEM_ACCOMPANIMENTS),\n    CUISINE: TableNameManager.getTableName(BASE_TABLE_NAMES.CUISINE),\n    TIER_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_DETAILS),\n    USER_ORDER_SUMMARY: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ORDER_SUMMARY),\n    TIER_REFERRAL: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_REFERRAL),\n    USER_ADDRESS_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS_REQUEST),\n    COMMON_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.COMMON_FEEDBACK),\n    GUEST_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.GUEST_FEEDBACK),\n    COUNTER: TableNameManager.getTableName(BASE_TABLE_NAMES.COUNTER),\n    REQUEST_INVOICE: TableNameManager.getTableName(BASE_TABLE_NAMES.REQUEST_INVOICE),\n    PLATTER_SEARCH_EVENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATTER_SEARCH_EVENTS),\n    ORDER_REVIEW_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW_FEEDBACK),\n    CATERING_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING_REQUEST),\n    FMP_REQUEST_CALLBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.FMP_REQUEST_CALLBACK),\n\n    // Order Module Tables\n    ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER),\n    ORDER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_ADDRESS),\n    ORDER_REVIEW: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW),\n    PAYMENT: TableNameManager.getTableName(BASE_TABLE_NAMES.PAYMENT),\n    PLATE_ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATE_ORDER),\n    TRACKING: TableNameManager.getTableName(BASE_TABLE_NAMES.TRACKING),\n    USER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS),\n    USER_SPECIFICS: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_SPECIFICS),\n    BBQ_SKEWERS: TableNameManager.getTableName(BASE_TABLE_NAMES.BBQ_SKEWERS),\n\n    // Other Customer Tables\n    ADD_ONS: TableNameManager.getTableName(BASE_TABLE_NAMES.ADD_ONS),\n    BANK_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.BANK_DETAILS),\n    CART: TableNameManager.getTableName(BASE_TABLE_NAMES.CART),\n    CART_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.CART_CATEGORIES),\n    CATEGORY: TableNameManager.getTableName(BASE_TABLE_NAMES.CATEGORY),\n    CATERING: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING),\n    CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.CONTENT),\n    COUPONS: TableNameManager.getTableName(BASE_TABLE_NAMES.COUPONS),\n    DEFAULT_PLATTER: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER),\n    DEFAULT_PLATTER_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_CATEGORIES),\n    DEFAULT_PLATTER_ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_ITEMS),\n    EVENT_EXECUTIVES: TableNameManager.getTableName(BASE_TABLE_NAMES.EVENT_EXECUTIVES),\n    ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEMS),\n    LEAD: TableNameManager.getTableName(BASE_TABLE_NAMES.LEAD),\n    OCCASION: TableNameManager.getTableName(BASE_TABLE_NAMES.OCCASION),\n    REFERRAL_CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.REFERRAL_CONTENT),\n    USER: TableNameManager.getTableName(BASE_TABLE_NAMES.USER),\n    WALLET: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET),\n    WALLET_TRANSACTION: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET_TRANSACTION),\n    WITHDRAWN: TableNameManager.getTableName(BASE_TABLE_NAMES.WITHDRAWN),\n\n    // Internal User Tables\n    INTERNAL_USER: TableNameManager.getTableName(BASE_TABLE_NAMES.INTERNAL_USER),\n    ACTIVITY_LOGS: TableNameManager.getTableName(BASE_TABLE_NAMES.ACTIVITY_LOGS),\n    QUOTATIONS: TableNameManager.getTableName(BASE_TABLE_NAMES.QUOTATIONS),\n} as const;\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-names.js","sourceRoot":"","sources":["../../src/config/table-names.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatabaseFactory } from './database-factory';\n\n// Base table names (without environment prefix)\nexport const BASE_TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: 'AppFeedbackTable',\n    LSQ_CRM: 'LsqCrmTable',\n    CUTLERY: 'CutleryTable',\n    ITEM_ACCOMPANIMENTS: 'ItemAccompanimentsTable',\n    CUISINE: 'CuisineTable',\n    TIER_DETAILS: 'TierDetailsTable',\n    USER_ORDER_SUMMARY: 'UserOrderSummaryTable',\n    TIER_REFERRAL: 'TierReferralTable',\n    USER_ADDRESS_REQUEST: 'UserAddressRequestTable',\n    COMMON_FEEDBACK: 'CommonFeedbackTable',\n    GUEST_FEEDBACK: 'GuestFeedbackTable',\n    COUNTER: 'CounterTable',\n    REQUEST_INVOICE: 'RequestInvoiceTable',\n    PLATTER_SEARCH_EVENTS: 'PlatterSearchEventsTable',\n    ORDER_REVIEW_FEEDBACK: 'OrderReviewFeedbackTable',\n    CATERING_REQUEST: 'CateringRequestTable',\n    FMP_REQUEST_CALLBACK: 'FmpRequestCallbackTable',\n    PLATTER_FIT: 'PlatterFitTable',\n\n    // Order Module Tables\n    ORDER: 'OrderTable',\n    ORDER_ADDRESS: 'OrderAddressTable',\n    ORDER_REVIEW: 'OrderReviewTable',\n    PAYMENT: 'PaymentTable',\n    PLATE_ORDER: 'PlateOrderTable',\n    TRACKING: 'TrackingTable',\n    USER_ADDRESS: 'UserAddressTable',\n    USER_SPECIFICS: 'UserSpecificsTable',\n    BBQ_SKEWERS: 'BbqSkewersTable',\n\n    // Other Customer Tables\n    ADD_ONS: 'AddOnsTable',\n    BANK_DETAILS: 'BankDetailsTable',\n    CART: 'CartTable',\n    CART_CATEGORIES: 'CartCategoriesTable',\n    CATEGORY: 'CategoryTable',\n    CATERING: 'CateringTable',\n    CONTENT: 'ContentTable',\n    COUPONS: 'CouponsTable',\n    DEFAULT_PLATTER: 'DefaultPlatterTable',\n    DEFAULT_PLATTER_CATEGORIES: 'DefaultPlatterCategoriesTable',\n    DEFAULT_PLATTER_ITEMS: 'DefaultPlatterItemsTable',\n    EVENT_EXECUTIVES: 'EventExecutivesTable',\n    ITEMS: 'ItemsTable',\n    LEAD: 'LeadTable',\n    OCCASION: 'OccasionTable',\n    REFERRAL_CONTENT: 'ReferralContentTable',\n    USER: 'UserTable',\n    WALLET: 'WalletTable',\n    WALLET_TRANSACTION: 'WalletTransactionTable',\n    WITHDRAWN: 'WithdrawnTable',\n\n    // Internal User Tables\n    INTERNAL_USER: 'InternalUserTable',\n    ACTIVITY_LOGS: 'ActivityLogsTable',\n    QUOTATIONS: 'QuotationsTable',\n} as const;\n\n// Environment-aware table name getter\nexport class TableNameManager {\n    public static getTableName(baseTableName: string): string {\n        return DatabaseFactory.getTableName(baseTableName);\n    }\n\n    public static getAllTableNames(): Record<string, string> {\n        const tableNames: Record<string, string> = {};\n\n        Object.entries(BASE_TABLE_NAMES).forEach(([key, value]) => {\n            tableNames[key] = this.getTableName(value);\n        });\n\n        return tableNames;\n    }\n}\n\n// Export environment-aware table names\nexport const TABLE_NAMES = {\n    // Customer App Tables\n    APP_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.APP_FEEDBACK),\n    LSQ_CRM: TableNameManager.getTableName(BASE_TABLE_NAMES.LSQ_CRM),\n    CUTLERY: TableNameManager.getTableName(BASE_TABLE_NAMES.CUTLERY),\n    ITEM_ACCOMPANIMENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEM_ACCOMPANIMENTS),\n    CUISINE: TableNameManager.getTableName(BASE_TABLE_NAMES.CUISINE),\n    TIER_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_DETAILS),\n    USER_ORDER_SUMMARY: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ORDER_SUMMARY),\n    TIER_REFERRAL: TableNameManager.getTableName(BASE_TABLE_NAMES.TIER_REFERRAL),\n    USER_ADDRESS_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS_REQUEST),\n    COMMON_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.COMMON_FEEDBACK),\n    GUEST_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.GUEST_FEEDBACK),\n    COUNTER: TableNameManager.getTableName(BASE_TABLE_NAMES.COUNTER),\n    REQUEST_INVOICE: TableNameManager.getTableName(BASE_TABLE_NAMES.REQUEST_INVOICE),\n    PLATTER_SEARCH_EVENTS: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATTER_SEARCH_EVENTS),\n    ORDER_REVIEW_FEEDBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW_FEEDBACK),\n    CATERING_REQUEST: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING_REQUEST),\n    FMP_REQUEST_CALLBACK: TableNameManager.getTableName(BASE_TABLE_NAMES.FMP_REQUEST_CALLBACK),\n    PLATTER_FIT: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATTER_FIT),\n\n    // Order Module Tables\n    ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER),\n    ORDER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_ADDRESS),\n    ORDER_REVIEW: TableNameManager.getTableName(BASE_TABLE_NAMES.ORDER_REVIEW),\n    PAYMENT: TableNameManager.getTableName(BASE_TABLE_NAMES.PAYMENT),\n    PLATE_ORDER: TableNameManager.getTableName(BASE_TABLE_NAMES.PLATE_ORDER),\n    TRACKING: TableNameManager.getTableName(BASE_TABLE_NAMES.TRACKING),\n    USER_ADDRESS: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_ADDRESS),\n    USER_SPECIFICS: TableNameManager.getTableName(BASE_TABLE_NAMES.USER_SPECIFICS),\n    BBQ_SKEWERS: TableNameManager.getTableName(BASE_TABLE_NAMES.BBQ_SKEWERS),\n\n    // Other Customer Tables\n    ADD_ONS: TableNameManager.getTableName(BASE_TABLE_NAMES.ADD_ONS),\n    BANK_DETAILS: TableNameManager.getTableName(BASE_TABLE_NAMES.BANK_DETAILS),\n    CART: TableNameManager.getTableName(BASE_TABLE_NAMES.CART),\n    CART_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.CART_CATEGORIES),\n    CATEGORY: TableNameManager.getTableName(BASE_TABLE_NAMES.CATEGORY),\n    CATERING: TableNameManager.getTableName(BASE_TABLE_NAMES.CATERING),\n    CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.CONTENT),\n    COUPONS: TableNameManager.getTableName(BASE_TABLE_NAMES.COUPONS),\n    DEFAULT_PLATTER: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER),\n    DEFAULT_PLATTER_CATEGORIES: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_CATEGORIES),\n    DEFAULT_PLATTER_ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.DEFAULT_PLATTER_ITEMS),\n    EVENT_EXECUTIVES: TableNameManager.getTableName(BASE_TABLE_NAMES.EVENT_EXECUTIVES),\n    ITEMS: TableNameManager.getTableName(BASE_TABLE_NAMES.ITEMS),\n    LEAD: TableNameManager.getTableName(BASE_TABLE_NAMES.LEAD),\n    OCCASION: TableNameManager.getTableName(BASE_TABLE_NAMES.OCCASION),\n    REFERRAL_CONTENT: TableNameManager.getTableName(BASE_TABLE_NAMES.REFERRAL_CONTENT),\n    USER: TableNameManager.getTableName(BASE_TABLE_NAMES.USER),\n    WALLET: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET),\n    WALLET_TRANSACTION: TableNameManager.getTableName(BASE_TABLE_NAMES.WALLET_TRANSACTION),\n    WITHDRAWN: TableNameManager.getTableName(BASE_TABLE_NAMES.WITHDRAWN),\n\n    // Internal User Tables\n    INTERNAL_USER: TableNameManager.getTableName(BASE_TABLE_NAMES.INTERNAL_USER),\n    ACTIVITY_LOGS: TableNameManager.getTableName(BASE_TABLE_NAMES.ACTIVITY_LOGS),\n    QUOTATIONS: TableNameManager.getTableName(BASE_TABLE_NAMES.QUOTATIONS),\n} as const;\n"]}
@@ -1,4 +1,11 @@
1
1
  import { BaseModel } from "../../base-model";
2
+ /**
3
+ * Arbitrary metadata: any key name, values can be primitives, nested maps, or lists (including lists of objects).
4
+ * Example: metadata.homeBanner = [{ platterImage, platterId, ... }, ...]; metadata.tags = ["a","b"];
5
+ */
6
+ export type ContentMetadataValue = string | number | boolean | null | ContentMetadataValue[] | {
7
+ [key: string]: ContentMetadataValue;
8
+ };
2
9
  export declare class ContentModel extends BaseModel {
3
10
  id: string;
4
11
  category: string;
@@ -14,6 +21,5 @@ export declare class ContentModel extends BaseModel {
14
21
  contentActive: string;
15
22
  description?: string;
16
23
  content_title?: string[];
17
- /** Arbitrary string key–value pairs (DynamoDB Map); extend schema without new columns */
18
- metadata?: Record<string, string>;
24
+ metadata?: Record<string, ContentMetadataValue>;
19
25
  }
@@ -78,10 +78,10 @@ __decorate([
78
78
  __metadata("design:type", Array)
79
79
  ], ContentModel.prototype, "content_title", void 0);
80
80
  __decorate([
81
- (0, annotations_1.attribute)({ memberType: "String" }),
81
+ (0, annotations_1.attribute)(),
82
82
  __metadata("design:type", Object)
83
83
  ], ContentModel.prototype, "metadata", void 0);
84
84
  exports.ContentModel = ContentModel = __decorate([
85
85
  (0, annotations_1.table)("ContentTable")
86
86
  ], ContentModel);
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL2NvbnRlbnQvY29udGVudC1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSx1REFBK0U7QUFDL0UsaURBQTZDO0FBR3RDLElBQU0sWUFBWSxHQUFsQixNQUFNLFlBQWEsU0FBUSxzQkFBUztDQXVDMUMsQ0FBQTtBQXZDWSxvQ0FBWTtBQUVyQjtJQURDLElBQUEsa0NBQW9CLEVBQUMsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7O3dDQUM5QjtBQUtYO0lBSkMsSUFBQSx1QkFBUyxFQUFDO1FBQ1Asc0JBQXNCLEVBQUUsRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVE7S0FDdEUsQ0FBQzs7OENBRWU7QUFJakI7SUFIQyxJQUFBLHVCQUFTLEVBQUM7UUFDUCxzQkFBc0IsRUFBRSxFQUFFLG9CQUFvQixFQUFFLE9BQU8sRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRO0tBQzVFLENBQUM7O29EQUNxQjtBQUl2QjtJQUhDLElBQUEsdUJBQVMsRUFBQztRQUNQLHNCQUFzQixFQUFFLEVBQUUsb0JBQW9CLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVE7S0FDNUUsQ0FBQzs7MkNBQ1k7QUFFZDtJQURDLElBQUEsdUJBQVMsR0FBRTs7Z0RBQ087QUFFbkI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7O2tEQUNVO0FBRXRCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztpREFDUTtBQUVwQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7cURBQ2M7QUFFMUI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7O2dEQUNTO0FBRXJCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztnREFDUztBQUVyQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7OENBQ087QUFFbkI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQzs7bURBQ2xFO0FBRXRCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztpREFDUztBQUVyQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7bURBQ2E7QUFHekI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLENBQUM7OzhDQUNGO3VCQXRDekIsWUFBWTtJQUR4QixJQUFBLG1CQUFLLEVBQUMsY0FBYyxDQUFDO0dBQ1QsWUFBWSxDQXVDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhdHRyaWJ1dGUsIGF1dG9HZW5lcmF0ZWRIYXNoS2V5LCB0YWJsZSB9IGZyb20gXCJAbm92YS1vZG0vYW5ub3RhdGlvbnNcIjtcbmltcG9ydCB7IEJhc2VNb2RlbCB9IGZyb20gXCIuLi8uLi9iYXNlLW1vZGVsXCI7XG5cbkB0YWJsZShcIkNvbnRlbnRUYWJsZVwiKVxuZXhwb3J0IGNsYXNzIENvbnRlbnRNb2RlbCBleHRlbmRzIEJhc2VNb2RlbCB7XG4gICAgQGF1dG9HZW5lcmF0ZWRIYXNoS2V5KHsgdHlwZTogXCJTdHJpbmdcIiB9KVxuICAgIGlkOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSh7XG4gICAgICAgIGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjYXRlZ29yeUluZGV4XCI6IFwiSEFTSFwiIH0sIHR5cGU6ICdTdHJpbmcnXG4gICAgfSlcblxuICAgIGNhdGVnb3J5OiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSh7XG4gICAgICAgIGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjYXRlZ29yeU9yZGVySW5kZXhcIjogXCJSQU5HRVwiIH0sIHR5cGU6ICdOdW1iZXInXG4gICAgfSlcbiAgICBjYXRlZ29yeV9vcmRlcjogbnVtYmVyO1xuICAgIEBhdHRyaWJ1dGUoe1xuICAgICAgICBpbmRleEtleUNvbmZpZ3VyYXRpb25zOiB7IFwidGl0bGVDYXRlZ29yeUluZGV4XCI6IFwiUkFOR0VcIiB9LCB0eXBlOiAnU3RyaW5nJ1xuICAgIH0pXG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBAYXR0cmlidXRlKClcbiAgICB0aXRsZV9pY29uOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF90eXBlPzogc3RyaW5nO1xuICAgIEBhdHRyaWJ1dGUoKVxuICAgIHRpdGxlX2ltYWdlOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF9kZXRhaWxzOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICBpbWFnZXNfdXJsOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICB2aWRlb3NfdXJsOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICBsb2NhdGlvbjogc3RyaW5nW107XG4gICAgQGF0dHJpYnV0ZSh7IGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjb250ZW50QWN0aXZlSW5kZXhcIjogXCJIQVNIXCIgfSwgdHlwZTogJ1N0cmluZycgfSlcbiAgICBjb250ZW50QWN0aXZlOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7IC8vIE5ldyBBZGRlZCAwNi0wMy0yMDI2XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF90aXRsZT86IHN0cmluZ1tdOyAvLyBOZXcgQWRkZWQgMDYtMDMtMjAyNlxuICAgIC8qKiBBcmJpdHJhcnkgc3RyaW5nIGtleeKAk3ZhbHVlIHBhaXJzIChEeW5hbW9EQiBNYXApOyBleHRlbmQgc2NoZW1hIHdpdGhvdXQgbmV3IGNvbHVtbnMgKi9cbiAgICBAYXR0cmlidXRlKHsgbWVtYmVyVHlwZTogXCJTdHJpbmdcIiB9KVxuICAgIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbn0iXX0=
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL2NvbnRlbnQvY29udGVudC1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSx1REFBK0U7QUFDL0UsaURBQTZDO0FBZXRDLElBQU0sWUFBWSxHQUFsQixNQUFNLFlBQWEsU0FBUSxzQkFBUztDQXNDMUMsQ0FBQTtBQXRDWSxvQ0FBWTtBQUVyQjtJQURDLElBQUEsa0NBQW9CLEVBQUMsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7O3dDQUM5QjtBQUtYO0lBSkMsSUFBQSx1QkFBUyxFQUFDO1FBQ1Asc0JBQXNCLEVBQUUsRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVE7S0FDdEUsQ0FBQzs7OENBRWU7QUFJakI7SUFIQyxJQUFBLHVCQUFTLEVBQUM7UUFDUCxzQkFBc0IsRUFBRSxFQUFFLG9CQUFvQixFQUFFLE9BQU8sRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRO0tBQzVFLENBQUM7O29EQUNxQjtBQUl2QjtJQUhDLElBQUEsdUJBQVMsRUFBQztRQUNQLHNCQUFzQixFQUFFLEVBQUUsb0JBQW9CLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLFFBQVE7S0FDNUUsQ0FBQzs7MkNBQ1k7QUFFZDtJQURDLElBQUEsdUJBQVMsR0FBRTs7Z0RBQ087QUFFbkI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7O2tEQUNVO0FBRXRCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztpREFDUTtBQUVwQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7cURBQ2M7QUFFMUI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7O2dEQUNTO0FBRXJCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztnREFDUztBQUVyQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7OENBQ087QUFFbkI7SUFEQyxJQUFBLHVCQUFTLEVBQUMsRUFBRSxzQkFBc0IsRUFBRSxFQUFFLG9CQUFvQixFQUFFLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQzs7bURBQ2xFO0FBRXRCO0lBREMsSUFBQSx1QkFBUyxHQUFFOztpREFDUztBQUVyQjtJQURDLElBQUEsdUJBQVMsR0FBRTs7bURBQ2E7QUFFekI7SUFEQyxJQUFBLHVCQUFTLEdBQUU7OzhDQUNvQzt1QkFyQ3ZDLFlBQVk7SUFEeEIsSUFBQSxtQkFBSyxFQUFDLGNBQWMsQ0FBQztHQUNULFlBQVksQ0FzQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXR0cmlidXRlLCBhdXRvR2VuZXJhdGVkSGFzaEtleSwgdGFibGUgfSBmcm9tIFwiQG5vdmEtb2RtL2Fubm90YXRpb25zXCI7XG5pbXBvcnQgeyBCYXNlTW9kZWwgfSBmcm9tIFwiLi4vLi4vYmFzZS1tb2RlbFwiO1xuXG4vKipcbiAqIEFyYml0cmFyeSBtZXRhZGF0YTogYW55IGtleSBuYW1lLCB2YWx1ZXMgY2FuIGJlIHByaW1pdGl2ZXMsIG5lc3RlZCBtYXBzLCBvciBsaXN0cyAoaW5jbHVkaW5nIGxpc3RzIG9mIG9iamVjdHMpLlxuICogRXhhbXBsZTogbWV0YWRhdGEuaG9tZUJhbm5lciA9IFt7IHBsYXR0ZXJJbWFnZSwgcGxhdHRlcklkLCAuLi4gfSwgLi4uXTsgbWV0YWRhdGEudGFncyA9IFtcImFcIixcImJcIl07XG4gKi9cbmV4cG9ydCB0eXBlIENvbnRlbnRNZXRhZGF0YVZhbHVlID1cbiAgICB8IHN0cmluZ1xuICAgIHwgbnVtYmVyXG4gICAgfCBib29sZWFuXG4gICAgfCBudWxsXG4gICAgfCBDb250ZW50TWV0YWRhdGFWYWx1ZVtdXG4gICAgfCB7IFtrZXk6IHN0cmluZ106IENvbnRlbnRNZXRhZGF0YVZhbHVlIH07XG5cbkB0YWJsZShcIkNvbnRlbnRUYWJsZVwiKVxuZXhwb3J0IGNsYXNzIENvbnRlbnRNb2RlbCBleHRlbmRzIEJhc2VNb2RlbCB7XG4gICAgQGF1dG9HZW5lcmF0ZWRIYXNoS2V5KHsgdHlwZTogXCJTdHJpbmdcIiB9KVxuICAgIGlkOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSh7XG4gICAgICAgIGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjYXRlZ29yeUluZGV4XCI6IFwiSEFTSFwiIH0sIHR5cGU6ICdTdHJpbmcnXG4gICAgfSlcblxuICAgIGNhdGVnb3J5OiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSh7XG4gICAgICAgIGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjYXRlZ29yeU9yZGVySW5kZXhcIjogXCJSQU5HRVwiIH0sIHR5cGU6ICdOdW1iZXInXG4gICAgfSlcbiAgICBjYXRlZ29yeV9vcmRlcjogbnVtYmVyO1xuICAgIEBhdHRyaWJ1dGUoe1xuICAgICAgICBpbmRleEtleUNvbmZpZ3VyYXRpb25zOiB7IFwidGl0bGVDYXRlZ29yeUluZGV4XCI6IFwiUkFOR0VcIiB9LCB0eXBlOiAnU3RyaW5nJ1xuICAgIH0pXG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBAYXR0cmlidXRlKClcbiAgICB0aXRsZV9pY29uOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF90eXBlPzogc3RyaW5nO1xuICAgIEBhdHRyaWJ1dGUoKVxuICAgIHRpdGxlX2ltYWdlOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF9kZXRhaWxzOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICBpbWFnZXNfdXJsOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICB2aWRlb3NfdXJsOiBzdHJpbmdbXTtcbiAgICBAYXR0cmlidXRlKClcbiAgICBsb2NhdGlvbjogc3RyaW5nW107XG4gICAgQGF0dHJpYnV0ZSh7IGluZGV4S2V5Q29uZmlndXJhdGlvbnM6IHsgXCJjb250ZW50QWN0aXZlSW5kZXhcIjogXCJIQVNIXCIgfSwgdHlwZTogJ1N0cmluZycgfSlcbiAgICBjb250ZW50QWN0aXZlOiBzdHJpbmc7XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7IC8vIE5ldyBBZGRlZCAwNi0wMy0yMDI2XG4gICAgQGF0dHJpYnV0ZSgpXG4gICAgY29udGVudF90aXRsZT86IHN0cmluZ1tdOyAvLyBOZXcgQWRkZWQgMDYtMDMtMjAyNlxuICAgIEBhdHRyaWJ1dGUoKVxuICAgIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgQ29udGVudE1ldGFkYXRhVmFsdWU+O1xufSJdfQ==
@@ -0,0 +1,41 @@
1
+ import { GenericDynamooseDAO } from "../../base-dynamoose-dao";
2
+ import { AuthContext } from "../../base-dynamoose-model";
3
+ import { CreatePlatterFitInput, PlatterFit } from "./platter-fit-model";
4
+ type ListResult = {
5
+ items: PlatterFit[];
6
+ nextToken?: string;
7
+ };
8
+ declare class PlatterFitDao extends GenericDynamooseDAO<PlatterFit> {
9
+ /**
10
+ * Connects platter-fit DAO to the table model and its primary key.
11
+ */
12
+ constructor();
13
+ /**
14
+ * Creates one platter-fit record.
15
+ * If platterFitId is not passed, Dynamoose auto-generates it from schema default.
16
+ */
17
+ save: (item: CreatePlatterFitInput, authContext?: AuthContext) => Promise<PlatterFit>;
18
+ /**
19
+ * Updates one platter-fit record by id with conditional existence check.
20
+ */
21
+ update: (platterFitId: string, updates: Partial<PlatterFit>, authContext?: AuthContext) => Promise<PlatterFit>;
22
+ /**
23
+ * Returns one platter-fit record by primary key.
24
+ */
25
+ getById: (platterFitId: string) => Promise<PlatterFit | null>;
26
+ /**
27
+ * Lists records by status using token-based pagination.
28
+ * Pass returned nextToken in the next call to continue.
29
+ */
30
+ listByStatus: (status: string, limit?: number, token?: string) => Promise<ListResult>;
31
+ /**
32
+ * Lists records by occasionType using token-based pagination.
33
+ */
34
+ listByOccasionType: (occasionType: string, limit?: number, token?: string) => Promise<ListResult>;
35
+ /**
36
+ * Lists records by platterId using token-based pagination.
37
+ */
38
+ listByPlatterId: (platterId: string, limit?: number, token?: string) => Promise<ListResult>;
39
+ }
40
+ export declare const platterFitDao: PlatterFitDao;
41
+ export {};
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.platterFitDao = void 0;
7
+ const dynamoose_1 = __importDefault(require("dynamoose"));
8
+ const base_dynamoose_dao_1 = require("../../base-dynamoose-dao");
9
+ const platter_fit_model_1 = require("./platter-fit-model");
10
+ class PlatterFitDao extends base_dynamoose_dao_1.GenericDynamooseDAO {
11
+ /**
12
+ * Connects platter-fit DAO to the table model and its primary key.
13
+ */
14
+ constructor() {
15
+ super(platter_fit_model_1.PlatterFitModel, "platterFitId");
16
+ /**
17
+ * Creates one platter-fit record.
18
+ * If platterFitId is not passed, Dynamoose auto-generates it from schema default.
19
+ */
20
+ this.save = async (item, authContext) => {
21
+ return super.save(item, authContext);
22
+ };
23
+ /**
24
+ * Updates one platter-fit record by id with conditional existence check.
25
+ */
26
+ this.update = async (platterFitId, updates, authContext) => {
27
+ const updated = await platter_fit_model_1.PlatterFitModel.update({ platterFitId }, {
28
+ ...updates,
29
+ updated_time: new Date(),
30
+ updated_user: authContext?.userSub
31
+ }, {
32
+ condition: new dynamoose_1.default.Condition().where("platterFitId").eq(platterFitId)
33
+ });
34
+ return { ...updated };
35
+ };
36
+ /**
37
+ * Returns one platter-fit record by primary key.
38
+ */
39
+ this.getById = async (platterFitId) => this.get(platterFitId);
40
+ /**
41
+ * Lists records by status using token-based pagination.
42
+ * Pass returned nextToken in the next call to continue.
43
+ */
44
+ this.listByStatus = async (status, limit, token) => {
45
+ const decodedToken = this.decode(token);
46
+ let queryBuilder = platter_fit_model_1.PlatterFitModel
47
+ .query("status")
48
+ .eq(status)
49
+ .using("statusIndex");
50
+ if (decodedToken) {
51
+ queryBuilder = queryBuilder.startAt(decodedToken);
52
+ }
53
+ if (typeof limit === "number") {
54
+ queryBuilder = queryBuilder.limit(limit);
55
+ }
56
+ const queryResult = await queryBuilder.exec();
57
+ return {
58
+ items: queryResult.map((item) => ({ ...item })),
59
+ nextToken: await this.encode(queryResult.lastKey)
60
+ };
61
+ };
62
+ /**
63
+ * Lists records by occasionType using token-based pagination.
64
+ */
65
+ this.listByOccasionType = async (occasionType, limit, token) => {
66
+ const decodedToken = this.decode(token);
67
+ let queryBuilder = platter_fit_model_1.PlatterFitModel
68
+ .query("occasionType")
69
+ .eq(occasionType)
70
+ .using("occasionTypeIndex");
71
+ if (decodedToken) {
72
+ queryBuilder = queryBuilder.startAt(decodedToken);
73
+ }
74
+ if (typeof limit === "number") {
75
+ queryBuilder = queryBuilder.limit(limit);
76
+ }
77
+ const queryResult = await queryBuilder.exec();
78
+ return {
79
+ items: queryResult.map((item) => ({ ...item })),
80
+ nextToken: await this.encode(queryResult.lastKey)
81
+ };
82
+ };
83
+ /**
84
+ * Lists records by platterId using token-based pagination.
85
+ */
86
+ this.listByPlatterId = async (platterId, limit, token) => {
87
+ const decodedToken = this.decode(token);
88
+ let queryBuilder = platter_fit_model_1.PlatterFitModel
89
+ .query("platterId")
90
+ .eq(platterId)
91
+ .using("platterIdIndex");
92
+ if (decodedToken) {
93
+ queryBuilder = queryBuilder.startAt(decodedToken);
94
+ }
95
+ if (typeof limit === "number") {
96
+ queryBuilder = queryBuilder.limit(limit);
97
+ }
98
+ const queryResult = await queryBuilder.exec();
99
+ return {
100
+ items: queryResult.map((item) => ({ ...item })),
101
+ nextToken: await this.encode(queryResult.lastKey)
102
+ };
103
+ };
104
+ }
105
+ }
106
+ exports.platterFitDao = new PlatterFitDao();
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"platter-fit-dao.js","sourceRoot":"","sources":["../../../src/customer-user/platter-fit-module/platter-fit-dao.ts"],"names":[],"mappings":"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","sourcesContent":["import dynamoose from \"dynamoose\";\nimport { DynamoKey, GenericDynamooseDAO } from \"../../base-dynamoose-dao\";\nimport { AuthContext } from \"../../base-dynamoose-model\";\nimport { CreatePlatterFitInput, PlatterFit, PlatterFitModel } from \"./platter-fit-model\";\n\ntype ListResult = {\n    items: PlatterFit[];\n    nextToken?: string;\n};\n\nclass PlatterFitDao extends GenericDynamooseDAO<PlatterFit> {\n    /**\n     * Connects platter-fit DAO to the table model and its primary key.\n     */\n    constructor() {\n        super(PlatterFitModel, \"platterFitId\");\n    }\n\n    /**\n     * Creates one platter-fit record.\n     * If platterFitId is not passed, Dynamoose auto-generates it from schema default.\n     */\n    save = async (item: CreatePlatterFitInput, authContext?: AuthContext): Promise<PlatterFit> => {\n        return super.save(item as PlatterFit, authContext);\n    };\n\n    /**\n     * Updates one platter-fit record by id with conditional existence check.\n     */\n    update = async (\n        platterFitId: string,\n        updates: Partial<PlatterFit>,\n        authContext?: AuthContext\n    ): Promise<PlatterFit> => {\n        const updated = await PlatterFitModel.update(\n            { platterFitId },\n            {\n                ...updates,\n                updated_time: new Date(),\n                updated_user: authContext?.userSub\n            },\n            {\n                condition: new dynamoose.Condition().where(\"platterFitId\").eq(platterFitId)\n            }\n        );\n        return { ...(updated as object) } as PlatterFit;\n    };\n\n    /**\n     * Returns one platter-fit record by primary key.\n     */\n    getById = async (platterFitId: string): Promise<PlatterFit | null> => this.get(platterFitId);\n\n    /**\n     * Lists records by status using token-based pagination.\n     * Pass returned nextToken in the next call to continue.\n     */\n    listByStatus = async (status: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"status\")\n            .eq(status)\n            .using(\"statusIndex\");\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by occasionType using token-based pagination.\n     */\n    listByOccasionType = async (occasionType: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"occasionType\")\n            .eq(occasionType)\n            .using(\"occasionTypeIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n\n    /**\n     * Lists records by platterId using token-based pagination.\n     */\n    listByPlatterId = async (platterId: string, limit?: number, token?: string): Promise<ListResult> => {\n        const decodedToken = this.decode(token);\n        let queryBuilder = PlatterFitModel\n            .query(\"platterId\")\n            .eq(platterId)\n            .using(\"platterIdIndex\");\n\n        if (decodedToken) {\n            queryBuilder = queryBuilder.startAt(decodedToken);\n        }\n\n        if (typeof limit === \"number\") {\n            queryBuilder = queryBuilder.limit(limit);\n        }\n\n        const queryResult = await queryBuilder.exec();\n\n        return {\n            items: queryResult.map((item) => ({ ...(item as object) } as PlatterFit)),\n            nextToken: await this.encode(queryResult.lastKey as DynamoKey | undefined)\n        };\n    };\n}\n\nexport const platterFitDao = new PlatterFitDao();\n"]}
@@ -0,0 +1,23 @@
1
+ import { BaseDynamooseModel } from "../../base-dynamoose-model";
2
+ export declare const PLATTER_FIT_TABLE_NAME = "PlatterFitTable";
3
+ export interface PlatterFit extends BaseDynamooseModel {
4
+ platterFitId: string;
5
+ occasionName: string;
6
+ occasionType: string;
7
+ occasionSubType?: string;
8
+ minPax: number;
9
+ maxPax: number;
10
+ budgetTier: string;
11
+ rank: number;
12
+ rankTag?: string;
13
+ platterId: string;
14
+ platterName: string;
15
+ bucketPaxDescription?: string;
16
+ occasionDescription?: string;
17
+ othersDescription?: string;
18
+ status: string;
19
+ }
20
+ export type CreatePlatterFitInput = Omit<PlatterFit, "platterFitId"> & {
21
+ platterFitId?: string;
22
+ };
23
+ export declare const PlatterFitModel: import("dynamoose/dist/General").ModelType<import("dynamoose/dist/Item").AnyItem>;
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PlatterFitModel = exports.PLATTER_FIT_TABLE_NAME = void 0;
7
+ const dynamoose_1 = __importDefault(require("dynamoose"));
8
+ const crypto_1 = require("crypto");
9
+ const base_dynamoose_model_1 = require("../../base-dynamoose-model");
10
+ exports.PLATTER_FIT_TABLE_NAME = "PlatterFitTable";
11
+ const platterFitSchema = new dynamoose_1.default.Schema({
12
+ platterFitId: {
13
+ type: String,
14
+ hashKey: true,
15
+ required: true,
16
+ default: () => (0, crypto_1.randomUUID)()
17
+ },
18
+ occasionName: {
19
+ type: String,
20
+ required: true
21
+ },
22
+ occasionType: {
23
+ type: String,
24
+ required: true,
25
+ index: {
26
+ name: "occasionTypeIndex",
27
+ type: "global"
28
+ }
29
+ },
30
+ occasionSubType: String,
31
+ minPax: {
32
+ type: Number,
33
+ required: true
34
+ },
35
+ maxPax: {
36
+ type: Number,
37
+ required: true
38
+ },
39
+ budgetTier: {
40
+ type: String,
41
+ required: true
42
+ },
43
+ rank: {
44
+ type: Number,
45
+ required: true
46
+ },
47
+ rankTag: String,
48
+ platterId: {
49
+ type: String,
50
+ required: true,
51
+ index: {
52
+ name: "platterIdIndex",
53
+ type: "global"
54
+ }
55
+ },
56
+ platterName: {
57
+ type: String,
58
+ required: true
59
+ },
60
+ bucketPaxDescription: String,
61
+ occasionDescription: String,
62
+ othersDescription: String,
63
+ status: {
64
+ type: String,
65
+ required: true,
66
+ index: {
67
+ name: "statusIndex",
68
+ type: "global"
69
+ }
70
+ },
71
+ ...base_dynamoose_model_1.BASE_DYNAMOOSE_AUDIT_SCHEMA
72
+ }, {
73
+ saveUnknown: false
74
+ });
75
+ exports.PlatterFitModel = dynamoose_1.default.model(exports.PLATTER_FIT_TABLE_NAME, platterFitSchema, {
76
+ create: false,
77
+ waitForActive: false
78
+ });
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdHRlci1maXQtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VzdG9tZXItdXNlci9wbGF0dGVyLWZpdC1tb2R1bGUvcGxhdHRlci1maXQtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsMERBQWtDO0FBQ2xDLG1DQUFvQztBQUNwQyxxRUFBNkY7QUFFaEYsUUFBQSxzQkFBc0IsR0FBRyxpQkFBaUIsQ0FBQztBQXdCeEQsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLG1CQUFTLENBQUMsTUFBTSxDQUN6QztJQUNJLFlBQVksRUFBRTtRQUNWLElBQUksRUFBRSxNQUFNO1FBQ1osT0FBTyxFQUFFLElBQUk7UUFDYixRQUFRLEVBQUUsSUFBSTtRQUNkLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFBLG1CQUFVLEdBQUU7S0FDOUI7SUFDRCxZQUFZLEVBQUU7UUFDVixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsWUFBWSxFQUFFO1FBQ1YsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxtQkFBbUI7WUFDekIsSUFBSSxFQUFFLFFBQVE7U0FDakI7S0FDSjtJQUNELGVBQWUsRUFBRSxNQUFNO0lBQ3ZCLE1BQU0sRUFBRTtRQUNKLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxNQUFNLEVBQUU7UUFDSixJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0QsVUFBVSxFQUFFO1FBQ1IsSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtLQUNqQjtJQUNELElBQUksRUFBRTtRQUNGLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7S0FDakI7SUFDRCxPQUFPLEVBQUUsTUFBTTtJQUNmLFNBQVMsRUFBRTtRQUNQLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLElBQUk7UUFDZCxLQUFLLEVBQUU7WUFDSCxJQUFJLEVBQUUsZ0JBQWdCO1lBQ3RCLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxXQUFXLEVBQUU7UUFDVCxJQUFJLEVBQUUsTUFBTTtRQUNaLFFBQVEsRUFBRSxJQUFJO0tBQ2pCO0lBQ0Qsb0JBQW9CLEVBQUUsTUFBTTtJQUM1QixtQkFBbUIsRUFBRSxNQUFNO0lBQzNCLGlCQUFpQixFQUFFLE1BQU07SUFDekIsTUFBTSxFQUFFO1FBQ0osSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRTtZQUNILElBQUksRUFBRSxhQUFhO1lBQ25CLElBQUksRUFBRSxRQUFRO1NBQ2pCO0tBQ0o7SUFDRCxHQUFHLGtEQUEyQjtDQUNqQyxFQUNEO0lBQ0ksV0FBVyxFQUFFLEtBQUs7Q0FDckIsQ0FDSixDQUFDO0FBRVcsUUFBQSxlQUFlLEdBQUcsbUJBQVMsQ0FBQyxLQUFLLENBQzFDLDhCQUFzQixFQUN0QixnQkFBZ0IsRUFDaEI7SUFDSSxNQUFNLEVBQUUsS0FBSztJQUNiLGFBQWEsRUFBRSxLQUFLO0NBQ3ZCLENBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkeW5hbW9vc2UgZnJvbSBcImR5bmFtb29zZVwiO1xuaW1wb3J0IHsgcmFuZG9tVVVJRCB9IGZyb20gXCJjcnlwdG9cIjtcbmltcG9ydCB7IEJBU0VfRFlOQU1PT1NFX0FVRElUX1NDSEVNQSwgQmFzZUR5bmFtb29zZU1vZGVsIH0gZnJvbSBcIi4uLy4uL2Jhc2UtZHluYW1vb3NlLW1vZGVsXCI7XG5cbmV4cG9ydCBjb25zdCBQTEFUVEVSX0ZJVF9UQUJMRV9OQU1FID0gXCJQbGF0dGVyRml0VGFibGVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQbGF0dGVyRml0IGV4dGVuZHMgQmFzZUR5bmFtb29zZU1vZGVsIHtcbiAgICBwbGF0dGVyRml0SWQ6IHN0cmluZztcbiAgICBvY2Nhc2lvbk5hbWU6IHN0cmluZztcbiAgICBvY2Nhc2lvblR5cGU6IHN0cmluZztcbiAgICBvY2Nhc2lvblN1YlR5cGU/OiBzdHJpbmc7XG4gICAgbWluUGF4OiBudW1iZXI7XG4gICAgbWF4UGF4OiBudW1iZXI7XG4gICAgYnVkZ2V0VGllcjogc3RyaW5nO1xuICAgIHJhbms6IG51bWJlcjtcbiAgICByYW5rVGFnPzogc3RyaW5nO1xuICAgIHBsYXR0ZXJJZDogc3RyaW5nO1xuICAgIHBsYXR0ZXJOYW1lOiBzdHJpbmc7XG4gICAgYnVja2V0UGF4RGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgb2NjYXNpb25EZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBvdGhlcnNEZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBzdGF0dXM6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgQ3JlYXRlUGxhdHRlckZpdElucHV0ID0gT21pdDxQbGF0dGVyRml0LCBcInBsYXR0ZXJGaXRJZFwiPiAmIHtcbiAgICBwbGF0dGVyRml0SWQ/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBwbGF0dGVyRml0U2NoZW1hID0gbmV3IGR5bmFtb29zZS5TY2hlbWEoXG4gICAge1xuICAgICAgICBwbGF0dGVyRml0SWQ6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIGhhc2hLZXk6IHRydWUsXG4gICAgICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgICAgIGRlZmF1bHQ6ICgpID0+IHJhbmRvbVVVSUQoKVxuICAgICAgICB9LFxuICAgICAgICBvY2Nhc2lvbk5hbWU6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIG9jY2FzaW9uVHlwZToge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgICAgICBpbmRleDoge1xuICAgICAgICAgICAgICAgIG5hbWU6IFwib2NjYXNpb25UeXBlSW5kZXhcIixcbiAgICAgICAgICAgICAgICB0eXBlOiBcImdsb2JhbFwiXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIG9jY2FzaW9uU3ViVHlwZTogU3RyaW5nLFxuICAgICAgICBtaW5QYXg6IHtcbiAgICAgICAgICAgIHR5cGU6IE51bWJlcixcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIG1heFBheDoge1xuICAgICAgICAgICAgdHlwZTogTnVtYmVyLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgYnVkZ2V0VGllcjoge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgcmFuazoge1xuICAgICAgICAgICAgdHlwZTogTnVtYmVyLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgcmFua1RhZzogU3RyaW5nLFxuICAgICAgICBwbGF0dGVySWQ6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICAgICAgaW5kZXg6IHtcbiAgICAgICAgICAgICAgICBuYW1lOiBcInBsYXR0ZXJJZEluZGV4XCIsXG4gICAgICAgICAgICAgICAgdHlwZTogXCJnbG9iYWxcIlxuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBwbGF0dGVyTmFtZToge1xuICAgICAgICAgICAgdHlwZTogU3RyaW5nLFxuICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgYnVja2V0UGF4RGVzY3JpcHRpb246IFN0cmluZyxcbiAgICAgICAgb2NjYXNpb25EZXNjcmlwdGlvbjogU3RyaW5nLFxuICAgICAgICBvdGhlcnNEZXNjcmlwdGlvbjogU3RyaW5nLFxuICAgICAgICBzdGF0dXM6IHtcbiAgICAgICAgICAgIHR5cGU6IFN0cmluZyxcbiAgICAgICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICAgICAgaW5kZXg6IHtcbiAgICAgICAgICAgICAgICBuYW1lOiBcInN0YXR1c0luZGV4XCIsXG4gICAgICAgICAgICAgICAgdHlwZTogXCJnbG9iYWxcIlxuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICAuLi5CQVNFX0RZTkFNT09TRV9BVURJVF9TQ0hFTUFcbiAgICB9LFxuICAgIHtcbiAgICAgICAgc2F2ZVVua25vd246IGZhbHNlXG4gICAgfVxuKTtcblxuZXhwb3J0IGNvbnN0IFBsYXR0ZXJGaXRNb2RlbCA9IGR5bmFtb29zZS5tb2RlbChcbiAgICBQTEFUVEVSX0ZJVF9UQUJMRV9OQU1FLFxuICAgIHBsYXR0ZXJGaXRTY2hlbWEsXG4gICAge1xuICAgICAgICBjcmVhdGU6IGZhbHNlLFxuICAgICAgICB3YWl0Rm9yQWN0aXZlOiBmYWxzZVxuICAgIH1cbik7XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cmp-aws-database",
3
- "version": "1.7.1-dev.25",
3
+ "version": "1.7.1-dev.27",
4
4
  "bin": {
5
5
  "craft-my-plate-database": "bin/craft-my-plate-database.js"
6
6
  },