Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21612 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
26817 amit.gupta 3
import com.google.gson.Gson;
23203 ashik.ali 4
import com.spice.profitmandi.common.enumuration.SearchType;
21612 ashik.ali 5
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
30322 amit.gupta 6
import com.spice.profitmandi.common.model.*;
28339 tejbeer 7
import com.spice.profitmandi.common.solr.SolrService;
33213 tejus.loha 8
import com.spice.profitmandi.common.util.FileUtil;
21689 ashik.ali 9
import com.spice.profitmandi.common.util.PdfUtils;
23638 amit.gupta 10
import com.spice.profitmandi.common.util.StringUtils;
22244 ashik.ali 11
import com.spice.profitmandi.common.web.util.ResponseSender;
33213 tejus.loha 12
import com.spice.profitmandi.dao.entity.auth.AuthUser;
33795 ranu 13
import com.spice.profitmandi.dao.entity.catalog.CustomerOffer;
14
import com.spice.profitmandi.dao.entity.catalog.CustomerOfferItem;
23638 amit.gupta 15
import com.spice.profitmandi.dao.entity.catalog.Item;
27861 tejbeer 16
import com.spice.profitmandi.dao.entity.catalog.TagListing;
33400 ranu 17
import com.spice.profitmandi.dao.entity.cs.Position;
34798 ranu 18
import com.spice.profitmandi.dao.entity.dtr.*;
30322 amit.gupta 19
import com.spice.profitmandi.dao.entity.fofo.*;
34194 ranu 20
import com.spice.profitmandi.dao.entity.transaction.EInvoiceDetails;
21
import com.spice.profitmandi.dao.entity.transaction.Order;
22
import com.spice.profitmandi.dao.entity.transaction.TransactionApproval;
23
import com.spice.profitmandi.dao.entity.transaction.UserWalletHistory;
23298 ashik.ali 24
import com.spice.profitmandi.dao.entity.user.Address;
33400 ranu 25
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
23548 ashik.ali 26
import com.spice.profitmandi.dao.enumuration.dtr.PaymentOptionReferenceType;
27046 tejbeer 27
import com.spice.profitmandi.dao.enumuration.transaction.OrderStatus;
33213 tejus.loha 28
import com.spice.profitmandi.dao.enumuration.transaction.TransactionApprovalStatus;
34788 ranu 29
import com.spice.profitmandi.dao.model.ItemWiseCustomerOfferSummaryModel;
34168 tejus.loha 30
import com.spice.profitmandi.dao.model.hdfc.IrnResetOrderModel;
33213 tejus.loha 31
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
33795 ranu 32
import com.spice.profitmandi.dao.repository.catalog.*;
33400 ranu 33
import com.spice.profitmandi.dao.repository.cs.PositionRepository;
30322 amit.gupta 34
import com.spice.profitmandi.dao.repository.dtr.*;
35
import com.spice.profitmandi.dao.repository.fofo.*;
24440 amit.gupta 36
import com.spice.profitmandi.dao.repository.inventory.StateRepository;
33336 tejus.loha 37
import com.spice.profitmandi.dao.repository.transaction.*;
23298 ashik.ali 38
import com.spice.profitmandi.dao.repository.user.AddressRepository;
33336 tejus.loha 39
import com.spice.profitmandi.dao.repository.user.CartRepository;
34474 aman.kumar 40
import com.spice.profitmandi.dao.service.ScratchService;
28377 tejbeer 41
import com.spice.profitmandi.service.EmailService;
32251 amit.gupta 42
import com.spice.profitmandi.service.NotificationService;
23798 amit.gupta 43
import com.spice.profitmandi.service.authentication.RoleManager;
34798 ranu 44
import com.spice.profitmandi.service.integrations.bharti.model.PlanVariant;
45
import com.spice.profitmandi.service.integrations.icicilombard.IciciLombardService;
46
import com.spice.profitmandi.service.integrations.icicilombard.model.AfinityQuoteModel;
34805 ranu 47
import com.spice.profitmandi.service.integrations.icicilombard.model.AfinityQuoteResponseModel;
25726 amit.gupta 48
import com.spice.profitmandi.service.integrations.zest.InsuranceService;
24440 amit.gupta 49
import com.spice.profitmandi.service.integrations.zest.MobileInsurancePlan;
33172 tejus.loha 50
import com.spice.profitmandi.service.order.BulkOrderService;
23366 ashik.ali 51
import com.spice.profitmandi.service.order.OrderService;
22069 ashik.ali 52
import com.spice.profitmandi.service.pricing.PricingService;
33696 amit.gupta 53
import com.spice.profitmandi.service.transaction.SDCreditService;
33213 tejus.loha 54
import com.spice.profitmandi.service.transaction.TransactionService;
26647 tejbeer 55
import com.spice.profitmandi.service.user.RetailerService;
33336 tejus.loha 56
import com.spice.profitmandi.service.wallet.WalletService;
32405 jai.hind 57
import com.spice.profitmandi.service.whatsapp.WhatsappMessageService;
32855 amit.gupta 58
import com.spice.profitmandi.service.whatsapp.WhatsappMessageType;
22139 amit.gupta 59
import com.spice.profitmandi.web.model.LoginDetails;
22069 ashik.ali 60
import com.spice.profitmandi.web.util.CookiesProcessor;
24105 govind 61
import com.spice.profitmandi.web.util.MVCResponseSender;
33336 tejus.loha 62
import in.shop2020.model.v1.order.WalletReferenceType;
30148 amit.gupta 63
import org.apache.logging.log4j.LogManager;
64
import org.apache.logging.log4j.Logger;
32405 jai.hind 65
import org.json.JSONArray;
30148 amit.gupta 66
import org.json.JSONObject;
67
import org.springframework.beans.factory.annotation.Autowired;
68
import org.springframework.core.io.InputStreamResource;
69
import org.springframework.http.HttpHeaders;
70
import org.springframework.http.HttpStatus;
71
import org.springframework.http.MediaType;
72
import org.springframework.http.ResponseEntity;
73
import org.springframework.stereotype.Controller;
74
import org.springframework.transaction.annotation.Transactional;
75
import org.springframework.ui.Model;
76
import org.springframework.web.bind.annotation.*;
33172 tejus.loha 77
import org.springframework.web.multipart.MultipartFile;
21612 ashik.ali 78
 
33336 tejus.loha 79
import javax.mail.MessagingException;
30148 amit.gupta 80
import javax.servlet.http.HttpServletRequest;
81
import javax.servlet.http.HttpServletResponse;
34805 ranu 82
import java.io.*;
32271 amit.gupta 83
import java.nio.charset.StandardCharsets;
34805 ranu 84
import java.nio.file.Files;
33367 ranu 85
import java.time.LocalDate;
30148 amit.gupta 86
import java.time.LocalDateTime;
87
import java.time.format.DateTimeFormatter;
88
import java.time.temporal.ChronoUnit;
89
import java.util.*;
90
import java.util.stream.Collectors;
91
 
21612 ashik.ali 92
@Controller
23973 govind 93
@Transactional(rollbackFor = Throwable.class)
21612 ashik.ali 94
public class OrderController {
95
 
33213 tejus.loha 96
    private static final Logger LOGGER = LogManager.getLogger(OrderController.class);
21985 kshitij.so 97
 
33213 tejus.loha 98
    private static final List<String> offlineOrders = Arrays.asList("EMIOD", "POD");
99
    private static final List<String> allowedDoaImeis = Arrays.asList("863903054378477");
100
    @Autowired
101
    NotificationService notificationService;
102
    @Autowired
103
    TransactionApprovalRepository transactionApprovalRepository;
104
    @Autowired
105
    LineItemRepository lineItemRepository;
106
    @Autowired
107
    AuthRepository authRepository;
108
    @Autowired
109
    TransactionService transactionService;
110
    @Autowired
111
    BulkOrderService bulkOrderService;
112
    @Autowired
113
    private CustomerRepository customerRepository;
114
    private boolean accessoriesDeals = true;
115
    @Autowired
116
    private RoleManager roleManager;
117
    @Autowired
118
    private Gson gson;
119
    @Autowired
120
    private CustomerReturnItemRepository customerReturnItemRepository;
121
    @Autowired
122
    private FofoOrderItemRepository fofoOrderItemRepository;
123
    @Autowired
124
    private PaymentOptionRepository paymentOptionRepository;
125
    @Autowired
126
    private StateRepository stateRepository;
127
    @Autowired
128
    private ItemRepository itemRepository;
129
    @Autowired
130
    private MVCResponseSender mvcResponseSender;
131
    @Autowired
132
    private InsuranceService insuranceService;
133
    @Autowired
134
    private FofoOrderRepository fofoOrderRepository;
135
    @Autowired
136
    private CustomerAddressRepository customerAddressRepository;
137
    @Autowired
138
    private InsurancePolicyRepository insurancePolicyRepository;
139
    @Autowired
140
    private InsuranceProviderRepository insuranceProviderRepository;
141
    @Autowired
142
    private CookiesProcessor cookiesProcessor;
143
    @Autowired
144
    private PricingService pricingService;
145
    @Autowired
146
    private OrderService orderService;
147
    @Autowired
148
    private RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
149
    @Autowired
150
    private AddressRepository addressRepository;
151
    @Autowired
152
    private PaymentOptionTransactionRepository paymentOptionTransactionRepository;
153
    @Autowired
154
    private FofoPartnerPaymentOptionRepository fofoPartnerPaymentOptionRepository;
155
    @Autowired
156
    private ResponseSender<?> responseSender;
157
    @Autowired
158
    private PendingOrderRepository pendingOrderRepository;
159
    @Autowired
160
    private OrderRepository orderRepository;
161
    @Autowired
162
    private PendingOrderItemRepository pendingOrderItemRepository;
163
    @Autowired
164
    private FofoStoreRepository fofoStoreRepository;
165
    @Autowired
166
    private RetailerService retailerService;
167
    @Autowired
168
    private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
169
    @Autowired
170
    private TagListingRepository tagListingRepository;
171
    @Autowired
172
    private PendingOrderService pendingOrderService;
173
    @Autowired
174
    private EmailService emailService;
175
    @Autowired
176
    private SolrService commonSolrService;
177
    @Autowired
178
    private MouRepository mouRepository;
179
    @Autowired
180
    private WhatsappMessageService whatsappMessageService;
181
    @Autowired
182
    private TransactionRepository transactionRepository;
33336 tejus.loha 183
    @Autowired
184
    WalletService walletService;
185
    @Autowired
186
    CartRepository cartRepository;
187
    @Autowired
188
    UserWalletRepository userWalletRepository;
28339 tejbeer 189
 
33795 ranu 190
    @Autowired
191
    private CatalogRepository catalogRepository;
33336 tejus.loha 192
 
33400 ranu 193
    @Autowired
33795 ranu 194
    private CustomerOfferRepository customerOfferRepository;
195
 
196
    @Autowired
197
    private CustomerOfferItemRepository customerOfferItemRepository;
198
 
199
    @Autowired
200
    private WebOfferRepository webOfferRepository;
201
 
202
    @Autowired
33400 ranu 203
    PositionRepository positionRepository;
32405 jai.hind 204
 
33437 ranu 205
    @Autowired
206
    PendingOrderPlanRepository pendingOrderPlanRepository;
24105 govind 207
 
34168 tejus.loha 208
    @Autowired
209
    PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
210
 
211
    @Autowired
212
    SDCreditService sdCreditService;
213
 
34798 ranu 214
    @Autowired
215
    IciciPolicyTrackerRepository iciciPolicyTrackerRepository;
34788 ranu 216
 
217
    @Autowired
34474 aman.kumar 218
    ScratchService scratchService;
34798 ranu 219
 
34788 ranu 220
    @Autowired
34798 ranu 221
    IciciLombardService iciciLombardService;
34788 ranu 222
 
33419 amit.gupta 223
    @RequestMapping(value = "/wa-send-invoice", method = RequestMethod.GET)
224
    public String sendWhatsappMessage(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId, Model model) {
225
        try {
226
            this.sendWhatsappInvoice(fofoOrderRepository.selectByOrderId(orderId));
227
        } catch (Exception e) {
228
            LOGGER.info("Could not send whatsapp message");
229
            e.printStackTrace();
230
        }
231
        model.addAttribute("response1", true);
232
        return "response";
233
    }
234
 
33213 tejus.loha 235
    @RequestMapping(value = "/get-order", method = RequestMethod.GET)
236
    public String getOrder(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId,
237
                           Model model) throws ProfitMandiBusinessException {
238
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
239
        FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoDetails.getFofoId(), orderId);
240
        List<FofoOrderItem> fofoLineItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
241
        CustomerAddress customerAddress = null;
242
        if (fofoOrder.getCustomerAddressId() != 0) {
243
            customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
244
        }
23973 govind 245
 
33213 tejus.loha 246
        Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
247
        if (customerAddress != null) {
248
            customerAddress.setPhoneNumber(customer.getMobileNumber());
249
        }
250
        LOGGER.info("Added to get invoice - {}, {}", customer, 123);
251
        List<PaymentOptionTransaction> paymentOptionTransactions = paymentOptionTransactionRepository
252
                .selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
253
        Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = this
254
                .paymentOptionIdPaymentOptionMap(paymentOptionTransactions);
255
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
256
                .selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
257
        this.addInsuranceProvider(insurancePolicies);
32627 ranu 258
 
33213 tejus.loha 259
        model.addAttribute("fofoOrder", fofoOrder);
260
        model.addAttribute("fofoLineItems", fofoLineItems);
261
        if (customerAddress != null) {
262
            model.addAttribute("customerBillingAddress", orderService.getBillingAddress(customerAddress));
263
        } else {
264
            model.addAttribute("customerBillingAddress", "");
21985 kshitij.so 265
 
33213 tejus.loha 266
        }
267
        model.addAttribute("customerBillingAddressObj", customerAddress);
268
        model.addAttribute("customerDetailsObj", customer);
269
        model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
270
        model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
271
        model.addAttribute("insurancePolicies", insurancePolicies);
272
        return "order-details";
273
    }
