Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21577 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
30039 tejbeer 3
import com.fasterxml.jackson.databind.ObjectMapper;
21987 kshitij.so 4
import com.google.gson.Gson;
25698 tejbeer 5
import com.spice.profitmandi.common.enumuration.MessageType;
21577 ashik.ali 6
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
32438 amit.gupta 7
import com.spice.profitmandi.common.model.*;
22472 ashik.ali 8
import com.spice.profitmandi.common.util.ExcelUtils;
25140 amit.gupta 9
import com.spice.profitmandi.common.util.PdfUtils;
28084 amit.gupta 10
import com.spice.profitmandi.common.util.Utils;
11
import com.spice.profitmandi.common.util.Utils.Attachment;
32402 tejbeer 12
import com.spice.profitmandi.common.web.client.RestClient;
28701 tejbeer 13
import com.spice.profitmandi.dao.entity.auth.AuthUser;
32438 amit.gupta 14
import com.spice.profitmandi.dao.entity.catalog.*;
28701 tejbeer 15
import com.spice.profitmandi.dao.entity.cs.Position;
30596 tejbeer 16
import com.spice.profitmandi.dao.entity.dtr.WebOffer;
25140 amit.gupta 17
import com.spice.profitmandi.dao.entity.fofo.FofoOrder;
24917 tejbeer 18
import com.spice.profitmandi.dao.entity.fofo.FofoStore;
24465 tejbeer 19
import com.spice.profitmandi.dao.entity.fofo.InventoryItem;
20
import com.spice.profitmandi.dao.entity.fofo.LiveDemoSerialNumber;
32438 amit.gupta 21
import com.spice.profitmandi.dao.entity.transaction.*;
30989 tejbeer 22
import com.spice.profitmandi.dao.entity.user.Address;
28701 tejbeer 23
import com.spice.profitmandi.dao.enumuration.catalog.ByPassRequestStatus;
24
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
32438 amit.gupta 25
import com.spice.profitmandi.dao.model.*;
28701 tejbeer 26
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
32438 amit.gupta 27
import com.spice.profitmandi.dao.repository.catalog.*;
28701 tejbeer 28
import com.spice.profitmandi.dao.repository.cs.CsService;
29
import com.spice.profitmandi.dao.repository.cs.PositionRepository;
24465 tejbeer 30
import com.spice.profitmandi.dao.repository.dtr.FofoStoreRepository;
26482 tejbeer 31
import com.spice.profitmandi.dao.repository.dtr.Mongo;
24917 tejbeer 32
import com.spice.profitmandi.dao.repository.dtr.UserAccountRepository;
30596 tejbeer 33
import com.spice.profitmandi.dao.repository.dtr.WebOfferRepository;
32438 amit.gupta 34
import com.spice.profitmandi.dao.repository.fofo.*;
24917 tejbeer 35
import com.spice.profitmandi.dao.repository.inventory.NotifyStatus;
32438 amit.gupta 36
import com.spice.profitmandi.dao.repository.transaction.*;
30989 tejbeer 37
import com.spice.profitmandi.dao.repository.user.AddressRepository;
38
import com.spice.profitmandi.dao.repository.user.UserRepository;
27723 tejbeer 39
import com.spice.profitmandi.dao.repository.warehouse.WarehousePurchaseOrderRepository;
40
import com.spice.profitmandi.dao.repository.warehouse.WarehouseScanRepository;
25851 amit.gupta 41
import com.spice.profitmandi.service.NotificationService;
30683 tejbeer 42
import com.spice.profitmandi.service.inventory.Combo;
32339 tejbeer 43
import com.spice.profitmandi.service.inventory.ComboOptionModel;
22927 ashik.ali 44
import com.spice.profitmandi.service.inventory.InventoryService;
30683 tejbeer 45
import com.spice.profitmandi.service.inventory.MappedComboModel;
27516 amit.gupta 46
import com.spice.profitmandi.service.order.OrderService;
33697 amit.gupta 47
import com.spice.profitmandi.service.transaction.SDCreditService;
24465 tejbeer 48
import com.spice.profitmandi.service.user.RetailerService;
22139 amit.gupta 49
import com.spice.profitmandi.web.model.LoginDetails;
22069 ashik.ali 50
import com.spice.profitmandi.web.util.CookiesProcessor;
24106 tejbeer 51
import com.spice.profitmandi.web.util.MVCResponseSender;
24658 tejbeer 52
import in.shop2020.model.v1.order.OrderStatus;
24739 tejbeer 53
import in.shop2020.model.v1.order.TransactionServiceException;
32438 amit.gupta 54
import org.apache.commons.csv.CSVFormat;
55
import org.apache.commons.csv.CSVParser;
56
import org.apache.commons.csv.CSVRecord;
57
import org.apache.commons.io.FileUtils;
58
import org.apache.commons.lang3.StringUtils;
59
import org.apache.logging.log4j.LogManager;
60
import org.apache.logging.log4j.Logger;
61
import org.apache.thrift.TException;
62
import org.json.JSONObject;
63
import org.springframework.beans.factory.annotation.Autowired;
64
import org.springframework.beans.factory.annotation.Qualifier;
65
import org.springframework.beans.factory.annotation.Value;
66
import org.springframework.core.io.ByteArrayResource;
67
import org.springframework.core.io.ClassPathResource;
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.mail.javamail.JavaMailSender;
74
import org.springframework.stereotype.Controller;
75
import org.springframework.transaction.annotation.Transactional;
76
import org.springframework.ui.Model;
77
import org.springframework.web.bind.annotation.*;
78
import org.springframework.web.multipart.MultipartFile;
24658 tejbeer 79
 
32438 amit.gupta 80
import javax.servlet.http.HttpServletRequest;
81
import javax.servlet.http.HttpServletResponse;
82
import java.io.*;
83
import java.net.URISyntaxException;
84
import java.time.LocalDate;
85
import java.time.LocalDateTime;
86
import java.time.YearMonth;
87
import java.time.format.DateTimeFormatter;
88
import java.time.temporal.ChronoUnit;
89
import java.util.*;
90
import java.util.stream.Collectors;
91
import java.util.stream.Stream;
30827 amit.gupta 92
 
32438 amit.gupta 93
 
21577 ashik.ali 94
@Controller
24123 tejbeer 95
@Transactional(rollbackFor = Throwable.class)
21577 ashik.ali 96
public class InventoryController {
21987 kshitij.so 97
 
31762 tejbeer 98
    private static final Logger LOGGER = LogManager.getLogger(InventoryController.class);
26482 tejbeer 99
 
31762 tejbeer 100
    private static final DateTimeFormatter formatter = DateTimeFormatter.ofPattern("M/d/yyyy H:m:s");
21987 kshitij.so 101
 
31762 tejbeer 102
    private static final List<String> imeis = Arrays.asList("351030944216680", "351030944217183", "351030944217886", "351030944507286", "351081710231270", "351081710238713", "351081710238796", "351081710241279", "351081710244737", "355777112655976");
27583 tejbeer 103
 
31762 tejbeer 104
    List<EscalationType> esclationType = Arrays.asList(EscalationType.L3, EscalationType.L4);
28701 tejbeer 105
 
31762 tejbeer 106
    List<String> emails = Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com");
28701 tejbeer 107
 
31762 tejbeer 108
    @Autowired
109
    private CookiesProcessor cookiesProcessor;
24123 tejbeer 110
 
31762 tejbeer 111
    @Autowired
112
    @Qualifier("fofoInventoryService")
113
    private InventoryService inventoryService;
24465 tejbeer 114
 
31762 tejbeer 115
    @Autowired
116
    TagListingRepository tagListingRepository;
24950 tejbeer 117
 
31762 tejbeer 118
    @Autowired
119
    private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
24123 tejbeer 120
 
31762 tejbeer 121
    @Autowired
122
    private TagRankingRepository tagRankingRepository;
24123 tejbeer 123
 
31762 tejbeer 124
    @Autowired
125
    private InventoryItemRepository inventoryItemRepository;
24465 tejbeer 126
 
31762 tejbeer 127
    @Autowired
128
    private LiveDemoBillingRespository liveDemoBillingRespository;
24465 tejbeer 129
 
31762 tejbeer 130
    @Autowired
131
    private ItemRepository itemRepository;
24123 tejbeer 132
 
31762 tejbeer 133
    @Autowired
134
    private Gson gson;
26512 amit.gupta 135
 
31762 tejbeer 136
    @Autowired
137
    private RetailerService retailerService;
24465 tejbeer 138
 
31762 tejbeer 139
    @Autowired
140
    private MVCResponseSender mvcResponseSender;
24123 tejbeer 141
 
31762 tejbeer 142
    @Autowired
143
    FofoStoreRepository fofoStoreRepository;
24465 tejbeer 144
 
31762 tejbeer 145
    @Autowired
146
    private OrderRepository orderRepository;
24658 tejbeer 147
 
31762 tejbeer 148
    @Autowired
149
    private NotifyItemRepository notifyItemRepository;
24739 tejbeer 150
 
31762 tejbeer 151
    @Autowired
152
    private NotifyColorChangeRepository notifyColorChangeRepository;
24917 tejbeer 153
 
31762 tejbeer 154
    @Autowired
155
    private NotifyOrderRespository notifyOrderRespository;
24917 tejbeer 156
 
31762 tejbeer 157
    @Autowired
158
    private NotificationService notificationService;
25851 amit.gupta 159
 
31762 tejbeer 160
    @Autowired
161
    private NotifyMessageRepository notifyMessageRepository;
25066 tejbeer 162
 
31762 tejbeer 163
    @Autowired
164
    private UserAccountRepository userAccountRepository;
24917 tejbeer 165
 
31762 tejbeer 166
    @Autowired
167
    private OrderService orderService;
27583 tejbeer 168
 
31762 tejbeer 169
    @Value("${saholic.api.host}")
170
    private String host;
23786 amit.gupta 171
 
31762 tejbeer 172
    @Value("${saholic.api.port}")
173
    private int port;
23786 amit.gupta 174
 
31762 tejbeer 175
    @Value("${saholic.api.webapp}")
176
    private String webapp;
21987 kshitij.so 177
 
31762 tejbeer 178
    @Autowired
179
    JavaMailSender mailSender;
24917 tejbeer 180
 
31762 tejbeer 181
    @Autowired
182
    private NotifyCancelOrderRepository notifyCancelOrderRepository;
26031 tejbeer 183
 
31762 tejbeer 184
    @Autowired
185
    private WarehousePurchaseOrderRepository warehousePurchaseOrderRepository;
27723 tejbeer 186
 
31762 tejbeer 187
    @Autowired
188
    private WarehouseScanRepository warehouseScanRepository;
27723 tejbeer 189
 
31762 tejbeer 190
    @Autowired
191
    private FofoOrderRepository fofoOrderRepository;
192
    @Autowired
193
    private Mongo mongoClient;
26482 tejbeer 194
 
31762 tejbeer 195
    @Autowired
196
    private FocusedModelByPassRepository focusedModelByPassRepository;
28701 tejbeer 197
 
31762 tejbeer 198
    @Autowired
199
    private CsService csService;
28701 tejbeer 200
 
31762 tejbeer 201
    @Autowired
202
    AuthRepository authRepository;
28701 tejbeer 203
 
31762 tejbeer 204
    @Autowired
205
    PositionRepository positionRepository;
28701 tejbeer 206
 
31762 tejbeer 207
    @Autowired
208
    ActivatedImeiRepository activatedImeiRepository;
30456 amit.gupta 209
 
31762 tejbeer 210
    @Autowired
211
    HighDemandItemsRepository highDemandItemsRepository;
28754 tejbeer 212
 
31762 tejbeer 213
    @Autowired
214
    WebOfferRepository webOfferRepository;
30596 tejbeer 215
 
31762 tejbeer 216
    @Autowired
217
    ComboModelRepository comboModelRepository;
30683 tejbeer 218
 
31762 tejbeer 219
    @Autowired
220
    ComboMappedModelRepository comboMappedModelRepository;
30683 tejbeer 221
 
31762 tejbeer 222
    @Autowired
32339 tejbeer 223
    private ComboOptionRepository comboOptionRepository;
224
 
225
    @Autowired
31762 tejbeer 226
    private UserRepository userUserRepository;
30989 tejbeer 227
 
31762 tejbeer 228
    @Autowired
229
    private AddressRepository addressRepository;
30989 tejbeer 230
 
33796 ranu 231
    @Autowired
232
    private CustomerOfferRepository customerOfferRepository;
233
 
234
    @Autowired
235
    private CustomerOfferItemRepository customerOfferItemRepository;
236
 
31762 tejbeer 237
    @RequestMapping(value = "/getCurrentInventorySnapshot")
238
    public String getCurrentAvailability(HttpServletRequest request, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = "searchTerm", required = false, defaultValue = "") String searchTerm, Model model) throws ProfitMandiBusinessException {
239
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
240
        Map<String, Object> map = inventoryService.getCurrentInventorySnapshot(loginDetails.getFofoId(), offset, limit, searchTerm);
241
        model.addAllAttributes(map);
242
        return "inventory-snapshot";
243
    }
21987 kshitij.so 244
 
31762 tejbeer 245
    @RequestMapping(value = "/getBadInventorySnapshot")
246
    public String getBadAvailability(HttpServletRequest request, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = "searchTerm", required = false, defaultValue = "") String searchTerm, Model model) throws ProfitMandiBusinessException {
247
        if (searchTerm == null) {
248
            searchTerm = "";
249
        }
250
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
251
        Map<String, Object> map = inventoryService.getBadInventorySnapshot(loginDetails.getFofoId(), offset, limit, searchTerm);
252
        model.addAllAttributes(map);
253
        return "bad-inventory-snapshot";
254
    }
21987 kshitij.so 255
 
31762 tejbeer 256
    @RequestMapping(value = "/getPaginatedCurrentInventorySnapshot")
257
    public String getPaginatedCurrentInventorySnapshot(HttpServletRequest request, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = "searchTerm", required = false, defaultValue = "") String searchTerm, Model model) throws ProfitMandiBusinessException {
258
        if (searchTerm == null) {
259
            searchTerm = "";
260
        }
261
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
262
        Map<String, Object> map = inventoryService.getPaginatedCurrentInventorySnapshot(loginDetails.getFofoId(), offset, limit, searchTerm);
263
        model.addAllAttributes(map);
264
        return "inventory-snapshot-paginated";
265
    }
