Subversion Repositories SmartDukaan

Rev

Rev 35067 | Rev 35192 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
30725 amit.gupta 1
$(function () {
31274 amit.gupta 2
    //Price change handler
33149 ranu 3
    $(document).on('change', "form#cd input.unitPrice, form#cd input.discount", function () {
4
        var $row = $(this).closest('tr'); // Get the closest <tr> parent of the changed input
33437 ranu 5
        var unitPrice = parseFloat($row.find('input.unitPrice').val());
24440 amit.gupta 6
 
31274 amit.gupta 7
        if (isNaN(unitPrice)) {
8
            unitPrice = 0;
9
        }
33149 ranu 10
        var discount = parseFloat($row.find('input.discount').val());
11
        var maxDiscount = parseFloat($row.find('input.discount').data('maxdiscount'));
31274 amit.gupta 12
        if (isNaN(discount)) {
13
            discount = 0;
14
        }
15
        if (isNaN(maxDiscount)) {
16
            maxDiscount = 0;
17
        }
18
        if (discount > maxDiscount) {
33149 ranu 19
            alert("Discount can't be greater than max Discount");
20
            $row.find('input.discount').val(maxDiscount);
31274 amit.gupta 21
            $(this).focus();
22
            return;
23
        }
24
        if (unitPrice < 0 || (unitPrice > 0 && unitPrice - discount < 0)) {
25
            alert("Invalid unit/discount price");
26
            $(this).focus();
27
            return;
28
        }
32468 amit.gupta 29
        let lines = $("#order-items").find('tbody>tr:gt(0)').length;
30
        if (lines > 3) {
33149 ranu 31
            calculateTotalAmount($row);
32469 amit.gupta 32
        } else {
33
            calculateTotalAmount();
32468 amit.gupta 34
        }
33149 ranu 35
        $row.find('.mk_check_plans').trigger('click', ['manual']); // Trigger the button within the same row
31274 amit.gupta 36
    });
30725 amit.gupta 37
 
33795 ranu 38
    $(document).on('click', ".upgrade-offer", function () {
39
        var itemId = $(this).data('itemid');
40
        doGetAjaxRequestHandler(`${context}/getItemWiseUpgradeOffer?itemId=` + itemId, function (response) {
41
            $('#upgradeOfferModal .modal-content').html(response);
42
        });
43
    });
30725 amit.gupta 44
 
33149 ranu 45
 
31274 amit.gupta 46
    $(document).on('change', "form#cd input.insuranceamount", function () {
47
        calculateTotalAmount();
48
    });
30725 amit.gupta 49
 
31274 amit.gupta 50
    $(document).on('click', ".create-order", function () {
51
        checkout("main-content");
52
    });
30725 amit.gupta 53
 
31274 amit.gupta 54
    $(document).on('click', ".mk_check_plans", function (event, source) {
33149 ranu 55
        console.log("checkPlansssssss99999");
32434 amit.gupta 56
        let lines = $("#order-items").find('tbody>tr:gt(0)').length;
32414 amit.gupta 57
        if (lines > 3) {
58
            //No need to check plans
59
            return;
60
        }
31274 amit.gupta 61
        $('div.itemdetails').find('input').val('');
62
        let price = mop;
63
        var mop = parseFloat($(this).data("mop"));
64
        var sellingPrice = $(this).val();
65
        var itemId = $(this).closest(".input-group").find("input.insuranceamount").attr("itemid");
66
        if (!isNaN(sellingPrice) && parseFloat(sellingPrice) >= mop) {
67
            price = parseFloat(sellingPrice);
68
        } else {
69
            price = mop;
70
        }
33437 ranu 71
        var poiId = parseFloat($(this).closest("tr").find("input.poiId").val());
31274 amit.gupta 72
        var discount = parseFloat($(this).closest("tr").find("input.discount").val());
73
        if (!isNaN(discount)) {
74
            price = price - discount;
75
        }
76
        let that = this;
33437 ranu 77
        doGetAjaxRequestHandler(`${context}/checkplans?price=${price}&itemId=${itemId}&poiId=${poiId}`, function (response) {
31274 amit.gupta 78
            var obj = JSON.parse(response);
79
            if (obj != null) {
34798 ranu 80
                getInsurancePlansModal(obj, that, price, itemId);
31274 amit.gupta 81
                return;
82
            } else {
83
                if (typeof source === "undefined") {
84
                    alert("Product is not eligible for insurance");
85
                }
86
            }
87
        });
88
    });
30725 amit.gupta 89
 
22245 ashik.ali 90
});
23343 ashik.ali 91
 