32637 amit.gupta 274
 
33213 tejus.loha 275
    private Map<Integer, InsuranceProvider> toInsuranceProviderIdInsuranceProvider(
276
            List<InsuranceProvider> insuranceProviders) {
277
        Map<Integer, InsuranceProvider> insuranceProviderIdInsuranceProviderMap = new HashMap<>();
278
        for (InsuranceProvider insuranceProvider : insuranceProviders) {
279
            insuranceProviderIdInsuranceProviderMap.put(insuranceProvider.getId(), insuranceProvider);
280
        }
281
        return insuranceProviderIdInsuranceProviderMap;
282
    }
23973 govind 283
 
33247 ranu 284
    private void addInsuranceProvider(List<InsurancePolicy> insurancePolicies) throws ProfitMandiBusinessException {
33213 tejus.loha 285
        if (insurancePolicies.isEmpty()) {
286
            return;
287
        }
288
        Set<Integer> insuranceProviderIds = new HashSet<>();
289
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
290
            insuranceProviderIds.add(insurancePolicy.getProviderId());
291
        }
292
        LOGGER.info("insuranceProviderIds {}", insuranceProviderIds);
293
        List<InsuranceProvider> insuranceProviders = insuranceProviderRepository.selectByIds(insuranceProviderIds);
294
        Map<Integer, InsuranceProvider> insuranceProviderIdInsuranceProviderMap = this
295
                .toInsuranceProviderIdInsuranceProvider(insuranceProviders);
296
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
297
            insurancePolicy
298
                    .setInsuranceProvider(insuranceProviderIdInsuranceProviderMap.get(insurancePolicy.getProviderId()));
299
        }
300
    }
23973 govind 301
 
33213 tejus.loha 302
    @RequestMapping(value = "/saleDetails", method = RequestMethod.GET)
303
    public String getSaleDetails(HttpServletRequest request,
304
                                 @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId, Model model) throws Exception {
305
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
306
        boolean isAdmin = roleManager.isAdmin(fofoDetails.getRoleIds());
307
        FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoDetails.getFofoId(), orderId);
308
        List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
309
        CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
310
        List<PaymentOptionTransaction> paymentOptionTransactions = paymentOptionTransactionRepository
311
                .selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
23973 govind 312
 
33213 tejus.loha 313
        // Added Migration info as we lost it.
314
        if (paymentOptionTransactions == null || paymentOptionTransactions.size() == 0) {
315
            PaymentOptionTransaction pot = new PaymentOptionTransaction();
316
            pot.setAmount(fofoOrder.getTotalAmount());
317
            pot.setCreateTimestamp(fofoOrder.getCreateTimestamp());
318
            // Mark it paid through cash
319
            pot.setPaymentOptionId(1);
320
            pot.setReferenceType(PaymentOptionReferenceType.ORDER);
321
            paymentOptionTransactionRepository.persist(pot);
322
            paymentOptionTransactions.add(pot);
323
            LOGGER.info("Added to get invoice");
324
        }
325
        Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = this
326
                .paymentOptionIdPaymentOptionMap(paymentOptionTransactions);
327
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
328
                .selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
329
        this.addInsuranceProvider(insurancePolicies);
330
        Map<Integer, Item> itemsMap = fofoOrderItems.stream().collect(Collectors.toMap(x -> x.getItemId(), x -> {
331
            try {
332
                return itemRepository.selectById(x.getItemId());
333
            } catch (ProfitMandiBusinessException e) {
334
                // TODO Auto-generated catch block
335
                return null;
336
            }
337
        }));
338
        Map<Integer, Set<FofoLineItem>> fofoOrderItemIdLineItemMap = fofoOrderItems.stream()
339
                .collect(Collectors.toMap(FofoOrderItem::getId, FofoOrderItem::getFofoLineItems));
23973 govind 340
 
33213 tejus.loha 341
        Map<Integer, List<CustomerReturnItem>> foiIdCustomerReturnInventoryItemsMap = fofoOrderItems.stream()
342
                .collect(Collectors.toMap(foi -> foi.getId(),
343
                        foi -> customerReturnItemRepository.selectAllByOrderItemId(foi.getId())));
23973 govind 344
 
33213 tejus.loha 345
        Map<Integer, Integer> inventoryItemBilledQtyMap = new HashMap<>();
23973 govind 346
 
33213 tejus.loha 347
        for (FofoOrderItem foi : fofoOrderItems) {
348
            for (FofoLineItem fli : foi.getFofoLineItems()) {
349
                inventoryItemBilledQtyMap.put(fli.getInventoryItemId(), fli.getQuantity());
350
            }
351
            List<CustomerReturnItem> customerReturnItems = customerReturnItemRepository
352
                    .selectAllByOrderItemId(foi.getId());
353
            this.markDoa(fofoOrder, foi, isAdmin);
354
            for (CustomerReturnItem customerReturnItem : customerReturnItems) {
355
                inventoryItemBilledQtyMap.put(customerReturnItem.getInventoryItemId(),
356
                        inventoryItemBilledQtyMap.get(customerReturnItem.getInventoryItemId()) - 1);
357
            }
358
        }
23973 govind 359
 
33213 tejus.loha 360
        LOGGER.info("fofoOrderItemIdLineItemMap {}", fofoOrderItemIdLineItemMap);
361
        model.addAttribute("fofoOrder", fofoOrder);
362
        model.addAttribute("itemsMap", itemsMap);
363
        model.addAttribute("fofoOrderItemIdLineItemsMap", StringUtils.toString(fofoOrderItemIdLineItemMap));
364
        model.addAttribute("foiIdCustomerReturnInventoryItemsMap",
365
                StringUtils.toString(foiIdCustomerReturnInventoryItemsMap));
366
        model.addAttribute("fofoOrderItemIdLineItemMap", fofoOrderItemIdLineItemMap);
23973 govind 367
 
33213 tejus.loha 368
        model.addAttribute("fofoOrderItems", fofoOrderItems);
369
        model.addAttribute("inventoryItemBilledQtyMap", StringUtils.toString(inventoryItemBilledQtyMap));
370
        if (customerAddress != null) {
30426 tejbeer 371
 
33213 tejus.loha 372
            model.addAttribute("customerBillingAddress", orderService.getBillingAddress(customerAddress));
373
        } else {
374
            model.addAttribute("customerBillingAddress", "");
32637 amit.gupta 375
 
33213 tejus.loha 376
        }
377
        model.addAttribute("customerBillingAddressObj", customerAddress);
378
        model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
379
        model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
380
        model.addAttribute("insurancePolicies", insurancePolicies);
381
        model.addAttribute("markDefective", this.markDefective(fofoOrder));
382
        return "sale-details";
383
    }
32637 amit.gupta 384
 
33213 tejus.loha 385
    private void markDoa(FofoOrder fofoOrder, FofoOrderItem foi, boolean isAdmin) {
386
        if (isAdmin) {
387
            foi.setDoa(true);
388
            return;
389
        }
390
        boolean isImei = foi.getFofoLineItems().stream()
391
                .anyMatch(x -> org.apache.commons.lang3.StringUtils.isNotEmpty(x.getSerialNumber())
392
                        && allowedDoaImeis.contains(x.getSerialNumber()));
393
        LocalDateTime buyDate = fofoOrder.getCreateTimestamp().truncatedTo(ChronoUnit.DAYS);
394
        LocalDateTime curDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS);
395
        if (buyDate.isAfter(curDate.minusDays(45)) || isImei) {
396
            foi.setDoa(true);
397
        } else
398
            foi.setDoa(
399
                    foi.getBrand().equals("Nokia") && foi.getCost() < 4990 && buyDate.isAfter(curDate.minusYears(1)));
400
    }
30426 tejbeer 401
 
33213 tejus.loha 402
    private boolean markDefective(FofoOrder fofoOrder) {
403
        return fofoOrder.getCreateTimestamp().truncatedTo(ChronoUnit.DAYS).plusDays(180)
404
                .isAfter(LocalDateTime.now().truncatedTo(ChronoUnit.DAYS));
26647 tejbeer 405
 
33213 tejus.loha 406
    }
26647 tejbeer 407
 
33213 tejus.loha 408
    @RequestMapping(value = "/getSearchOrder")
409
    public String getSearchOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
410
        return "search-order";
411
    }
26647 tejbeer 412
 
33213 tejus.loha 413
    @RequestMapping(value = "/getInvoiceSearchOrder")
414
    public String getInvoiceSearchOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
415
        return "invoices-cancel";
416
    }
33172 tejus.loha 417
 
33213 tejus.loha 418
    @RequestMapping(value = "/customerDetails", method = RequestMethod.PUT)
419
    public String updateCustomerDetails(HttpServletRequest request, @RequestBody CustomCustomer customCustomer,
420
                                        @RequestParam(name = ProfitMandiConstants.INVOICE_NUMBER) String invoiceNumber, Model model)
421
            throws Exception {
34338 ranu 422
        LOGGER.info("CustomCustomer {}", customCustomer);
33172 tejus.loha 423
 
33213 tejus.loha 424
        orderService.updateCustomerDetails(customCustomer, invoiceNumber);
425
        return this.getSearchOrderDetails(request, invoiceNumber, model);
426
    }
33172 tejus.loha 427
 
33213 tejus.loha 428
    @RequestMapping(value = "/searchOrderDetails", method = RequestMethod.GET)
429
    public String getSearchOrderDetails(HttpServletRequest request,
430
                                        @RequestParam(name = ProfitMandiConstants.INVOICE_NUMBER) String invoiceNumber, Model model)
431
            throws Exception {
33172 tejus.loha 432
 
33213 tejus.loha 433
        FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
34474 aman.kumar 434
        if (fofoOrder == null) {
435
            throw new ProfitMandiBusinessException("invalid invoice number", "invoice - " + invoiceNumber, "Please enter valid invoice number");
34181 tejus.loha 436
        }
437
 
33213 tejus.loha 438
        List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
439
        Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
440
        CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
441
        Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = paymentOptionRepository.selectActiveOption().stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
442
        List<Integer> fofoPartnerPaymentOptions = new ArrayList<>(paymentOptionIdPaymentOptionMap.keySet());
443
        Map<Integer, Item> itemsMap = fofoOrderItems.stream().collect(Collectors.toMap(x -> x.getItemId(), x -> {
444
            try {
445
                return itemRepository.selectById(x.getItemId());
446
            } catch (ProfitMandiBusinessException e) {
447
                // TODO Auto-generated catch block
448
                return null;
449
            }
450
        }));
451
        LOGGER.info("fofoPartnerPaymentOptions" + fofoPartnerPaymentOptions);
452
        List<PaymentOptionTransaction> paymentOptionTransactions = paymentOptionTransactionRepository
453
                .selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
454
        LOGGER.info("paymentOptionTransactions" + paymentOptionTransactions);
26647 tejbeer 455
 
33213 tejus.loha 456
        Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = this
457
                .paymentOptionIdPaymentOptionTransactionMap(paymentOptionTransactions);
458
        LOGGER.info("paymentOptionIdPaymentOptionTransactionMap" + paymentOptionIdPaymentOptionTransactionMap.keySet());
459
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
460
                .selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
461
        this.addInsuranceProvider(insurancePolicies);
462
        model.addAttribute("fofoOrder", fofoOrder);
463
        for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
464
            fofoOrderItem.setDoa(true);
465
        }
27861 tejbeer 466
 
33213 tejus.loha 467
        Map<Integer, Set<FofoLineItem>> fofoOrderItemIdLineItemMap = fofoOrderItems.stream()
468
                .collect(Collectors.toMap(FofoOrderItem::getId, FofoOrderItem::getFofoLineItems));
28339 tejbeer 469
 
33213 tejus.loha 470
        Map<Integer, List<CustomerReturnItem>> foiIdCustomerReturnInventoryItemsMap = fofoOrderItems.stream()
471
                .collect(Collectors.toMap(foi -> foi.getId(),
472
                        foi -> customerReturnItemRepository.selectAllByOrderItemId(foi.getId())));
28339 tejbeer 473
 
33213 tejus.loha 474
        Map<Integer, Integer> inventoryItemBilledQtyMap = new HashMap<>();
28339 tejbeer 475
 
33213 tejus.loha 476
        for (FofoOrderItem foi : fofoOrderItems) {
477
            for (FofoLineItem fli : foi.getFofoLineItems()) {
478
                inventoryItemBilledQtyMap.put(fli.getInventoryItemId(), fli.getQuantity());
479
            }
480
            List<CustomerReturnItem> customerReturnItems = customerReturnItemRepository
481
                    .selectAllByOrderItemId(foi.getId());
482
            for (CustomerReturnItem customerReturnItem : customerReturnItems) {
483
                inventoryItemBilledQtyMap.put(customerReturnItem.getInventoryItemId(),
484
                        inventoryItemBilledQtyMap.get(customerReturnItem.getInventoryItemId()) - 1);
485
            }
486
        }
487
        model.addAttribute("foiIdCustomerReturnInventoryItemsMap",
488
                StringUtils.toString(foiIdCustomerReturnInventoryItemsMap));
489
        model.addAttribute("fofoOrderItems", fofoOrderItems);
490
        model.addAttribute("inventoryItemBilledQtyMap", StringUtils.toString(inventoryItemBilledQtyMap));
491
        model.addAttribute("fofoOrderItemIdLineItemsMap", StringUtils.toString(fofoOrderItemIdLineItemMap));
492
        model.addAttribute("itemsMap", itemsMap);
493
        model.addAttribute("markDefective", true);
494
        model.addAttribute("customer", customer);
495
        model.addAttribute("customerAddress", customerAddress);
496
        model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
497
        model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
498
        model.addAttribute("paymentOptionIdPaymentOptionTransactionMap", paymentOptionIdPaymentOptionTransactionMap);
499
        model.addAttribute("insurancePolicies", insurancePolicies);
500
        model.addAttribute("fofoPartnerPaymentOptions", fofoPartnerPaymentOptions);