23786 amit.gupta 266
 
31762 tejbeer 267
    @RequestMapping(value = "/getCatalog")
268
    public String getCatalog(HttpServletRequest request, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "20") int limit, @RequestParam(name = "searchTerm", required = false, defaultValue = "") String searchTerm, @RequestParam(name = "itemId", required = false, defaultValue = "0") int itemId, @RequestParam(name = "accesories", required = false, defaultValue = "0") boolean accesories,
27596 tejbeer 269
 
31762 tejbeer 270
                             @RequestParam(name = "brand", required = false, defaultValue = "") String brand, Model model)
27618 tejbeer 271
 
31762 tejbeer 272
            throws ProfitMandiBusinessException {
273
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
274
        if (searchTerm == null) {
275
            searchTerm = "";
276
        }
24739 tejbeer 277
 
31762 tejbeer 278
        Map<String, Object> map = inventoryService.getCatalog(loginDetails.getFofoId(), offset, limit, searchTerm, itemId, brand, accesories);
279
        model.addAllAttributes(map);
280
        model.addAttribute("hasGift", hasGift(loginDetails.getFofoId()));
24658 tejbeer 281
 
31762 tejbeer 282
        return "catalog";
283
    }
23786 amit.gupta 284
 
31762 tejbeer 285
    @RequestMapping(value = "/getWebOfferByCatalogId")
286
    public String getCatalog(HttpServletRequest request, @RequestParam int catalogItemId, Model model)
287
            throws ProfitMandiBusinessException {
30596 tejbeer 288
 
31762 tejbeer 289
        List<WebOffer> webOffers = webOfferRepository.selectAllActiveOffers().get(catalogItemId);
30596 tejbeer 290
 
33796 ranu 291
        LocalDateTime todayDateTime = LocalDateTime.now();
292
        LocalDate todayDate = LocalDate.now();
293
 
294
        List<CustomerOffer> customerOffers = customerOfferRepository.selectOffersByDate(todayDateTime);
33818 ranu 295
        List<Integer> customerOfferIds = customerOffers.stream().map(CustomerOffer::getId).collect(Collectors.toList());
296
 
297
        // Retrieve customer offer items
33796 ranu 298
        List<CustomerOfferItem> customerOfferItems = customerOfferItemRepository.selectByOfferIds(customerOfferIds, catalogItemId, todayDate);
299
 
33818 ranu 300
        // Filter customer offer items with endDate greater than today
301
        List<CustomerOfferItem> filteredCustomerOfferItems = customerOfferItems.stream()
33822 ranu 302
                .filter(x -> x.getEndDate() != null && !x.getEndDate().isBefore(todayDate))
33818 ranu 303
                .collect(Collectors.toList());
304
 
31762 tejbeer 305
        model.addAttribute("webOffers", webOffers);
33818 ranu 306
        model.addAttribute("customerOfferItems", filteredCustomerOfferItems);
30596 tejbeer 307
 
31762 tejbeer 308
        return "web-offer-model";
309
    }
30596 tejbeer 310
 
33818 ranu 311
 
31762 tejbeer 312
    // This method is currently hardcoded to faciliate watches sold as gift.
313
    private boolean hasGift(int fofoId) {
314
        try {
315
            return currentInventorySnapshotRepository.selectByItemIdAndFofoId(ProfitMandiConstants.GIFT_ID, fofoId).getAvailability() > 0;
316
        } catch (ProfitMandiBusinessException e) {
317
            return false;
318
        }
319
    }
24203 amit.gupta 320
 
31762 tejbeer 321
    @RequestMapping(value = "/getPaginatedCatalog")
322
    public String getCatalogPaginated(HttpServletRequest request, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "20") int limit, @RequestParam(name = "searchTerm", required = false, defaultValue = "") String searchTerm, @RequestParam(name = "itemId", required = false, defaultValue = "0") int itemId, @RequestParam(name = "accesories", required = false, defaultValue = "0") boolean accesories, @RequestParam(name = "brand", required = false, defaultValue = "") String brand, Model model) throws ProfitMandiBusinessException {
323
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
324
        if (searchTerm == null) {
325
            searchTerm = "";
326
        }
327
        Map<String, Object> map = inventoryService.getPaginatedCatalog(loginDetails.getFofoId(), offset, limit, searchTerm, itemId, brand, accesories);
328
        model.addAllAttributes(map);
329
        return "catalog-paginated";
330
    }
21987 kshitij.so 331
 
31762 tejbeer 332
    @RequestMapping(value = "/checkItemAvailability")
333
    public String getItemAvailability(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.ITEM_ID) int itemId, Model model) throws ProfitMandiBusinessException {
334
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
335
        CustomCurrentInventorySnapshot customCurrentInventorySnapshot = inventoryService.checkItemAvailability(itemId, loginDetails.getFofoId());
336
        /*
337
         * customCurrentInventorySnapshot
338
         * .setIconUrl(Utils.getIconUrl(customCurrentInventorySnapshot.getCatalogItemId(
339
         * ), host, port, webapp));
340
         */
341
        model.addAttribute("currentInventorySnapshot", new Gson().toJson(customCurrentInventorySnapshot));
342
        return "current-item-availability";
23786 amit.gupta 343
 
31762 tejbeer 344
    }
23786 amit.gupta 345
 
31762 tejbeer 346
    @RequestMapping(value = "/cart", method = RequestMethod.POST)
347
    public String addToCart(HttpServletRequest request, @RequestParam(name = "cartData") String cartData, Model model) throws ProfitMandiBusinessException {
348
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
23786 amit.gupta 349
 
31762 tejbeer 350
        Map<String, Object> map = inventoryService.addToCart(cartData, loginDetails.getFofoId());
351
        model.addAllAttributes(map);
352
        return "cart";
353
    }
23786 amit.gupta 354
 
31762 tejbeer 355
    @RequestMapping(value = "/validate-cart", method = RequestMethod.POST)
356
    public String validateCart(HttpServletRequest request, HttpServletResponse response, @RequestParam(name = "cartData") String cartData, Model model) throws ProfitMandiBusinessException {
357
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
23786 amit.gupta 358
 
31762 tejbeer 359
        Map<String, Object> map = inventoryService.validateCart(cartData, loginDetails.getFofoId());
360
        model.addAllAttributes(map);
361
        return "validate-cart";
362
    }
21987 kshitij.so 363
 
31762 tejbeer 364
    @RequestMapping(value = "/grnHistory")
365
    public String getGrnHistory(HttpServletRequest request, @RequestParam(required = false) LocalDateTime startTime, @RequestParam(required = false) LocalDateTime endTime, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = ProfitMandiConstants.PURCHASE_REFERENCE, defaultValue = "") String purchaseReference, @RequestParam(name = "searchType", defaultValue = "") String searchType, Model model) throws ProfitMandiBusinessException {
366
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
367
        Map<String, Object> map = inventoryService.getGrnHistory(loginDetails.getFofoId(), startTime, endTime, offset, limit, purchaseReference, searchType);
368
        model.addAllAttributes(map);
369
        return "grn-history";
370
    }
21987 kshitij.so 371
 
31762 tejbeer 372
    @RequestMapping(value = "/downloadPurchaseInvoices")
373
    public ResponseEntity<?> downloadPurchaseInvoices(HttpServletRequest request, @RequestParam(required = false) LocalDateTime startTime, @RequestParam(required = false) LocalDateTime endTime, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = ProfitMandiConstants.PURCHASE_REFERENCE, defaultValue = "") String purchaseReference, @RequestParam(name = "searchType", defaultValue = "") String searchType, Model model) throws ProfitMandiBusinessException {
374
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
375
        Map<String, Object> map = inventoryService.getGrnHistory(loginDetails.getFofoId(), startTime, endTime, offset, limit, purchaseReference, searchType);
25140 amit.gupta 376
 
31762 tejbeer 377
        List<FofoOrder> fofoOrders = (List<FofoOrder>) map.get("saleHistories");
25140 amit.gupta 378
 
31762 tejbeer 379
        if (fofoOrders.size() == 0) {
380
            throw new ProfitMandiBusinessException("Search criteria", "", "No orders found for criteria");
381
        }
25140 amit.gupta 382
 
31762 tejbeer 383
        final HttpHeaders headers = new HttpHeaders();
384
        headers.setContentType(MediaType.APPLICATION_PDF);
385
        headers.set("Content-disposition", "inline; filename=invoices.pdf");
386
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
387
        List<InvoicePdfModel> pdfModels = new ArrayList<>();
388
        PdfUtils.generateAndWrite(pdfModels, byteArrayOutputStream);
389
        headers.setContentLength(byteArrayOutputStream.toByteArray().length);
390
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
391
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
392
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
393
    }
25140 amit.gupta 394
 
31762 tejbeer 395
    @RequestMapping(value = "/getPaginatedGrnHistory")
396
    public String getPaginatedGrnHistory(HttpServletRequest request, @RequestParam(required = false) LocalDateTime startTime, @RequestParam(required = false) LocalDateTime endTime, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "10") int limit, @RequestParam(name = ProfitMandiConstants.PURCHASE_REFERENCE, defaultValue = "") String purchaseReference, @RequestParam(name = "searchType", defaultValue = "") String searchType, Model model) throws ProfitMandiBusinessException {
397
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
398
        Map<String, Object> map = inventoryService.getPaginatedGrnHistory(loginDetails.getFofoId(), startTime, endTime, offset, limit);
399
        model.addAllAttributes(map);
400
        return "grn-history-paginated";
401
    }
21987 kshitij.so 402
 
31762 tejbeer 403
    @RequestMapping(value = "/grnHistoryDetailByPurchaseId")
404
    public String grnHistoryByPurchaseId(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.PURCHASE_ID) int purchaseId, Model model) throws ProfitMandiBusinessException {
405
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
406
        Map<String, Object> map = inventoryService.getGrnHistoryDetail(loginDetails.getFofoId(), purchaseId, host, port, webapp);
407
        model.addAllAttributes(map);
408
        return "grn-details";
409
    }
21987 kshitij.so 410
 
31762 tejbeer 411
    @RequestMapping(value = "/grnHistoryDetailByPurchaseReference")
412
    public String grnHistoryByPurchaseReference(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.PURCHASE_REFERENCE) String purchaseReference, Model model) throws ProfitMandiBusinessException {
413
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
414
        Map<String, Object> map = inventoryService.getGrnHistoryDetail(loginDetails.getFofoId(), purchaseReference, host, port, webapp);
415
        model.addAllAttributes(map);
32584 raveendra. 416
 
31762 tejbeer 417
        return "grn-details";
418
    }
23786 amit.gupta 419
 
31762 tejbeer 420
    @RequestMapping(value = "/activatedImeis")
421
    public String activatedImeis(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
422
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
26248 amit.gupta 423
 
31762 tejbeer 424
        List<InventoryItem> inventoryItems = inventoryItemRepository.selectByActivatedNotSold(loginDetails.getFofoId());
425
        inventoryItems.stream().forEach(x -> {
426
            try {
427
                x.setItem(itemRepository.selectById(x.getItemId()));
428
            } catch (Exception e) {
429
                e.printStackTrace();
430
            }
431
        });
432
        model.addAttribute("inventoryItems", inventoryItems);
433
        return "activated-imeis";
434
    }
27583 tejbeer 435
 
31762 tejbeer 436
    @RequestMapping(value = "/activated-imeis-grn-pending")
437
    public String activatedImeisGrnPending(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
438
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
30456 amit.gupta 439
 
33312 amit.gupta 440
        List<Order> openOrders = orderRepository.selectGrnTimestampNull(loginDetails.getFofoId(), Arrays.asList(OrderStatus.DELIVERY_SUCCESS));
31762 tejbeer 441
        List<ImeiActivationTimestampModel> imeiActivationTimestampModels = activatedImeiRepository.selectActivatedImeisByOrders(openOrders.stream().map(x -> x.getId()).collect(Collectors.toList()));
442
        Map<Integer, Order> ordersMap = openOrders.stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
443
        model.addAttribute("ordersMap", ordersMap);
444
        model.addAttribute("imeiActivationTimestampModels", imeiActivationTimestampModels);
445
        return "activated-imeis-grn-pending";
446
    }
30456 amit.gupta 447
 
31762 tejbeer 448
    @RequestMapping(value = "/view-invoices")
449
    public String viewInvoices(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
450
        return "view-dummy-invoices";
451
    }
27583 tejbeer 452
 
31762 tejbeer 453
    @RequestMapping(value = "/dummy-invoices")
454
    public ResponseEntity<?> downloadInvoices(HttpServletRequest request, @RequestParam String serialNumber, Model model) throws ProfitMandiBusinessException {
455
        byte[] bytes = null;
456
        if (!imeis.contains(serialNumber)) {
27583 tejbeer 457
 
31762 tejbeer 458
            InvoicePdfModel pdfModel = orderService.getDummyPdfModel(serialNumber);
459
            ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
460
            PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
461
            bytes = byteArrayOutputStream.toByteArray();
462
        } else {
463
            ClassPathResource resource = new ClassPathResource("/META-INF/" + serialNumber + ".pdf");
464
            try {
465
                bytes = FileUtils.readFileToByteArray(resource.getFile());
466
            } catch (Exception e) {
27583 tejbeer 467
 
31762 tejbeer 468
            }
469
        }
470
        final HttpHeaders headers = new HttpHeaders();
471
        headers.setContentType(MediaType.APPLICATION_PDF);
472
        headers.set("Content-disposition", "inline; filename=invoice-" + serialNumber + ".pdf");
473
        headers.setContentLength(bytes.length);
474
        final InputStream inputStream = new ByteArrayInputStream(bytes);
475
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
476
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
477
    }
28714 tejbeer 478
 
31762 tejbeer 479
    @RequestMapping(value = "/dummy-invoices-bulk")