31274 amit.gupta 92
class InsuranceElement extends React.Component {
35098 ranu 93
 
31274 amit.gupta 94
    planChecked;
23343 ashik.ali 95
 
31274 amit.gupta 96
    constructor(props) {
97
        super(props);
34798 ranu 98
        this.state = {
99
            quotedPlans: {}
100
        };
31274 amit.gupta 101
    }
24440 amit.gupta 102
 
31274 amit.gupta 103
    render() {
104
        console.log(this.props);
105
        return <table className="table table-sm">
106
            <thead>
107
            <tr>
108
                <th>Plan Name</th>
109
                <th>Duration</th>
110
                <th>DP</th>
111
                <th>Selling Price</th>
112
                <th>Action</th>
113
            </tr>
114
            </thead>
115
            <tbody>
116
            {Object.keys(this.props.plans).map((planName, i) =>
34798 ranu 117
                this.props.plans[planName].map((plan, j) => {
118
                    const quoted = this.state.quotedPlans[plan.productId];
119
                    const isQuoted = !!quoted;
120
                    const displayPremium = isQuoted ? quoted.premium : (plan.premium || 0);
34805 ranu 121
                    const displayDP = isQuoted ? quoted.dp : (plan.dp || 0);
34798 ranu 122
 
123
                    return (
124
                        <tr key={`${i}-${j}`}>
35098 ranu 125
                            <td>
126
                                {plan.providerId == 6 ? (
127
                                    <img
128
                                        src="/resources/images/ProtectPlusLogo2.jpg"
129
                                        style={{height: "70px", marginLeft: "5px"}}
130
                                    />
131
                                ) : (
132
                                    planName
133
                                )}
134
 
135
                            </td>
136
 
34798 ranu 137
                            <td>{plan.duration}</td>
138
                            <td>{displayDP ? displayDP.toFixed(2) : "-"}</td>
139
                            <td>{displayPremium ? displayPremium.toFixed(2) : "-"}</td>
140
 
141
                            <td>
142
                                {isQuoted || (plan.dp > 0 && plan.premium > 0) ? (
143
                                    <button
144
                                        className="btn btn-primary"
145
                                        data-key={plan.productId}
146
                                        data-amount={isQuoted ? quoted.premium.toFixed(2) : plan.premium.toFixed(2)}
35067 ranu 147
                                        data-correlationid={isQuoted ? quoted.correlationId : plan.correlationId}
34798 ranu 148
                                        onClick={this.planChecked}
149
                                    >
150
                                        Add
151
                                    </button>
152
                                ) : (
35002 ranu 153
                                    <button className="btn btn-warning"
154
                                            onClick={(e) => this.checkQuote(e, plan, planName)}>
34798 ranu 155
                                        Check Quote
156
                                    </button>
157
                                )}
158
                            </td>
159
                        </tr>
160
                    );
161
                })
162
            )}
31274 amit.gupta 163
            </tbody>
34798 ranu 164
 
31274 amit.gupta 165
        </table>;
166
    }
167
 
168
    planChecked = (e) => {
34798 ranu 169
        //debugger;
31274 amit.gupta 170
        let $itemDetails = $('div.itemdetails');
171
        if ($itemDetails.find('.dgram').val() === '') {
172
            bootbox.alert('Mobile RAM is required');
173
            return;
174
        }
175
        if ($itemDetails.find('.dgmemory').val() === '') {
176
            bootbox.alert('Mobile Memory is required');
177
            return;
178
        }
179
        if ($itemDetails.find('#dgmfgdate').val() === '') {
180
            bootbox.alert('Mobile Mfg Date is required');
181
            return;
182
        }
183
        let $orderItemRow = $(this.props.elePlanCheckedOn).closest('td');
184
        $orderItemRow.find('.insuranceid').val($(e.target).data('key'));
34798 ranu 185
        $orderItemRow.find('.correlationid').val($(e.target).data('correlationid'));
31274 amit.gupta 186
        $orderItemRow.find('.insuranceamount').val($(e.target).data('amount'));
187
        $orderItemRow.find('.ram').val($itemDetails.find('.dgram').val());
188
        $orderItemRow.find('.memory').val($itemDetails.find('.dgmemory').val());
34798 ranu 189
        // $orderItemRow.find('.mfgdate').val(window.mfgDate);
190
        $orderItemRow.find('.mfgdate').val($itemDetails.find('.dgmfgdate').val());
31274 amit.gupta 191
        $('#mobilePlansModal').modal('hide');
192
        calculateTotalAmount();
193
    }
34798 ranu 194
 
35002 ranu 195
    checkQuote = (e, plan, planName) => {
34798 ranu 196
        //debugger;
197
        let $itemDetails = $('div.itemdetails');
198
        if ($itemDetails.find('.dgram').val() === '') {
199
            bootbox.alert('Mobile RAM is required');
200
            return;
201
        }
202
        if ($itemDetails.find('.dgmemory').val() === '') {
203
            bootbox.alert('Mobile Memory is required');
204
            return;
205
        }
206
        if ($itemDetails.find('#dgmfgdate').val() === '') {
207
            bootbox.alert('Mobile Mfg Date is required');
208
            return;
209
        }
210
        let planCode = plan.productId;
211
        let manuFacturedDate = $itemDetails.find('.dgmfgdate').val();
35002 ranu 212
        this.calculateQuote(planCode, this.props.itemId, this.props.devicePrice, manuFacturedDate, planName);
34798 ranu 213
 
214
    }
215
 
35002 ranu 216
    calculateQuote = (planCode, itemId, devicePrice, manuFacturedDate, planName) => {
34798 ranu 217
        doGetAjaxRequestHandler(
35002 ranu 218
            `${context}/getPlanQuote?planCode=${planCode}&itemId=${itemId}&sumInsured=${devicePrice}&manufacturedDate=${manuFacturedDate}&planName=${planName}`,
34798 ranu 219
            (responseText) => {
220
                const response = JSON.parse(responseText);
221
                console.log("quote call back", response);
222
 
35002 ranu 223
                if (response.afinityQuoteModel.policyStatus === "APPROVE" || response.afinityQuoteModel.message === "Success") {
34798 ranu 224
                    const updatedPlan = {
34805 ranu 225
                        premium: response.afinityQuoteModel.totalPremium,
226
                        dp: response.planDp,
227
                        correlationId: response.afinityQuoteModel.correlationId
34798 ranu 228
                    };
229
 
230
                    this.setState((prevState) => ({
231
                        quotedPlans: {
232
                            ...prevState.quotedPlans,
233
                            [planCode]: updatedPlan
234
                        }
235
                    }));
236
                } else {
34805 ranu 237
                    bootbox.alert("Quote failed: " + (response.afinityQuoteModel.message || "Unknown error"));
34798 ranu 238
                }
239
            }
240
        );
241
    }
24440 amit.gupta 242
}
243
 