501
        model.addAttribute("totalNumberOfPaymentOptionId", fofoPartnerPaymentOptions.size());
502
        model.addAttribute("stateNames",
503
                stateRepository.selectAll().stream().map(x -> x.getName()).collect(Collectors.toList()));
504
        return "search-order-details";
505
    }
28420 tejbeer 506
 
33213 tejus.loha 507
    private Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap(
33247 ranu 508
            List<PaymentOptionTransaction> paymentOptionTransactions) throws ProfitMandiBusinessException {
33213 tejus.loha 509
        Set<Integer> paymentOptionIds = new HashSet<>();
510
        for (PaymentOptionTransaction paymentOptionTransaction : paymentOptionTransactions) {
511
            paymentOptionIds.add(paymentOptionTransaction.getPaymentOptionId());
512
        }
513
        List<PaymentOption> paymentOptions = paymentOptionRepository.selectByIds(paymentOptionIds);
514
        Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = new HashMap<>();
515
        for (PaymentOption paymentOption : paymentOptions) {
516
            paymentOptionIdPaymentOptionMap.put(paymentOption.getId(), paymentOption);
517
        }
518
        return paymentOptionIdPaymentOptionMap;
519
    }
23973 govind 520
 
33213 tejus.loha 521
    private Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMapUsingPaymentOptions(
33247 ranu 522
            List<Integer> fofoPartnerPaymentOptions) throws ProfitMandiBusinessException {
33213 tejus.loha 523
        List<PaymentOption> paymentOptions = paymentOptionRepository
524
                .selectByIds(new HashSet<>(fofoPartnerPaymentOptions));
525
        Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = new HashMap<>();
526
        for (PaymentOption paymentOption : paymentOptions) {
527
            paymentOptionIdPaymentOptionMap.put(paymentOption.getId(), paymentOption);
528
        }
529
        return paymentOptionIdPaymentOptionMap;
530
    }
23973 govind 531
 
33213 tejus.loha 532
    private Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap(
533
            List<PaymentOptionTransaction> paymentOptionTransactions) {
534
        Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = new HashMap<>();
535
        for (PaymentOptionTransaction paymentOptionTransaction : paymentOptionTransactions) {
536
            paymentOptionIdPaymentOptionTransactionMap.put(paymentOptionTransaction.getPaymentOptionId(),
537
                    paymentOptionTransaction);
538
        }
539
        return paymentOptionIdPaymentOptionTransactionMap;
540
    }
28339 tejbeer 541
 
33437 ranu 542
    @RequestMapping(value = "/checkplans", method = RequestMethod.GET)
543
    public String getInsurancePrices(HttpServletRequest request, @RequestParam float price, Model model,
544
                                     @RequestParam int itemId, @RequestParam int poiId) throws ProfitMandiBusinessException {
545
        LOGGER.info("Request received at url : {}", request.getRequestURI());
28339 tejbeer 546
 
33437 ranu 547
        try {
548
            String response = mvcResponseSender.createResponseString(this.getPlans(price, itemId, poiId));
549
            model.addAttribute("response1", response);
550
        } catch (Exception e) {
551
            // TODO Auto-generated catch block
552
            LOGGER.info(e.getMessage(), e);
553
            throw new ProfitMandiBusinessException("Plans", "Plans API", "Error formatting insurance plans");
33213 tejus.loha 554
        }
33400 ranu 555
 
33437 ranu 556
        return "response";
33213 tejus.loha 557
    }
28339 tejbeer 558
 
34798 ranu 559
    @RequestMapping(value = "/getPlanQuote", method = RequestMethod.GET)
34788 ranu 560
    public String getPlanQuote(HttpServletRequest request, Model model,
34798 ranu 561
                               @RequestParam String planCode, @RequestParam int sumInsured, @RequestParam String manufacturedDate, @RequestParam int itemId) throws ProfitMandiBusinessException {
34788 ranu 562
 
563
        try {
34798 ranu 564
 
565
            DateTimeFormatter formatter = DateTimeFormatter.ofPattern("MM/dd/yyyy");
566
            LocalDate manufactured = LocalDate.parse(manufacturedDate, formatter);
567
 
34788 ranu 568
            PlanVariant planVariant = insuranceService.getICICIPremiumByVariantId(planCode);
569
 
570
            LOGGER.info("planVariant111 {}",planVariant);
571
 
572
            String correlationId = UUID.randomUUID().toString();
573
            IciciPolicyTracker policyTracker = new IciciPolicyTracker();
574
            policyTracker.setCorrelationId(correlationId);
575
            iciciPolicyTrackerRepository.persist(policyTracker);
576
 
577
            // Policy validity (1 year from today)
578
            LocalDate today = LocalDate.now();
579
            LocalDate oneYearLater = today.plusYears(1);
580
 
581
            String itemBrand = itemRepository.selectById(itemId).getBrand();
582
 
583
            AfinityQuoteModel quoteModel = new AfinityQuoteModel();
584
            quoteModel.setPolicyStartDate(today.toString());          // format: yyyy-MM-dd
585
            quoteModel.setPolicyEndDate(oneYearLater.toString());
34810 ranu 586
            quoteModel.setPlanCode(String.valueOf(planVariant.getOurPlanId()));
587
//            quoteModel.setPlanCode(String.valueOf(10357));
34788 ranu 588
            quoteModel.setSumInsured((int) sumInsured);
589
            quoteModel.setBasisOfValuation("Market_Value");
34805 ranu 590
            quoteModel.setPartyStateName(iciciLombardService.PARTY_STATE_NAME);
34788 ranu 591
            quoteModel.setRiskSIComponent("MOBILE");
592
            quoteModel.setMakeManufacturer(itemBrand.toUpperCase());
34798 ranu 593
            quoteModel.setYearOfManufacture(manufactured.getYear());
34788 ranu 594
            quoteModel.setCoverName("All Risk");
595
            quoteModel.setCorrelationId(correlationId);
596
 
34805 ranu 597
            AfinityQuoteResponseModel afinityQuoteResponseModel = iciciLombardService.hitAfinityQuote(quoteModel);
598
            float planDp = insuranceService.getPlanDp(afinityQuoteResponseModel.getTotalPremium(), planVariant.getCoverage());
599
 
600
            Map<String, Object> responseMap = new HashMap<>();
601
            responseMap.put("afinityQuoteModel", afinityQuoteResponseModel);
602
            responseMap.put("planDp", planDp);
603
            model.addAttribute("response1", mvcResponseSender.createResponseString(responseMap));
34788 ranu 604
        } catch (Exception e) {
605
            // TODO Auto-generated catch block
606
            LOGGER.info(e.getMessage(), e);
607
            throw new ProfitMandiBusinessException("Plans", "Plans Quote", "Error qutotation insurance plans");
608
        }
609
 
610
        return "response";
34798 ranu 611
    }
34788 ranu 612
 
34204 tejus.loha 613
    private boolean sendWhatsappInvoice(FofoOrder fofoOrder) throws Exception {
614
        return this.sendWhatsappInvoice(fofoOrder, "");
34179 tejus.loha 615
    }
616
 
34204 tejus.loha 617
    private boolean sendWhatsappInvoice(FofoOrder fofoOrder, String whatsAppNo) throws Exception {
618
        boolean shouldSendWhatsappMessage = notificationService.shouldSendWhatsappMessage(whatsAppNo);
34474 aman.kumar 619
        boolean isSend = false;
34204 tejus.loha 620
        if (shouldSendWhatsappMessage) {
621
            Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
622
            String mobileNumber;
623
            if (!whatsAppNo.isEmpty()) {
34474 aman.kumar 624
                mobileNumber = whatsAppNo;
625
            } else {
626
                mobileNumber = customer.getMobileNumber();
627
            }
628
            CustomRetailer retailer = retailerService.getFofoRetailer(fofoOrder.getFofoId());
629
            String message = String.format("Dear %s,\n" +
630
                    "Thank you for your purchase from SmartDukaan store - %s, %s.\n" +
631
                    "Your purchase invoice is attached for your reference.\n" +
632
                    "\n" +
633
                    "Download our app for offers and updates on new products.\n" +
634
                    "https://www.smartdukaan.com/b2c\n" +
635
                    "\n" +
636
                    "Best Regards\n" +
637
                    "SmartDukaan", customer.getFirstName(), retailer.getBusinessName(), retailer.getAddress().getCity());
34204 tejus.loha 638
 
34474 aman.kumar 639
            isSend = notificationService.sendWhatsappMediaMessage(message, mobileNumber, this.getPublicInvoiceUrl(fofoOrder.getInvoiceNumber()),
33213 tejus.loha 640
                    this.getFileName(fofoOrder.getInvoiceNumber()), WhatsappMessageType.DOCUMENT);
641
        }
34204 tejus.loha 642
        return isSend;
33213 tejus.loha 643
    }
28339 tejbeer 644
 
33213 tejus.loha 645
    private String getFileName(String invoiceNumber) {
646
        return "INV-" + invoiceNumber.replace("/", "-") + ".pdf";
647
    }
31375 tejbeer 648
 
33213 tejus.loha 649
    private String getPublicInvoiceUrl(String invoiceNumber) {
650
        String base64Encoded = Base64.getMimeEncoder().encodeToString(invoiceNumber.getBytes(StandardCharsets.UTF_8));
651
        String publicUrl = "https://partners.smartdukaan.com/wa-invoice-send/" + base64Encoded + ".pdf";
652
        LOGGER.info("Public Whatsapp Url for Invoice Message - {}", publicUrl);
653
        return publicUrl;
654
    }
28339 tejbeer 655
 
33213 tejus.loha 656
    @RequestMapping(value = "/order/bad_return", method = RequestMethod.POST)
657
    public ResponseEntity<?> badReturn(HttpServletRequest request, @RequestBody FoiBadReturnRequest foiBadReturnRequest,
658
                                       Model model) throws ProfitMandiBusinessException {
659
        LOGGER.info("request at uri {} body {}", request.getRequestURI(), foiBadReturnRequest);
660
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
661
        CustomerCreditNote custmoerCreditNote;
662
        if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
663
            FofoOrderItem foi = fofoOrderItemRepository.selectById(foiBadReturnRequest.getFofoOrderItemId());
664
            FofoOrder fo = fofoOrderRepository.selectByOrderId(foi.getOrderId());
34168 tejus.loha 665
            custmoerCreditNote = orderService.badReturn(fofoDetails.getEmailId(), fo.getFofoId(), foiBadReturnRequest);
33213 tejus.loha 666
        } else {
667
            custmoerCreditNote = orderService.badReturn(fofoDetails.getFofoId(), foiBadReturnRequest);
668
        }
669
        return responseSender.ok(custmoerCreditNote.getId());
670
    }
28339 tejbeer 671
 
33213 tejus.loha 672
    @GetMapping(value = "/wa-invoice-send/{invoiceHash}")
673
    public ResponseEntity<?> generateInvoice(@PathVariable String invoiceHash) throws ProfitMandiBusinessException {
674
        String decodedInvoiceNumber = new String(Base64.getMimeDecoder().decode(invoiceHash));
675
        LOGGER.info("Invoice Hash {}", invoiceHash);
28339 tejbeer 676
 
23973 govind 677
 
33213 tejus.loha 678
        FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(decodedInvoiceNumber);
24844 amit.gupta 679
 
33213 tejus.loha 680
        InvoicePdfModel pdfModel = orderService.getInvoicePdfModel(fofoOrder.getId());
24844 amit.gupta 681
 
33213 tejus.loha 682
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
683
        PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
684
        final HttpHeaders headers = new HttpHeaders();
685
        //headers.setContentDispositionFormData("inline", number + ".pdf");
686
        headers.add(HttpHeaders.CONTENT_DISPOSITION, "inline;filename=" + pdfModel.getInvoiceNumber() + ".pdf");
687
        int contentLength = byteArrayOutputStream.toByteArray().length;
688
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
689
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
690
        return ResponseEntity.ok()
691
                .headers(headers)
692
                .contentLength(contentLength)
693
                .contentType(MediaType.parseMediaType("application/pdf"))
694
                .body(inputStreamResource);
695
    }
23973 govind 696
 
33213 tejus.loha 697
    @RequestMapping(value = "/wa-listen", method = RequestMethod.POST)
698
    public ResponseEntity<?> listenWhatsappStatus(@RequestBody String whatsappJsonResponse) {
699
        LOGGER.info("whatsappJsonResponse {}", whatsappJsonResponse);
700
        //jaihind
701
        //  String jsonString = "[{\"srcAddr\":\"TESTSM\",\"channel\":\"WHATSAPP\",\"externalId\":\"4977024756456780043-180044363908187691\",\"cause\":\"SUCCESS\",\"errorCode\":\"000\",\"destAddr\":\"919813272029\",\"eventType\":\"DELIVERED\",\"eventTs\":1692848106000}]";
702
        JSONArray jsonArray = new JSONArray(whatsappJsonResponse);
703
        for (int i = 0; i < jsonArray.length(); i++) {
32711 amit.gupta 704
 
33213 tejus.loha 705
            JSONObject jsonObject = jsonArray.getJSONObject(i);
706
            String externalId = jsonObject.getString("externalId");
707
            String destAddr = jsonObject.getString("destAddr");
708
            String eventType = jsonObject.getString("eventType");
709
            whatsappMessageService.setWhatsappResponse(externalId, destAddr, eventType);
710
        }
711
        //jaihind
712
        return responseSender.ok("Success");
32711 amit.gupta 713
 
33213 tejus.loha 714
    }
32271 amit.gupta 715
 
33213 tejus.loha 716
    @RequestMapping(value = "/generateInvoice")
717
    public ResponseEntity<?> generateInvoice(HttpServletRequest request, HttpServletResponse response,
718
                                             @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId) throws ProfitMandiBusinessException {
719
        LOGGER.info("Request received at url {} with params [{}={}] ", request.getRequestURI(),
720
                ProfitMandiConstants.ORDER_ID, orderId);
721
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
722
        InvoicePdfModel pdfModel = null;
723
        if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
724
            pdfModel = orderService.getInvoicePdfModel(orderId);
725
        } else {
726
            pdfModel = orderService.getInvoicePdfModel(fofoDetails.getFofoId(), orderId);
727
        }
