cmp-aws-database 1.2.0-dev.126 → 1.2.0-dev.128
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/customer-user/cart/cart-model.d.ts +2 -0
- package/dist/customer-user/cart/cart-model.js +9 -1
- package/dist/customer-user/order-module/payment/payment-dao.d.ts +8 -0
- package/dist/customer-user/order-module/payment/payment-dao.js +22 -1
- package/dist/customer-user/order-module/plate-order/plateOrderDao.d.ts +8 -0
- package/dist/customer-user/order-module/plate-order/plateOrderDao.js +22 -1
- package/package.json +1 -1
|
@@ -220,7 +220,15 @@ __decorate([
|
|
|
220
220
|
(0, annotations_1.attribute)(),
|
|
221
221
|
__metadata("design:type", Boolean)
|
|
222
222
|
], CartModel.prototype, "isFMPCreated", void 0);
|
|
223
|
+
__decorate([
|
|
224
|
+
(0, annotations_1.attribute)(),
|
|
225
|
+
__metadata("design:type", Number)
|
|
226
|
+
], CartModel.prototype, "helperCount", void 0);
|
|
227
|
+
__decorate([
|
|
228
|
+
(0, annotations_1.attribute)(),
|
|
229
|
+
__metadata("design:type", String)
|
|
230
|
+
], CartModel.prototype, "cateringServiceType", void 0);
|
|
223
231
|
exports.CartModel = CartModel = __decorate([
|
|
224
232
|
(0, annotations_1.table)("CartTable")
|
|
225
233
|
], CartModel);
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart-model.js","sourceRoot":"","sources":["../../../src/customer-user/cart/cart-model.ts"],"names":[],"mappings":"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","sourcesContent":["import { attribute, hashKey, rangeKey, table } from \"@nova-odm/annotations\"\nimport { BaseModel } from \"../../base-model\";\n\n\nexport class GuestCount {\n    @attribute()\n    vegGuestCount: number;\n    @attribute()\n    nonVegGuestCount: number;\n    @attribute()\n    totalGuestCount?: number;\n}\n\nexport interface AddOnsDetails {\n    addOnsId: string;\n    addOnsQty: number;\n    addOnsQtyUnit: string;\n    isBonelessItem?: boolean; // V2\n    boneItemPrice?: number; // V2\n    accompaniments?: AccompanimentsDetails[];\n}\n\nexport interface AccompanimentsDetails {\n    accompanimentId: string;\n    accompanimentQty: number;\n    accompanimentQtyUnit: string;\n    isFree?: boolean; // Added New 11-11-2025\n    isBonelessItem?: boolean; // Added New 11-11-2025\n    boneItemPrice?: number; // Added New 11-11-2025\n}\n\nexport interface CutleryDetails {\n    cutleryId: string; // Added New 24-11-2025\n    cutleryQty: number; // Added New 24-11-2025\n    isServing?: boolean; // Added New 24-11-2025 // true | false\n}\n\n\n\nexport class SetPreferences {\n    @attribute()\n    pureVegGuest?: number; // In Future they should be removed.\n    @attribute()\n    spicyLevel?: string;\n    @attribute()\n    tellUsMore?: string;\n    @attribute()\n    consumeAlcohol?: string; // In Future they should be removed.\n}\n\nexport class BbqCredential {\n    @attribute()\n    isPartialGrill: boolean;\n    @attribute()\n    freeKits: number;\n    @attribute()\n    chargeableKits: number;\n    @attribute()\n    pricePerKit: number;\n}\n\n@table(\"CartTable\")\nexport class CartModel extends BaseModel {\n    @hashKey({ type: 'String' })\n    userId: string;\n    @rangeKey({ type: 'String' })\n    cartId: string;\n    @attribute()\n    platterType?: string;\n    @attribute({ indexKeyConfigurations: { \"cartStatusIndex\": \"HASH\" }, type: 'String' })\n    cartStatus: string; // ACTIVE, INACTIVE, INDRAFT\n    @attribute({ indexKeyConfigurations: { \"cartStageIndex\": \"HASH\" }, type: 'String' })\n    cartStage: string; // DETAILS_NOT_FILLED, COMPLETED, ITEM_NOT_FILLED, MISSTING_DATE_TIME\n    @attribute({ indexKeyConfigurations: { \"phoneNumberIndex\": \"HASH\" }, type: 'String' })\n    phoneNumber: string;\n    @attribute()\n    occasionId?: string; // Think Again\n    @attribute()\n    cartName: string; // by default Custom Platter or Choice of Users based on their changes\n    @attribute()\n    cartImage?: string;\n    @attribute()\n    defaultPlatterId?: string;\n    @attribute()\n    cartCategoriesId?: string;\n    @attribute()\n    addressId?: string;\n    @attribute()\n    addonsId?: string[]; // Remove After This Build gone\n    @attribute()\n    couponCode?: string; // Remove After This Build gone\n    @attribute()\n    guestCount?: number; // Remove After This Build gone\n    @attribute()\n    addonsIds?: AddOnsDetails[]; // previoully they show only addonsId\n    // @attribute()\n    // cutleryIds?: string[];\n    @attribute()\n    cutleryIds?: CutleryDetails[]; // Added New 24-11-2025\n    @attribute()\n    guestCounts?: GuestCount; // previoully they show only guestCount as a number\n    @attribute()\n    selectedServiceType?: string;\n    @attribute()\n    eventDate?: string;\n    @attribute()\n    eventTime?: string;\n    @attribute()\n    minPrice?: number; // Remove After This Build gone\n    @attribute()\n    maxPrice?: number; // Remove After This Build gone\n    @attribute()\n    doorStepService: string; // Remove After This Build gone\n    @attribute()\n    deliveryService: string; // STANDARD, DOORSTEP, PREMIUM\n    @attribute()\n    setPreferences?: SetPreferences[];\n    @attribute()\n    createOwn?: boolean;\n    @attribute()\n    menuType?: string;\n    @attribute()\n    mealTime?: string;\n    @attribute()\n    platterSubType?: string; // \"DISCOUNTED\", \"REGULAR\", \"CREATE_OWN\"\n    @attribute()\n    platterMinPrice?: number; // New Added 10-09-2025\n    @attribute()\n    addonsAccompanimentsCost?: number; // New Added 10-09-2025\n    @attribute()\n    extraQtyCost?: number; // New Added 10-09-2025\n    @attribute()\n    premiumItemsCost?: number; // New Added 10-09-2025\n    @attribute()\n    cutleryCost?: number; // New Added 10-09-2025\n    @attribute()\n    bbqCredential?: BbqCredential; // New Added 11-12-2025\n    @attribute()\n    bbqGuidelines?: boolean; // New Added 22-12-2025\n    @attribute()\n    isFMPCreated?: boolean; // New Added 06-03-2026\n\n    @attribute()\n    helperCount?: number;\n    @attribute()\n    cateringServiceType?: string;\n\n}"]}
|
|
@@ -1,6 +1,14 @@
|
|
|
1
1
|
import { GenericDAO } from "../../../base-dao";
|
|
2
2
|
import { PaymentModel } from "./payment-model";
|
|
3
3
|
declare class PaymentDAO extends GenericDAO<PaymentModel> {
|
|
4
|
+
/**
|
|
5
|
+
* Fetches all payment records for a given order using the `orderIndex` GSI.
|
|
6
|
+
* The mapper may return multiple pages; this method aggregates them into one array.
|
|
7
|
+
*
|
|
8
|
+
* @param orderId - Order identifier (hash key on `orderIndex`)
|
|
9
|
+
* @returns All `PaymentModel` rows for that order (may be empty)
|
|
10
|
+
*/
|
|
11
|
+
getPaymentByOrderId: (orderId: string) => Promise<PaymentModel[]>;
|
|
4
12
|
}
|
|
5
13
|
export declare const paymentDao: PaymentDAO;
|
|
6
14
|
export {};
|
|
@@ -2,7 +2,28 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.paymentDao = void 0;
|
|
4
4
|
const base_dao_1 = require("../../../base-dao");
|
|
5
|
+
const payment_model_1 = require("./payment-model");
|
|
5
6
|
class PaymentDAO extends base_dao_1.GenericDAO {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
/**
|
|
10
|
+
* Fetches all payment records for a given order using the `orderIndex` GSI.
|
|
11
|
+
* The mapper may return multiple pages; this method aggregates them into one array.
|
|
12
|
+
*
|
|
13
|
+
* @param orderId - Order identifier (hash key on `orderIndex`)
|
|
14
|
+
* @returns All `PaymentModel` rows for that order (may be empty)
|
|
15
|
+
*/
|
|
16
|
+
this.getPaymentByOrderId = async (orderId) => {
|
|
17
|
+
const payments = [];
|
|
18
|
+
// Query by orderId on the orderIndex secondary index
|
|
19
|
+
const paymentPaginator = base_dao_1.mapper.query(payment_model_1.PaymentModel, { orderId: orderId }, { indexName: "orderIndex" });
|
|
20
|
+
// Drain async iterator (handles pagination under the hood)
|
|
21
|
+
for await (const payment of paymentPaginator) {
|
|
22
|
+
payments.push(payment);
|
|
23
|
+
}
|
|
24
|
+
return payments;
|
|
25
|
+
};
|
|
26
|
+
}
|
|
6
27
|
}
|
|
7
28
|
exports.paymentDao = new PaymentDAO();
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC1kYW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY3VzdG9tZXItdXNlci9vcmRlci1tb2R1bGUvcGF5bWVudC9wYXltZW50LWRhby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxnREFBdUQ7QUFDdkQsbURBQStDO0FBRS9DLE1BQU0sVUFBVyxTQUFRLHFCQUF3QjtJQUFqRDs7UUFFSTs7Ozs7O1dBTUc7UUFDSCx3QkFBbUIsR0FBRyxLQUFLLEVBQUUsT0FBZSxFQUEyQixFQUFFO1lBQ3JFLE1BQU0sUUFBUSxHQUFtQixFQUFFLENBQUM7WUFDcEMscURBQXFEO1lBQ3JELE1BQU0sZ0JBQWdCLEdBQUcsaUJBQU0sQ0FBQyxLQUFLLENBQUMsNEJBQVksRUFBRSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO1lBRXZHLDJEQUEyRDtZQUMzRCxJQUFJLEtBQUssRUFBRSxNQUFNLE9BQU8sSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO2dCQUMzQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQXVCLENBQUMsQ0FBQztZQUMzQyxDQUFDO1lBQ0QsT0FBTyxRQUFRLENBQUM7UUFDcEIsQ0FBQyxDQUFBO0lBRUwsQ0FBQztDQUFBO0FBRVksUUFBQSxVQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdlbmVyaWNEQU8sIG1hcHBlciB9IGZyb20gXCIuLi8uLi8uLi9iYXNlLWRhb1wiO1xuaW1wb3J0IHsgUGF5bWVudE1vZGVsIH0gZnJvbSBcIi4vcGF5bWVudC1tb2RlbFwiO1xuXG5jbGFzcyBQYXltZW50REFPIGV4dGVuZHMgR2VuZXJpY0RBTzxQYXltZW50TW9kZWw+IHtcblxuICAgIC8qKlxuICAgICAqIEZldGNoZXMgYWxsIHBheW1lbnQgcmVjb3JkcyBmb3IgYSBnaXZlbiBvcmRlciB1c2luZyB0aGUgYG9yZGVySW5kZXhgIEdTSS5cbiAgICAgKiBUaGUgbWFwcGVyIG1heSByZXR1cm4gbXVsdGlwbGUgcGFnZXM7IHRoaXMgbWV0aG9kIGFnZ3JlZ2F0ZXMgdGhlbSBpbnRvIG9uZSBhcnJheS5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBvcmRlcklkIC0gT3JkZXIgaWRlbnRpZmllciAoaGFzaCBrZXkgb24gYG9yZGVySW5kZXhgKVxuICAgICAqIEByZXR1cm5zIEFsbCBgUGF5bWVudE1vZGVsYCByb3dzIGZvciB0aGF0IG9yZGVyIChtYXkgYmUgZW1wdHkpXG4gICAgICovXG4gICAgZ2V0UGF5bWVudEJ5T3JkZXJJZCA9IGFzeW5jIChvcmRlcklkOiBzdHJpbmcpOiBQcm9taXNlPFBheW1lbnRNb2RlbFtdPiA9PiB7XG4gICAgICAgIGNvbnN0IHBheW1lbnRzOiBQYXltZW50TW9kZWxbXSA9IFtdO1xuICAgICAgICAvLyBRdWVyeSBieSBvcmRlcklkIG9uIHRoZSBvcmRlckluZGV4IHNlY29uZGFyeSBpbmRleFxuICAgICAgICBjb25zdCBwYXltZW50UGFnaW5hdG9yID0gbWFwcGVyLnF1ZXJ5KFBheW1lbnRNb2RlbCwgeyBvcmRlcklkOiBvcmRlcklkIH0sIHsgaW5kZXhOYW1lOiBcIm9yZGVySW5kZXhcIiB9KTtcblxuICAgICAgICAvLyBEcmFpbiBhc3luYyBpdGVyYXRvciAoaGFuZGxlcyBwYWdpbmF0aW9uIHVuZGVyIHRoZSBob29kKVxuICAgICAgICBmb3IgYXdhaXQgKGNvbnN0IHBheW1lbnQgb2YgcGF5bWVudFBhZ2luYXRvcikge1xuICAgICAgICAgICAgcGF5bWVudHMucHVzaChwYXltZW50IGFzIFBheW1lbnRNb2RlbCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHBheW1lbnRzO1xuICAgIH1cblxufVxuXG5leHBvcnQgY29uc3QgcGF5bWVudERhbyA9IG5ldyBQYXltZW50REFPKCk7Il19
|
|
@@ -1,6 +1,14 @@
|
|
|
1
1
|
import { GenericDAO } from "../../../base-dao";
|
|
2
2
|
import { PlateModel } from "./plate-order-model";
|
|
3
3
|
declare class PlateOrderDAO extends GenericDAO<PlateModel> {
|
|
4
|
+
/**
|
|
5
|
+
* Fetches all plate (line-item) records for a given order using the `orderIndex` GSI.
|
|
6
|
+
* Results are paginated by the mapper; this method collects every page into a single array.
|
|
7
|
+
*
|
|
8
|
+
* @param orderId - Parent order identifier (hash key on `orderIndex`)
|
|
9
|
+
* @returns All `PlateModel` rows linked to that order
|
|
10
|
+
*/
|
|
11
|
+
getPlateOrdersByOrderId: (orderId: string) => Promise<PlateModel[]>;
|
|
4
12
|
}
|
|
5
13
|
export declare const plateOrderDAO: PlateOrderDAO;
|
|
6
14
|
export {};
|
|
@@ -2,7 +2,28 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.plateOrderDAO = void 0;
|
|
4
4
|
const base_dao_1 = require("../../../base-dao");
|
|
5
|
+
const plate_order_model_1 = require("./plate-order-model");
|
|
5
6
|
class PlateOrderDAO extends base_dao_1.GenericDAO {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
/**
|
|
10
|
+
* Fetches all plate (line-item) records for a given order using the `orderIndex` GSI.
|
|
11
|
+
* Results are paginated by the mapper; this method collects every page into a single array.
|
|
12
|
+
*
|
|
13
|
+
* @param orderId - Parent order identifier (hash key on `orderIndex`)
|
|
14
|
+
* @returns All `PlateModel` rows linked to that order
|
|
15
|
+
*/
|
|
16
|
+
this.getPlateOrdersByOrderId = async (orderId) => {
|
|
17
|
+
const plates = [];
|
|
18
|
+
// Query by orderId on the orderIndex secondary index
|
|
19
|
+
const platePaginator = base_dao_1.mapper.query(plate_order_model_1.PlateModel, { orderId: orderId }, { indexName: "orderIndex" });
|
|
20
|
+
// Drain async iterator (handles pagination under the hood)
|
|
21
|
+
for await (const plate of platePaginator) {
|
|
22
|
+
plates.push(plate);
|
|
23
|
+
}
|
|
24
|
+
return plates;
|
|
25
|
+
};
|
|
26
|
+
}
|
|
6
27
|
}
|
|
7
28
|
exports.plateOrderDAO = new PlateOrderDAO();
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdGVPcmRlckRhby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jdXN0b21lci11c2VyL29yZGVyLW1vZHVsZS9wbGF0ZS1vcmRlci9wbGF0ZU9yZGVyRGFvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQUF1RDtBQUN2RCwyREFBaUQ7QUFFakQsTUFBTSxhQUFjLFNBQVEscUJBQXNCO0lBQWxEOztRQUVJOzs7Ozs7V0FNRztRQUNILDRCQUF1QixHQUFHLEtBQUssRUFBRSxPQUFlLEVBQXlCLEVBQUU7WUFDdkUsTUFBTSxNQUFNLEdBQWlCLEVBQUUsQ0FBQztZQUNoQyxxREFBcUQ7WUFDckQsTUFBTSxjQUFjLEdBQUcsaUJBQU0sQ0FBQyxLQUFLLENBQUMsOEJBQVUsRUFBRSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO1lBRW5HLDJEQUEyRDtZQUMzRCxJQUFJLEtBQUssRUFBRSxNQUFNLEtBQUssSUFBSSxjQUFjLEVBQUUsQ0FBQztnQkFDdkMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFtQixDQUFDLENBQUM7WUFDckMsQ0FBQztZQUNELE9BQU8sTUFBTSxDQUFDO1FBQ2xCLENBQUMsQ0FBQTtJQUVMLENBQUM7Q0FBQTtBQUNZLFFBQUEsYUFBYSxHQUFHLElBQUksYUFBYSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHZW5lcmljREFPLCBtYXBwZXIgfSBmcm9tIFwiLi4vLi4vLi4vYmFzZS1kYW9cIjtcbmltcG9ydCB7IFBsYXRlTW9kZWwgfSBmcm9tIFwiLi9wbGF0ZS1vcmRlci1tb2RlbFwiO1xuXG5jbGFzcyBQbGF0ZU9yZGVyREFPIGV4dGVuZHMgR2VuZXJpY0RBTzxQbGF0ZU1vZGVsPiB7XG5cbiAgICAvKipcbiAgICAgKiBGZXRjaGVzIGFsbCBwbGF0ZSAobGluZS1pdGVtKSByZWNvcmRzIGZvciBhIGdpdmVuIG9yZGVyIHVzaW5nIHRoZSBgb3JkZXJJbmRleGAgR1NJLlxuICAgICAqIFJlc3VsdHMgYXJlIHBhZ2luYXRlZCBieSB0aGUgbWFwcGVyOyB0aGlzIG1ldGhvZCBjb2xsZWN0cyBldmVyeSBwYWdlIGludG8gYSBzaW5nbGUgYXJyYXkuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gb3JkZXJJZCAtIFBhcmVudCBvcmRlciBpZGVudGlmaWVyIChoYXNoIGtleSBvbiBgb3JkZXJJbmRleGApXG4gICAgICogQHJldHVybnMgQWxsIGBQbGF0ZU1vZGVsYCByb3dzIGxpbmtlZCB0byB0aGF0IG9yZGVyXG4gICAgICovXG4gICAgZ2V0UGxhdGVPcmRlcnNCeU9yZGVySWQgPSBhc3luYyAob3JkZXJJZDogc3RyaW5nKTogUHJvbWlzZTxQbGF0ZU1vZGVsW10+ID0+IHtcbiAgICAgICAgY29uc3QgcGxhdGVzOiBQbGF0ZU1vZGVsW10gPSBbXTtcbiAgICAgICAgLy8gUXVlcnkgYnkgb3JkZXJJZCBvbiB0aGUgb3JkZXJJbmRleCBzZWNvbmRhcnkgaW5kZXhcbiAgICAgICAgY29uc3QgcGxhdGVQYWdpbmF0b3IgPSBtYXBwZXIucXVlcnkoUGxhdGVNb2RlbCwgeyBvcmRlcklkOiBvcmRlcklkIH0sIHsgaW5kZXhOYW1lOiBcIm9yZGVySW5kZXhcIiB9KTtcblxuICAgICAgICAvLyBEcmFpbiBhc3luYyBpdGVyYXRvciAoaGFuZGxlcyBwYWdpbmF0aW9uIHVuZGVyIHRoZSBob29kKVxuICAgICAgICBmb3IgYXdhaXQgKGNvbnN0IHBsYXRlIG9mIHBsYXRlUGFnaW5hdG9yKSB7XG4gICAgICAgICAgICBwbGF0ZXMucHVzaChwbGF0ZSBhcyBQbGF0ZU1vZGVsKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcGxhdGVzO1xuICAgIH1cblxufVxuZXhwb3J0IGNvbnN0IHBsYXRlT3JkZXJEQU8gPSBuZXcgUGxhdGVPcmRlckRBTygpOyJdfQ==
|