31274 amit.gupta 244
let reactRoot = null;
24440 amit.gupta 245
 
34798 ranu 246
function getInsurancePlansModal(insurancePlans, elePlanCheckedOn, devicePrice, itemId) {
31274 amit.gupta 247
    const domContainer = document.querySelector('.insurancedetails');
248
    reactRoot = ReactDOM.createRoot(domContainer);
34798 ranu 249
    reactRoot.render(<InsuranceElement plans={insurancePlans} elePlanCheckedOn={elePlanCheckedOn}
250
                                       devicePrice={devicePrice} itemId={itemId}/>)
31274 amit.gupta 251
    $('#mobilePlansModal').modal({show: true});
252
 
253
}
254
 
255
 
32468 amit.gupta 256
function calculateTotalAmount(inputEle) {
257
    if (typeof inputEle !== "undefined") {
258
        let itemId = $(inputEle).attr("itemid");
259
        let unitPrice = inputEle.value;
260
        $("#order-items").find(`input.unitPrice[itemid=${itemId}]`).each(function () {
261
            this.value = unitPrice;
262
        })
263
 
264
    }
31274 amit.gupta 265
    var netPayableAmount = 0;
266
    var totaInsuranceAmount = 0;
32329 amit.gupta 267
    $("#order-items").find('tbody>tr:gt(0)').each(function (index, el) {
31274 amit.gupta 268
        var rowTotal = 0;
269
        let $tr = $(el);
270
        var insuranceAmount = $tr.find('input.insuranceamount').val();
271
        if (isNaN(insuranceAmount)) {
272
            insuranceAmount = 0;
273
        } else {
274
            insuranceAmount = parseFloat(insuranceAmount);
275
        }
30725 amit.gupta 276
 
31274 amit.gupta 277
        var quantity = parseFloat($(el).find('.unitPrice').attr('quantity'));
30725 amit.gupta 278
 
31274 amit.gupta 279
        var unitPrice = parseFloat($(el).find('.unitPrice').val());
280
        if (isNaN(unitPrice)) {
281
            unitPrice = 0;
282
        }
30725 amit.gupta 283
 
31274 amit.gupta 284
        var discount = $(el).find('.discount').val();
285
        if (isNaN(discount)) {
286
            discount = 0;
287
        }
23343 ashik.ali 288
 
32329 amit.gupta 289
        rowTotal = (unitPrice - discount + insuranceAmount) * quantity;
31274 amit.gupta 290
        $tr.find('.totalPrice').val(rowTotal);
291
        netPayableAmount += rowTotal;
292
        totaInsuranceAmount += insuranceAmount;
293
    });
294
    if (totaInsuranceAmount > 0) {
295
        $(".mk_insurance_row").show();
296
    } else {
297
        $(".mk_insurance_row").hide();
298
    }
299
    $('#cd').find('input.netPayableAmount').val(netPayableAmount);
23343 ashik.ali 300
}
33795 ranu 301
 