34805 ranu 728
        FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(orderId);
729
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
730
 
731
        // Step 1: Generate invoice PDF
732
        ByteArrayOutputStream invoiceOutput = new ByteArrayOutputStream();
733
        PdfUtils.generateAndWrite(Arrays.asList(pdfModel), invoiceOutput);
734
        byte[] invoicePdf = invoiceOutput.toByteArray();
735
 
736
        // Step 2: Load all policy certificate PDFs
737
        List<byte[]> pdfFiles = new ArrayList<>();
738
        pdfFiles.add(invoicePdf); // first add invoice
739
 
740
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
741
            String policyNumber = insurancePolicy.getPolicyNumber();
742
            String safePolicyNo = policyNumber.replace("/", "-");
743
            String filePath = "/Users/amit/uploads/policy-certificate-" + safePolicyNo + ".pdf";
744
            File file = new File(filePath);
745
 
746
            if (file.exists()) {
747
                try {
748
                    byte[] policyPdf = Files.readAllBytes(file.toPath());
749
                    pdfFiles.add(policyPdf);
750
                } catch (IOException e) {
751
                    LOGGER.error("Failed to read policy PDF: {}", filePath, e);
752
                }
753
            } else {
754
                LOGGER.warn("Policy PDF not found: {}", filePath);
755
            }
756
        }
757
 
758
        // Step 3: Merge all PDFs
759
        byte[] mergedPdf;
760
        try {
761
            mergedPdf = PdfUtils.mergePdfFiles(pdfFiles);
762
        } catch (Exception e) {
763
            LOGGER.error("Error merging PDFs", e);
764
            throw new ProfitMandiBusinessException("Failed to generate merged PDF", "", "");
765
        }
766
 
767
        // Step 4: Return merged PDF as response
768
        HttpHeaders headers = new HttpHeaders();
33213 tejus.loha 769
        headers.setContentType(MediaType.APPLICATION_PDF);
34805 ranu 770
        headers.setContentDispositionFormData("inline", "invoice-with-policies-" + pdfModel.getInvoiceNumber() + ".pdf");
771
        headers.setContentLength(mergedPdf.length);
772
 
773
        InputStreamResource resource = new InputStreamResource(new ByteArrayInputStream(mergedPdf));
774
        return new ResponseEntity<>(resource, headers, HttpStatus.OK);
33213 tejus.loha 775
    }
24087 amit.gupta 776
 
33213 tejus.loha 777
    @RequestMapping(value = "/generateInvoices")
778
    public ResponseEntity<?> generateInvoice(HttpServletRequest request, HttpServletResponse response,
779
                                             @RequestParam LocalDateTime startDate, @RequestParam LocalDateTime endDate, @RequestParam int partnerId)
780
            throws ProfitMandiBusinessException {
781
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
782
        List<InvoicePdfModel> pdfModels = new ArrayList<>();
783
        if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
784
            List<Integer> orderIds = fofoOrderRepository.selectByFofoId(partnerId, startDate, endDate, 0, 0).stream()
785
                    .map(x -> x.getId()).collect(Collectors.toList());
786
            for (int orderId : orderIds) {
787
                pdfModels.add(orderService.getInvoicePdfModel(orderId));
788
            }
789
            ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
790
            PdfUtils.generateAndWrite(pdfModels, byteArrayOutputStream);
791
            LOGGER.info("Pdf Stream length {}", byteArrayOutputStream.toByteArray().length);
792
            final HttpHeaders headers = new HttpHeaders();
793
            headers.setContentType(MediaType.APPLICATION_PDF);
794
            headers.set("Content-disposition", "inline; filename=invoice-" + partnerId + ".pdf");
795
            headers.setContentLength(byteArrayOutputStream.toByteArray().length);
796
            final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
797
            final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
798
            return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
799
        } else {
800
            throw new ProfitMandiBusinessException("Auth", fofoDetails.getEmailId(), "Unauthorised access");
801
        }
802
    }
23973 govind 803
 
33213 tejus.loha 804
    @RequestMapping(value = "/saleHistory")
