Subversion Repositories SmartDukaan

Rev

Rev 34798 | Rev 35002 | 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 {
93
    planChecked;
23343 ashik.ali 94
 
31274 amit.gupta 95
    constructor(props) {
96
        super(props);
34798 ranu 97
        this.state = {
98
            quotedPlans: {}
99
        };
31274 amit.gupta 100
    }
24440 amit.gupta 101
 
31274 amit.gupta 102
    render() {
103
        console.log(this.props);
104
        return <table className="table table-sm">
105
            <thead>
106
            <tr>
107
                <th>Plan Name</th>
108
                <th>Duration</th>
109
                <th>DP</th>
110
                <th>Selling Price</th>
111
                <th>Action</th>
112
            </tr>
113
            </thead>
114
            <tbody>
115
            {Object.keys(this.props.plans).map((planName, i) =>
34798 ranu 116
                this.props.plans[planName].map((plan, j) => {
117
                    const quoted = this.state.quotedPlans[plan.productId];
118
                    const isQuoted = !!quoted;
119
                    const displayPremium = isQuoted ? quoted.premium : (plan.premium || 0);
34805 ranu 120
                    const displayDP = isQuoted ? quoted.dp : (plan.dp || 0);
34798 ranu 121
 
122
                    return (
123
                        <tr key={`${i}-${j}`}>
124
                            <td>{planName}</td>
125
                            <td>{plan.duration}</td>
126
                            <td>{displayDP ? displayDP.toFixed(2) : "-"}</td>
127
                            <td>{displayPremium ? displayPremium.toFixed(2) : "-"}</td>
128
 
129
                            <td>
130
                                {isQuoted || (plan.dp > 0 && plan.premium > 0) ? (
131
                                    <button
132
                                        className="btn btn-primary"
133
                                        data-key={plan.productId}
134
                                        data-amount={isQuoted ? quoted.premium.toFixed(2) : plan.premium.toFixed(2)}
135
                                        data-correlationid={isQuoted ? quoted.correlationId : ''}
136
                                        onClick={this.planChecked}
137
                                    >
138
                                        Add
139
                                    </button>
140
                                ) : (
141
                                    <button className="btn btn-warning" onClick={(e) => this.checkQuote(e, plan)}>
142
                                        Check Quote
143
                                    </button>
144
                                )}
145
                            </td>
146
                        </tr>
147
                    );
148
                })
149
            )}
31274 amit.gupta 150
            </tbody>
34798 ranu 151
 
31274 amit.gupta 152
        </table>;
153
    }
154
 
155
    planChecked = (e) => {
34798 ranu 156
        //debugger;
31274 amit.gupta 157
        let $itemDetails = $('div.itemdetails');
158
        if ($itemDetails.find('.dgram').val() === '') {
159
            bootbox.alert('Mobile RAM is required');
160
            return;
161
        }
162
        if ($itemDetails.find('.dgmemory').val() === '') {
163
            bootbox.alert('Mobile Memory is required');
164
            return;
165
        }
166
        if ($itemDetails.find('#dgmfgdate').val() === '') {
167
            bootbox.alert('Mobile Mfg Date is required');
168
            return;
169
        }
170
        let $orderItemRow = $(this.props.elePlanCheckedOn).closest('td');
171
        $orderItemRow.find('.insuranceid').val($(e.target).data('key'));
34798 ranu 172
        $orderItemRow.find('.correlationid').val($(e.target).data('correlationid'));
31274 amit.gupta 173
        $orderItemRow.find('.insuranceamount').val($(e.target).data('amount'));
174
        $orderItemRow.find('.ram').val($itemDetails.find('.dgram').val());
175
        $orderItemRow.find('.memory').val($itemDetails.find('.dgmemory').val());
34798 ranu 176
        // $orderItemRow.find('.mfgdate').val(window.mfgDate);
177
        $orderItemRow.find('.mfgdate').val($itemDetails.find('.dgmfgdate').val());
31274 amit.gupta 178
        $('#mobilePlansModal').modal('hide');
179
        calculateTotalAmount();
180
    }
34798 ranu 181
 
182
    checkQuote = (e, plan) => {
183
        //debugger;
184
        let $itemDetails = $('div.itemdetails');
185
        if ($itemDetails.find('.dgram').val() === '') {
186
            bootbox.alert('Mobile RAM is required');
187
            return;
188
        }
189
        if ($itemDetails.find('.dgmemory').val() === '') {
190
            bootbox.alert('Mobile Memory is required');
191
            return;
192
        }
193
        if ($itemDetails.find('#dgmfgdate').val() === '') {
194
            bootbox.alert('Mobile Mfg Date is required');
195
            return;
196
        }
197
        let planCode = plan.productId;
198
        let manuFacturedDate = $itemDetails.find('.dgmfgdate').val();
199
        this.calculateQuote(planCode, this.props.itemId, this.props.devicePrice, manuFacturedDate);
200
 
201
    }
202
 
203
    calculateQuote = (planCode, itemId, devicePrice, manuFacturedDate) => {
204
        doGetAjaxRequestHandler(
205
            `${context}/getPlanQuote?planCode=${planCode}&itemId=${itemId}&sumInsured=${devicePrice}&manufacturedDate=${manuFacturedDate}`,
206
            (responseText) => {
207
                const response = JSON.parse(responseText);
208
                console.log("quote call back", response);
209
 
34805 ranu 210
                if (response.afinityQuoteModel.statusMessage === "Success" && response.afinityQuoteModel.policyStatus === "APPROVE") {
34798 ranu 211
                    const updatedPlan = {
34805 ranu 212
                        premium: response.afinityQuoteModel.totalPremium,
213
                        dp: response.planDp,
214
                        correlationId: response.afinityQuoteModel.correlationId
34798 ranu 215
                    };
216
 
217
                    this.setState((prevState) => ({
218
                        quotedPlans: {
219
                            ...prevState.quotedPlans,
220
                            [planCode]: updatedPlan
221
                        }
222
                    }));
223
                } else {
34805 ranu 224
                    bootbox.alert("Quote failed: " + (response.afinityQuoteModel.message || "Unknown error"));
34798 ranu 225
                }
226
            }
227
        );
228
    }
24440 amit.gupta 229
}
230
 