480
    public ResponseEntity<?> downloadInvoicesBulk(HttpServletRequest request, @RequestParam List<String> serialNumbers, Model model) throws Exception {
481
        byte[] bytes = null;
482
        List<Attachment> attachments = new ArrayList<>();
483
        for (String serialNumber : serialNumbers) {
484
            if (!imeis.contains(serialNumber)) {
485
                InvoicePdfModel pdfModel = null;
486
                try {
487
                    pdfModel = orderService.getDummyPdfModel(serialNumber);
488
                } catch (Exception e) {
489
                    continue;
490
                }
491
                ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
492
                PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
493
                bytes = byteArrayOutputStream.toByteArray();
494
            } else {
495
                ClassPathResource resource = new ClassPathResource("/META-INF/" + serialNumber + ".pdf");
496
                try {
497
                    bytes = FileUtils.readFileToByteArray(resource.getFile());
498
                } catch (Exception e) {
499
                    continue;
500
                }
501
            }
502
            attachments.add(new Attachment("invoice-" + serialNumber + ".pdf", new ByteArrayResource(bytes)));
503
        }
28109 tejbeer 504
 
31762 tejbeer 505
        Utils.sendMailWithAttachments(mailSender, new String[]{"kuldeep.kumar@smartdukaan.com"}, null, "Invoices List", "PFA", attachments.toArray(new Attachment[attachments.size()]));
506
        return new ResponseEntity<Boolean>(true, HttpStatus.OK);
507
    }
26248 amit.gupta 508
 
31762 tejbeer 509
    @RequestMapping(value = "/getInventoryItemAgingByInterval", method = RequestMethod.POST)
32075 tejbeer 510
    public String getInventoryItemAgingByInterval(HttpServletRequest request, @RequestBody List<Integer> intervals, Model model, @RequestParam(name = "searchContent", defaultValue = "") String searchContent, @RequestParam(name = "offset", defaultValue = "0") int offset, @RequestParam(name = "limit", defaultValue = "1000") int limit) throws ProfitMandiBusinessException {
31762 tejbeer 511
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
512
        Map<String, Object> map = inventoryService.getPaginatedItemAgingByInterval(loginDetails.getFofoId(), intervals, searchContent, offset, limit);
513
        model.addAllAttributes(map);
514
        return "item-aging";
515
    }
23786 amit.gupta 516
 
31762 tejbeer 517
    @RequestMapping(value = "/downloadInventoryItemAgingByInterval", method = RequestMethod.POST)
518
    public ResponseEntity<?> downloadInventoryItemAgingByInterval(HttpServletRequest request, @RequestBody List<Integer> intervals, Model model) throws ProfitMandiBusinessException {
519
        LOGGER.info("Request received at url{} with body {}", request.getRequestURI(), intervals);
520
        LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
23786 amit.gupta 521
 
31762 tejbeer 522
        List<InventoryItemAgingModel> inventoryItemAgingModels = inventoryService.getItemAgingByInterval(fofoDetails.getFofoId(), intervals);
23786 amit.gupta 523
 
31762 tejbeer 524
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
525
        ExcelUtils.writeInventoryItemAgingModels(inventoryItemAgingModels, intervals, byteArrayOutputStream);
23786 amit.gupta 526
 
31762 tejbeer 527
        final HttpHeaders headers = new HttpHeaders();
528
        // private static final String CONTENT_TYPE_XLSX =
529
        // "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
530
        headers.set("Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
531
        // headers.set("Content-Type", "application/vnd.ms-excel");
532
        headers.set("Content-disposition", "inline; filename=InventoryItemAging.xlsx");
533
        headers.setContentLength(byteArrayOutputStream.toByteArray().length);
534
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
535
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
536
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
537
    }
27583 tejbeer 538
 
31762 tejbeer 539
    @RequestMapping(value = "/aging-report", method = RequestMethod.GET)
540
    public ResponseEntity<?> downloadInventoryItemAgingByInterval(HttpServletRequest request) throws ProfitMandiBusinessException {
27583 tejbeer 541
 
31762 tejbeer 542
        List<Integer> intervals = Arrays.asList(5, 15, 30, 45);
543
        List<InventoryItemAgingModel> inventoryItemAgingModels = inventoryService.getItemAgingByInterval(intervals).values().stream().flatMap(Collection::stream).collect(Collectors.toList());
544
        LOGGER.info("Fofo Id {}", inventoryItemAgingModels.get(0).getFofoId());
545
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
546
        ExcelUtils.writeInventoryItemAgingModels(inventoryItemAgingModels, intervals, byteArrayOutputStream);
27583 tejbeer 547
 
31762 tejbeer 548
        final HttpHeaders headers = new HttpHeaders();
549
        // private static final String CONTENT_TYPE_XLSX =
550
        // "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
551
        headers.set("Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
552
        // headers.set("Content-Type", "application/vnd.ms-excel");
553
        headers.set("Content-disposition", "inline; filename=InventoryItemAging.xlsx");
554
        headers.setContentLength(byteArrayOutputStream.toByteArray().length);
555
        final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
556
        final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
557
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
558
    }
24123 tejbeer 559
 
31762 tejbeer 560
    @RequestMapping(value = "/featurePanel", method = RequestMethod.GET)
561
    public String FeaturePanel(HttpServletRequest request, Model model) throws Exception {
21987 kshitij.so 562
 
31762 tejbeer 563
        List<TagRanking> tagRanking = null;
564
        tagRanking = tagRankingRepository.getAllTagRanking();
565
        LOGGER.info("tagRanking" + tagRanking);
566
        if (!tagRanking.isEmpty()) {
567
            Set<Integer> catalogIds = tagRanking.stream().map(x -> x.getCatalogItemId()).collect(Collectors.toSet());
568
            List<Item> items = itemRepository.selectAllByCatalogIds(catalogIds);
569
            Map<Integer, String> catalogDescription = items.stream().collect(Collectors.toMap(x -> x.getCatalogItemId(), x -> x.getItemDescription(), (description1, description2) -> description1));
24798 tejbeer 570
 
31762 tejbeer 571
            LOGGER.info("catalogDescription" + catalogDescription);
572
            model.addAttribute("tagRanking", tagRanking);
573
            model.addAttribute("catalogDescription", catalogDescription);
24106 tejbeer 574
 
31762 tejbeer 575
        } else {
576
            model.addAttribute("tagRanking", tagRanking);
25362 tejbeer 577
 
31762 tejbeer 578
        }
24106 tejbeer 579
 
31762 tejbeer 580
        return "feature";
24106 tejbeer 581
 
31762 tejbeer 582
    }
24123 tejbeer 583
 
31762 tejbeer 584
    @PostMapping(value = "/imei/upload")
585
    public String uploadContent(HttpServletRequest request, @RequestPart("file") MultipartFile file, Model model) throws Exception {
586
        /*
587
         * if(brand==null) { throw new
588
         * ProfitMandiBusinessException("Please select brand", "Brand empty",
589
         * "Brand required"); }
590
         */
591
        List<CSVRecord> masterDataList = readFile(file);
26279 amit.gupta 592
 
31762 tejbeer 593
        Map<String, LocalDateTime> imeisActivationMap = masterDataList.stream().collect(Collectors.toMap(x -> x.get(0).trim(), x -> {
594
            if (!StringUtils.isEmpty(x.get(1).trim())) {
595
                return LocalDateTime.parse((String) (x.get(1).trim()), formatter);
596
            } else {
597
                return null;
598
            }
599
        }));
600
        inventoryService.addActivatedImeis(imeisActivationMap);
601
        model.addAttribute("response1", true);
602
        return "response";
603
    }
26279 amit.gupta 604
 
31762 tejbeer 605
    private List<CSVRecord> readFile(MultipartFile file) throws Exception {
606
        List<CSVRecord> records = null;
607
        try (CSVParser parser = new CSVParser(new InputStreamReader(file.getInputStream()), CSVFormat.DEFAULT)) {
608
            records = parser.getRecords();
609
            if (records.size() < 2) {
610
                throw new ProfitMandiBusinessException("Uploaded File", "", "No records Found");
611
            }
612
            records.remove(0);
613
        } catch (Exception e) {
614
            throw new ProfitMandiBusinessException("Parsing Failed", "parse failed", "file parse failed");
615
        }
616
        return records;
617
    }
26279 amit.gupta 618
 
31762 tejbeer 619
    @RequestMapping(value = "/itemfeature", method = RequestMethod.POST)
620
    public String Itemfeature(HttpServletRequest request, @RequestBody ItemFeatureDataModel itemFeatureDatatModel, Model model) throws Exception {
621
        TagRanking tagRanking = tagRankingRepository.selectBycatalogItemId(itemFeatureDatatModel.getCatalogItemId());
622
        LOGGER.info("tagRanking" + tagRanking);
623
        if (tagRanking == null) {
624
            tagRanking = new TagRanking();
625
            tagRanking.setCatalogItemId(itemFeatureDatatModel.getCatalogItemId());
626
        }
627
        tagRanking.setFeature(itemFeatureDatatModel.getFeature());
628
        tagRanking.setRankPoints(itemFeatureDatatModel.getRankPoints());
25371 tejbeer 629
 
31762 tejbeer 630
        tagRankingRepository.persist(tagRanking);
631
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
632
        return "response";
633
    }
24106 tejbeer 634
 
31762 tejbeer 635
    @RequestMapping(value = "/removeFeature", method = RequestMethod.DELETE)
636
    public String removeTagRankingEnteries(HttpServletRequest request, @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
24917 tejbeer 637
 
31762 tejbeer 638
        tagRankingRepository.deleteById(id);
639
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
640
        return "response";
641
    }
24798 tejbeer 642
 
31762 tejbeer 643
    @RequestMapping(value = "/getDemolistbyfofoId", method = RequestMethod.GET)
644
    public String DemoListbyFofoId(HttpServletRequest request, @RequestParam(required = false, defaultValue = "0") int fofoId, Model model) throws Exception {
24465 tejbeer 645
 
31762 tejbeer 646
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId()).collect(Collectors.toList());
30426 tejbeer 647
 
31762 tejbeer 648
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
649
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null).collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
650
        String customRetailers = JSONObject.valueToString(customRetailersMap.values());
651
        List<String> serailNumberList = liveDemoBillingRespository.selectAllSerialNumber();
652
        LOGGER.info("serailNumberList" + serailNumberList);
653
        List<InventoryItem> inventoryItem = null;
654
        List<InventoryItem> inventoryItem1 = new ArrayList<>();
655
        if (fofoId > 0) {
656
            List<Item> items = itemRepository.selectAllByBrand("Live Demo");
657
            Set<Integer> itemIds = new HashSet<>();
658
            for (Item Item : items) {
659
                itemIds.add(Item.getId());
660
            }
661
            inventoryItem = inventoryItemRepository.selectByFofoIdItemIds(fofoId, itemIds);
24465 tejbeer 662
 
31762 tejbeer 663
            Set<String> serial = new HashSet<>();
664
            for (InventoryItem invItem : inventoryItem) {
665
                if (!serailNumberList.contains(invItem.getSerialNumber())) {
666
                    inventoryItem1.add(invItem);
25371 tejbeer 667
 
31762 tejbeer 668
                }
24465 tejbeer 669
 
31762 tejbeer 670
            }
24465 tejbeer 671
 
31762 tejbeer 672
            LOGGER.info("inventoyItem" + inventoryItem1);
673
            model.addAttribute("customRetailers", customRetailers);
25371 tejbeer 674
 
31762 tejbeer 675
            model.addAttribute("liveDemo", inventoryItem1);
676
            CustomRetailer fofoIdsAndRetailerName = retailerService.getFofoRetailer(fofoId);
24465 tejbeer 677
 
31762 tejbeer 678
            model.addAttribute("fofoIdsAndRetailerName", fofoIdsAndRetailerName);
24465 tejbeer 679
 
31785 amit.gupta 680
        } else {
31762 tejbeer 681
            model.addAttribute("customRetailers", customRetailers);
682
            model.addAttribute("liveDemo", inventoryItem1);
683
        }
24465 tejbeer 684
 
31762 tejbeer 685
        return "live_demo_billing";
24465 tejbeer 686
 
31762 tejbeer 687
    }
24465 tejbeer 688
 
31762 tejbeer 689
    @RequestMapping(value = "/enableliveDemoSerailNumber", method = RequestMethod.POST)
690
    public String EnableliveDemoSerailNumber(HttpServletRequest request, @RequestParam String serial_number, Model model) throws Exception {
24465 tejbeer 691
 
31762 tejbeer 692
        LiveDemoSerialNumber liveDemoSerialNumber = new LiveDemoSerialNumber();
693
        liveDemoSerialNumber.setSerialNumber(serial_number);
24465 tejbeer 694
 
31762 tejbeer 695
        liveDemoBillingRespository.persist(liveDemoSerialNumber);
696
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
697
        return "response";
698
    }
24465 tejbeer 699
 
31762 tejbeer 700
    @RequestMapping(value = "/getInProcessOrder", method = RequestMethod.GET)
701
    public String getInProcessOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
24739 tejbeer 702
 
32868 amit.gupta 703
        List<com.spice.profitmandi.dao.entity.transaction.Order> inProcessOrders = orderRepository.selectAllOrder(Arrays.asList(OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.LOW_INV_PO_RAISED));
31762 tejbeer 704
        List<Integer> retailerIds = new ArrayList<>();
705
        List<Integer> orderIds = new ArrayList<>();