805
    public String saleHistory(HttpServletRequest request,
806
                              @RequestParam(name = "searchValue", defaultValue = "") String searchValue,
807
                              @RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
808
                              @RequestParam(required = false) LocalDateTime startTime,
809
                              @RequestParam(required = false) LocalDateTime endTime,
810
                              @RequestParam(name = "offset", defaultValue = "0") int offset,
811
                              @RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
812
            throws ProfitMandiBusinessException {
813
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
32405 jai.hind 814
 
33213 tejus.loha 815
        Map<String, Object> map = orderService.getSaleHistory(loginDetails.getFofoId(), searchType, searchValue,
816
                startTime, endTime, offset, limit);
817
        model.addAllAttributes(map);
818
        return "sale-history";
819
    }
32405 jai.hind 820
 
33213 tejus.loha 821
    @RequestMapping(value = "/downloadInvoices")
822
    public ResponseEntity<?> downloadInvoices(HttpServletRequest request,
823
                                              @RequestParam(name = "searchValue", defaultValue = "") String searchValue,
824
                                              @RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
825
                                              @RequestParam(required = false) LocalDateTime startTime,
826
                                              @RequestParam(required = false) LocalDateTime endTime,
827
                                              @RequestParam(name = "offset", defaultValue = "0") int offset,
828
                                              @RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
829
            throws ProfitMandiBusinessException {
830
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
32409 amit.gupta 831
 
33213 tejus.loha 832
        Map<String, Object> map = orderService.getSaleHistory(loginDetails.getFofoId(), searchType, searchValue,
833
                startTime, endTime, offset, 100);
834
        List<FofoOrder> fofoOrders = (List<FofoOrder>) map.get("saleHistories");
23973 govind 835
 
33213 tejus.loha 836
        if (fofoOrders.size() == 0) {
837
            throw new ProfitMandiBusinessException("Search criteria", "", "No orders found for criteria");
838
        }
23654 amit.gupta 839
 
33213 tejus.loha 840
        final HttpHeaders headers = new HttpHeaders();
841
        headers.setContentType(MediaType.APPLICATION_PDF);
842
        headers.set("Content-disposition", "inline; filename=invoices.pdf");
843
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
844
        List<InvoicePdfModel> pdfModels = new ArrayList<>();
845
        for (FofoOrder fofoOrder : fofoOrders) {
846
            try {
847
                pdfModels.add(orderService.getInvoicePdfModel(fofoOrder.getId()));
848
            } catch (Exception e) {
849
                LOGGER.info("could not create invoice for {}, invoice number {}", fofoOrder.getId(),
850
                        fofoOrder.getInvoiceNumber());
851
            }
852
        }
853
        PdfUtils.generateAndWrite(pdfModels, byteArrayOutputStream);
854
        headers.setContentLength(byteArrayOutputStream.toByteArray().length);
855
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
856
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
857
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
858
    }
23654 amit.gupta 859
 
33213 tejus.loha 860
    @RequestMapping(value = "/credit-note/{creditNoteId}")
861
    public ResponseEntity<?> downloadCreditNote(HttpServletRequest request, @PathVariable int creditNoteId)
862
            throws ProfitMandiBusinessException {
863
        CreditNotePdfModel creditNotePdfModel = orderService.getCreditNotePdfModel(creditNoteId);
864
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
865
        PdfUtils.generateAndWriteCustomerCreditNotes(Arrays.asList(creditNotePdfModel), byteArrayOutputStream);
866
        LOGGER.info("Pdf Stream length {}", byteArrayOutputStream.toByteArray().length);
867
        final HttpHeaders headers = new HttpHeaders();
868
        headers.setContentType(MediaType.APPLICATION_PDF);
869
        headers.set("Content-disposition",
870
                "inline; filename=invoice-" + creditNotePdfModel.getCreditNoteNumber() + ".pdf");
871
        headers.setContentLength(byteArrayOutputStream.toByteArray().length);
872
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
873
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
874
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
875
    }
23973 govind 876
 
33213 tejus.loha 877
    @RequestMapping(value = "/getPaginatedSaleHistory")
878
    public String getSaleHistoryPaginated(HttpServletRequest request,
879
                                          @RequestParam(name = "searchValue", defaultValue = "") String searchValue,
880
                                          @RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
881
                                          @RequestParam(required = false) LocalDateTime startTime,
882
                                          @RequestParam(required = false) LocalDateTime endTime,
883
                                          @RequestParam(name = "offset", defaultValue = "0") int offset,
884
                                          @RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
885
            throws ProfitMandiBusinessException {
886
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
887
        Map<String, Object> map = orderService.getSaleHistoryPaginated(loginDetails.getFofoId(), searchType,
888
                searchValue, startTime, endTime, offset, limit);
889
        model.addAllAttributes(map);
890
        return "sale-history-paginated";
891
    }
23973 govind 892
 
33213 tejus.loha 893
    @PutMapping(value = "/updatePaymentTransaction")
894
    public String updateTransactionDetails(HttpServletRequest request, @RequestParam String referenceType,
895
                                           @RequestParam int fofoId, @RequestParam int referenceId,
896
                                           @RequestBody PartnerOptionsAndItemAmountModel partnerOptionsAndItemAmountModel,
897
                                           @RequestParam float totalAmount, Model model) throws Exception {
29707 tejbeer 898
 
33213 tejus.loha 899
        List<PaymentOptionTransactionModel> paymentOptionTransactionModels = partnerOptionsAndItemAmountModel
900
                .getPaymentOptionTransactionModel();
901
        LOGGER.info(paymentOptionTransactionModels);
902
        FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoId, referenceId);
903
        LOGGER.info("sdssd" + fofoOrder);
904
        fofoOrder.setTotalAmount(totalAmount);
905
        List<FofoItemIdAmountModel> fofoItemIdAmountModel = partnerOptionsAndItemAmountModel.getItemAmountModel();
906
        for (FofoItemIdAmountModel fim : fofoItemIdAmountModel) {
907
            LOGGER.info("fim" + fim.getFofoItemId());
23973 govind 908
 
33213 tejus.loha 909
            LOGGER.info("fimAmount" + fim.getAmount());
910
            Item item = itemRepository.selectById(fim.getItemId());
911
            TagListing tagListing = tagListingRepository.selectByItemId(item.getId());
912
            FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectById(fim.getFofoItemId());
913
            LOGGER.info("category" + item.getCategoryId());
914
            if (item.getCategoryId() == ProfitMandiConstants.MOBILE_CATEGORY_ID) {
915
                if (fofoOrderItem.getMop() <= fim.getAmount()) {
23973 govind 916
 
33213 tejus.loha 917
                    if (fim.getAmount() <= tagListing.getMrp()) {
918
                        fofoOrderItem.setSellingPrice(fim.getAmount());
919
                    } else {
920
                        throw new ProfitMandiBusinessException("Amount", fim.getAmount(),
921
                                "Sum of amount is not less than  to MRP");
922
                    }
23973 govind 923
 
33213 tejus.loha 924
                    LOGGER.info("fofoOrderItem2" + fofoOrderItem);
23973 govind 925
 
33213 tejus.loha 926
                } else {
927
                    // TODO below mop condition need to added added
928
                    fofoOrderItem.setSellingPrice(fim.getAmount());
929
                }
23973 govind 930
 
33213 tejus.loha 931
            } else {
932
                fofoOrderItem.setSellingPrice(fim.getAmount());
933
                LOGGER.info("fofoOrderItem1" + fofoOrderItem);
27819 tejbeer 934
 
33213 tejus.loha 935
            }
936
            LOGGER.info("fofoOrderItem" + fofoOrderItem);
23973 govind 937
 
33213 tejus.loha 938
        }
23973 govind 939
 
33213 tejus.loha 940
        /*
941
         * for (PaymentOptionTransactionModel paymentOptionTransactionModel :
942
         * paymentOptionTransactionModels) { amount = amount +
943
         * paymentOptionTransactionModel.getAmount(); } LOGGER.info("FofoOrder amount" +
944
         * fofoOrder.getUnitPrice() + "amount" + amount); if (amount ==
945
         * fofoOrder.getUnitPrice()) {
946
         */
947
        if (paymentOptionTransactionModels.size() > 0) {
948
            List<PaymentOptionTransaction> paymentOptionTransactions = paymentOptionTransactionRepository
949
                    .selectByReferenceIdAndType(referenceId, PaymentOptionReferenceType.ORDER);
950
            Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = this
951
                    .paymentOptionIdPaymentOptionTransactionMap(paymentOptionTransactions);
952
            LOGGER.info(
953
                    "paymentOptionIdPaymentOptionTransactionMap" + paymentOptionIdPaymentOptionTransactionMap.keySet());
954
            for (PaymentOptionTransactionModel paymentOptionTransactionModel : paymentOptionTransactionModels) {
955
                if (paymentOptionIdPaymentOptionTransactionMap
956
                        .containsKey(paymentOptionTransactionModel.getPaymentOptionId())) {
23973 govind 957
 
33213 tejus.loha 958
                    PaymentOptionTransaction paymentOptionTransaction = paymentOptionIdPaymentOptionTransactionMap
959
                            .get(paymentOptionTransactionModel.getPaymentOptionId());
31739 amit.gupta 960
 
33213 tejus.loha 961
                    if (paymentOptionTransactionModel.getAmount() == 0) {
962
                        paymentOptionTransactionRepository.delete(paymentOptionTransaction);
963
                        LOGGER.info("deleted successfully");
964
                    } else {
24844 amit.gupta 965
 
33213 tejus.loha 966
                        paymentOptionTransaction.setAmount(paymentOptionTransactionModel.getAmount());
967
                        paymentOptionTransactionRepository.persist(paymentOptionTransaction);
968
                        LOGGER.info("updated successfully");
24281 amit.gupta 969
 
33213 tejus.loha 970
                    }
971
                } else {
972
                    if (paymentOptionTransactionModel.getAmount() > 0) {
973
                        PaymentOptionTransaction paymentOptionTransaction = new PaymentOptionTransaction();
974
                        paymentOptionTransaction.setReferenceId(referenceId);
975
                        paymentOptionTransaction.setReferenceType(PaymentOptionReferenceType.ORDER);
976
                        paymentOptionTransaction.setPaymentOptionId(paymentOptionTransactionModel.getPaymentOptionId());
977
                        paymentOptionTransaction.setAmount(paymentOptionTransactionModel.getAmount());
978
                        paymentOptionTransaction.setFofoId(fofoId);
979
                        paymentOptionTransaction.setCreateTimestamp(fofoOrder.getCreateTimestamp());
980
                        paymentOptionTransactionRepository.persist(paymentOptionTransaction);
981
                        LOGGER.info("inserted successfully");
982
                    }
983
                }
24281 amit.gupta 984
 
33213 tejus.loha 985
            }
24281 amit.gupta 986
 
33213 tejus.loha 987
            model.addAttribute("response1", mvcResponseSender.createResponseString(true));
988
        }
989
        /*
990
         * else
991
         *
992
         * { throw new ProfitMandiBusinessException("Amount", amount,
993
         * "Sum of amount is not equal to total amount"); }
994
         */
23973 govind 995
 
33213 tejus.loha 996
        return "response";
23973 govind 997
 
33213 tejus.loha 998
    }
24105 govind 999
 
33437 ranu 1000
    @RequestMapping(value = "/order")
1001
    public String orderIndex(HttpServletRequest request, @RequestParam(name = "cartData") String cartData, Model model)
33213 tejus.loha 1002
            throws ProfitMandiBusinessException {
33437 ranu 1003
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1004
 
1005
        int addressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(loginDetails.getFofoId());
1006
        Address address = addressRepository.selectById(addressId);
1007
 
1008
        List<CartFofo> cartItems = orderService.cartCheckout(cartData);
1009
        Set<Integer> itemIds = new HashSet<>();
1010
        List<Integer> poIds = new ArrayList<>();
1011
        List<Integer> poItemIds = new ArrayList<>();
1012
        for (CartFofo cartFofo : cartItems) {
1013
            itemIds.add(cartFofo.getItemId());
1014
            if (cartFofo.getPoId() != 0) {
1015
                poIds.add(cartFofo.getPoId());
1016
                poItemIds.add(cartFofo.getPoItemId());
1017
            }
1018
        }
1019
 
1020
        PendingOrder po = null;
1021
        Customer customer = null;
1022
        PendingOrderItem poi = null;
1023
        Map<Integer, PriceModel> mopPriceMap = pricingService.getPurchasePriceMopPriceNotFound(itemIds,
1024
                loginDetails.getFofoId());
1025
        List<Integer> paymentOptionIds = fofoPartnerPaymentOptionRepository
1026
                .selectPaymentOptionIdsByFofoId(loginDetails.getFofoId());
1027
 
1028
        if (!poIds.isEmpty()) {
1029
            po = pendingOrderRepository.selectById(poIds.get(0));
1030
            customer = customerRepository.selectById(po.getCustomerId());
1031
            if (!offlineOrders.contains(po.getPayMethod())) {
1032
                paymentOptionIds.add(23);
1033
            }
1034
        }
1035
 
1036
        if (!poItemIds.isEmpty()) {
1037
            poi = pendingOrderItemRepository.selectById(poItemIds.get(0));
1038
        }
1039
 
1040
        // List<PaymentOption> paymentOptions = paymentOptionRepository.selectByIds(new
1041
        // HashSet<>(paymentOptionIds));
1042
 
1043
        List<PaymentOption> paymentOptions = paymentOptionRepository.selectActiveOption();
1044
 
1045
        LOGGER.info("pendingOrder" + po);
1046
        LOGGER.info("pendingOrderItem" + poi);
1047
 
1048
        int onlineSellingPrice = 0;
1049
        Map<Integer, PendingOrderItem> itemIdAndPoiMap = new HashMap<>();
1050
 
1051
        if (po != null) {
1052
            List<PendingOrderItem> pendingOrderItems = pendingOrderItemRepository.selectByOrderId(po.getId());
1053
            if (!(po.getPayMethod().equals("EMIOD") || po.getPayMethod().equals("POD"))) {
1054
                for (CartFofo cartItem : cartItems) {
1055
                    PendingOrderItem pendingOItem = pendingOrderItemRepository.selectById(cartItem.getPoItemId());
1056
                    PendingOrderPlan pendingOrderPlan = pendingOrderPlanRepository.selectByPoid(cartItem.getPoItemId());
1057
                    if (pendingOrderPlan != null) {
1058
                        onlineSellingPrice += pendingOItem.getSellingPrice() * pendingOItem.getQuantity() + pendingOrderPlan.getPremiumPrice() * pendingOItem.getQuantity();
1059
                    } else {
1060
                        onlineSellingPrice += pendingOItem.getSellingPrice() * pendingOItem.getQuantity();
1061
                    }
1062
                }
1063
            }
1064
 
1065
            itemIdAndPoiMap = pendingOrderItems.stream().collect(Collectors.toMap(x -> x.getItemId(), x -> pendingOrderItemRepository.selectById(x.getId())));
1066
        }
1067
 
33795 ranu 1068
 
1069
//        get the list of customer item for every item code start here
1070
//        ...............................................................
1071
 
1072
        LocalDateTime todayDate = LocalDateTime.now();
1073
        LocalDate todayDate2 = LocalDate.now();
1074
 
1075
        Map<Integer, List<CustomerOfferItem>> offerItemMap = new HashMap<>();
1076
        Map<Integer, List<WebOffer>> webOfferMap = new HashMap<>();
1077
 
1078
        List<CustomerOffer> customerOffers = customerOfferRepository.selectOffersByDate(todayDate);
1079
        List<Integer> customerOfferIds = customerOffers.stream().map(x -> x.getId()).distinct().collect(Collectors.toList());
34788 ranu 1080
        /*for (CartFofo cartItem : cartItems) {
33795 ranu 1081
            Item item = itemRepository.selectById(cartItem.getItemId());
33907 amit.gupta 1082
            if (customerOfferIds.size() > 0) {
33795 ranu 1083
 
33907 amit.gupta 1084
                List<CustomerOfferItem> customerOfferItems = customerOfferItemRepository.selectByOfferIds(customerOfferIds, item.getCatalogItemId(), todayDate2);
33795 ranu 1085
 
33907 amit.gupta 1086
                List<CustomerOfferItem> filteredCustomerOfferItems = customerOfferItems.stream()
1087
                        .filter(x -> x.getEndDate() != null && !x.getEndDate().isBefore(todayDate2))
1088
                        .collect(Collectors.toList());
33795 ranu 1089
 
33907 amit.gupta 1090
                offerItemMap.put(item.getId(), filteredCustomerOfferItems);
1091
            }
33818 ranu 1092
 
33907 amit.gupta 1093
 
33795 ranu 1094
            List<WebOffer> webOffers = webOfferRepository.selectAllActiveOffers().get(item.getCatalogItemId());
1095
            webOfferMap.put(item.getId(), webOffers);
34788 ranu 1096
        }*/
1097
 
1098
 
1099
        Map<Integer, ItemWiseCustomerOfferSummaryModel> offerItemSummaryMap = new HashMap<>();
1100
 
1101
        for (CartFofo cartItem : cartItems) {
1102
            Item item = itemRepository.selectById(cartItem.getItemId());
34838 amit 1103
            List<CustomerOfferItem> customerOfferItems = null;
1104
            if (customerOfferIds.size() > 0) {
1105
                customerOfferItems = customerOfferItemRepository
1106
                        .selectByOfferIds(customerOfferIds, item.getCatalogItemId(), todayDate2)
1107
                        .stream()
1108
                        .filter(x -> x.getEndDate() != null && !x.getEndDate().isBefore(todayDate2))
1109
                        .collect(Collectors.toList());
1110
            }
34788 ranu 1111
 
1112
 
1113
            ItemWiseCustomerOfferSummaryModel summary = new ItemWiseCustomerOfferSummaryModel();
1114
            summary.setItemId(item.getId());
1115
            summary.setCatalogId(item.getCatalogItemId());
1116
 
34838 amit 1117
            if (customerOfferItems != null) {
1118
                for (CustomerOfferItem coi : customerOfferItems) {
1119
                    String key = coi.getOfferType().name() + "-" + coi.getCustomerOfferId();
34788 ranu 1120
 
34838 amit 1121
                    ItemWiseCustomerOfferSummaryModel.OfferTypeSummary typeSummary =
1122
                            summary.getOfferTypeMap().computeIfAbsent(key, k -> {
1123
                                ItemWiseCustomerOfferSummaryModel.OfferTypeSummary ts = new ItemWiseCustomerOfferSummaryModel.OfferTypeSummary();
1124
                                ts.setOfferType(coi.getOfferType());
1125
                                ts.setCustomerOfferId(coi.getCustomerOfferId());
1126
                                return ts;
1127
                            });
34788 ranu 1128
 
34838 amit 1129
                    typeSummary.setTotalSchemePayout(typeSummary.getTotalSchemePayout() + coi.getSchemePayout());
1130
                    typeSummary.setTotalDealerPayout(typeSummary.getTotalDealerPayout() + coi.getDealerPayout());
1131
                    typeSummary.getDescriptions().add(coi.getAdditionalInfo());
1132
                    typeSummary.getOfferItemIds().add(coi.getId());
1133
                }
34788 ranu 1134
            }
1135
 
1136
            offerItemSummaryMap.put(item.getId(), summary);
33795 ranu 1137
        }
1138
 
34788 ranu 1139
 
33795 ranu 1140
//        get the list of customer item for every item code end here
1141
//        ...............................................................
1142
 
33437 ranu 1143
        LOGGER.info("itemIdAndPoiMap {}", itemIdAndPoiMap);
1144
        LOGGER.info("mopPriceMap {}", mopPriceMap);
1145
        model.addAttribute("stateNames",
1146
                stateRepository.selectAll().stream().map(x -> x.getName()).collect(Collectors.toList()));
1147
        model.addAttribute("retailerStateName", address.getState());
1148
        model.addAttribute("pendingPOCustomer", gson.toJson(customer));
1149
        model.addAttribute("pendingPO", gson.toJson(po));
1150
 
1151
        model.addAttribute("cartItems", cartItems);
1152
        model.addAttribute("pendingOrder", po);
1153
        model.addAttribute("pendingOrderItem", poi);
1154
        model.addAttribute("itemIdAndPoiMap", itemIdAndPoiMap);
1155
        model.addAttribute("onlineSellingPrice", onlineSellingPrice);
1156
 
1157
        model.addAttribute("mopPriceMap", mopPriceMap);
1158
        model.addAttribute("paymentOptions", paymentOptions);
1159
        model.addAttribute("accessoriesDeals", accessoriesDeals);
33795 ranu 1160
        model.addAttribute("webOfferMap", webOfferMap);
34788 ranu 1161
        model.addAttribute("offerItemSummaryMap", offerItemSummaryMap);
33437 ranu 1162
        return "order-index";
1163
    }
1164
 
1165
    private Map<String, List<MobileInsurancePlan>> getPlans(float sellingPrice, int itemId, int poiId)
1166
            throws ProfitMandiBusinessException {
33213 tejus.loha 1167
        try {
33437 ranu 1168
            Map<String, List<MobileInsurancePlan>> productDurationPlans = new HashMap<>();
1169
            PendingOrderPlan pendingOrderPlan = null;
1170
            if (poiId > 0) {
1171
                pendingOrderPlan = pendingOrderPlanRepository.selectByPoid(poiId);
1172
            }
1173
            if (pendingOrderPlan != null) {
33715 ranu 1174
                MobileInsurancePlan productDurationPlan = insuranceService.getPlanById(String.valueOf(pendingOrderPlan.getPlanId()), sellingPrice);
33437 ranu 1175
                productDurationPlans.put(pendingOrderPlan.getPlanName(), Collections.singletonList(productDurationPlan));
1176
 
1177
            } else {
1178
                productDurationPlans = insuranceService.getAllPlans(itemId,
1179
                        sellingPrice, false);
1180
            }
1181
 
33213 tejus.loha 1182
            return productDurationPlans;
1183
        } catch (Exception e) {
1184
            LOGGER.info(e, e);
1185
            throw new ProfitMandiBusinessException("Fetch Insurance Plans", "Insurance",
1186
                    "Could not fetch insurance Plans");
1187
        }
24105 govind 1188
 
33213 tejus.loha 1189
    }
23973 govind 1190
 
33795 ranu 1191
 
1192
    @GetMapping("/getItemWiseUpgradeOffer")
1193
    public String getItemWiseUpgradeOffer(HttpServletRequest request, @RequestParam int itemId, Model model)
1194
            throws ProfitMandiBusinessException {
1195
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1196
 
1197
        Item item = itemRepository.selectById(itemId);
1198
 
1199
        LocalDateTime todayDate = LocalDateTime.now();
1200
        LocalDate todayDate2 = LocalDate.now();
1201
 
1202
        List<CustomerOffer> customerOffers = customerOfferRepository.selectOffersByDate(todayDate);
1203
        Map<Integer, CustomerOffer> customerOfferMap = customerOffers.stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
1204
        List<Integer> customerOfferIds = customerOffers.stream().map(x -> x.getId()).distinct().collect(Collectors.toList());
1205
        List<CustomerOfferItem> customerOfferItems = customerOfferItemRepository.selectByOfferIds(customerOfferIds, item.getCatalogItemId(), todayDate2);
1206
 
33818 ranu 1207
        List<CustomerOfferItem> filteredCustomerOfferItems = customerOfferItems.stream()
33822 ranu 1208
                .filter(x -> x.getEndDate() != null && !x.getEndDate().isBefore(todayDate2))
33818 ranu 1209
                .collect(Collectors.toList());
1210
 
33795 ranu 1211
        List<WebOffer> webOffers = webOfferRepository.selectAllActiveOffers().get(item.getCatalogItemId());
1212
 
1213
        model.addAttribute("webOffers", webOffers);
1214
        model.addAttribute("customerOfferMap", customerOfferMap);
33818 ranu 1215
        model.addAttribute("customerOfferItems", filteredCustomerOfferItems);
33795 ranu 1216
 
1217
        return "upgrade-customer-offer-model";
1218
    }
1219
 
33213 tejus.loha 1220
    @GetMapping("/insuranceDetails")
1221
    public String getInsuranceDetails(HttpServletRequest request,
1222
                                      @RequestParam(name = "offset", defaultValue = "0") int offset,
1223
                                      @RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
1224
            throws ProfitMandiBusinessException {
1225
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1226
        long size = 0;
1227
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerId(loginDetails.getFofoId(),
1228
                offset, limit);
1229
        size = insurancePolicyRepository.selectCountByRetailerId(loginDetails.getFofoId());
1230
        Map<Integer, String> providerPolicyNameAndIdMap = insuranceProviderRepository
1231
                .selectByIds(insurancePolicies.stream().map(x -> x.getProviderId()).collect(Collectors.toSet()))
1232
                .stream().collect(Collectors.toMap(InsuranceProvider::getId, InsuranceProvider::getName));
1233
        if (size < limit) {
1234
            model.addAttribute("end", offset + size);
1235
        } else {
1236
            model.addAttribute("end", offset + limit);
1237
        }
1238
        model.addAttribute("start", offset + 1);
1239
        model.addAttribute("size", size);
1240
        model.addAttribute("insurancePolicies", insurancePolicies);
1241
        model.addAttribute("providerPolicyNameAndIdMap", providerPolicyNameAndIdMap);
1242
        return "insurance-details";
1243
    }
28339 tejbeer 1244
 
33213 tejus.loha 1245
    @GetMapping("/insuranceDetailsPaginated")
1246
    public String getInsuranceDetailsPaginated(HttpServletRequest request,
1247
                                               @RequestParam(name = "offset", defaultValue = "0") int offset,
1248
                                               @RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
1249
            throws ProfitMandiBusinessException {
1250
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1251
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerId(loginDetails.getFofoId(),
1252
                offset, limit);
1253
        Map<Integer, String> providerPolicyNameAndIdMap = insuranceProviderRepository
1254
                .selectByIds(insurancePolicies.stream().map(x -> x.getProviderId()).collect(Collectors.toSet()))
1255
                .stream().collect(Collectors.toMap(InsuranceProvider::getId, InsuranceProvider::getName));
1256
        model.addAttribute("insurancePolicies", insurancePolicies);
1257
        model.addAttribute("providerPolicyNameAndIdMap", providerPolicyNameAndIdMap);
1258
        return "insurance-details-paginated";
1259
    }
23973 govind 1260
 
33213 tejus.loha 1261
    @GetMapping("/getMouForm")
1262
    public String getMouForm(HttpServletRequest request, Model model) throws Exception {
1263
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
21985 kshitij.so 1264
 
33213 tejus.loha 1265
        Mou mou = mouRepository.selectByFofoId(loginDetails.getFofoId());
1266
        if (mou != null) {
1267
            if (mou.getUpdateTimestamp().getMonth().equals(LocalDateTime.now().getMonth())) {
1268
                model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1269
            } else {
1270
                model.addAttribute("response1", mvcResponseSender.createResponseString(false));
1271
            }
32238 amit.gupta 1272
 
33213 tejus.loha 1273
        } else {
1274
            model.addAttribute("response1", mvcResponseSender.createResponseString(false));
32238 amit.gupta 1275
 
33213 tejus.loha 1276
        }
1277
        return "response";
32238 amit.gupta 1278
 
33213 tejus.loha 1279
    }
23973 govind 1280
 
33213 tejus.loha 1281
    @GetMapping("/pendingOrders")
1282
    public String getPendingOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
1283
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1284
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
1285
        Mou mou = mouRepository.selectByFofoId(loginDetails.getFofoId());
1286
        if (mou == null) {
1287
            mou = new Mou();
1288
            mou.setFofoId(loginDetails.getFofoId());
1289
            mou.setCreateTimestamp(LocalDateTime.now());
1290
            mou.setUpdateTimestamp(LocalDateTime.now());
1291
            mouRepository.persist(mou);
1292
        } else if (!mou.getUpdateTimestamp().getMonth().equals(LocalDateTime.now().getMonth())) {
1293
            mou.setUpdateTimestamp(LocalDateTime.now());
1294
        }
24844 amit.gupta 1295
 
33213 tejus.loha 1296
        List<PendingOrderItem> pendingOrderItems = pendingOrderItemRepository.selectOrderItemByStatusAndFofoId(OrderStatus.PROCESSING,
1297
                loginDetails.getFofoId());
23973 govind 1298
 
34387 vikas.jang 1299
        Map<String, List<PendingOrderPlan>> pendingOrderPlansMap = pendingOrderPlanRepository.selectAll().stream()
1300
                .collect(Collectors.groupingBy(PendingOrderPlan::getPlanId));
33213 tejus.loha 1301
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItems, loginDetails.getFofoId());
1302
        model.addAttribute("inventoryMap", map.get("inventoryMap"));
33437 ranu 1303
        model.addAttribute("pendingOrderPlansMap", pendingOrderPlansMap);
33213 tejus.loha 1304
        model.addAttribute("pendingOrderItems", (List<PendingOrderItem>) map.get("pendingOrderItems"));
23973 govind 1305
 
33213 tejus.loha 1306
        model.addAttribute("isAdmin", isAdmin);
1307
        return "pending_fofo_order";
25092 amit.gupta 1308
 
33213 tejus.loha 1309
    }
25092 amit.gupta 1310
 
33400 ranu 1311
    @RequestMapping(value = "/create-order", method = RequestMethod.POST)
1312
    public String createOrder(HttpServletRequest request, @RequestBody CreateOrderRequest createOrderRequest,
34194 ranu 1313
                              Model model) throws Exception {
33400 ranu 1314
        // throw new ProfitMandiBusinessException("Billing is on hold temporarily",
1315
        // "Billing is on hold temporarily", "Billing is on hold temporarily");
1316
        LOGGER.info("request at uri {}", request.getRequestURI());
1317
        LOGGER.info("request body {}", createOrderRequest);
1318
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
1319
        int fofoOrderId = orderService.createOrder(createOrderRequest, fofoDetails.getFofoId(), accessoriesDeals);
34479 tejus.loha 1320
//        try {
1321
//            scratchService.processScratchOffer(fofoOrderId, createOrderRequest.getPaymentOptions(), createOrderRequest.getFofoOrderItems());
1322
//        } catch (Exception e) {
1323
//            LOGGER.info("Exception during processScratchOffer - " + e.getMessage());
1324
//        }
1325
 
34179 tejus.loha 1326
        LOGGER.info("Order has been created successfully...");
33400 ranu 1327
        return "redirect:/get-order/?orderId=" + fofoOrderId;
1328
    }
1329
 
33213 tejus.loha 1330
    @GetMapping("/billedOrders")
1331
    public String getBilledOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
1332
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1333
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
25092 amit.gupta 1334
 
33400 ranu 1335
        List<PendingOrderItem> pendingOrderItems;
23973 govind 1336
 
33213 tejus.loha 1337
        if (isAdmin) {
27861 tejbeer 1338
 
33400 ranu 1339
            pendingOrderItems = pendingOrderItemRepository.selectOrderItemByStatus(OrderStatus.BILLED);
27861 tejbeer 1340
 
33213 tejus.loha 1341
        } else {
33400 ranu 1342
            pendingOrderItems = pendingOrderItemRepository.selectOrderItemByStatusAndFofoId(OrderStatus.BILLED,
33213 tejus.loha 1343
                    loginDetails.getFofoId());
33400 ranu 1344
 
1345
 
33213 tejus.loha 1346
        }
27861 tejbeer 1347
 
33400 ranu 1348
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItems, loginDetails.getFofoId());
1349
        model.addAttribute("pendingOrderItems", (List<PendingOrderItem>) map.get("pendingOrderItems"));
27861 tejbeer 1350
 
33213 tejus.loha 1351
        model.addAttribute("isAdmin", isAdmin);
1352
        return "billed_order_item";
1353
    }