31274 amit.gupta 231
let reactRoot = null;
24440 amit.gupta 232
 
34798 ranu 233
function getInsurancePlansModal(insurancePlans, elePlanCheckedOn, devicePrice, itemId) {
31274 amit.gupta 234
    const domContainer = document.querySelector('.insurancedetails');
235
    reactRoot = ReactDOM.createRoot(domContainer);
34798 ranu 236
    reactRoot.render(<InsuranceElement plans={insurancePlans} elePlanCheckedOn={elePlanCheckedOn}
237
                                       devicePrice={devicePrice} itemId={itemId}/>)
31274 amit.gupta 238
    $('#mobilePlansModal').modal({show: true});
239
 
240
}
241
 
242
 
32468 amit.gupta 243
function calculateTotalAmount(inputEle) {
244
    if (typeof inputEle !== "undefined") {
245
        let itemId = $(inputEle).attr("itemid");
246
        let unitPrice = inputEle.value;
247
        $("#order-items").find(`input.unitPrice[itemid=${itemId}]`).each(function () {
248
            this.value = unitPrice;
249
        })
250
 
251
    }
31274 amit.gupta 252
    var netPayableAmount = 0;
253
    var totaInsuranceAmount = 0;
32329 amit.gupta 254
    $("#order-items").find('tbody>tr:gt(0)').each(function (index, el) {
31274 amit.gupta 255
        var rowTotal = 0;
256
        let $tr = $(el);
257
        var insuranceAmount = $tr.find('input.insuranceamount').val();
258
        if (isNaN(insuranceAmount)) {
259
            insuranceAmount = 0;
260
        } else {
261
            insuranceAmount = parseFloat(insuranceAmount);
262
        }
30725 amit.gupta 263
 
31274 amit.gupta 264
        var quantity = parseFloat($(el).find('.unitPrice').attr('quantity'));
30725 amit.gupta 265
 
31274 amit.gupta 266
        var unitPrice = parseFloat($(el).find('.unitPrice').val());
267
        if (isNaN(unitPrice)) {
268
            unitPrice = 0;
269
        }
30725 amit.gupta 270
 
31274 amit.gupta 271
        var discount = $(el).find('.discount').val();
272
        if (isNaN(discount)) {
273
            discount = 0;
274
        }
23343 ashik.ali 275
 
32329 amit.gupta 276
        rowTotal = (unitPrice - discount + insuranceAmount) * quantity;
31274 amit.gupta 277
        $tr.find('.totalPrice').val(rowTotal);
278
        netPayableAmount += rowTotal;
279
        totaInsuranceAmount += insuranceAmount;
280
    });
281
    if (totaInsuranceAmount > 0) {
282
        $(".mk_insurance_row").show();
283
    } else {
284
        $(".mk_insurance_row").hide();
285
    }
286
    $('#cd').find('input.netPayableAmount').val(netPayableAmount);
23343 ashik.ali 287
}
33795 ranu 288
 