32868 amit.gupta 706
        if (!inProcessOrders.isEmpty()) {
707
            for (com.spice.profitmandi.dao.entity.transaction.Order order : inProcessOrders) {
31762 tejbeer 708
                retailerIds.add(order.getRetailerId());
709
                orderIds.add(order.getId());
24739 tejbeer 710
 
31762 tejbeer 711
            }
24739 tejbeer 712
 
31762 tejbeer 713
            List<NotifyOrder> notify = notifyOrderRespository.selectByorderIds(orderIds);
714
            for (NotifyOrder notifyOrder : notify) {
25449 tejbeer 715
 
31762 tejbeer 716
                Order orderdetail = orderRepository.selectById(notifyOrder.getOrderId());
717
                if (!orderdetail.getStatus().equals(OrderStatus.SUBMITTED_FOR_PROCESSING)) {
718
                    notifyOrder.setStatus(NotifyStatus.rejected);
719
                }
720
            }
24950 tejbeer 721
 
31762 tejbeer 722
            Map<Integer, Optional<NotifyOrder>> notifyOrders = notifyOrderRespository.selectByorderIds(orderIds).stream().collect(Collectors.groupingBy(NotifyOrder::getOrderId, Collectors.maxBy((x1, x2) -> x1.getId() - x2.getId())));
24950 tejbeer 723
 
31762 tejbeer 724
            Map<Integer, NotifyCancel> notifyCancelOrders = notifyCancelOrderRepository.selectByOrderIds(orderIds).stream().collect(Collectors.toMap(x -> x.getOrderId(), x -> x));
725
            Map<Integer, String> storeIdAndFofoIdMap = fofoStoreRepository.selectByRetailerIds(retailerIds).stream().collect(Collectors.toMap(FofoStore::getId, FofoStore::getCode));
24917 tejbeer 726
 
32868 amit.gupta 727
            model.addAttribute("inProcessorder", inProcessOrders);
31762 tejbeer 728
            model.addAttribute("storeIdAndFofoIdMap", storeIdAndFofoIdMap);
729
            model.addAttribute("latestNotifyOrders", notifyOrders);
730
            model.addAttribute("notifyCancelOrders", notifyCancelOrders);
731
        } else {
32868 amit.gupta 732
            model.addAttribute("inProcessorder", inProcessOrders);
31762 tejbeer 733
        }
734
        return "review_order";
735
    }
24739 tejbeer 736
 
31762 tejbeer 737
    @RequestMapping(value = "/getPaymentPendingOrder", method = RequestMethod.GET)
738
    public String getPaymentPendingOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
28109 tejbeer 739
 
31762 tejbeer 740
        List<com.spice.profitmandi.dao.entity.transaction.Order> pendingPaymentorder = orderRepository.selectAllOrderDatesBetweenByStatus(LocalDateTime.now().minusMonths(3), LocalDateTime.now(), OrderStatus.PAYMENT_PENDING);
741
        List<com.spice.profitmandi.dao.entity.transaction.Order> failedPaymentorder = orderRepository.selectAllOrderDatesBetweenByStatus(LocalDateTime.now().minusMonths(3), LocalDateTime.now(), OrderStatus.PAYMENT_FAILED);
742
        pendingPaymentorder.addAll(failedPaymentorder);
743
        model.addAttribute("pendingPaymentorder", pendingPaymentorder);
28109 tejbeer 744
 
31762 tejbeer 745
        return "payment-pending-order";
746
    }
28109 tejbeer 747
 
31762 tejbeer 748
    @RequestMapping(value = "/getKeepInTabOrder", method = RequestMethod.GET)
749
    public String getKeepInTabOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
24739 tejbeer 750
 
32868 amit.gupta 751
        List<com.spice.profitmandi.dao.entity.transaction.Order> keepatab = orderRepository.selectAllOrder(Arrays.asList(OrderStatus.KEEP_A_TAB));
24739 tejbeer 752
 
31762 tejbeer 753
        model.addAttribute("keepatab", keepatab);
24739 tejbeer 754
 
31762 tejbeer 755
        return "keep-a-tab";
756
    }
24739 tejbeer 757
 
31762 tejbeer 758
    @RequestMapping(value = "/closeOrder", method = RequestMethod.POST)
759
    public String closeOrder(HttpServletRequest request, @RequestParam int orderId, Model model) throws Exception {
24798 tejbeer 760
 
31762 tejbeer 761
        Order order = orderRepository.selectById(orderId);
762
        if (order != null) {
763
            order.setStatus(OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY);
24798 tejbeer 764
 
31762 tejbeer 765
            model.addAttribute("response1", mvcResponseSender.createResponseString(true));
24739 tejbeer 766
 
31762 tejbeer 767
        } else {
768
            model.addAttribute("response1", mvcResponseSender.createResponseString(false));
24739 tejbeer 769
 
31762 tejbeer 770
        }
771
        return "response";
772
    }
24658 tejbeer 773
 
31762 tejbeer 774
    @RequestMapping(value = "/getcancelOrderItems", method = RequestMethod.GET)
775
    public String getcancelOrderItems(HttpServletRequest request, @RequestParam int itemId, Model model) throws Exception {
25640 tejbeer 776
 
32944 amit.gupta 777
        List<Order> inProcessSelectedOrders = orderRepository.selectByItemIdOrderStatus(itemId, OrderStatus.SUBMITTED_FOR_PROCESSING);
25640 tejbeer 778
 
31762 tejbeer 779
        List<Integer> retailerIds = new ArrayList<>();
32944 amit.gupta 780
        for (com.spice.profitmandi.dao.entity.transaction.Order order : inProcessSelectedOrders) {
31762 tejbeer 781
            retailerIds.add(order.getRetailerId());
782
        }
25640 tejbeer 783
 
31762 tejbeer 784
        Map<Integer, String> storeIdAndFofoIdMap = fofoStoreRepository.selectByRetailerIds(retailerIds).stream().collect(Collectors.toMap(FofoStore::getId, FofoStore::getCode));
25640 tejbeer 785
 
32944 amit.gupta 786
        model.addAttribute("inProcessCancelOrders", inProcessSelectedOrders);
31762 tejbeer 787
        model.addAttribute("storeIdAndFofoIdMap", storeIdAndFofoIdMap);
25640 tejbeer 788
 
31762 tejbeer 789
        return "cancel-order-modal";
790
    }
25640 tejbeer 791
 
33697 amit.gupta 792
    @Autowired
793
    SDCreditService sdCreditService;
794
 
795
 
31762 tejbeer 796
    @RequestMapping(value = "/cancelOrder", method = RequestMethod.POST)
797
    public String cancelOrder(HttpServletRequest request, @RequestBody OrderCancellationModel orderCancellationModel, Model model) throws Exception {
798
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
799
        LOGGER.info("orderId" + orderCancellationModel.getOrderIds());
25640 tejbeer 800
 
31762 tejbeer 801
        try {
802
            // List<Order> orders =
803
            // orderRepository.selectByOrderIds(orderCancellationModel.getOrderIds());
25640 tejbeer 804
 
31762 tejbeer 805
            List<Order> orders = orderRepository.selectByOrderIdsOrdersStatus(orderCancellationModel.getOrderIds(), OrderStatus.SUBMITTED_FOR_PROCESSING);
806
            if (!orders.isEmpty()) {
807
                for (Order order : orders) {
25640 tejbeer 808
 
31762 tejbeer 809
                    orderRepository.refundOrder(order.getId(), loginDetails.getEmailId(), orderCancellationModel.getReason(), OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY);
810
                    List<NotifyOrder> notifyOrders = notifyOrderRespository.selectByOrder(order.getId());
811
                    for (NotifyOrder notifyOrder : notifyOrders) {
812
                        if (notifyOrder.getStatus() == NotifyStatus.pending) {
813
                            notifyOrder.setStatus(NotifyStatus.rejected);
814
                        }
815
                    }
816
                    sendCancellationNotificationToPartner(order, orderCancellationModel.getReason());
817
                    model.addAttribute("response1", mvcResponseSender.createResponseString(true));
25699 tejbeer 818
 
31762 tejbeer 819
                }
33697 amit.gupta 820
                sdCreditService.settleBlockedLoan(orders.get(0).getTransactionId());
31762 tejbeer 821
            }
822
        } catch (TransactionServiceException | TException e) {
823
            model.addAttribute("response1", mvcResponseSender.createResponseString(false));
24739 tejbeer 824
 
31762 tejbeer 825
        }
25640 tejbeer 826
 
31762 tejbeer 827
        return "response";
828
    }
24739 tejbeer 829
 
31762 tejbeer 830
    private void sendCancellationNotificationToPartner(Order order, String reason) throws Exception {
831
        Item item = itemRepository.selectById(order.getLineItem().getItemId());
25383 tejbeer 832
 
31762 tejbeer 833
        String title = "Order Cancellation";
834
        String message = String.format("Order %s %d(Pcs) has been cancelled", item.getItemDescription(), order.getLineItem().getQuantity());
30989 tejbeer 835
 
31762 tejbeer 836
        com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(order.getRetailerId());
30989 tejbeer 837
 
31762 tejbeer 838
        Address address = addressRepository.selectById(user.getAddressId());
30989 tejbeer 839
 
31762 tejbeer 840
        SendNotificationModel sendNotificationModel = new SendNotificationModel();
841
        sendNotificationModel.setCampaignName(title);
842
        sendNotificationModel.setTitle(message);
843
        sendNotificationModel.setType("url");
844
        sendNotificationModel.setMessage(reason);
845
        sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/orderDetails");
846
        sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
847
        sendNotificationModel.setMessageType(MessageType.notification);
848
        int userId = userAccountRepository.selectUserIdByRetailerId(order.getRetailerId());
849
        sendNotificationModel.setUserIds(Arrays.asList(userId));
850
        notificationService.sendNotification(sendNotificationModel);
25140 amit.gupta 851
 
31762 tejbeer 852
        // notificationService.sendWhatsappMessage(message, title,
853
        // address.getPhoneNumber());
30989 tejbeer 854
 
31762 tejbeer 855
    }
25039 amit.gupta 856
 
31762 tejbeer 857
    @RequestMapping(value = "/getNotifyItemColor", method = RequestMethod.GET)
858
    public String getNotifyItemColor(HttpServletRequest request, @RequestParam int catalogItemId, @RequestParam int itemId, Model model) throws ProfitMandiBusinessException {
24917 tejbeer 859
 
31762 tejbeer 860
        List<Item> availableColorItems = itemRepository.selectAllByCatalogItemId(catalogItemId);
861
        Iterator<Item> itemsIterator = availableColorItems.iterator();
24917 tejbeer 862
 
31762 tejbeer 863
        while (itemsIterator.hasNext()) {
864
            Item item = itemsIterator.next();
865
            TagListing itemTagListing = tagListingRepository.selectByItemId(item.getId());
24950 tejbeer 866
 
31762 tejbeer 867
            if (itemTagListing == null) {
868
                itemsIterator.remove();
24950 tejbeer 869
 
31785 amit.gupta 870
            } else if (!itemTagListing.isActive()) {
31762 tejbeer 871
                itemsIterator.remove();
24950 tejbeer 872
 
31762 tejbeer 873
            }
874
        }
24950 tejbeer 875
 
31762 tejbeer 876
        List<Order> inProcessselectedOrder = orderRepository.selectByItemIdOrderStatus(itemId, OrderStatus.SUBMITTED_FOR_PROCESSING);
877
        List<Integer> retailerIds = new ArrayList<>();
24917 tejbeer 878
 
31762 tejbeer 879
        for (com.spice.profitmandi.dao.entity.transaction.Order order : inProcessselectedOrder) {
880
            retailerIds.add(order.getRetailerId());
24917 tejbeer 881
 
31762 tejbeer 882
        }
24917 tejbeer 883
 
31762 tejbeer 884
        Map<Integer, String> storeIdAndFofoIdMap = fofoStoreRepository.selectByRetailerIds(retailerIds).stream().collect(Collectors.toMap(FofoStore::getId, FofoStore::getCode));
885
        LOGGER.info("item" + availableColorItems);
886
        model.addAttribute("item", availableColorItems);
887
        model.addAttribute("inProcessselectedOrder", inProcessselectedOrder);
888
        model.addAttribute("storeIdAndFofoIdMap", storeIdAndFofoIdMap);
24917 tejbeer 889
 
31762 tejbeer 890
        return "notify-order-modal";
891
    }
24917 tejbeer 892
 
31762 tejbeer 893
    @RequestMapping(value = "/notifyOrder", method = RequestMethod.POST)
894
    public String NotifyOrder(HttpServletRequest request, @RequestBody NotifyOrderModel notifyOrderModel, Model model) throws Exception {
24917 tejbeer 895
 
31762 tejbeer 896
        com.spice.profitmandi.dao.entity.transaction.NotifyItem notifyItem = null;
897
        List<Integer> orderIds = new ArrayList<>();
24917 tejbeer 898
 
31762 tejbeer 899
        NotifyColorChange notifytimestamp = new NotifyColorChange();
900
        notifytimestamp.setCreated(LocalDateTime.now());
901
        notifyColorChangeRepository.persist(notifytimestamp);
902
        NotifyMessage notifyMessage = new NotifyMessage();
903
        notifyMessage.setNotifyId(notifytimestamp.getId());
904
        notifyMessage.setNotifyMessages(notifyOrderModel.getMessage());
905
        notifyMessageRepository.persist(notifyMessage);
906
        for (NotifyItemIdModel itemid : notifyOrderModel.getItemIds()) {
24917 tejbeer 907
 
31762 tejbeer 908
            notifyItem = new com.spice.profitmandi.dao.entity.transaction.NotifyItem();
909
            notifyItem.setItemId(itemid.getItemId());
910
            notifyItem.setResponseTime(itemid.getResponseTime());
911
            notifyItem.setProcuredDate(itemid.getProcuredTime());
912
            notifyItem.setNotifyColorchangeId(notifytimestamp.getId());
913
            notifyItemRepository.persist(notifyItem);
914
            LOGGER.info("notifyItem" + notifyItem);
915
        }
916
        for (NotifyOrderIdModel st : notifyOrderModel.getOrderIds()) {
917
            List<NotifyOrder> existingOrder = notifyOrderRespository.selectByOrder(st.getOrderId());
918
            if (!existingOrder.isEmpty()) {
919
                LOGGER.info("existingOrder" + existingOrder);
920
                for (NotifyOrder notifyOrder : existingOrder) {
33741 amit.gupta 921
                    if (NotifyStatus.pending.equals(notifyOrder.getStatus())) {
31762 tejbeer 922
                        notifyOrder.setStatus(NotifyStatus.rejected);
923
                        notifyOrder.setUpdateTimestamp(LocalDateTime.now());
924
                    }
925
                }
926
            }
927
            NotifyOrder orderStatus = new NotifyOrder();
928
            orderStatus.setOrderId(st.getOrderId());
929
            orderStatus.setNotifyId(notifytimestamp.getId());
930
            orderStatus.setItemId(st.getOlditemId());
931
            Order id = orderRepository.selectById(st.getOrderId());
932
            orderStatus.setFofoId(id.getRetailerId());
933
            orderStatus.setStatus(NotifyStatus.pending);
934
            notifyOrderRespository.persist(orderStatus);
24917 tejbeer 935
 
31762 tejbeer 936
            LOGGER.info("itemStatus" + orderStatus);
937
            orderIds.add(st.getOrderId());
938
        }
24917 tejbeer 939
 
31762 tejbeer 940
        LOGGER.info("orderIds" + orderIds);
941
        List<Order> orders = orderRepository.selectByOrderIds(orderIds);
942
        for (Order order : orders) {
943
            LOGGER.info("order" + order.getId());
24917 tejbeer 944
 
31762 tejbeer 945
            String title = "Alert!";
30989 tejbeer 946
 
31762 tejbeer 947
            NotifyMessage message = notifyMessageRepository.selectByNotifyId(notifytimestamp.getId());
25140 amit.gupta 948
 
31762 tejbeer 949
            com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(order.getRetailerId());
30989 tejbeer 950
 
31762 tejbeer 951
            Address address = addressRepository.selectById(user.getAddressId());
30989 tejbeer 952
 
31762 tejbeer 953
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
954
            sendNotificationModel.setCampaignName("Notify Partner");
955
            sendNotificationModel.setMessage(message.getNotifyMessages());
956
            sendNotificationModel.setType("url");
957
            sendNotificationModel.setTitle("Alert");
958
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifyOrder");
959
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
960
            sendNotificationModel.setMessageType(MessageType.notification);
961
            int userId = userAccountRepository.selectUserIdByRetailerId(order.getRetailerId());
25873 tejbeer 962
 
31762 tejbeer 963
            sendNotificationModel.setUserIds(Arrays.asList(userId));
964
            notificationService.sendNotification(sendNotificationModel);
25140 amit.gupta 965
 
31762 tejbeer 966
            // notificationService.sendWhatsappMessage(message.getNotifyMessages(), title,
967
            // address.getPhoneNumber());
30989 tejbeer 968
 
31762 tejbeer 969
        }
970
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
971
        return "response";
972
    }