27861 tejbeer 1354
 
33213 tejus.loha 1355
    @GetMapping("/settledOrders")
1356
    public String getSettledOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
1357
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1358
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
27861 tejbeer 1359
 
33213 tejus.loha 1360
        List<PendingOrderItem> pendingOrderItem = null;
27861 tejbeer 1361
 
33213 tejus.loha 1362
        if (isAdmin) {
24105 govind 1363
 
33213 tejus.loha 1364
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatus(OrderStatus.SETTLED);
24105 govind 1365
 
33213 tejus.loha 1366
        } else {
1367
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatusAndFofoId(OrderStatus.SETTLED,
1368
                    loginDetails.getFofoId());
1369
        }
24105 govind 1370
 
33213 tejus.loha 1371
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItem, loginDetails.getFofoId());
24105 govind 1372
 
33400 ranu 1373
        model.addAttribute("pendingOrderItems", (List<PendingOrderItem>) map.get("pendingOrderItems"));
33213 tejus.loha 1374
        model.addAttribute("isAdmin", isAdmin);
1375
        return "settled_order_item";
1376
    }
27861 tejbeer 1377
 
33213 tejus.loha 1378
    @GetMapping("/unsettledOrders")
1379
    public String getunsettledOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
1380
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1381
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
24105 govind 1382
 
33213 tejus.loha 1383
        List<PendingOrderItem> pendingOrderItem = null;
27861 tejbeer 1384
 
33213 tejus.loha 1385
        if (isAdmin) {
24105 govind 1386
 
33213 tejus.loha 1387
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatus(OrderStatus.UNSETTLED);
27861 tejbeer 1388
 
33213 tejus.loha 1389
        } else {
1390
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatusAndFofoId(OrderStatus.UNSETTLED,
1391
                    loginDetails.getFofoId());
1392
        }
24440 amit.gupta 1393
 
33213 tejus.loha 1394
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItem, loginDetails.getFofoId());
25726 amit.gupta 1395
 
33400 ranu 1396
        model.addAttribute("pendingOrderItems", (List<PendingOrderItem>) map.get("pendingOrderItems"));
33213 tejus.loha 1397
        model.addAttribute("isAdmin", isAdmin);
1398
        return "unsettled_order_item";
1399
    }
24880 govind 1400
 
33213 tejus.loha 1401
    @GetMapping("/getPendingOrderItem")
1402
    public String getPendingOrderItem(HttpServletRequest request, @RequestParam int orderId, Model model)
1403
            throws ProfitMandiBusinessException {
1404
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1405
        Map<Integer, Item> itemMap = new HashMap<>();
1406
        Map<Integer, CurrentInventorySnapshot> inventoryMap = new HashMap<>();
1407
        PendingOrder pendingPO = pendingOrderRepository.selectById(orderId);
1408
        Customer customer = customerRepository.selectById(pendingPO.getCustomerId());
1409
        List<PendingOrderItem> pendingOrderItems = pendingOrderItemRepository.selectByOrderId(orderId);
1410
        for (PendingOrderItem pendingOrderItem : pendingOrderItems) {
1411
            Item item = itemRepository.selectById(pendingOrderItem.getItemId());
1412
            CurrentInventorySnapshot cis = currentInventorySnapshotRepository
1413
                    .selectByItemAndFofoId(pendingOrderItem.getItemId(), pendingPO.getFofoId());
1414
            itemMap.put(pendingOrderItem.getItemId(), item);
1415
            LOGGER.info("cis" + cis);
1416
            inventoryMap.put(pendingOrderItem.getItemId(), cis);
1417
        }
28339 tejbeer 1418
 
33213 tejus.loha 1419
        LOGGER.info("inventoryMap" + inventoryMap);
1420
        model.addAttribute("pendingOrderItems", pendingOrderItems);
1421
        model.addAttribute("itemMap", itemMap);
1422
        model.addAttribute("inventoryMap", inventoryMap);
1423
        model.addAttribute("pendingPO", gson.toJson(pendingPO));
1424
        model.addAttribute("pendingPOCustomer", gson.toJson(customer));
1425
        model.addAttribute("isAdmin", roleManager.isAdmin(loginDetails.getRoleIds()));
1426
        return "pending-order-item";
1427
    }
28339 tejbeer 1428
 
33213 tejus.loha 1429
    @RequestMapping(value = "/getPendingOrderItemById", method = RequestMethod.GET)
1430
    public String getPendingOrderItemById(HttpServletRequest request, @RequestParam int id, Model model)
1431
            throws Exception {
27046 tejbeer 1432
 
33213 tejus.loha 1433
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
1434
        model.addAttribute("pendingOrderItem", pendingOrderItem);
1435
        return "cancel-pending-order";
1436
    }
27046 tejbeer 1437
 
33213 tejus.loha 1438
    @RequestMapping(value = "/getPendingOrderChangePartnerById", method = RequestMethod.GET)
33367 ranu 1439
    public String getPendingOrderChangePartnerById(HttpServletRequest request, @RequestParam int id, @RequestParam String pinCode, Model model)
33213 tejus.loha 1440
            throws Exception {
28350 tejbeer 1441
 
33213 tejus.loha 1442
        PendingOrder pendingOrder = pendingOrderRepository.selectById(id);
33374 ranu 1443
        Map<Integer, CustomRetailer> customRetailersMap = retailerService.getFofoRetailers(true);
33213 tejus.loha 1444
        model.addAttribute("customRetailersMap", customRetailersMap);
1445
        model.addAttribute("pendingOrder", pendingOrder);
1446
        return "change-partner-po";
1447
    }
28358 tejbeer 1448
 
33213 tejus.loha 1449
    @RequestMapping(value = "/changePendingOrderPartner", method = RequestMethod.POST)
1450
    public String changePendingOrderPartner(HttpServletRequest request, @RequestParam int id, @RequestParam int fofoId,
1451
                                            Model model) throws Exception {
28350 tejbeer 1452
 
33213 tejus.loha 1453
        PendingOrder pendingOrder = pendingOrderRepository.selectById(id);
1454
        pendingOrder.setFofoId(fofoId);
1455
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28339 tejbeer 1456
 
33213 tejus.loha 1457
        return "response";
1458
    }