289
$(document).on('change', '.offerSelect', function () {
290
    calculateAndUpdatePaymentOptions();
291
});
292
 
293
function calculateAndUpdatePaymentOptions() {
294
    let totalSchemePayout = 0;
295
    let totalPartnerPayout = 0;
296
 
297
    // Loop through all selected options in each row
298
    $('.offerSelect').each(function () {
299
        let selectedOption = $(this).find('option:selected');
300
 
301
        let schemePayout = parseFloat(selectedOption.data('scheme-payout')) || 0;
302
        let partnerPayout = parseFloat(selectedOption.data('partner-payout')) || 0;
303
 
304
        // Accumulate the payouts
305
        totalSchemePayout += schemePayout;
306
        totalPartnerPayout += partnerPayout;
307
    });
308
 
309
    // Now update the payment options with the accumulated values
310
    updatePaymentOptions(totalSchemePayout, totalPartnerPayout);
311
}
312
 
313
function updatePaymentOptions(schemePayout, partnerPayout) {
314
    $("#payment-option-id-amount-container").find('.paymentOptionAmount').each(function () {
315
        let paymentOptionName = $(this).closest('.row').find('h5').text().trim();
316
 
317
        if (paymentOptionName.includes('SAMSUNG UPGRADE')) {
318
            $(this).val(schemePayout);  // Set the total scheme payout
319
        }
320
 
321
        if (paymentOptionName.includes('CASH DISCOUNT')) {
322
            $(this).val(partnerPayout);  // Set the total partner payout
323
        }
324
    });
325
}
326
 
34168 tejus.loha 327
$(document).on('click', '.reset-irn-generated-panel', function () {
328
    getResetIrnGeneratedPanel();
329
});
33795 ranu 330
 
34168 tejus.loha 331
$(document).on('click', '#search-invoice-for-irn-reset', function () {
332
    var invoiceNumber = $("#search-invoice-number").val();
333
    if (!invoiceNumber) {
334
        alert("Please enter Invoice Number");
335
        return;
336
    }
337
    doGetAjaxRequestHandler(`${context}/getTransactionForIrnReset?invoiceNumber=${invoiceNumber}`, function (response) {
338
        $('#transaction-for-reset-irn-container').html(response);
339
    });
340
});
33795 ranu 341
 
34168 tejus.loha 342
$(document).on('click', '#reset-irn-button', function () {
343
    if (confirm("Are you sure to Reset IRN")) {
344
        let invoices = [];
345
        $('#eligible-irn-order tbody tr').each(function () {
346
            const invoiceNumber = $(this).find('td:nth-child(3)').text();
347
            invoices.push(invoiceNumber);
348
        });
349
        const invoiceNumbers = invoices.join(', ');
350
        console.log('invoiceNumbersString - ', invoiceNumbers)
351
        let url = `${context}/resetOrdersIrn?invoiceNumbers=${invoiceNumbers}`
352
        doPutAjaxRequestHandler(url, function (response) {
353
            if (response) {
354
                alert(`IRN reset successfully for Invoice No - ${invoiceNumbers}`);
355
                getResetIrnGeneratedPanel();
356
            }
357
        });
358
    }
359
});
33795 ranu 360
 
34168 tejus.loha 361
function getResetIrnGeneratedPanel() {
362
    doGetAjaxRequestHandler(`${context}/resetIrnGeneratedPanel`, function (response) {
363
        $('#main-content').html(response);
364
    });
365
}
33795 ranu 366
 
367
 
368
 
34168 tejus.loha 369
 
370
 
371
 
372