24917 tejbeer 973
 
31762 tejbeer 974
    @RequestMapping(value = "/getAllNotifyOrder", method = RequestMethod.GET)
975
    public String getAllNotifyOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
976
        List<NotifyOrder> notifyOrders = null;
32868 amit.gupta 977
        List<com.spice.profitmandi.dao.entity.transaction.Order> inProcessorder = orderRepository.selectAllOrder(Arrays.asList(OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.INVENTORY_LOW));
24950 tejbeer 978
 
31762 tejbeer 979
        List<Integer> orderIds = new ArrayList<>();
980
        if (!inProcessorder.isEmpty()) {
981
            for (com.spice.profitmandi.dao.entity.transaction.Order order : inProcessorder) {
24950 tejbeer 982
 
31762 tejbeer 983
                orderIds.add(order.getId());
24917 tejbeer 984
 
31762 tejbeer 985
            }
986
            notifyOrders = notifyOrderRespository.selectByorderIds(orderIds);
987
            Set<Integer> oldItemIds = new HashSet<>();
988
            List<Integer> fofoIds = new ArrayList<>();
989
            List<Integer> notifyIds = new ArrayList<>();
990
            if (!notifyOrders.isEmpty()) {
991
                for (NotifyOrder notifyOrder : notifyOrders) {
992
                    oldItemIds.add(notifyOrder.getItemId());
993
                    fofoIds.add(notifyOrder.getFofoId());
994
                    notifyIds.add(notifyOrder.getNotifyId());
995
                }
24917 tejbeer 996
 
31762 tejbeer 997
                List<NotifyColorChange> notifyColorChanges = notifyColorChangeRepository.selectByNotifyId(notifyIds);
998
                Map<Integer, NotifyColorChange> notifyIdNotifyColorMap = this.notifyOrdersToNotifyId(notifyColorChanges);
999
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
1000
                Map<Integer, CustomRetailer> fofoIdsAndRetailerName = fofoIds.stream().distinct().map(x -> customRetailerMap.get(x)).filter(x -> x != null).collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
1001
                Map<Integer, String> itemdescription = inventoryService.getItemIdDescriptionMap(oldItemIds);
24917 tejbeer 1002
 
31762 tejbeer 1003
                model.addAttribute("notifyOrders", notifyOrders);
1004
                model.addAttribute("notifyIdNotifyColorMap", notifyIdNotifyColorMap);
1005
                model.addAttribute("itemdescription", itemdescription);
1006
                model.addAttribute("fofoIdsAndRetailerName", fofoIdsAndRetailerName);
24917 tejbeer 1007
 
31762 tejbeer 1008
            } else {
1009
                model.addAttribute("notifyOrders", notifyOrders);
1010
            }
1011
        } else {
1012
            model.addAttribute("notifyOrders", notifyOrders);
1013
        }
1014
        return "notify_order";
1015
    }
24917 tejbeer 1016
 
31762 tejbeer 1017
    private Map<Integer, NotifyColorChange> notifyOrdersToNotifyId(List<NotifyColorChange> notifyColorChanges) {
1018
        Map<Integer, NotifyColorChange> notifyIdNotifyColorMap = new HashMap<>();
1019
        for (NotifyColorChange notifyColorChange : notifyColorChanges) {
1020
            notifyIdNotifyColorMap.put(notifyColorChange.getId(), notifyColorChange);
1021
        }
1022
        return notifyIdNotifyColorMap;
1023
    }
24917 tejbeer 1024
 
31762 tejbeer 1025
    @RequestMapping(value = "/getItems", method = RequestMethod.GET)
1026
    public String getItems(HttpServletRequest request, @RequestParam int catalogItemId, Model model) throws Exception {
26031 tejbeer 1027
 
31762 tejbeer 1028
        Set<Integer> itemIds = itemRepository.selectAllByCatalogItemId(catalogItemId).stream().map(x -> x.getId()).collect(Collectors.toSet());
26031 tejbeer 1029
 
31762 tejbeer 1030
        List<Order> notAvailableProcessingOrder = orderRepository.selectByItemIdsOrderStatus(itemIds, OrderStatus.SUBMITTED_FOR_PROCESSING);
1031
        LOGGER.info("notAvailableProcessingOrder" + notAvailableProcessingOrder);
26031 tejbeer 1032
 
31762 tejbeer 1033
        List<Integer> retailerIds = new ArrayList<>();
1034
        for (com.spice.profitmandi.dao.entity.transaction.Order order : notAvailableProcessingOrder) {
1035
            retailerIds.add(order.getRetailerId());
26031 tejbeer 1036
 
31762 tejbeer 1037
        }
26031 tejbeer 1038
 
31762 tejbeer 1039
        Map<Integer, String> storeIdAndFofoIdMap = fofoStoreRepository.selectByRetailerIds(retailerIds).stream().collect(Collectors.toMap(FofoStore::getId, FofoStore::getCode));
26031 tejbeer 1040
 
31762 tejbeer 1041
        model.addAttribute("notAvailableProcessingOrder", notAvailableProcessingOrder);
1042
        model.addAttribute("storeIdAndFofoIdMap", storeIdAndFofoIdMap);
26031 tejbeer 1043
 
31762 tejbeer 1044
        return "partner-cancel-order-modal";
1045
    }
26031 tejbeer 1046
 
31762 tejbeer 1047
    @RequestMapping(value = "/notifyCancelOrder", method = RequestMethod.POST)
1048
    public String NotifyCancelOrder(HttpServletRequest request, @RequestBody NotifyOrderModel notifyOrderModel, Model model) throws Exception {
1049
        for (NotifyOrderIdModel st : notifyOrderModel.getOrderIds()) {
1050
            LOGGER.info("orderId" + st.getOrderId());
1051
            Order order = orderRepository.selectById(st.getOrderId());
1052
            NotifyCancel nc = notifyCancelOrderRepository.selectByOrderId(st.getOrderId());
1053
            if (nc == null) {
1054
                nc = new NotifyCancel();
1055
                nc.setOrderId(st.getOrderId());
1056
                nc.setItemId(st.getOlditemId());
1057
                nc.setFofoId(order.getRetailerId());
1058
                nc.setCancellation(false);
1059
                nc.setCreatedTimestamp(LocalDateTime.now());
1060
                nc.setUpdatedTimestamp(LocalDateTime.now());
1061
                notifyCancelOrderRepository.persist(nc);
1062
            } else {
1063
                nc.setOrderId(st.getOrderId());
1064
                nc.setItemId(st.getOlditemId());
1065
                nc.setFofoId(order.getRetailerId());
1066
                nc.setCancellation(false);
1067
                nc.setUpdatedTimestamp(LocalDateTime.now());
1068
                notifyCancelOrderRepository.persist(nc);
1069
            }
26031 tejbeer 1070
 
31762 tejbeer 1071
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
1072
            sendNotificationModel.setCampaignName("Notify Partner");
1073
            sendNotificationModel.setMessage(notifyOrderModel.getMessage());
1074
            sendNotificationModel.setType("url");
1075
            sendNotificationModel.setTitle("Alert");
1076
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifyCancelOrder");
1077
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
1078
            sendNotificationModel.setMessageType(MessageType.notification);
1079
            int userId = userAccountRepository.selectUserIdByRetailerId(order.getRetailerId());
26031 tejbeer 1080
 
31762 tejbeer 1081
            sendNotificationModel.setUserIds(Arrays.asList(userId));
1082
            notificationService.sendNotification(sendNotificationModel);
26031 tejbeer 1083
 
31762 tejbeer 1084
        }
26031 tejbeer 1085
 
31762 tejbeer 1086
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1087
        return "response";
1088
    }
26039 tejbeer 1089
 
31762 tejbeer 1090
    @RequestMapping(value = "/getNotifiedCancelOrder", method = RequestMethod.GET)
1091
    public String getNotifiedCancelOrder(HttpServletRequest request, Model model) throws Exception {
26039 tejbeer 1092
 
31762 tejbeer 1093
        List<NotifyCancel> notifyCancels = notifyCancelOrderRepository.selectAllNonCancelOrder();
1094
        if (!notifyCancels.isEmpty()) {
1095
            List<Integer> retailerIds = new ArrayList<>();
1096
            Set<Integer> itemIds = new HashSet<>();
1097
            for (NotifyCancel nc : notifyCancels) {
1098
                retailerIds.add(nc.getFofoId());
1099
                itemIds.add(nc.getItemId());
1100
            }
26039 tejbeer 1101
 
31762 tejbeer 1102
            Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
26039 tejbeer 1103
 
31762 tejbeer 1104
            Map<Integer, CustomRetailer> fofoIdsAndRetailerName = retailerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null).collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
1105
            Map<Integer, String> itemdescription = inventoryService.getItemIdDescriptionMap(itemIds);
1106
            model.addAttribute("notifyCancels", notifyCancels);
1107
            model.addAttribute("itemdescription", itemdescription);
1108
            model.addAttribute("fofoIdsAndRetailerName", fofoIdsAndRetailerName);
1109
        } else {
26039 tejbeer 1110
 
31762 tejbeer 1111
            model.addAttribute("notifyCancels", notifyCancels);
26039 tejbeer 1112
 
31762 tejbeer 1113
        }
1114
        return "notify_cancel";
1115
    }
26039 tejbeer 1116
 
31762 tejbeer 1117
    @RequestMapping(value = "/getNotifyItems", method = RequestMethod.GET)
1118
    public String getNotifyItems(HttpServletRequest request, @RequestParam int itemId, Model model) throws Exception {
1119
        Item item = itemRepository.selectById(itemId);
26039 tejbeer 1120
 
31762 tejbeer 1121
        List<Integer> itemIds = itemRepository.selectAllByCatalogItemId(item.getCatalogItemId()).stream().map(x -> x.getId()).collect(Collectors.toList());
26039 tejbeer 1122
 
31762 tejbeer 1123
        List<NotifyCancel> ncs = notifyCancelOrderRepository.selectByItemIdsAndStatus(itemIds);
1124
        List<Integer> retailerIds = new ArrayList<>();
1125
        Map<Integer, Object> orders = new HashMap<>();
1126
        for (NotifyCancel nc : ncs) {
1127
            retailerIds.add(nc.getFofoId());
1128
            Order od = orderRepository.selectById(nc.getOrderId());
1129
            orders.put(nc.getOrderId(), od);
1130
        }
26039 tejbeer 1131
 
31762 tejbeer 1132
        Map<Integer, String> storeIdAndFofoIdMap = fofoStoreRepository.selectByRetailerIds(retailerIds).stream().collect(Collectors.toMap(FofoStore::getId, FofoStore::getCode));
26039 tejbeer 1133
 
31762 tejbeer 1134
        model.addAttribute("notifyItems", ncs);
1135
        model.addAttribute("orders", orders);
1136
        model.addAttribute("storeIdAndFofoIdMap", storeIdAndFofoIdMap);
26039 tejbeer 1137
 
31762 tejbeer 1138
        return "notify_cancel_order_modal";
1139
    }
26039 tejbeer 1140
 
31762 tejbeer 1141
    @RequestMapping(value = "/changeNotifyCancelRequest", method = RequestMethod.POST)
1142
    public String changeNotifyCancelRequest(HttpServletRequest request, @RequestBody NotifyOrderModel notifyOrderModel, Model model) throws Exception {
1143
        List<Integer> orderIds = notifyOrderModel.getOrderIds().stream().map(x -> x.getOrderId()).collect(Collectors.toList());
26039 tejbeer 1144
 
31762 tejbeer 1145
        List<NotifyCancel> ncs = notifyCancelOrderRepository.selectByOrderIds(orderIds);
1146
        for (NotifyCancel nc : ncs) {
1147
            nc.setCancellation(true);
1148
        }
26039 tejbeer 1149
 
31762 tejbeer 1150
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1151
        return "response";
1152
    }
26482 tejbeer 1153
 
31762 tejbeer 1154
    @RequestMapping(value = "/getProducts", method = RequestMethod.GET)
1155
    public String getProducts(HttpServletRequest request, Model model) throws ProfitMandiBusinessException, URISyntaxException, IOException {
26482 tejbeer 1156
 
31762 tejbeer 1157
        return "product-detail";
1158
    }