28339 tejbeer 1459
 
33213 tejus.loha 1460
    @RequestMapping(value = "/cancelPendingOrderItem", method = RequestMethod.POST)
1461
    public String cancelPendingOrderItem(HttpServletRequest request, @RequestParam int id, @RequestParam String reason,
1462
                                         Model model) throws Exception {
28339 tejbeer 1463
 
33213 tejus.loha 1464
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1465
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
28339 tejbeer 1466
 
33213 tejus.loha 1467
        pendingOrderItem.setStatus(OrderStatus.CANCELLED);
1468
        pendingOrderItem.setStatusDescription(loginDetails.getEmailId());
1469
        pendingOrderItem.setRemark(reason);
1470
        pendingOrderItem.setCancelledTimestamp(LocalDateTime.now());
1471
        PendingOrder pendingOrder = pendingOrderRepository.selectById(pendingOrderItem.getOrderId());
27046 tejbeer 1472
 
33213 tejus.loha 1473
        List<OrderStatus> status = pendingOrderItemRepository.selectByOrderId(pendingOrderItem.getOrderId()).stream()
1474
                .map(x -> x.getStatus()).collect(Collectors.toList());
28339 tejbeer 1475
 
33213 tejus.loha 1476
        Customer customer = customerRepository.selectById(pendingOrder.getCustomerId());
26647 tejbeer 1477
 
33213 tejus.loha 1478
        List<Integer> catalogIds = new ArrayList<>();
28339 tejbeer 1479
 
33213 tejus.loha 1480
        Item item = itemRepository.selectById(pendingOrderItem.getItemId());
1481
        pendingOrderItem.setItemName(item.getItemDescription());
1482
        catalogIds.add(item.getCatalogItemId());
28339 tejbeer 1483
 
33213 tejus.loha 1484
        Map<Integer, JSONObject> contentMap = commonSolrService.getContentByCatalogIds(catalogIds);
1485
        JSONObject jsonObj = contentMap.get(item.getCatalogItemId());
1486
        pendingOrderItem.setImgUrl(jsonObj.getString("imageUrl_s"));
1487
        pendingOrder.setPendingOrderItems(Arrays.asList(pendingOrderItem));
1488
        CustomerAddress customerAddress = customerAddressRepository.selectById(pendingOrder.getCustomerAddressId());
28339 tejbeer 1489
 
33213 tejus.loha 1490
        DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy h:mm a");
28339 tejbeer 1491
 
33213 tejus.loha 1492
        Map<String, Object> emailModel = new HashMap<>();
1493
        emailModel.put("customer", customerAddress);
1494
        emailModel.put("pendingOrder", pendingOrder);
1495
        emailModel.put("date", dateTimeFormatter);
1496
        LOGGER.info("emal" + customer.getEmailId());
1497
        String[] customerEmail = null;
1498
        if (customer.getEmailId() != null && !customer.getEmailId().isEmpty()) {
1499
            customerEmail = new String[]{customer.getEmailId()};
28339 tejbeer 1500
 
34211 vikas.jang 1501
            List<String> bccTo = Arrays.asList("vikas.jangra@smartdukaan.com");
28339 tejbeer 1502
 
33213 tejus.loha 1503
            emailService.sendMailWithAttachments("Order Cancellation", "order-cancellation.vm", emailModel,
1504
                    customerEmail, null, bccTo.toArray(new String[0]));
28339 tejbeer 1505
 
33213 tejus.loha 1506
        }
28339 tejbeer 1507
 
33213 tejus.loha 1508
        if (!status.contains(OrderStatus.PENDING) && !status.contains(OrderStatus.PROCESSING)
1509
                && !status.contains(OrderStatus.BILLED) && !status.contains(OrderStatus.UNSETTLED)
1510
                && !status.contains(OrderStatus.CLAIMED)) {
1511
            pendingOrder.setStatus(OrderStatus.CLOSED);
1512
        }
1513
        pendingOrderItemRepository.persist(pendingOrderItem);
28339 tejbeer 1514
 
33213 tejus.loha 1515
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28339 tejbeer 1516
 
33213 tejus.loha 1517
        return "response";
1518
    }
28339 tejbeer 1519
 
33400 ranu 1520
    @GetMapping("/claimedOrders")
1521
    public String getclaimedOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
33213 tejus.loha 1522
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
33400 ranu 1523
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
1524
        List<Integer> fofoIds = fofoStoreRepository.selectActiveStores().stream().map(x -> x.getId())
1525
                .collect(Collectors.toList());
28339 tejbeer 1526
 
33400 ranu 1527
        List<PendingOrderItem> pendingOrderItem = null;
28339 tejbeer 1528
 
33400 ranu 1529
        if (isAdmin) {
28339 tejbeer 1530
 
33400 ranu 1531
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatus(OrderStatus.CLAIMED);
1532
            Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
28339 tejbeer 1533
 
33400 ranu 1534
            Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
1535
                    .filter(x -> x != null).collect(Collectors.toList()).stream()
1536
                    .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
1537
            model.addAttribute("customRetailersMap", customRetailersMap);
28339 tejbeer 1538
 
33400 ranu 1539
        } else {
1540
            pendingOrderItem = pendingOrderItemRepository.selectOrderItemByStatusAndFofoId(OrderStatus.CLAIMED,
1541
                    loginDetails.getFofoId());
1542
        }
30426 tejbeer 1543
 
33400 ranu 1544
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItem, loginDetails.getFofoId());
28339 tejbeer 1545
 
33400 ranu 1546
        model.addAttribute("pendingOrderItems", map.get("pendingOrderItems"));
1547
        model.addAttribute("isAdmin", isAdmin);
1548
        return "claim_raised_order_item";
33213 tejus.loha 1549
    }
27046 tejbeer 1550
 
33213 tejus.loha 1551
    @RequestMapping(value = "/raiseClaimOrderItem", method = RequestMethod.POST)
1552
    public String raiseClaimOrderItem(HttpServletRequest request, @RequestParam int id, Model model) throws Exception {
28352 tejbeer 1553
 
33213 tejus.loha 1554
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1555
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
1556
        PendingOrder pendingOrder = pendingOrderRepository.selectById(pendingOrderItem.getOrderId());
28437 tejbeer 1557
 
33213 tejus.loha 1558
        if (pendingOrder.getTotalAmount() == pendingOrder.getPaidAmount()) {
1559
            pendingOrderItem.setStatus(OrderStatus.CLAIMED);
1560
            pendingOrderItem.setClaimedTimestamp(LocalDateTime.now());
28437 tejbeer 1561
 
33213 tejus.loha 1562
        }
1563
        pendingOrderItemRepository.persist(pendingOrderItem);
1564
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28437 tejbeer 1565
 
33213 tejus.loha 1566
        return "response";
1567
    }
28437 tejbeer 1568
 
33213 tejus.loha 1569
    @RequestMapping(value = "/verifyOrderItem", method = RequestMethod.POST)
1570
    public String verifyOrderItem(HttpServletRequest request, @RequestParam int id, Model model) throws Exception {
28437 tejbeer 1571
 
33213 tejus.loha 1572
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1573
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
1574
        pendingOrderItem.setVerifiedTimestamp(LocalDateTime.now());
28352 tejbeer 1575
 
33213 tejus.loha 1576
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
26721 tejbeer 1577
 
33213 tejus.loha 1578
        return "response";
1579
    }
26721 tejbeer 1580
 
33213 tejus.loha 1581
    @RequestMapping(value = "/cancelOrderByInvoice", method = RequestMethod.POST)
1582
    public String cancelOrder(HttpServletRequest request, @RequestParam List<String> invoiceNumbers, Model model)
1583
            throws Exception {
1584
        orderService.cancelOrder(invoiceNumbers);
1585
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
26721 tejbeer 1586
 
33213 tejus.loha 1587
        return "response";
1588
    }
28352 tejbeer 1589
 
33213 tejus.loha 1590
    @RequestMapping(value = "/getOnlineOrder", method = RequestMethod.GET)
1591
    public String cancelOrder(HttpServletRequest request, Model model) throws Exception {
1592
        return "online-order";
1593
    }
28352 tejbeer 1594
 
33400 ranu 1595
    @RequestMapping(value = "/deliveredPendingOrderItem", method = RequestMethod.POST)
1596
    public String deliveredPendingOrderItem(HttpServletRequest request, @RequestParam(name = "id") int pendingOrderItemId, Model model)
1597
            throws Exception {
1598
 
1599
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1600
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(pendingOrderItemId);
1601
        PendingOrder pendingOrder = pendingOrderRepository.selectById(pendingOrderItem.getOrderId());
1602
 
1603
        //Prepaid payment successful
1604
        if (pendingOrder.getTotalAmount() == pendingOrder.getPaidAmount()) {
1605
            //pendingOrderItem.setStatus(OrderStatus.UNSETTLED);
1606
//            pendingOrderItem.setSettled(false);
1607
            pendingOrderItem.setStatus(OrderStatus.CLAIMED);
1608
            pendingOrderItem.setClaimedTimestamp(LocalDateTime.now());
1609
        } else {
1610
            pendingOrderItem.setStatus(OrderStatus.SETTLED);
1611
        }
1612
        pendingOrderItem.setDeliveredTimestamp(LocalDateTime.now());
1613
 
1614
        List<OrderStatus> pendingOrderItemStatusList = pendingOrderItemRepository.selectByOrderId(pendingOrderItem.getOrderId()).stream()
1615
                .map(x -> x.getStatus()).collect(Collectors.toList());
1616
 
1617
        List<Integer> catalogIds = new ArrayList<>();
1618
 
1619
        Item item = itemRepository.selectById(pendingOrderItem.getItemId());
1620
        pendingOrderItem.setItemName(item.getItemDescription());
1621
        catalogIds.add(item.getCatalogItemId());
1622
 
1623
        Map<Integer, JSONObject> contentMap = commonSolrService.getContentByCatalogIds(catalogIds);
1624
        JSONObject jsonObj = contentMap.get(item.getCatalogItemId());
1625
        pendingOrderItem.setImgUrl(jsonObj.getString("imageUrl_s"));
1626
        pendingOrder.setPendingOrderItems(Arrays.asList(pendingOrderItem));
1627
        CustomerAddress customerAddress = customerAddressRepository.selectById(pendingOrder.getCustomerAddressId());
1628
        DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy h:mm a");
1629
        Map<String, Object> emailModel = new HashMap<>();
1630
        emailModel.put("customer", customerAddress);
1631
        emailModel.put("pendingOrder", pendingOrder);
1632
        emailModel.put("date", dateTimeFormatter);
1633
        Customer customer = customerRepository.selectById(pendingOrder.getCustomerId());
1634
        String[] customerEmail = null;
1635
        if (customer.getEmailId() != null && !customer.getEmailId().isEmpty()) {
1636
            customerEmail = new String[]{customer.getEmailId()};
34211 vikas.jang 1637
            List<String> bccTo = Arrays.asList("vikas.jangra@smartdukaan.com");
33400 ranu 1638
 
1639
            emailService.sendMailWithAttachments("Order Delivered with SmartDukaan", "order-delivered.vm", emailModel,
1640
                    customerEmail, null, bccTo.toArray(new String[0]));
1641
 
1642
        }
1643
        if (!pendingOrderItemStatusList.contains(OrderStatus.PENDING) && !pendingOrderItemStatusList.contains(OrderStatus.PROCESSING)
1644
                && !pendingOrderItemStatusList.contains(OrderStatus.BILLED) && !pendingOrderItemStatusList.contains(OrderStatus.UNSETTLED)
1645
                && !pendingOrderItemStatusList.contains(OrderStatus.CLAIMED)) {
1646
            pendingOrder.setStatus(OrderStatus.CLOSED);
1647
        }
1648
        pendingOrderItemRepository.persist(pendingOrderItem);
1649
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1650
 
1651
        return "response";
1652
    }
1653
 
33213 tejus.loha 1654
    @GetMapping("/getAllOrdersByStatus")