302
$(document).on('change', '.offerSelect', function () {
303
    calculateAndUpdatePaymentOptions();
304
});
305
 
306
function calculateAndUpdatePaymentOptions() {
307
    let totalSchemePayout = 0;
308
    let totalPartnerPayout = 0;
309
 
310
    // Loop through all selected options in each row
311
    $('.offerSelect').each(function () {
312
        let selectedOption = $(this).find('option:selected');
313
 
314
        let schemePayout = parseFloat(selectedOption.data('scheme-payout')) || 0;
315
        let partnerPayout = parseFloat(selectedOption.data('partner-payout')) || 0;
316
 
317
        // Accumulate the payouts
318
        totalSchemePayout += schemePayout;
319
        totalPartnerPayout += partnerPayout;
320
    });
321
 
322
    // Now update the payment options with the accumulated values
323
    updatePaymentOptions(totalSchemePayout, totalPartnerPayout);
324
}
325
 
326
function updatePaymentOptions(schemePayout, partnerPayout) {
327
    $("#payment-option-id-amount-container").find('.paymentOptionAmount').each(function () {
328
        let paymentOptionName = $(this).closest('.row').find('h5').text().trim();
329
 
330
        if (paymentOptionName.includes('SAMSUNG UPGRADE')) {
331
            $(this).val(schemePayout);  // Set the total scheme payout
332
        }
333
 
35055 ranu 334
        // if (paymentOptionName.includes('CASH DISCOUNT')) {
335
        //     $(this).val(partnerPayout);  // Set the total partner payout
336
        // }
33795 ranu 337
    });
338
}
339
 
34168 tejus.loha 340
$(document).on('click', '.reset-irn-generated-panel', function () {
341
    getResetIrnGeneratedPanel();
342
});
33795 ranu 343
 
34168 tejus.loha 344
$(document).on('click', '#search-invoice-for-irn-reset', function () {
345
    var invoiceNumber = $("#search-invoice-number").val();
346
    if (!invoiceNumber) {
347
        alert("Please enter Invoice Number");
348
        return;
349
    }
350
    doGetAjaxRequestHandler(`${context}/getTransactionForIrnReset?invoiceNumber=${invoiceNumber}`, function (response) {
351
        $('#transaction-for-reset-irn-container').html(response);
352
    });
353
});
33795 ranu 354
 
34168 tejus.loha 355
$(document).on('click', '#reset-irn-button', function () {
356
    if (confirm("Are you sure to Reset IRN")) {
357
        let invoices = [];
358
        $('#eligible-irn-order tbody tr').each(function () {
359
            const invoiceNumber = $(this).find('td:nth-child(3)').text();
360
            invoices.push(invoiceNumber);
361
        });
362
        const invoiceNumbers = invoices.join(', ');
363
        console.log('invoiceNumbersString - ', invoiceNumbers)
364
        let url = `${context}/resetOrdersIrn?invoiceNumbers=${invoiceNumbers}`
365
        doPutAjaxRequestHandler(url, function (response) {
366
            if (response) {
367
                alert(`IRN reset successfully for Invoice No - ${invoiceNumbers}`);
368
                getResetIrnGeneratedPanel();
369
            }
370
        });
371
    }
372
});
33795 ranu 373
 
34168 tejus.loha 374
function getResetIrnGeneratedPanel() {
375
    doGetAjaxRequestHandler(`${context}/resetIrnGeneratedPanel`, function (response) {
376
        $('#main-content').html(response);
377
    });
378
}
33795 ranu 379
 
380
 
381
 
34168 tejus.loha 382
 
383
 
384
 
385