26482 tejbeer 1159
 
31762 tejbeer 1160
    @RequestMapping(value = "/getProductInfo", method = RequestMethod.GET)
1161
    public String getProductInfo(HttpServletRequest request, long catalogId, Model model) throws Exception {
1162
        ContentPojo cp = mongoClient.getEntityById(catalogId);
1163
        model.addAttribute("cp", cp);
1164
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1165
        return "product-info";
1166
    }
26493 tejbeer 1167
 
31762 tejbeer 1168
    @RequestMapping(value = "/getProductCompareInfo", method = RequestMethod.GET)
1169
    public String getProductCompareInfo(HttpServletRequest request, @RequestParam List<Long> catalogIds, Model model) throws Exception {
1170
        List<ContentPojo> cps = new ArrayList<>();
1171
        Set<Integer> cataogIds = catalogIds.stream().mapToInt(Long::intValue).boxed().collect(Collectors.toSet());
1172
        LOGGER.info("tagListingMOP" + cataogIds);
1173
        for (Long cId : catalogIds) {
1174
            ContentPojo cp = mongoClient.getEntityById(cId);
1175
            if (cp.getName() == null) {
1176
                cp.setName(itemRepository.selectAllByCatalogItemId(cId.intValue()).get(0).getItemDescriptionNoColor());
1177
            }
1178
            List<Item> items = itemRepository.selectAllByCatalogItemId(cId.intValue());
1179
            LOGGER.info("itemsMop" + items);
1180
            int i = 0;
1181
            for (Item item : items) {
1182
                TagListing tagListing = tagListingRepository.selectByItemId(items.get(i).getId());
27618 tejbeer 1183
 
31762 tejbeer 1184
                if (tagListing != null) {
1185
                    cp.setPrice(tagListing.getMop());
27618 tejbeer 1186
 
31762 tejbeer 1187
                    LOGGER.info("tagListingMOP" + tagListing);
27618 tejbeer 1188
 
31762 tejbeer 1189
                    break;
27618 tejbeer 1190
 
31762 tejbeer 1191
                }
1192
                i++;
1193
            }
1194
            cps.add(cp);
27583 tejbeer 1195
 
31762 tejbeer 1196
        }
26959 tejbeer 1197
 
31762 tejbeer 1198
        List<Map<String, String>> entityList = new ArrayList<>();
1199
        for (ContentPojo cp : cps) {
1200
            Map<String, String> specsMap = new HashMap<>();
1201
            for (SpecificationGroup sg : cp.getDetailedSpecs()) {
1202
                String title = sg.getTitle();
1203
                for (Specification s : sg.getSpecs()) {
1204
                    String key = title + s.getName();
1205
                    specsMap.put(key, String.join(", ", s.getValues()));
1206
                }
1207
            }
1208
            entityList.add(specsMap);
27723 tejbeer 1209
 
31762 tejbeer 1210
        }
26959 tejbeer 1211
 
31762 tejbeer 1212
        LOGGER.info("cps" + cps);
1213
        model.addAttribute("cps", cps);
1214
        model.addAttribute("catalogIds", gson.toJson(catalogIds, List.class));
1215
        model.addAttribute("entityList", entityList);
1216
        return "product-compare";
1217
    }
27723 tejbeer 1218
 
31762 tejbeer 1219
    @RequestMapping(value = "/inventory", method = RequestMethod.GET)
1220
    public String Inventory(HttpServletRequest request, @RequestParam(name = "warehouseIds", required = true, defaultValue = "0") List<Integer> warehouseIds, Model model) throws Exception {
1221
        model.addAttribute("warehouseId", warehouseIds);
1222
        LOGGER.info("warehouseIds" + warehouseIds);
27723 tejbeer 1223
 
31762 tejbeer 1224
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1225
        if (warehouseIds.contains(0)) {
1226
            warehouseIds.addAll(warehouseMap.keySet());
1227
        }
27723 tejbeer 1228
 
31762 tejbeer 1229
        long poTodayValue = 0;
1230
        long poThreedaysValue = 0;
1231
        long poSevendaysValue = 0;
1232
        long poTodayQty = 0;
1233
        long poThreedaysQty = 0;
1234
        long poSevendaysQty = 0;
27739 tejbeer 1235
 
31762 tejbeer 1236
        List<OpenPoModel> openPO = warehousePurchaseOrderRepository.selectOpenPo(warehouseIds);
1237
        for (OpenPoModel po : openPO) {
1238
            poTodayValue += po.getTodayValue();
1239
            poThreedaysValue += po.getThreedaysValue();
1240
            poSevendaysValue += po.getSevendaysValue();
1241
            poTodayQty += po.getTodayQty();
1242
            poThreedaysQty += po.getThreedaysQty();
1243
            poSevendaysQty += po.getSevendaysQty();
1244
        }
1245
        OpenPoModel poModel = new OpenPoModel();
1246
        poModel.setBrand("Total Values");
1247
        poModel.setTodayValue(poTodayValue);
1248
        poModel.setThreedaysValue(poThreedaysValue);
1249
        poModel.setSevendaysValue(poSevendaysValue);
1250
        poModel.setSevendaysQty(poSevendaysQty);
1251
        poModel.setThreedaysQty(poThreedaysQty);
1252
        poModel.setTodayQty(poTodayQty);
1253
        openPO.add(poModel);
27739 tejbeer 1254
 
31762 tejbeer 1255
        long purtodayValue = 0;
1256
        long purthreedaysValue = 0;
1257
        long purlmsValue = 0;
1258
        long purmtd = 0;
1259
        long purtodayQty = 0;
1260
        long purthreedaysQty = 0;
1261
        long purlmsQty = 0;
1262
        long purmtdQty = 0;
27739 tejbeer 1263
 
32763 amit.gupta 1264
        List<OurPurchaseModel> ourPurchaseModels = warehouseScanRepository.selectOurPurchase(warehouseIds);
27739 tejbeer 1265
 
32763 amit.gupta 1266
        for (OurPurchaseModel pm : ourPurchaseModels) {
31762 tejbeer 1267
            purtodayValue += pm.getTodayValue();
1268
            purthreedaysValue += pm.getThreedaysValue();
1269
            purlmsValue += pm.getLms();
1270
            purmtd += pm.getMtd();
1271
            purtodayQty += pm.getTodayQty();
1272
            purthreedaysQty += pm.getThreedaysQty();
1273
            purlmsQty += pm.getLmsQty();
1274
            purmtdQty += pm.getMtdQty();
1275
        }
1276
        OurPurchaseModel omp = new OurPurchaseModel();
1277
        omp.setBrand("Total Values");
1278
        omp.setTodayValue(purtodayValue);
1279
        omp.setThreedaysValue(purthreedaysValue);
1280
        omp.setLms(purlmsValue);
1281
        omp.setMtd(purmtd);
1282
        omp.setTodayQty(purtodayQty);
1283
        omp.setThreedaysQty(purthreedaysQty);
1284
        omp.setLmsQty(purlmsQty);
1285
        omp.setMtdQty(purmtdQty);
32763 amit.gupta 1286
        ourPurchaseModels.add(omp);
27749 tejbeer 1287
 
31762 tejbeer 1288
        List<BrandWiseTertiaryModel> tertiary = fofoOrderRepository.selectGroupByBrandPartnerTertiary(warehouseIds);
1289
        long tertodayValue = 0;
1290
        long terthreedaysValue = 0;
1291
        long termtd = 0;
1292
        long terlmtd = 0;
1293
        long terlms = 0;
1294
        long tertodayQty = 0;
1295
        long terthreedaysQty = 0;
1296
        long termtdQty = 0;
1297
        long terlmtdQty = 0;
1298
        long terlmsQty = 0;
1299
        for (BrandWiseTertiaryModel btm : tertiary) {
1300
            tertodayValue += btm.getTodayValue();
1301
            terthreedaysValue += btm.getThreedaysValue();
1302
            termtd += btm.getMtd();
1303
            terlmtd += btm.getLmtd();
1304
            terlms += btm.getLms();
1305
            tertodayQty += btm.getTodayQty();
1306
            terthreedaysQty += btm.getThreedaysQty();
1307
            termtdQty += btm.getMtdQty();
1308
            terlmtdQty += btm.getLmtdQty();
1309
            terlmsQty += btm.getLmsQty();
1310
        }
1311
        BrandWiseTertiaryModel bwt = new BrandWiseTertiaryModel();
1312
        bwt.setBrand("Total Values");
1313
        bwt.setTodayValue(tertodayValue);
1314
        bwt.setThreedaysValue(terthreedaysValue);
1315
        bwt.setMtd(termtd);
1316
        bwt.setLmtd(terlmtd);
1317
        bwt.setLms(terlms);
1318
        bwt.setTodayQty(tertodayQty);
1319
        bwt.setThreedaysQty(terthreedaysQty);
1320
        bwt.setMtdQty(termtdQty);
1321
        bwt.setLmtdQty(terlmtdQty);
1322
        bwt.setLmsQty(terlmsQty);
1323
        tertiary.add(bwt);
27749 tejbeer 1324
 
31762 tejbeer 1325
        List<SecondaryOrderBillingModel> billing = orderRepository.selectAllBilledOrderGroupByBrand(warehouseIds);
1326
        long sectodayValue = 0;
1327
        long secthreedaysValue = 0;
1328
        long secmtd = 0;
1329
        long seclmtd = 0;
1330
        long seclms = 0;
1331
        long sectodayQty = 0;
1332
        long secthreedaysQty = 0;
1333
        long secmtdQty = 0;
1334
        long seclmtdQty = 0;
1335
        long seclmsQty = 0;
1336
        for (SecondaryOrderBillingModel sbm : billing) {
1337
            sectodayValue += sbm.getTodayValue();
1338
            secthreedaysValue += sbm.getThreedaysValue();
1339
            secmtd += sbm.getMtd();
1340
            seclmtd += sbm.getLmtd();
1341
            seclms += sbm.getLms();
1342
            sectodayQty += sbm.getTodayQty();
1343
            secthreedaysQty += sbm.getThreedaysQty();
1344
            secmtdQty += sbm.getMtdQty();
1345
            seclmtdQty += sbm.getLmtdQty();
1346
            seclmsQty += sbm.getLmsQty();
1347
        }
27739 tejbeer 1348
 
31762 tejbeer 1349
        SecondaryOrderBillingModel som = new SecondaryOrderBillingModel();
1350
        som.setBrand("Total Values");
1351
        som.setTodayValue(sectodayValue);
1352
        som.setThreedaysValue(secthreedaysValue);
1353
        som.setMtd(secmtd);
1354
        som.setLmtd(seclmtd);
1355
        som.setLms(seclms);
1356
        som.setTodayQty(sectodayQty);
1357
        som.setThreedaysQty(secthreedaysQty);
1358
        som.setMtdQty(secmtdQty);
1359
        som.setLmtdQty(seclmtdQty);
1360
        som.setLmsQty(seclmsQty);
1361
        billing.add(som);
1362
        LOGGER.info("openPO" + openPO);
32763 amit.gupta 1363
        LOGGER.info("purchase" + ourPurchaseModels);
31762 tejbeer 1364
        LOGGER.info("tertiary" + tertiary);
1365
        LOGGER.info("billing" + billing);
27723 tejbeer 1366
 
31762 tejbeer 1367
        LOGGER.info("warehouseIds" + warehouseIds);
1368
        model.addAttribute("warehouseMap", warehouseMap);
1369
        model.addAttribute("openPO", openPO);
32763 amit.gupta 1370
        model.addAttribute("ourPurchaseModels", ourPurchaseModels);
31762 tejbeer 1371
        model.addAttribute("tertiary", tertiary);
1372
        model.addAttribute("billing", billing);
27723 tejbeer 1373
 
31762 tejbeer 1374
        return "inventory-listing";
27723 tejbeer 1375
 
31762 tejbeer 1376
    }
27738 tejbeer 1377
 
31762 tejbeer 1378
    @RequestMapping(value = "/getOpenPoItemByBrand", method = RequestMethod.GET)
1379
    public String Inventory(HttpServletRequest request, @RequestParam(name = "warehouseIds", required = true, defaultValue = "0") List<Integer> warehouseIds, @RequestParam(name = "brand", required = true, defaultValue = "") List<String> brand, int timeValue, Model model) throws Exception {
1380
        model.addAttribute("warehouseId", warehouseIds);
1381
        LOGGER.info("warehouseIds" + warehouseIds);
27738 tejbeer 1382
 
31762 tejbeer 1383
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1384
        if (warehouseIds.contains(0)) {
1385
            warehouseIds.addAll(warehouseMap.keySet());
1386
        }
1387
        LOGGER.info("brand" + brand);
27749 tejbeer 1388
 
31762 tejbeer 1389
        if (brand.contains("Total Values")) {
1390
            List<String> poBrands = warehousePurchaseOrderRepository.selectOpenPo(warehouseIds).stream().map(x -> x.getBrand()).collect(Collectors.toList());
27749 tejbeer 1391
 
31762 tejbeer 1392
            brand.addAll(poBrands);
1393
        }
27749 tejbeer 1394
 
31762 tejbeer 1395
        LOGGER.info("brand" + brand);
1396
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
1397
        List<OpenPoItemModel> openPOItem = null;
1398
        if (timeValue != 0) {
1399
            openPOItem = warehousePurchaseOrderRepository.selectOpenPoItem(warehouseIds, brand, curDate.minusDays(timeValue), curDate);
1400
        } else {
1401
            openPOItem = warehousePurchaseOrderRepository.selectTodayOpenPoItem(warehouseIds, brand, curDate);
1402
        }
1403
        LOGGER.info("openPOItem" + openPOItem);
27738 tejbeer 1404
 
31762 tejbeer 1405
        model.addAttribute("openPOItem", openPOItem);
27738 tejbeer 1406
 
31762 tejbeer 1407
        return "inventory-listing-po-item";
27738 tejbeer 1408
 
31762 tejbeer 1409
    }
27738 tejbeer 1410
 
31762 tejbeer 1411
    @RequestMapping(value = "/getOurPurchaseItemByBrand", method = RequestMethod.GET)