1655
    public String getAllOrdersByStatus(HttpServletRequest request, @RequestParam OrderStatus status,
1656
                                       @RequestParam(required = false) LocalDateTime startTime,
1657
                                       @RequestParam(required = false) LocalDateTime endTime, Model model) throws ProfitMandiBusinessException {
1658
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1659
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
33437 ranu 1660
        boolean isAccountsL2AndL3 = false;
33400 ranu 1661
        if (isAdmin) {
1662
            AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
1663
            List<Position> positions = positionRepository.selectPositionByAuthId(authUser.getId());
1664
            for (Position position : positions) {
33437 ranu 1665
                if (((position.getEscalationType().equals(EscalationType.L2) || position.getEscalationType().equals(EscalationType.L3))
33400 ranu 1666
                        && position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS)) {
33437 ranu 1667
                    isAccountsL2AndL3 = true;
33400 ranu 1668
                    break;
1669
                }
1670
            }
1671
        }
1672
 
33213 tejus.loha 1673
        LOGGER.info("startTime {}", startTime);
1674
        LOGGER.info("endTime {}", endTime);
28352 tejbeer 1675
 
33213 tejus.loha 1676
        List<PendingOrderItem> pendingOrderItems;
1677
        if (startTime == null) {
33367 ranu 1678
            LocalDate date = LocalDate.now().minusDays(15);
1679
            if (status.equals(OrderStatus.PENDING)) {
1680
                pendingOrderItems = pendingOrderItemRepository.selectByStatusAndCreateTimestamp(Collections.singletonList(status), date.atStartOfDay(), LocalDateTime.now());
1681
            } else {
1682
                pendingOrderItems = pendingOrderItemRepository.selectOrderItemByStatus(status);
1683
            }
1684
 
33213 tejus.loha 1685
        } else {
1686
            List<OrderStatus> statusList = new ArrayList<>();
1687
            if (status.equals(OrderStatus.DELIVERED)) {
1688
                statusList.add(OrderStatus.SETTLED);
1689
                statusList.add(OrderStatus.UNSETTLED);
1690
            } else {
1691
                statusList.add(status);
1692
            }
1693
            pendingOrderItems = pendingOrderItemRepository.selectByStatusAndCreateTimestamp(statusList,
1694
                    startTime.toLocalDate().atStartOfDay(), endTime);
1695
        }
28352 tejbeer 1696
 
33213 tejus.loha 1697
        List<Integer> pendingOrderIds = pendingOrderItems.stream().map(x -> x.getOrderId()).collect(Collectors.toList());
28352 tejbeer 1698
 
33213 tejus.loha 1699
        List<Integer> fofoIds = pendingOrderRepository.selectByIds(pendingOrderIds)
1700
                .stream().map(x -> x.getFofoId()).distinct().collect(Collectors.toList());
28356 tejbeer 1701
 
33213 tejus.loha 1702
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
28352 tejbeer 1703
 
33213 tejus.loha 1704
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
1705
                .filter(x -> x != null).collect(Collectors.toList()).stream()
1706
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
1707
        model.addAttribute("customRetailersMap", customRetailersMap);
28352 tejbeer 1708
 
33213 tejus.loha 1709
        LOGGER.info("customRetailersMap {}", customRetailersMap);
28339 tejbeer 1710
 
33213 tejus.loha 1711
        Map<String, Object> map = pendingOrderService.getItemOrders(pendingOrderItems, 0);
32697 ranu 1712
 
33213 tejus.loha 1713
        model.addAttribute("pendingOrderItems", (List<PendingOrderItem>) map.get("pendingOrderItems"));
1714
        model.addAttribute("partnerInventoryMap", map.get("partnerInventoryMap"));
32697 ranu 1715
 
33213 tejus.loha 1716
        model.addAttribute("isAdmin", isAdmin);
33437 ranu 1717
        model.addAttribute("isAccountsL2AndL3", isAccountsL2AndL3);
33213 tejus.loha 1718
        return "online-order-item";
1719
    }
32697 ranu 1720
 
33400 ranu 1721
    @RequestMapping(value = "/onlinePaymentAddToPartnerWallet", method = RequestMethod.POST)
1722
    public String onlinePaymentAddToPartnerWallet(HttpServletRequest request, @RequestParam int id,
1723
                                                  Model model) throws Exception {
1724
        PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
1725
        PendingOrder pendingOrder = pendingOrderRepository.selectById(pendingOrderItem.getOrderId());
1726
        int fofoId = pendingOrder.getFofoId();
1727
        double deductionPayment = (pendingOrderItem.getSellingPrice() * 2.36) / 100;
1728
        walletService.addAmountToWallet(fofoId, id, WalletReferenceType.ONLINE_ORDER_PAYMENT, "Online Order Payment", pendingOrderItem.getSellingPrice(), LocalDateTime.now());
1729
        walletService.consumeAmountFromWallet(fofoId, id,
1730
                WalletReferenceType.ONLINE_GATEWAY_FEE, "Payment Gatewayfee", (float) deductionPayment, LocalDateTime.now());
1731
 
1732
        pendingOrderItem.setStatus(OrderStatus.CLOSED);
1733
        pendingOrder.setStatus(OrderStatus.CLOSED);
1734
 
1735
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1736
 
1737
        return "response";
1738
    }
1739
 
33213 tejus.loha 1740
    //TODO Tejus
1741
    @RequestMapping(value = "/getBulkOrder")
33336 tejus.loha 1742
    public String getBulkOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException, MessagingException, IOException {
33213 tejus.loha 1743
        return "bulk-order";
1744
    }
32697 ranu 1745
 
33213 tejus.loha 1746
    @PostMapping(value = "/bulkOrder/upload")
1747
    public String uploadCatalog(HttpServletRequest request, @RequestPart("file") MultipartFile file, Model model)
1748
            throws Exception {
1749
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
1750
        int authId = authRepository.selectByEmailOrMobile(fofoDetails.getEmailId()).getId();
1751
        LOGGER.info("authId - {}", authId);
1752
        bulkOrderService.parseBulkOrders(file, authId);
1753
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1754
        return "response";
1755
    }
32697 ranu 1756
 
33213 tejus.loha 1757
    // This method is use for sending all pending transaction to Transation Approval menu
1758
    @RequestMapping(value = "/transaction/pendingApprovals", method = RequestMethod.GET)
1759
    public String getTransactionApproval(HttpServletRequest request, Model model) throws Exception {
33219 tejus.loha 1760
        List<TransactionApproval> transactionApprovals = transactionApprovalRepository.selectAllPending();
1761
        LOGGER.info("list of Approval transaction Id " + transactionApprovals);
33336 tejus.loha 1762
        List<TransactionApprovalModel> approvalModelList = bulkOrderService.getAllPendingTransactionApproval();
33213 tejus.loha 1763
        model.addAttribute("approvalModelList", approvalModelList);
1764
        return "transaction/transaction-approvals";
1765
    }
33092 tejus.loha 1766
 
33213 tejus.loha 1767
    @RequestMapping(value = "transaction/approval", method = RequestMethod.PUT)
1768
    public String transactionApproval(HttpServletRequest request, Model model,
1769
                                      @RequestParam int transactionId,
1770
                                      @RequestParam String remark,
1771
                                      @RequestParam TransactionApprovalStatus transactionApprovalStatus
1772
    ) throws Exception {
1773
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1774
        AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
1775
        int approvalId = authUser.getId();
1776
        String approvedBy = authUser.getFullName();
1777
        LocalDateTime approvedOn = LocalDateTime.now();
1778
        this.updateApprovalStatus(transactionId, approvalId, approvedBy, approvedOn, remark, transactionApprovalStatus);
1779
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1780
        return "response";
1781
 
1782
    }
1783
 
33696 amit.gupta 1784
 
33213 tejus.loha 1785
    private void updateApprovalStatus(int transactionId, int approvalId, String approvedBy, LocalDateTime approvedOn, String remark, TransactionApprovalStatus transactionApprovalStatus) throws Exception {
1786
        TransactionApproval transactionApproval = transactionApprovalRepository.selectById(transactionId);
33336 tejus.loha 1787
        int retailerId = transactionRepository.selectById(transactionId).getRetailerId();
33213 tejus.loha 1788
        if (!transactionApproval.getStatus().equals(TransactionApprovalStatus.PENDING)) {
1789
            throw new ProfitMandiBusinessException("Transaction already Processed", "Transaction already Processed", "Transaction already Processed");
1790
        }
1791
        transactionApproval.setStatus(transactionApprovalStatus);
1792
        transactionApproval.setRemark(remark);
1793
        transactionApproval.setApprovalId(approvalId);
1794
        transactionApproval.setApprovedBy(approvedBy);
1795
        transactionApproval.setApprovedOn(approvedOn);
1796
        if (transactionApprovalStatus.equals(TransactionApprovalStatus.APPROVED)) {
34313 ranu 1797
            transactionService.processTransaction(transactionId, 0);
33336 tejus.loha 1798
        } else {
1799
            float totalAmount = 0;
1800
            // referense id = transaction id
1801
            // here refund the amount of an order
1802
            List<UserWalletHistory> uwhList = walletService.getAllByReference(retailerId, transactionId, WalletReferenceType.PURCHASE);
33687 amit.gupta 1803
            //Refund only if any amount is deducted from wallet for that particular Transaction
33696 amit.gupta 1804
            if (uwhList.size() > 0) {
33687 amit.gupta 1805
                totalAmount = -uwhList.get(0).getAmount();
1806
                walletService.refundToWallet(retailerId, totalAmount, transactionId, WalletReferenceType.PURCHASE, "Order canceled");
34733 amit.gupta 1807
                sdCreditService.settleBlockedLoan(transactionId, totalAmount);
33687 amit.gupta 1808
            }
33213 tejus.loha 1809
        }
1810
    }
1811
 
1812
    @RequestMapping(value = "/bulkOrderTemplate", method = RequestMethod.GET)
1813
    public ResponseEntity<?> bulkOrderTemplate() throws Exception {
1814
        List<List<?>> rows = new ArrayList<>();
1815
        rows.add(Arrays.asList("Mahaveer", "Change description for your reference", "175139287", "28264", "0", "4"));
1816
        rows.add(Arrays.asList("Mahaveer", "Price =0 means system price", "175139287", "28268", "0", "7"));
1817
        rows.add(Arrays.asList("Jas", "You give custom price also ", "171273247", "28264", "300", "3"));
1818
        org.apache.commons.io.output.ByteArrayOutputStream baos = FileUtil
1819
                .getCSVByteStream(Arrays.asList("Partner name", "Description", "Partner Id", "Item Id", "Price", "Quantity"), rows);
1820
        ResponseEntity<?> responseEntity = orderService.downloadReportInCsv(baos, rows, "Bulk order template");
1821
 
1822
        return responseEntity;
1823
 
1824
    }
34168 tejus.loha 1825
 
1826
    @Autowired
1827
    EInvoiceDetailsRepository eInvoiceDetailsRepository;
1828
 
1829
    @GetMapping("/resetIrnGeneratedPanel")
1830
    public String resetIrnGeneratedPanel() {
1831
        return "reset-irn-panel";
1832
    }
1833
 
1834
    @GetMapping("/getTransactionForIrnReset")
1835
    public String getTransactionForIrnReset(@RequestParam String invoiceNumber, Model model) throws Exception {
1836
        List<String> invoiceNumbers = Arrays.asList(invoiceNumber.split(","));
1837
        List<EInvoiceDetails> eInvoiceDetailsList = eInvoiceDetailsRepository.selectByInvoiceNumbers(invoiceNumbers);
1838
        if (invoiceNumbers.size() == eInvoiceDetailsList.size()) {
1839
            model.addAttribute("irnResetOrderModelList", new ArrayList<>());
1840
            model.addAttribute("notEligibleInvoiceNumbers", invoiceNumber);
1841
            return "eligible-irn-reset-orders";
1842
        }
1843
        Set<String> existingInvoiceInEInvoiceDtl = eInvoiceDetailsList.stream().map(x -> x.getInvoiceNumber()).collect(Collectors.toSet());
1844
        List<String> missingInvoiceInEInvoiceDtl = invoiceNumbers.stream().filter(x -> !existingInvoiceInEInvoiceDtl.contains(x)).collect(Collectors.toList());
1845
 
1846
        List<Order> orderList = orderRepository.selectByInvoiceNumbers(missingInvoiceInEInvoiceDtl).stream().filter(x -> x.getIrnGenerated() != null).collect(Collectors.toList());
1847
        Map<String, List<Order>> invoiceMap = orderList.stream().collect(Collectors.groupingBy(x -> x.getInvoiceNumber()));
1848
        Set<String> notEligibleInvoiceNumbers = new HashSet<>();
1849
        notEligibleInvoiceNumbers.addAll(existingInvoiceInEInvoiceDtl);
1850
        List<IrnResetOrderModel> irnResetOrderModelList = new ArrayList<>();
1851
        for (Map.Entry<String, List<Order>> invoiceMapEntry : invoiceMap.entrySet()) {
1852
            String invoice = invoiceMapEntry.getKey();
1853
            List<Order> orders = invoiceMapEntry.getValue();
1854
            boolean isEligible = !orders.isEmpty() && orders.stream().allMatch(x -> x.getBillingTimestamp().toLocalDate().isAfter(LocalDate.now().minusDays(5)) && x.getIrnGenerated() != null);
1855
            if (isEligible) {
1856
                Order order = orders.get(0);
1857
                FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(order.getRetailerId());
1858
 
1859
                IrnResetOrderModel irnResetOrderModel = new IrnResetOrderModel();
1860
                irnResetOrderModel.setName(partnerOnBoardingPanelRepository.selectByCode(fofoStore.getCode()).getOutLetName());
1861
                irnResetOrderModel.setInvoiceNumber(order.getInvoiceNumber());
1862
                irnResetOrderModel.setInvoiceDate(order.getBillingTimestamp());
1863
                irnResetOrderModel.setWarehouseId(ProfitMandiConstants.WAREHOUSE_MAP.get(order.getWarehouseId()));
1864
                irnResetOrderModel.setTotalOrderValue(orders.stream().mapToDouble(Order::getTotalAmount).sum());
1865
                irnResetOrderModelList.add(irnResetOrderModel);
1866
            } else {
1867
                notEligibleInvoiceNumbers.add(invoice);
1868
            }
1869
        }
1870
        model.addAttribute("irnResetOrderModelList", irnResetOrderModelList);
1871
        model.addAttribute("notEligibleInvoiceNumbers", notEligibleInvoiceNumbers.stream().collect(Collectors.joining(", ")));
1872
        return "eligible-irn-reset-orders";
1873
    }
1874
 
1875
    @PutMapping("/resetOrdersIrn")
1876
    public String resetIrn(@RequestParam String invoiceNumbers, Model model) throws Exception {
1877
        List<String> invoices = new ArrayList<>();
1878
        if (!invoiceNumbers.isEmpty()) {
1879
            invoices = Arrays.asList(invoiceNumbers.split(","));
1880
        }
1881
        List<Order> orderList = orderRepository.selectByInvoiceNumbers(invoices);
1882
        orderList.forEach(order -> {
1883
            order.setIrnGenerated(null);
1884
        });
1885
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1886
        return "response";
1887
    }
34179 tejus.loha 1888
 
34474 aman.kumar 1889
    @PutMapping(value = "/sendInvoiceOnWhatsApp")
1890
    public String sendInvoiceOnWhatsApp(HttpServletRequest request, @RequestParam int orderId, @RequestParam String whatsAppMobile, Model model) throws Exception {
1891
        boolean isSend = this.sendWhatsappInvoice(fofoOrderRepository.selectByOrderId(orderId), whatsAppMobile);
1892
        model.addAttribute("response1", isSend);
34179 tejus.loha 1893
        return "response";
1894
    }
1895
 
1896
 
32409 amit.gupta 1897
}
32405 jai.hind 1898