1412
    public String getOurPurchaseItemByBrand(HttpServletRequest request, @RequestParam(name = "warehouseIds", required = true, defaultValue = "0") List<Integer> warehouseIds, @RequestParam(name = "brand", required = true, defaultValue = "") List<String> brand, int timeValue, Model model) throws Exception {
1413
        model.addAttribute("warehouseId", warehouseIds);
1414
        LOGGER.info("warehouseIds" + warehouseIds);
27738 tejbeer 1415
 
31762 tejbeer 1416
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1417
        if (warehouseIds.contains(0)) {
1418
            warehouseIds.addAll(warehouseMap.keySet());
1419
        }
1420
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
27749 tejbeer 1421
 
31762 tejbeer 1422
        if (brand.contains("Total Values")) {
1423
            List<String> purchasebrands = warehouseScanRepository.selectOurPurchase(warehouseIds).stream().map(x -> x.getBrand()).collect(Collectors.toList());
27749 tejbeer 1424
 
31762 tejbeer 1425
            brand.addAll(purchasebrands);
1426
        }
1427
        List<OurPurchaseItemModel> ourPurchaseItem = null;
1428
        if (timeValue != 0) {
1429
            if (timeValue == 1) {
1430
                ourPurchaseItem = warehouseScanRepository.selectOurPurchaseItemByBrand(warehouseIds, brand, curDate.withDayOfMonth(1), curDate.plusDays(1));
27749 tejbeer 1431
 
31762 tejbeer 1432
            } else if (timeValue == -1) {
27749 tejbeer 1433
 
31762 tejbeer 1434
                ourPurchaseItem = warehouseScanRepository.selectOurPurchaseItemByBrand(warehouseIds, brand, curDate.minusMonths(1).withDayOfMonth(1), curDate.withDayOfMonth(1));
27749 tejbeer 1435
 
31762 tejbeer 1436
            } else {
1437
                ourPurchaseItem = warehouseScanRepository.selectOurPurchaseItemByBrand(warehouseIds, brand, curDate.minusDays(timeValue), curDate);
27749 tejbeer 1438
 
31762 tejbeer 1439
            }
1440
        } else {
1441
            ourPurchaseItem = warehouseScanRepository.selectTodayOurPurchaseItemByBrand(warehouseIds, brand, curDate);
1442
        }
1443
        LOGGER.info("ourPurchaseItem" + ourPurchaseItem);
27738 tejbeer 1444
 
31762 tejbeer 1445
        model.addAttribute("ourPurchaseItem", ourPurchaseItem);
1446
        model.addAttribute("warehouseMap", warehouseMap);
27738 tejbeer 1447
 
31762 tejbeer 1448
        return "inventory-listing-purchase-item";
27738 tejbeer 1449
 
31762 tejbeer 1450
    }
27738 tejbeer 1451
 
31762 tejbeer 1452
    @RequestMapping(value = "/getWarehouseWiseSecondaryBillingByBrand", method = RequestMethod.GET)
1453
    public String getWarehouseWiseSecondaryBillingByBrand(HttpServletRequest request, @RequestParam(name = "brand", required = true, defaultValue = "") String brand, int timeValue, Model model) throws Exception {
27738 tejbeer 1454
 
31762 tejbeer 1455
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
1456
        int dayOfMonth = curDate.getDayOfMonth();
1457
        LocalDateTime startOfMonth = curDate.withDayOfMonth(1);
1458
        int lengthOfMonth = YearMonth.from(startOfMonth.minusMonths(1)).lengthOfMonth();
27749 tejbeer 1459
 
31762 tejbeer 1460
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1461
        SecondaeryOrderDateRange sr = null;
1462
        if (brand.equals("Total Values")) {
1463
            brand = null;
1464
        }
1465
        if (timeValue != 0) {
1466
            if (timeValue == 1) {
27738 tejbeer 1467
 
31762 tejbeer 1468
                sr = getSecondaryModel(brand, curDate.withDayOfMonth(1), curDate.plusDays(1));
27867 tejbeer 1469
 
31762 tejbeer 1470
            } else if (timeValue == 2) {
1471
                LOGGER.info("curDate" + curDate.withDayOfMonth(1).minusMonths(1));
1472
                LOGGER.info("curDate" + curDate.minusMonths(1).plusDays(Math.min(dayOfMonth, lengthOfMonth)));
27749 tejbeer 1473
 
31762 tejbeer 1474
                sr = getSecondaryModel(brand, curDate.withDayOfMonth(1).minusMonths(1), startOfMonth.minusMonths(1).plusDays(Math.min(dayOfMonth, lengthOfMonth)));
27867 tejbeer 1475
 
31762 tejbeer 1476
            } else if (timeValue == -1) {
27867 tejbeer 1477
 
31762 tejbeer 1478
                sr = getSecondaryModel(brand, curDate.minusMonths(1).withDayOfMonth(1), startOfMonth);
27867 tejbeer 1479
 
31762 tejbeer 1480
            } else {
27738 tejbeer 1481
 
31762 tejbeer 1482
                sr = getSecondaryModel(brand, curDate.minusDays(timeValue), curDate);
1483
            }
27738 tejbeer 1484
 
31762 tejbeer 1485
        } else {
1486
            sr = getSecondaryModel(brand, curDate, curDate.plusDays(1));
1487
        }
27738 tejbeer 1488
 
32438 amit.gupta 1489
        Map<BrandRegionModel, Map<LocalDate, SecondaryWarehouseWiseOrderBilllingModel>> brandWarehouseOrderMap = sr.getSecondaryModel().stream().collect(Collectors.groupingBy(x -> new BrandRegionModel(x.getWarehouseId(), x.getBrand()),
1490
                Collectors.collectingAndThen(Collectors.toList(), x -> x.stream().collect(Collectors.toMap(y -> y.getBillingTimestamp(), y -> y)))));
27738 tejbeer 1491
 
31762 tejbeer 1492
        Map<LocalDate, Integer> dateWiseTotal = sr.getSecondaryModel().stream().collect(
1493
                Collectors.groupingBy(x -> x.getBillingTimestamp(), Collectors.summingInt(x -> (int) x.getValue())));
27893 tejbeer 1494
 
31762 tejbeer 1495
        Map<LocalDate, Integer> dateWiseQtyTotal = sr.getSecondaryModel().stream().collect(
1496
                Collectors.groupingBy(x -> x.getBillingTimestamp(), Collectors.summingInt(x -> (int) x.getQty())));
27893 tejbeer 1497
 
31762 tejbeer 1498
        LOGGER.info("dateWiseTotal" + dateWiseTotal);
27893 tejbeer 1499
 
31762 tejbeer 1500
        brandWarehouseOrderMap.entrySet().stream().forEach(x -> {
1501
            x.getKey().setTotal(x.getValue().entrySet().stream().collect(Collectors.summingInt(y -> (int) y.getValue().getValue())));
1502
        });
27867 tejbeer 1503
 
31762 tejbeer 1504
        brandWarehouseOrderMap.entrySet().stream().forEach(x -> {
1505
            x.getKey().setQty(
1506
                    x.getValue().entrySet().stream().collect(Collectors.summingInt(y -> (int) y.getValue().getQty())));
1507
        });
1508
        LOGGER.info("brandWarehouseOrderMap" + brandWarehouseOrderMap);
27867 tejbeer 1509
 
31762 tejbeer 1510
        model.addAttribute("brandWarehouseOrderMap", brandWarehouseOrderMap);
1511
        model.addAttribute("dateWiseTotal", dateWiseTotal);
1512
        model.addAttribute("dateWiseQtyTotal", dateWiseQtyTotal);
1513
        model.addAttribute("dateRange", sr.getDateRange());
1514
        model.addAttribute("warehouseMap", warehouseMap);
1515
        return "secondary-warehouse-billing-order";
27867 tejbeer 1516
 
31762 tejbeer 1517
    }
27867 tejbeer 1518
 
31762 tejbeer 1519
    public SecondaeryOrderDateRange getSecondaryModel(String brand, LocalDateTime startDate, LocalDateTime endDate) {
27867 tejbeer 1520
 
31762 tejbeer 1521
        SecondaeryOrderDateRange sr = new SecondaeryOrderDateRange();
1522
        List<SecondaryWarehouseWiseOrderBilllingModel> secondaryOrderbilling = orderRepository.selectAllBilledOrderGroupByBrandWarehouse(brand, startDate, endDate).stream().sorted(Comparator.comparing(SecondaryWarehouseWiseOrderBilllingModel::getBillingTimestamp)).collect(Collectors.toList());
1523
        long noOfDaysBetween = ChronoUnit.DAYS.between(startDate, endDate);
27867 tejbeer 1524
 
31762 tejbeer 1525
        List<LocalDate> dateRange = Stream.iterate(startDate.toLocalDate(), date -> date.plusDays(1)).limit(noOfDaysBetween).collect(Collectors.toList());
27867 tejbeer 1526
 
31762 tejbeer 1527
        sr.setDateRange(dateRange);
1528
        sr.setSecondaryModel(secondaryOrderbilling);
27867 tejbeer 1529
 
31762 tejbeer 1530
        return sr;
27867 tejbeer 1531
 
31762 tejbeer 1532
    }
27867 tejbeer 1533
 
31762 tejbeer 1534
    @RequestMapping(value = "/getSecondaryBillingItemByBrand", method = RequestMethod.GET)
1535
    public String getSecondaryBillingItemByBrand(HttpServletRequest request, @RequestParam(name = "warehouseId", required = true, defaultValue = "0") int warehouseId, @RequestParam(name = "brand", required = true, defaultValue = "") String brand, @RequestParam List<LocalDate> date, Model model) throws Exception {
27867 tejbeer 1536
 
31762 tejbeer 1537
        List<SecondaryOrderItemBillingModel> orderItemBilling = orderRepository.selectAllBilledOrderItemByBrand(warehouseId, brand, date);
27867 tejbeer 1538
 
31762 tejbeer 1539
        LOGGER.info("orderItemBilling" + orderItemBilling);
1540
        model.addAttribute("billedItem", orderItemBilling);
1541
        model.addAttribute("date", date);
1542
        model.addAttribute("brand", brand);
1543
        return "inventory-listing-billing-item";
27738 tejbeer 1544
 
31762 tejbeer 1545
    }
27738 tejbeer 1546
 
31762 tejbeer 1547
    @RequestMapping(value = "/getPartnerTertiaryItemByBrand", method = RequestMethod.GET)
1548
    public String getPartnerTertiaryItemByBrand(HttpServletRequest request, @RequestParam(name = "warehouseIds", required = true, defaultValue = "0") List<Integer> warehouseIds, @RequestParam(name = "brand", required = true, defaultValue = "") List<String> brand, int timeValue, Model model) throws Exception {
1549
        model.addAttribute("warehouseId", warehouseIds);
1550
        LOGGER.info("warehouseIds" + warehouseIds);
27738 tejbeer 1551
 
31762 tejbeer 1552
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1553
        if (warehouseIds.contains(0)) {
1554
            warehouseIds.addAll(warehouseMap.keySet());
1555
        }
1556
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
1557
        int dayOfMonth = curDate.getDayOfMonth();
1558
        LocalDateTime startOfMonth = curDate.withDayOfMonth(1);
1559
        int lengthOfMonth = YearMonth.from(startOfMonth.minusMonths(1)).lengthOfMonth();
1560
        if (brand.contains("Total Values")) {
1561
            List<String> tertiaryBrands = fofoOrderRepository.selectGroupByBrandPartnerTertiary(warehouseIds).stream().map(x -> x.getBrand()).collect(Collectors.toList());
27738 tejbeer 1562
 
31762 tejbeer 1563
            brand.addAll(tertiaryBrands);
1564
        }
1565
        List<BrandItemWiseTertiaryModel> tertiaryItem = null;
1566
        if (timeValue != 0) {
1567
            if (timeValue == 1) {
27749 tejbeer 1568
 
31762 tejbeer 1569
                tertiaryItem = fofoOrderRepository.selectItemPartnerTertiaryByBrand(warehouseIds, brand, curDate.withDayOfMonth(1), curDate.plusDays(1));
27738 tejbeer 1570
 
31762 tejbeer 1571
            } else if (timeValue == 2) {
1572
                LOGGER.info("curDate" + startOfMonth.minusMonths(1));
1573
                LOGGER.info("curDate" + startOfMonth.minusMonths(1).plusDays(Math.min(dayOfMonth, lengthOfMonth)));
27738 tejbeer 1574
 
31762 tejbeer 1575
                tertiaryItem = fofoOrderRepository.selectItemPartnerTertiaryByBrand(warehouseIds, brand, startOfMonth.minusMonths(1), startOfMonth.minusMonths(1).plusDays(Math.min(dayOfMonth, lengthOfMonth)));
27738 tejbeer 1576
 
31762 tejbeer 1577
            } else if (timeValue == -1) {
1578
                LOGGER.info("date" + curDate.minusMonths(1).withDayOfMonth(1));
1579
                LOGGER.info("date" + curDate.minusMonths(1).withDayOfMonth(lengthOfMonth).plusDays(1));
27749 tejbeer 1580
 
31762 tejbeer 1581
                tertiaryItem = fofoOrderRepository.selectItemPartnerTertiaryByBrand(warehouseIds, brand, curDate.minusMonths(1).withDayOfMonth(1), startOfMonth);
1582
            } else {
1583
                tertiaryItem = fofoOrderRepository.selectItemPartnerTertiaryByBrand(warehouseIds, brand, curDate.minusDays(timeValue), curDate);
1584
            }
27738 tejbeer 1585
 
31762 tejbeer 1586
        } else {
1587
            tertiaryItem = fofoOrderRepository.selectTodayItemPartnerTertiaryByBrand(warehouseIds, brand, curDate);
1588
        }
1589
        LOGGER.info("tertiaryItem" + tertiaryItem);
27738 tejbeer 1590
 
31762 tejbeer 1591
        model.addAttribute("tertiaryItem", tertiaryItem);
27738 tejbeer 1592
 
31762 tejbeer 1593
        return "inventory-item-tertiary-item";
27738 tejbeer 1594
 
31762 tejbeer 1595
    }
28701 tejbeer 1596
 
31762 tejbeer 1597
    @RequestMapping(value = "/planogram")
1598
    public String Planogram(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
1599
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1600
        String email = loginDetails.getEmailId();
1601
        AuthUser authUser = authRepository.selectByEmailOrMobile(email);
1602
        List<FocusedModelByPassRequest> byPassRequest = null;
1603
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
28701 tejbeer 1604
 
31762 tejbeer 1605
        Set<Integer> authfofoIds = null;
28701 tejbeer 1606
 
31762 tejbeer 1607
        List<Position> positions = positionRepository.selectPositionByAuthId(authUser.getId());
28701 tejbeer 1608
 
31762 tejbeer 1609
        if (emails.contains(authUser.getEmailId())) {
1610
            authfofoIds = storeGuyMap.get("tarun.verma@smartdukaan.com");
1611
            LOGGER.info("fofoIds" + authfofoIds);
1612
        } else {
28701 tejbeer 1613
 
31762 tejbeer 1614
            for (Position ps : positions) {
1615
                if (esclationType.contains(ps.getEscalationType())) {
1616
                    authfofoIds = storeGuyMap.get(email);
1617
                    break;
1618
                }
28701 tejbeer 1619
 
31762 tejbeer 1620
            }
1621
        }
1622
        if (authfofoIds != null) {
1623
            byPassRequest = focusedModelByPassRepository.selectByStatusAndFofoIds(new ArrayList<>(authfofoIds), ByPassRequestStatus.PENDING);
1624
        }
1625
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
1626
        model.addAttribute("customRetailerMap", customRetailerMap);
1627
        model.addAttribute("byPassRequest", byPassRequest);
1628
        return "planogram";
1629
    }
28701 tejbeer 1630
 
31762 tejbeer 1631
    @RequestMapping(value = "/byPassRequestAction", method = RequestMethod.PUT)
1632
    public String addAmountToWalletRequestRejected(HttpServletRequest request, @RequestParam(name = "id", defaultValue = "0") int id, @RequestParam ByPassRequestStatus status, @RequestParam(name = "reason", required = false) String reason, Model model) throws Exception {
28701 tejbeer 1633
 
31762 tejbeer 1634
        FocusedModelByPassRequest byPassRequest = focusedModelByPassRepository.selectById(id);
1635
        if (status.equals(ByPassRequestStatus.APPROVED)) {
1636
            byPassRequest.setByPass(true);
1637
            byPassRequest.setStatus(ByPassRequestStatus.APPROVED);
1638
            byPassRequest.setUpdatedTimestamp(LocalDateTime.now());
1639
            byPassRequest.setReason(reason);
1640
        } else if (status.equals(ByPassRequestStatus.REJECTED)) {
1641
            byPassRequest.setByPass(false);
1642
            byPassRequest.setStatus(ByPassRequestStatus.REJECTED);
1643
            byPassRequest.setUpdatedTimestamp(LocalDateTime.now());
1644
            byPassRequest.setReason(reason);
1645
        }
28701 tejbeer 1646
 
31762 tejbeer 1647
        com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(byPassRequest.getFofoId());
30989 tejbeer 1648
 
31762 tejbeer 1649
        Address address = addressRepository.selectById(user.getAddressId());
30989 tejbeer 1650
 
31762 tejbeer 1651
        String title = "Billing Request";
30989 tejbeer 1652
 
31762 tejbeer 1653
        String message = String.format("Your Billing  Request is " + status + ". Please ensure to order the missing focus models as soon as possible.");
30989 tejbeer 1654
 
31762 tejbeer 1655
        SendNotificationModel sendNotificationModel = new SendNotificationModel();
1656
        sendNotificationModel.setCampaignName("Billing Request");
1657
        sendNotificationModel.setTitle(title);
1658
        sendNotificationModel.setMessage(message);
1659
        sendNotificationModel.setType("url");
1660
        sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
1661
        sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(1));
1662
        sendNotificationModel.setMessageType(MessageType.notification);
1663
        sendNotificationModel.setUserIds(Arrays.asList(userAccountRepository.selectUserIdByRetailerId(byPassRequest.getFofoId())));
28701 tejbeer 1664
 
31762 tejbeer 1665
        notificationService.sendNotification(sendNotificationModel);
32778 amit.gupta 1666
        //TODO-Whatsapp
1667
        //notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
28701 tejbeer 1668
 
31762 tejbeer 1669
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1670
        return "response";
1671
    }
28701 tejbeer 1672
 
31762 tejbeer 1673
    @RequestMapping(value = "/highDemandItem", method = RequestMethod.GET)
1674
    public String highDemandItem(HttpServletRequest request, Model model) throws Exception {
1675
        List<HighDemandItem> hdis = highDemandItemsRepository.selectAll();
1676
        if (!hdis.isEmpty()) {
1677
            Map<Integer, Item> itemMap = this.getItemByCatalogId(hdis);
1678
            model.addAttribute("itemMap", itemMap);
1679
        }
28754 tejbeer 1680
 
31762 tejbeer 1681
        model.addAttribute("hdis", hdis);
28754 tejbeer 1682
 
31762 tejbeer 1683
        return "high_demand_item";
1684
    }
28754 tejbeer 1685
 
31762 tejbeer 1686
    private Map<Integer, Item> getItemByCatalogId(List<HighDemandItem> hdis) {
1687
        Map<Integer, Item> itemMap = new HashMap<>();
1688
        for (HighDemandItem hdi : hdis) {
1689
            List<Item> items = itemRepository.selectAllByCatalogItemId(hdi.getCatalogId());
1690
            itemMap.put(items.get(0).getCatalogItemId(), items.get(0));
1691
        }
28754 tejbeer 1692
 
31762 tejbeer 1693
        return itemMap;
1694
    }
28754 tejbeer 1695
 
31762 tejbeer 1696
    @RequestMapping(value = "/addHighDemandItem", method = RequestMethod.POST)
1697
    public String addHighDemandItem(HttpServletRequest request, @RequestParam int catalogId, @RequestParam int qty, Model model) throws Exception {
1698
        HighDemandItem hdi = highDemandItemsRepository.selectByFofoIdAndCatalogId(catalogId);
28754 tejbeer 1699
 
31762 tejbeer 1700
        if (hdi == null) {
1701
            hdi = new HighDemandItem();
1702
            hdi.setCatalogId(catalogId);
1703
            hdi.setQty(qty);
1704
            hdi.setCreateTimestamp(LocalDateTime.now());
1705
            hdi.setUpdateTimestamp(LocalDateTime.now());
1706
            highDemandItemsRepository.persist(hdi);
1707
        }
28754 tejbeer 1708
 
31762 tejbeer 1709
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1710
        return "response";
1711
    }
28754 tejbeer 1712
 
31762 tejbeer 1713
    @RequestMapping(value = "/removeHighDemandItem", method = RequestMethod.DELETE)
1714
    public String removeHighDemandItem(HttpServletRequest request, @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
1715
        highDemandItemsRepository.deleteById(id);
1716
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1717
        return "response";
1718
    }
28754 tejbeer 1719
 
31762 tejbeer 1720
    @GetMapping(value = "/imei")
1721
    public String getImei(HttpServletRequest request, Model model, @RequestParam int fofoId, @RequestParam String query) throws Exception {
28795 tejbeer 1722
 
31762 tejbeer 1723
        List<String> serialNumber = inventoryItemRepository.selectAllByFofoId(fofoId, query).stream().map(x -> x.getSerialNumber()).collect(Collectors.toList());
1724
        LOGGER.info("serialNumber" + serialNumber);
1725
        LOGGER.info("query" + query);
28795 tejbeer 1726
 
31762 tejbeer 1727
        model.addAttribute("response1", mvcResponseSender.createResponseString(serialNumber));
28795 tejbeer 1728
 
31762 tejbeer 1729
        return "response";
1730
    }
28795 tejbeer 1731
 
31762 tejbeer 1732
    @GetMapping(value = "/allimei")
1733
    public String getAllImei(HttpServletRequest request, Model model, @RequestParam String query) throws Exception {
30039 tejbeer 1734
 
31762 tejbeer 1735
        List<String> serialNumber = inventoryItemRepository.selectAll(query).stream().map(x -> x.getSerialNumber()).collect(Collectors.toList());
1736
        LOGGER.info("serialNumber" + serialNumber);
1737
        LOGGER.info("query" + query);
30039 tejbeer 1738
 
31762 tejbeer 1739
        model.addAttribute("response1", mvcResponseSender.createResponseString(serialNumber));
30244 tejbeer 1740
 
31762 tejbeer 1741
        return "response";
1742
    }
30039 tejbeer 1743
 
31762 tejbeer 1744
    @Autowired
1745
    private ObjectMapper objectMapper;
30039 tejbeer 1746
 
31762 tejbeer 1747
    @RequestMapping(value = "/imei/validate", method = RequestMethod.GET)
1748
    public String validateImei(HttpServletRequest request, @RequestParam String imei, Model model) throws Exception {
1749
        boolean isImei = false;
30039 tejbeer 1750
 
31762 tejbeer 1751
        try {
1752
            InventoryItem inventoryItem = inventoryItemRepository.selectBySerialNumber(imei);
30683 tejbeer 1753
 
31762 tejbeer 1754
            isImei = true;
30683 tejbeer 1755
 
31762 tejbeer 1756
        } catch (Exception e) {
1757
            isImei = false;
1758
        }
30683 tejbeer 1759
 
31762 tejbeer 1760
        model.addAttribute("response1", objectMapper.writeValueAsString(isImei));
1761
        return "response";
1762
    }
30683 tejbeer 1763
 
32402 tejbeer 1764
    @Autowired
1765
    RestClient restClient;
1766
 
1767
 
1768
    @Autowired
1769
    private CustomerRepository customerRepository;
1770
 
1771
 
31762 tejbeer 1772
    @RequestMapping(value = "/createCombo", method = RequestMethod.GET)
1773
    public String createCombo(HttpServletRequest request, Model model) throws Exception {
30683 tejbeer 1774
 
31762 tejbeer 1775
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
30683 tejbeer 1776
 
32402 tejbeer 1777
 
31762 tejbeer 1778
        List<ComboModel> comboModels = comboModelRepository.selectAll();
30683 tejbeer 1779
 
31762 tejbeer 1780
        model.addAttribute("warehouseMap", warehouseMap);
1781
        model.addAttribute("comboModels", comboModels);
1782
        return "create-combo";
1783
    }
30683 tejbeer 1784
 
31762 tejbeer 1785
    @RequestMapping(value = "/addCombo", method = RequestMethod.POST)
1786
    public String addCombo(HttpServletRequest request, @RequestBody Combo combo, Model model) throws Exception {
32339 tejbeer 1787
        List<Integer> warehouseIds = new ArrayList<Integer>();
30683 tejbeer 1788
 
1789
 
32339 tejbeer 1790
        if (combo.getWarehouseId().isEmpty()) {
1791
            Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
1792
 
1793
            warehouseIds.addAll(warehouseMap.entrySet().stream().map(x -> x.getKey()).collect(Collectors.toList()));
1794
 
1795
        } else {
1796
            warehouseIds.addAll(combo.getWarehouseId());
1797
        }
1798
        for (Integer warehouseId : warehouseIds) {
1799
 
31762 tejbeer 1800
            ComboModel comboModel = comboModelRepository.selectByCatalogIdWarehouseIdAndQty(combo.getCatalogId(), warehouseId, combo.getQty());
1801
            if (comboModel != null) {
32339 tejbeer 1802
 
1803
                List<Integer> comboOptions = comboOptionRepository.selectByComboId(comboModel.getId()).stream().map(x -> x.getId()).collect(Collectors.toList());
1804
                for (Integer comboOption : comboOptions) {
1805
                    comboMappedModelRepository.deleteByEquals(comboOption);
31762 tejbeer 1806
                }
30683 tejbeer 1807
 
32339 tejbeer 1808
                comboOptionRepository.deleteByEquals(comboModel.getId());
1809
 
1810
 
31762 tejbeer 1811
                comboModelRepository.delete(comboModel);
1812
            }
32339 tejbeer 1813
 
31762 tejbeer 1814
            ComboModel cm = new ComboModel();
1815
            cm.setCatalogId(combo.getCatalogId());
1816
            cm.setQty(combo.getQty());
1817
            cm.setWarehouseId(warehouseId);
1818
            comboModelRepository.persist(cm);
30683 tejbeer 1819
 
31762 tejbeer 1820
            LOGGER.info("cm" + cm);
32339 tejbeer 1821
            for (ComboOptionModel comboOptionModel : combo.getComboOptionModel()) {
1822
                ComboOption comboOption = new ComboOption();
1823
                comboOption.setComboId(cm.getId());
1824
                comboOptionRepository.persist(comboOption);
1825
                for (MappedComboModel mappedComboModel : comboOptionModel.getMappedComboModel()) {
1826
                    ComboMappedModel cmm = new ComboMappedModel();
1827
                    cmm.setComboCatalogId(mappedComboModel.getCatalogId());
1828
                    cmm.setComboQty(mappedComboModel.getQty());
1829
                    cmm.setComboOptionId(comboOption.getId());
1830
                    comboMappedModelRepository.persist(cmm);
30683 tejbeer 1831
 
32339 tejbeer 1832
                }
30683 tejbeer 1833
 
31762 tejbeer 1834
            }
30683 tejbeer 1835
 
31762 tejbeer 1836
        }
1837
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
30683 tejbeer 1838
 
31762 tejbeer 1839
        return "response";
1840
 
1841
    }
1842
 
1843
    @RequestMapping(value = "/combo/remove", method = RequestMethod.POST)
1844
    public String removeCombo(HttpServletRequest request, @RequestParam int id, Model model) throws Exception {
32339 tejbeer 1845
 
1846
        List<Integer> comboOptions = comboOptionRepository.selectByComboId(id).stream().map(x -> x.getId()).collect(Collectors.toList());
1847
        for (Integer comboOption : comboOptions) {
1848
            comboMappedModelRepository.deleteByEquals(comboOption);
1849
        }
1850
 
1851
        comboOptionRepository.deleteByEquals(id);
31762 tejbeer 1852
        comboModelRepository.deleteById(id);
1853
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1854
 
1855
        return "response";
1856
 
1857
    }
32075 tejbeer 1858
 
1859
 
27867 tejbeer 1860
}