Subversion Repositories SmartDukaan

Rev

Rev 35674 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
22981 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
23494 ashik.ali 3
import com.spice.profitmandi.common.enumuration.ContentType;
23955 govind 4
import com.spice.profitmandi.common.enumuration.CounterSize;
28825 tejbeer 5
import com.spice.profitmandi.common.enumuration.FofoType;
22981 ashik.ali 6
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
30017 amit.gupta 7
import com.spice.profitmandi.common.model.*;
28024 tejbeer 8
import com.spice.profitmandi.common.util.Utils;
23330 ashik.ali 9
import com.spice.profitmandi.common.web.util.ResponseSender;
27231 tejbeer 10
import com.spice.profitmandi.dao.entity.auth.AuthUser;
30017 amit.gupta 11
import com.spice.profitmandi.dao.entity.dtr.*;
12
import com.spice.profitmandi.dao.entity.fofo.*;
34527 tejus.loha 13
import com.spice.profitmandi.dao.entity.onBoarding.LoiForm;
24159 tejbeer 14
import com.spice.profitmandi.dao.entity.user.Location;
15
import com.spice.profitmandi.dao.entity.user.Promoter;
24123 tejbeer 16
import com.spice.profitmandi.dao.entity.user.User;
27231 tejbeer 17
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
35648 ranu 18
import com.spice.profitmandi.dao.repository.catalog.BrandsRepository;
27231 tejbeer 19
import com.spice.profitmandi.dao.repository.cs.CsService;
28272 tejbeer 20
import com.spice.profitmandi.dao.repository.cs.RetailerBrandsLimitService;
30017 amit.gupta 21
import com.spice.profitmandi.dao.repository.dtr.*;
27797 tejbeer 22
import com.spice.profitmandi.dao.repository.fofo.PartnerTypeChangeRepository;
23
import com.spice.profitmandi.dao.repository.fofo.PartnerTypeChangeService;
28381 tejbeer 24
import com.spice.profitmandi.dao.repository.fofo.PincodePartnerRepository;
35289 amit 25
import com.spice.profitmandi.dao.repository.trialOnboarding.TrialFormRepository;
24123 tejbeer 26
import com.spice.profitmandi.dao.repository.user.LocationRepository;
34527 tejus.loha 27
import com.spice.profitmandi.dao.repository.user.LoiFormRepository;
24159 tejbeer 28
import com.spice.profitmandi.dao.repository.user.PromoterRepository;
24123 tejbeer 29
import com.spice.profitmandi.dao.repository.user.UserRepository;
33990 tejus.loha 30
import com.spice.profitmandi.dao.repository.warehouse.WarehouseSupplierInvoiceRepository;
24349 amit.gupta 31
import com.spice.profitmandi.service.PartnerInvestmentService;
33814 ranu 32
import com.spice.profitmandi.service.authentication.RoleManager;
32731 ranu 33
import com.spice.profitmandi.service.catalog.BrandsService;
24159 tejbeer 34
import com.spice.profitmandi.service.inventory.InventoryService;
22981 ashik.ali 35
import com.spice.profitmandi.service.user.RetailerService;
28908 tejbeer 36
import com.spice.profitmandi.service.user.StoreTimelineTatService;
25276 amit.gupta 37
import com.spice.profitmandi.web.model.LoginDetails;
38
import com.spice.profitmandi.web.util.CookiesProcessor;
24123 tejbeer 39
import com.spice.profitmandi.web.util.MVCResponseSender;
30017 amit.gupta 40
import org.apache.logging.log4j.LogManager;
41
import org.apache.logging.log4j.Logger;
42
import org.json.JSONObject;
43
import org.springframework.beans.factory.annotation.Autowired;
44
import org.springframework.beans.factory.annotation.Qualifier;
45
import org.springframework.core.io.InputStreamResource;
46
import org.springframework.http.HttpHeaders;
47
import org.springframework.http.HttpStatus;
48
import org.springframework.http.ResponseEntity;
49
import org.springframework.stereotype.Controller;
35648 ranu 50
import org.springframework.transaction.annotation.Transactional;
30017 amit.gupta 51
import org.springframework.ui.Model;
52
import org.springframework.web.bind.annotation.*;
22981 ashik.ali 53
 
30017 amit.gupta 54
import javax.servlet.http.HttpServletRequest;
55
import java.io.File;
56
import java.io.FileInputStream;
57
import java.io.FileNotFoundException;
58
import java.time.LocalDate;
59
import java.time.LocalDateTime;
60
import java.util.*;
61
import java.util.stream.Collectors;
62
 
22981 ashik.ali 63
@Controller
35458 amit 64
@Transactional(rollbackFor = Throwable.class)
22981 ashik.ali 65
public class RetailerController {
66
 
33990 tejus.loha 67
    private static final Logger LOGGER = LogManager.getLogger(RetailerController.class);
68
    private static final List<String> CHANGE_PARTNER_CATEGORY_PERMISSIONS = Arrays.asList("tarun.verma@smartdukaan.com", "kamini.sharma@smartdukaan.com", "shankar.mushra@smartdukaan.com");
69
    @Autowired
70
    PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
71
    @Autowired
72
    BrandsService brandsService;
73
    @Autowired
74
    private RetailerService retailerService;
75
    @Autowired
76
    private RetailerRepository retailerRepository;
77
    @Autowired
78
    private PincodePartnerRepository pincodePartnerRepository;
79
    @Autowired
80
    private BrandLimitRepository brandLimitRepository;
81
    @Autowired
82
    private RetailerBrandsLimitService retailerBrandsLimitService;
83
    @Autowired
84
    private RetailerBrandsLimitRepository retailerBrandsLimitRepository;
85
    @Autowired
86
    private ShopRepository shopRepository;
87
    @Autowired
88
    private RetailerBlockBrandsRepository retailerBlockBrandsRepository;
89
    @Autowired
90
    private FofoStoreRepository fofoStoreRepository;
91
    @Autowired
92
    private DocumentRepository documentRepository;
93
    @Autowired
94
    private CookiesProcessor cookiesProcessor;
95
    @Autowired
96
    @Qualifier("userUserRepository")
97
    private UserRepository userRepository;
98
    @Autowired
99
    private AuthRepository authRepository;
100
    @Autowired
101
    private CsService csService;
102
    @Autowired
103
    private LocationRepository locationRepository;
104
    @Autowired
105
    private ResponseSender<?> responseSender;
106
    @Autowired
107
    private MVCResponseSender mvcResponseSender;
108
    @Autowired
109
    private InventoryService inventoryService;
110
    @Autowired
111
    private PromoterRepository promoterRepository;
112
    @Autowired
113
    private PartnerInvestmentService partnerInvestmentService;
114
    @Autowired
115
    private Mongo mongoClient;
116
    @Autowired
117
    private PartnerTypeChangeService partnerTypeChangeService;
118
    @Autowired
119
    private PartnerTypeChangeRepository partnerTypeChangeRepository;
120
    @Autowired
121
    private StoreTimelineTatService storeTimelineTatService;
122
    @Autowired
123
    private RoleManager roleManager;
124
    @Autowired
125
    private RetailerContactRepository retailerContactRepository;
126
    @Autowired
35648 ranu 127
    private BrandsRepository brandsRepository;
128
    @Autowired
33990 tejus.loha 129
    private WarehouseSupplierInvoiceRepository warehouseSupplierInvoiceRepository;
24124 govind 130
 
35289 amit 131
    @Autowired
132
    TrialFormRepository trialFormRepository;
133
 
33990 tejus.loha 134
    @RequestMapping(value = "/retailerDetails", method = RequestMethod.GET)
135
    public String retailerInfoByEmailIdOrMobileNumber(HttpServletRequest request,
136
                                                      @RequestParam(name = ProfitMandiConstants.EMAIL_ID_OR_MOBILE_NUMBER) String emailIdOrMobileNumber,
137
                                                      Model model) throws ProfitMandiBusinessException {
138
        LOGGER.info("Request Received at url {} with emailIdOrMobileNumber {}", request.getRequestURI(),
139
                emailIdOrMobileNumber);
24124 govind 140
 
33990 tejus.loha 141
        Map<String, Object> map = retailerService.getByEmailIdOrMobileNumber(emailIdOrMobileNumber);
35372 aman 142
        LOGGER.info("map - {}", map.get("trialForm"));
143
        LOGGER.info("map - {}", map);
33990 tejus.loha 144
        model.addAllAttributes(map);
28832 tejbeer 145
 
33990 tejus.loha 146
        model.addAttribute("counterSizes", CounterSize.values());
147
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
28832 tejbeer 148
 
35375 aman 149
        LOGGER.info("warehouseMap {}", warehouseMap);
33990 tejus.loha 150
        model.addAttribute("warehouses", warehouseMap);
151
        model.addAttribute("fofoTypes", FofoType.values());
152
        if (map.containsKey("retailer")) {
153
            Retailer retailer = (Retailer) map.get("retailer");
154
            User user = userRepository.selectById(retailer.getId());
155
            if (user.getLocation() != null) {
156
                Location location = locationRepository.selectById(user.getLocation());
157
                model.addAttribute("locationdetail", location);
158
                LOGGER.info("location" + location);
159
            }
160
        }
161
        return "retailer-details";
162
    }
28272 tejbeer 163
 
34527 tejus.loha 164
    @Autowired
165
    LoiFormRepository loiFormRepository;
166
 
33990 tejus.loha 167
    @RequestMapping(value = "/retailerDetails", method = RequestMethod.PUT)
168
    public String updateRetailerDetails(HttpServletRequest request,
169
                                        @RequestBody UpdateRetailerRequest updateRetailerRequest, Model model) throws ProfitMandiBusinessException {
170
        LOGGER.info("Request Received at url {} with body {}", request.getRequestURI(), updateRetailerRequest);
34639 tejus.loha 171
        String storeCode = updateRetailerRequest.getFofostorecode();
34640 tejus.loha 172
        boolean isStoreCodeNotCreated = (storeCode == null || storeCode.isEmpty());
173
        LOGGER.info("isStoreCodeNotCreated - "+isStoreCodeNotCreated);
174
        if (!updateRetailerRequest.getFofoType().equals(FofoType.INTERNAL) && isStoreCodeNotCreated) {
34631 tejus.loha 175
            checkLoiCompletion(updateRetailerRequest);
34527 tejus.loha 176
        }
33990 tejus.loha 177
        Map<String, Object> map = retailerService.updateRetailerDetails(updateRetailerRequest);
178
        //retailerService.up
28272 tejbeer 179
 
33990 tejus.loha 180
        model.addAllAttributes(map);
181
        model.addAttribute("counterSizes", CounterSize.values());
182
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
183
        LOGGER.info("warehouseMap", warehouseMap);
184
        model.addAttribute("warehouses", warehouseMap);
185
        model.addAttribute("fofoTypes", FofoType.values());
186
        return "retailer-details";
187
    }
28272 tejbeer 188
 
34631 tejus.loha 189
    private void checkLoiCompletion(UpdateRetailerRequest updateRetailerRequest) throws ProfitMandiBusinessException {
35305 amit 190
        TrialForm trialForm;
191
        try {
192
            trialForm = trialFormRepository.selectByEmailOrMobile(updateRetailerRequest.getUserMobileNumber());
193
            if (updateRetailerRequest.getFofoType().equals(FofoType.INTERNAL) || trialForm != null) {
194
                return; // Early return for internal type
195
            }
196
        } catch (Exception e) {
197
            trialForm = null;
198
        }
35289 amit 199
        if (updateRetailerRequest.getFofoType().equals(FofoType.INTERNAL) || trialForm != null) {
34631 tejus.loha 200
            return; // Early return for internal type
201
        }
202
        String userMobile = updateRetailerRequest.getUserMobileNumber();
203
        String gstNumber = updateRetailerRequest.getGstNumber();
204
        LoiForm loiForm = findLoiForm(userMobile, gstNumber);
205
        if (loiForm == null) {
34640 tejus.loha 206
            throw new ProfitMandiBusinessException("Loi Not Available", "Message - ", "Please fill the LOI_FORM and try again");
34631 tejus.loha 207
        }
208
        if (loiForm.getOnBoardingId() <= 0) {
209
            throw new ProfitMandiBusinessException("Loi not completed", "Message - ", "Please Complete LOI_FORM and try again");
210
        }
211
    }
34640 tejus.loha 212
 
34631 tejus.loha 213
    private LoiForm findLoiForm(String mobile, String gstNumber) throws ProfitMandiBusinessException {
214
        LoiForm form = loiFormRepository.selectByEmailOrMobile(mobile);
215
        if (form == null && gstNumber != null) {
216
            form = loiFormRepository.selectByEqualsKeyValue("gstNo", gstNumber);
217
        }
218
        return form;
219
    }
220
 
33990 tejus.loha 221
    @RequestMapping(value = "/retailer/update-email", method = RequestMethod.POST)
222
    public String updateRetailerEmail(@RequestParam("newEmail") String newEmail, @RequestParam("fofoID") int fofoID) throws ProfitMandiBusinessException {
223
        retailerService.updateRetailerEmail(fofoID, newEmail);
224
        return "retailer-details";
225
    }
24124 govind 226
 
33990 tejus.loha 227
    @RequestMapping(value = "/retailerInfo", method = RequestMethod.GET)
228
    public String retailerInfo(HttpServletRequest request) throws Exception {
229
        return "retailer-info";
230
    }
28024 tejbeer 231
 
33990 tejus.loha 232
    @RequestMapping(value = "/district/all/stateName", method = RequestMethod.GET)
233
    public ResponseEntity<?> getAllDistrict(@RequestParam(name = "stateName") String stateName) {
234
        return responseSender.ok(retailerService.getAllDistrictMaster(stateName));
235
    }
24124 govind 236
 
33990 tejus.loha 237
    @RequestMapping(value = "/retailerDocument/documentId", method = RequestMethod.GET)
238
    public ResponseEntity<?> retailerDocumentById(HttpServletRequest request,
239
                                                  @RequestParam(name = ProfitMandiConstants.DOCUMENT_ID) int documentId,
240
                                                  @RequestParam(name = ProfitMandiConstants.RETAILER_ID) int retailerId) throws ProfitMandiBusinessException {
241
        Document document = documentRepository.selectById(documentId);
242
        Retailer retailer = retailerRepository.selectById(retailerId);
24124 govind 243
 
33990 tejus.loha 244
        if (retailer.getDocumentId() == null) {
245
            throw new ProfitMandiBusinessException(ProfitMandiConstants.RETAILER_ID, retailer.getId(), "RTLR_1012");
246
        }
247
        if (retailer.getDocumentId() != documentId) {
248
            throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, documentId, "RTLR_1014");
249
        }
250
        return responseSender.ok(document);
251
    }
25276 amit.gupta 252
 
33990 tejus.loha 253
    @RequestMapping(value = "/retailerDocument/download", method = RequestMethod.GET)
254
    public ResponseEntity<?> downloadRetailerDocument(HttpServletRequest request,
255
                                                      @RequestParam(name = ProfitMandiConstants.RETAILER_ID) int retailerId, Model model)
256
            throws ProfitMandiBusinessException {
24124 govind 257
 
33990 tejus.loha 258
        Retailer retailer = retailerRepository.selectById(retailerId);
27231 tejbeer 259
 
33990 tejus.loha 260
        if (retailer.getDocumentId() == null) {
261
            throw new ProfitMandiBusinessException(ProfitMandiConstants.RETAILER_ID, retailer.getId(), "RTLR_1012");
262
        }
27231 tejbeer 263
 
33990 tejus.loha 264
        Document document = documentRepository.selectById(retailer.getDocumentId());
24124 govind 265
 
33990 tejus.loha 266
        FileInputStream file = null;
267
        try {
268
            file = new FileInputStream(document.getPath() + File.separator + document.getName());
269
        } catch (FileNotFoundException e) {
270
            LOGGER.error("Retailer Document file not found : ", e);
271
            throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, document.getId(), "RTLR_1013");
272
        }
273
        // ByteArrayOutputStream byteArrayOutputStream = new
274
        // ByteArrayOutputStream();
275
        // ExcelUtils.writeSchemeModels(schemeModels, byteArrayOutputStream);
24124 govind 276
 
33990 tejus.loha 277
        final HttpHeaders headers = new HttpHeaders();
278
        String contentType = "";
279
        if (document.getContentType() == ContentType.JPEG) {
280
            contentType = "image/jpeg";
281
        } else if (document.getContentType() == ContentType.PNG) {
282
            contentType = "image/png";
283
        } else if (document.getContentType() == ContentType.PDF) {
284
            contentType = "application/pdf";
285
        }
286
        headers.set("Content-Type", contentType);
287
        headers.set("Content-disposition", "inline; filename=" + document.getName());
288
        headers.setContentLength(document.getSize());
289
        final InputStreamResource inputStreamResource = new InputStreamResource(file);
290
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
24124 govind 291
 
33990 tejus.loha 292
        // return
293
        // responseSender.ok(ResponseCodeHolder.getMessage("ITM_AGNG_OK_1000"));
294
    }
24159 tejbeer 295
 
33990 tejus.loha 296
    @RequestMapping(value = "/retailerShopDocument/shopId", method = RequestMethod.GET)
297
    public ResponseEntity<?> retailerShopDocumentById(HttpServletRequest request,
298
                                                      @RequestParam(name = ProfitMandiConstants.SHOP_ID) int shopId,
299
                                                      @RequestParam(name = ProfitMandiConstants.RETAILER_ID) int retailerId) throws ProfitMandiBusinessException {
300
        Shop shop = shopRepository.selectById(shopId);
24159 tejbeer 301
 
33990 tejus.loha 302
        if (shop.getRetailerId() != retailerId) {
303
            throw new ProfitMandiBusinessException(ProfitMandiConstants.SHOP_ID, shop.getId(), "SHP_1004");
304
        }
24349 amit.gupta 305
 
33990 tejus.loha 306
        if (shop.getDocumentId() == null) {
307
            throw new ProfitMandiBusinessException(ProfitMandiConstants.RETAILER_ID, shop.getId(), "SHP_1005");
308
        }
24159 tejbeer 309
 
33990 tejus.loha 310
        Document document = documentRepository.selectById(shop.getDocumentId());
311
        return responseSender.ok(document);
312
    }
27797 tejbeer 313
 
33990 tejus.loha 314
    @RequestMapping(value = "/retailerShopDocument/download", method = RequestMethod.GET)
315
    public ResponseEntity<?> downloadRetailerShopDocument(HttpServletRequest request,
316
                                                          @RequestParam(name = ProfitMandiConstants.SHOP_ID) int shopId,
317
                                                          @RequestParam(name = ProfitMandiConstants.RETAILER_ID) int retailerId, Model model)
318
            throws ProfitMandiBusinessException {
27797 tejbeer 319
 
33990 tejus.loha 320
        Shop shop = shopRepository.selectById(shopId);
28908 tejbeer 321
 
33990 tejus.loha 322
        if (shop.getRetailerId() != retailerId) {
323
            throw new ProfitMandiBusinessException(ProfitMandiConstants.SHOP_ID, shop.getId(), "SHP_1004");
324
        }
28908 tejbeer 325
 
33990 tejus.loha 326
        if (shop.getDocumentId() == null) {
327
            throw new ProfitMandiBusinessException(ProfitMandiConstants.RETAILER_ID, shop.getId(), "SHP_1005");
328
        }
33814 ranu 329
 
33990 tejus.loha 330
        Document document = documentRepository.selectById(shop.getDocumentId());
33814 ranu 331
 
33990 tejus.loha 332
        FileInputStream file = null;
333
        try {
334
            file = new FileInputStream(document.getPath() + File.separator + document.getName());
335
        } catch (FileNotFoundException e) {
336
            LOGGER.error("Retailer Document file not found : ", e);
337
            throw new ProfitMandiBusinessException(ProfitMandiConstants.DOCUMENT_ID, document.getId(), "RTLR_1013");
338
        }
339
        // ByteArrayOutputStream byteArrayOutputStream = new
340
        // ByteArrayOutputStream();
341
        // ExcelUtils.writeSchemeModels(schemeModels, byteArrayOutputStream);
28071 tejbeer 342
 
33990 tejus.loha 343
        final HttpHeaders headers = new HttpHeaders();
344
        String contentType = "";
345
        if (document.getContentType() == ContentType.JPEG) {
346
            contentType = "image/jpeg";
347
        } else if (document.getContentType() == ContentType.PNG) {
348
            contentType = "image/png";
349
        } else if (document.getContentType() == ContentType.PDF) {
350
            contentType = "application/pdf";
351
        }
352
        headers.set("Content-Type", contentType);
353
        headers.set("Content-disposition", "inline; filename=" + document.getName());
354
        headers.setContentLength(document.getSize());
355
        final InputStreamResource inputStreamResource = new InputStreamResource(file);
356
        return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
28071 tejbeer 357
 
33990 tejus.loha 358
        // return
359
        // responseSender.ok(ResponseCodeHolder.getMessage("ITM_AGNG_OK_1000"));
360
    }
28071 tejbeer 361
 
33990 tejus.loha 362
    @GetMapping(value = "/getstore")
33247 ranu 363
    public String getstore(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
30017 amit.gupta 364
 
33990 tejus.loha 365
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId())
366
                .collect(Collectors.toList());
30426 tejbeer 367
 
33990 tejus.loha 368
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
30426 tejbeer 369
 
33990 tejus.loha 370
        Map<Integer, CustomRetailer> fofoIdsAndCustomRetailer = fofoIds.stream().map(x -> customRetailerMap.get(x))
371
                .filter(x -> x != null).collect(Collectors.toList()).stream()
372
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
30426 tejbeer 373
 
33990 tejus.loha 374
        //LOGGER.info("fofoIds" + fofoIds);
375
        model.addAttribute("fofoIdsAndCustomRetailer", fofoIdsAndCustomRetailer);
376
        //LOGGER.info("fofoIdsAndCustomRetailer" + fofoIdsAndCustomRetailer);
377
        model.addAttribute("fofoIds", fofoIds);
24124 govind 378
 
33990 tejus.loha 379
        return "store";
29267 manish 380
 
33990 tejus.loha 381
    }
30017 amit.gupta 382
 
33990 tejus.loha 383
    @RequestMapping(value = "/getPartnerinfo")
384
    public String getPartnerinfo(HttpServletRequest request, @RequestBody SelectStorePartnerInfo selectStorePartnerInfo,
385
                                 Model model) throws ProfitMandiBusinessException {
386
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
387
        //LOGGER.info("selectStorePartnerInfo" + selectStorePartnerInfo.getUserIds());
388
        List<FofoStore> fofoStores = fofoStoreRepository.selectByRetailerIds(selectStorePartnerInfo.getUserIds());
389
        //LOGGER.info("fofoStoresInfo" + fofoStores);
390
        Map<Integer, Boolean> investments = new HashMap<>();
32207 amit.gupta 391
 
33990 tejus.loha 392
        for (FofoStore fofoStore : fofoStores) {
393
            boolean isOk = false;
394
            if (fofoStore.getGraceDate() != null && fofoStore.getGraceDate().isAfter(LocalDate.now())) {
395
                isOk = true;
396
            } else {
397
                try {
398
                    isOk = partnerInvestmentService.isInvestmentOk(fofoStore.getId(), ProfitMandiConstants.MIN_INVESTMENT_PERCENTAGE,
399
                            ProfitMandiConstants.CUTOFF_INVESTMENT);
400
                    if (fofoStore.getGraceCount() > 0) {
401
                        fofoStore.setGraceDate(null);
402
                        fofoStore.setGraceCount(0);
403
                    }
404
                } catch (ProfitMandiBusinessException e) {
405
                }
406
            }
407
            investments.put(fofoStore.getId(), isOk);
408
        }
29267 manish 409
 
33990 tejus.loha 410
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(false);
411
        model.addAttribute("fofoStores", fofoStores);
412
        model.addAttribute("investments", investments);
413
        model.addAttribute("customRetailers", customRetailers);
414
        boolean canChangeCategory = CHANGE_PARTNER_CATEGORY_PERMISSIONS.contains(loginDetails.getEmailId());
415
        model.addAttribute("canChangeCategory", canChangeCategory);
29267 manish 416
 
33990 tejus.loha 417
        return "store-investment";
29267 manish 418
 
33990 tejus.loha 419
    }
29267 manish 420
 
33990 tejus.loha 421
    @GetMapping(value = "/getAllStores")
422
    public String getAllStores(HttpServletRequest request, Model model) throws Exception {
30017 amit.gupta 423
 
33990 tejus.loha 424
        List<FofoStore> fofoStores = fofoStoreRepository.selectAll().stream().filter(x -> x.isActive())
425
                .collect(Collectors.toList());
426
        Map<Integer, Boolean> investments = new HashMap<>();
24124 govind 427
 
33990 tejus.loha 428
        for (FofoStore fofoStore : fofoStores) {
429
            boolean isOk = false;
430
            if (fofoStore.getGraceDate() != null && fofoStore.getGraceDate().isAfter(LocalDate.now())) {
431
                isOk = true;
432
            } else {
433
                try {
434
                    isOk = partnerInvestmentService.isInvestmentOk(fofoStore.getId(), ProfitMandiConstants.MIN_INVESTMENT_PERCENTAGE,
435
                            ProfitMandiConstants.CUTOFF_INVESTMENT);
436
                    if (fofoStore.getGraceCount() > 0) {
437
                        fofoStore.setGraceDate(null);
438
                        fofoStore.setGraceCount(0);
439
                    }
440
                } catch (ProfitMandiBusinessException e) {
441
                }
442
            }
443
            investments.put(fofoStore.getId(), isOk);
444
        }
24124 govind 445
 
33990 tejus.loha 446
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(false);
447
        model.addAttribute("fofoStores", fofoStores);
448
        model.addAttribute("investments", investments);
449
        model.addAttribute("customRetailers", customRetailers);
24124 govind 450
 
33990 tejus.loha 451
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
452
        boolean canChangeCategory = CHANGE_PARTNER_CATEGORY_PERMISSIONS.contains(loginDetails.getEmailId());
453
        model.addAttribute("canChangeCategory", canChangeCategory);
24124 govind 454
 
33990 tejus.loha 455
        return "store-investment";
32207 amit.gupta 456
 
33990 tejus.loha 457
    }
24124 govind 458
 
33990 tejus.loha 459
    @GetMapping(value = "/getPartnerCategory")
33247 ranu 460
    public String getPartnerCategory(HttpServletRequest request, @RequestParam int fofoId, Model model) throws ProfitMandiBusinessException {
27797 tejbeer 461
 
33990 tejus.loha 462
        PartnerType partnerType = partnerTypeChangeService.getTypeOnDate(fofoId, LocalDate.now());
463
        List<PartnerType> partnerTypes = partnerType.nextPartnerTypes();
464
        LOGGER.info("partnerType" + partnerTypes);
465
        model.addAttribute("partnerTypes", partnerTypes);
466
        model.addAttribute("fofoId", fofoId);
467
        return "partner-category";
468
    }
27797 tejbeer 469
 
33990 tejus.loha 470
    @PostMapping(value = "/updatePartnerCategory")
471
    public String updatePartnerCategory(HttpServletRequest request, @RequestParam(name = "fofoId") int fofoId,
35674 amit 472
                                        @RequestParam(name = "partnerType") PartnerType partnerType,
473
                                        @RequestParam(name = "durationMonths", defaultValue = "1") int durationMonths,
474
                                        Model model) throws Exception {
27797 tejbeer 475
 
35509 amit 476
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
477
 
35674 amit 478
        if (durationMonths < 1 || durationMonths > 3) {
479
            durationMonths = 1;
480
        }
481
 
482
        LocalDate startOfMonth = LocalDate.now().withDayOfMonth(1);
483
        for (int i = 0; i < durationMonths; i++) {
484
            PartnerTypeChange ptc = new PartnerTypeChange();
485
            ptc.setFofoId(fofoId);
486
            ptc.setPartnerType(partnerType);
487
            ptc.setCreateTimestamp(startOfMonth.plusMonths(i).atStartOfDay());
488
            ptc.setSource(PartnerTypeSource.MANUAL);
489
            ptc.setUpgradedBy(loginDetails.getEmailId());
490
            partnerTypeChangeRepository.persist(ptc);
491
        }
33990 tejus.loha 492
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
27797 tejbeer 493
 
33990 tejus.loha 494
        return "response";
495
    }
27797 tejbeer 496
 
33990 tejus.loha 497
    @GetMapping(value = "/partners")
498
    public String getStoreName(HttpServletRequest request, Model model, @RequestParam String query) throws Exception {
499
        model.addAttribute("response1",
500
                mvcResponseSender.createResponseString(retailerService.getFofoRetailers(false).values().stream()
501
                        .filter(x -> x.getDisplayName().toLowerCase().matches(".*?" + query.toLowerCase() + ".*?"))
502
                        .collect(Collectors.toList())));
503
        return "response";
504
    }
24349 amit.gupta 505
 
33990 tejus.loha 506
    @PostMapping(value = "/deactivateStore")
507
    public String deActivateStore(HttpServletRequest request,
508
                                  @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
509
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
510
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
511
        if (!Arrays
512
                .asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
34211 vikas.jang 513
                        "rahul.katyal@smartdukaan.com", "vikas.jangra@smartdukaan.com", "sm@smartdukaan.com")
33990 tejus.loha 514
                .contains(loginDetails.getEmailId())) {
515
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
516
                    "You are not authorise to deactivate retailer");
517
        }
35962 amit 518
        if (fofoStore.isClosed()) {
519
            throw new ProfitMandiBusinessException("Store Closed", "Store Already Closed",
520
                    "This store is permanently closed and cannot be modified");
521
        }
33990 tejus.loha 522
        fofoStore.setActive(false);
523
        LOGGER.info("inserted into InActiveFofoStore successfully");
524
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
525
        return "response";
526
    }
28825 tejbeer 527
 
35962 amit 528
    @PostMapping(value = "/closeStore")
529
    public String closeStore(HttpServletRequest request,
530
                             @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId,
531
                             @RequestParam(name = "storeCode") String storeCode, Model model) throws Exception {
532
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
533
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
534
        if (!Arrays
535
                .asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
536
                        "rahul.katyal@smartdukaan.com", "vikas.jangra@smartdukaan.com", "sm@smartdukaan.com")
537
                .contains(loginDetails.getEmailId())) {
538
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
539
                    "You are not authorise to close store");
540
        }
541
        if (fofoStore.isClosed()) {
542
            throw new ProfitMandiBusinessException("Store Closed", "Store Already Closed",
543
                    "This store is already permanently closed");
544
        }
545
        if (storeCode == null || !storeCode.equals(fofoStore.getCode())) {
546
            throw new ProfitMandiBusinessException("Invalid Store Code", "Store Code Mismatch",
547
                    "Please type the correct store code to confirm closure");
548
        }
549
        fofoStore.setActive(false);
550
        fofoStore.setClosed(true);
551
        fofoStore.setClosedTimestamp(LocalDateTime.now());
552
        LOGGER.info("Store {} closed permanently by {}", fofoStore.getCode(), loginDetails.getEmailId());
553
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
554
        return "response";
555
    }
556
 
33990 tejus.loha 557
    @PostMapping(value = "/activateStoreForever")
558
    public String activateStoreForever(HttpServletRequest request,
559
                                       @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
560
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
561
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
562
        if (!Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
563
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com").contains(loginDetails.getEmailId())) {
564
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
565
                    "You are not authorise to activate retailer");
566
        }
35962 amit 567
        if (fofoStore.isClosed()) {
568
            throw new ProfitMandiBusinessException("Store Closed", "Store Permanently Closed",
569
                    "This store is permanently closed and cannot be reactivated");
570
        }
33990 tejus.loha 571
        fofoStore.setActive(true);
572
        LOGGER.info("inserted into ActiveFofoStore successfully");
573
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
574
        return "response";
575
    }
28825 tejbeer 576
 
33990 tejus.loha 577
    @PostMapping(value = "/activateStoreTemporary")
578
    public String activateStoreTemporary(HttpServletRequest request,
579
                                         @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId,
580
                                         @RequestParam(name = "days", required = true) int days, Model model) throws Exception {
28825 tejbeer 581
 
33990 tejus.loha 582
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
583
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
584
        if (!Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
585
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com").contains(loginDetails.getEmailId())) {
586
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
587
                    "You are not authorise to deactivate retailer");
588
        }
28825 tejbeer 589
 
35962 amit 590
        if (fofoStore.isClosed()) {
591
            throw new ProfitMandiBusinessException("Store Closed", "Store Permanently Closed",
592
                    "This store is permanently closed and cannot be reactivated");
593
        }
594
 
33990 tejus.loha 595
        LocalDateTime currentDate = LocalDate.now().atStartOfDay();
28825 tejbeer 596
 
33990 tejus.loha 597
        LocalDateTime EndDate = currentDate.plusDays(days);
598
        fofoStore.setActiveTimeStamp(EndDate);
28825 tejbeer 599
 
33990 tejus.loha 600
        LOGGER.info("EndDate" + EndDate);
601
        LOGGER.info("getActiveTimeStamp" + fofoStore.getActiveTimeStamp());
28825 tejbeer 602
 
33990 tejus.loha 603
        if (currentDate.isBefore(fofoStore.getActiveTimeStamp())) {
604
            fofoStore.setActive(true);
605
            LOGGER.info("inserted into InActiveFofoStore successfully");
606
        }
28825 tejbeer 607
 
33990 tejus.loha 608
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
609
        return "response";
610
    }
25276 amit.gupta 611
 
33990 tejus.loha 612
    @GetMapping(value = "/getAllInactiveStores")
33247 ranu 613
    public String getInactiveStores(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
33990 tejus.loha 614
        List<FofoStore> inActiveFofoStores = fofoStoreRepository.selectInActiveStore();
30426 tejbeer 615
 
33990 tejus.loha 616
        LOGGER.info("inActiveFofoStores {}", inActiveFofoStores);
617
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
30426 tejbeer 618
 
33990 tejus.loha 619
        List<Integer> fofoIds = inActiveFofoStores.stream().map(x -> x.getId()).collect(Collectors.toList());
30431 tejbeer 620
 
33990 tejus.loha 621
        Map<Integer, CustomRetailer> customRetailers = fofoIds.stream().map(x -> customRetailerMap.get(x))
622
                .filter(x -> x != null).collect(Collectors.toList()).stream()
623
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
624
        LOGGER.info("customRetailers {}", customRetailers);
30426 tejbeer 625
 
33990 tejus.loha 626
        model.addAttribute("inActiveFofoStores", inActiveFofoStores);
627
        model.addAttribute("customRetailers", customRetailers);
628
        return "inactive-stores";
629
    }
25276 amit.gupta 630
 
33990 tejus.loha 631
    // Extend billing for 2 days
632
    @PostMapping(value = "/extendBilling")
633
    public String extendBilling(HttpServletRequest request,
634
                                @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
635
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
636
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
637
        if (Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
638
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com", "mohit.gulati@smartdukaan.com", "chiranjib.sarkar@smartdukaan.com").contains(loginDetails.getEmailId())) {
639
            fofoStore.setGraceDate(LocalDate.now().plusDays(2));
640
            fofoStore.setGraceCount(fofoStore.getGraceCount() + 1);
641
            model.addAttribute("response1", mvcResponseSender.createResponseString(fofoStore.getGraceCount()));
642
        } else {
643
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
644
                    "You are not authorise to extend billing");
645
        }
646
        return "response";
25276 amit.gupta 647
 
33990 tejus.loha 648
    }
24124 govind 649
 
33990 tejus.loha 650
    @RequestMapping(value = "/getPromoterInfo", method = RequestMethod.GET)
32887 shampa 651
 
33990 tejus.loha 652
    public String getShowPromoterInfo(HttpServletRequest request,
653
                                      @RequestParam(name = "offset", defaultValue = "0") int offset,
654
                                      @RequestParam(name = "limit", defaultValue = "10") int limit,
655
                                      @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
656
            throws Exception {
657
        //LOGGER.info("requested url : " + request.getRequestURL().toString());
658
        List<Promoter> promoterInfo = null;
659
        long size = 0;
24159 tejbeer 660
 
33990 tejus.loha 661
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId())
662
                .collect(Collectors.toList());
32887 shampa 663
 
33990 tejus.loha 664
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
32887 shampa 665
 
33990 tejus.loha 666
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
667
                .filter(x -> x != null).collect(Collectors.toList()).stream()
668
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
669
        String customRetailers = JSONObject.valueToString(customRetailersMap.values());
670
        Set<String> brands = inventoryService.getAllTagListingBrands(ProfitMandiConstants.MOBILE_CATEGORY_ID);
671
        brands.add("Airtel");
672
        brands.add("Vodafone");
673
        brands.add("Idea");
674
        LOGGER.info("brands" + brands);
675
        model.addAttribute("customRetailers", customRetailers);
676
        model.addAttribute("brands", brands);
32887 shampa 677
 
33990 tejus.loha 678
        if (fofoId != 0) {
679
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, true);
32887 shampa 680
 
33990 tejus.loha 681
            //size = promoterRepository.selectPromoterCount(fofoId);
682
            size = promoterInfo.size();
683
        } else {
684
            //rkb
685
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, true);
32887 shampa 686
 
33990 tejus.loha 687
            //size = promoterRepository.selectAllCount();
688
            size = promoterInfo.size();
689
        }
690
        if (!promoterInfo.isEmpty()) {
691
            Set<Integer> partnerIds = new HashSet<>();
32887 shampa 692
 
33990 tejus.loha 693
            for (Promoter promoterdetail : promoterInfo) {
694
                partnerIds.add(promoterdetail.getRetailerId());
695
            }
696
            Map<Integer, CustomRetailer> partnersMap = null;
697
            if (!partnerIds.equals(null)) {
698
                LOGGER.info("partnerIds" + partnerIds);
32887 shampa 699
 
33990 tejus.loha 700
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
701
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
32887 shampa 702
 
33990 tejus.loha 703
            }
32887 shampa 704
 
33990 tejus.loha 705
            LOGGER.info("partnerIds" + partnersMap);
706
            model.addAttribute("promoterInfo", promoterInfo);
707
            model.addAttribute("partnersMap", partnersMap);
708
            model.addAttribute("start", offset + 1);
709
            model.addAttribute("size", size);
710
            model.addAttribute("url", "/getPaginatedPromoterInfo");
32887 shampa 711
 
33990 tejus.loha 712
            if (promoterInfo.size() < limit) {
713
                model.addAttribute("end", offset + promoterInfo.size());
714
            } else {
715
                model.addAttribute("end", offset + limit);
716
            }
717
        } else {
718
            model.addAttribute("promoterInfo", promoterInfo);
719
            model.addAttribute("size", size);
720
        }
721
        return "promoter-info";
32887 shampa 722
 
33990 tejus.loha 723
    }
32887 shampa 724
 
33990 tejus.loha 725
    @RequestMapping(value = "/getPromoterInactive", method = RequestMethod.GET)
32887 shampa 726
 
33990 tejus.loha 727
    public String getShowPromoterInactiveInfo(HttpServletRequest request,
728
                                              @RequestParam(name = "offset", defaultValue = "0") int offset,
729
                                              @RequestParam(name = "limit", defaultValue = "10") int limit,
730
                                              @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
731
            throws Exception {
732
        //LOGGER.info("requested url : " + request.getRequestURL().toString());
733
        List<Promoter> promoterInfo = null;
734
        long size = 0;
32887 shampa 735
 
33990 tejus.loha 736
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId())
737
                .collect(Collectors.toList());
32887 shampa 738
 
33990 tejus.loha 739
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
27489 tejbeer 740
 
33990 tejus.loha 741
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
742
                .filter(x -> x != null).collect(Collectors.toList()).stream()
743
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
744
        String customRetailers = JSONObject.valueToString(customRetailersMap.values());
745
        Set<String> brands = inventoryService.getAllTagListingBrands(ProfitMandiConstants.MOBILE_CATEGORY_ID);
746
        brands.add("Airtel");
747
        brands.add("Vodafone");
748
        brands.add("Idea");
749
        LOGGER.info("brands" + brands);
750
        model.addAttribute("customRetailers", customRetailers);
751
        model.addAttribute("brands", brands);
30426 tejbeer 752
 
33990 tejus.loha 753
        if (fofoId != 0) {
754
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, false);
30426 tejbeer 755
 
33990 tejus.loha 756
            //size = promoterRepository.selectPromoterCount(fofoId);
757
            size = promoterInfo.size();
24159 tejbeer 758
 
33990 tejus.loha 759
        } else {
760
            //rkb
761
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, false);
24159 tejbeer 762
 
33990 tejus.loha 763
            //size = promoterRepository.selectAllCount();
764
            size = promoterInfo.size();
27489 tejbeer 765
 
33990 tejus.loha 766
        }
767
        if (!promoterInfo.isEmpty()) {
768
            Set<Integer> partnerIds = new HashSet<>();
27489 tejbeer 769
 
33990 tejus.loha 770
            for (Promoter promoterdetail : promoterInfo) {
771
                partnerIds.add(promoterdetail.getRetailerId());
772
            }
773
            Map<Integer, CustomRetailer> partnersMap = null;
774
            if (!partnerIds.equals(null)) {
775
                LOGGER.info("partnerIds" + partnerIds);
27489 tejbeer 776
 
33990 tejus.loha 777
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
778
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
24159 tejbeer 779
 
33990 tejus.loha 780
            }
30426 tejbeer 781
 
33990 tejus.loha 782
            LOGGER.info("partnerIds" + partnersMap);
783
            model.addAttribute("promoterInfo", promoterInfo);
784
            model.addAttribute("partnersMap", partnersMap);
785
            model.addAttribute("start", offset + 1);
786
            model.addAttribute("size", size);
787
            model.addAttribute("url", "/getPaginatedPromoterInactiveInfo");
30426 tejbeer 788
 
33990 tejus.loha 789
            if (promoterInfo.size() < limit) {
790
                model.addAttribute("end", offset + promoterInfo.size());
791
            } else {
792
                model.addAttribute("end", offset + limit);
793
            }
794
        } else {
795
            model.addAttribute("promoterInfo", promoterInfo);
796
            model.addAttribute("size", size);
797
        }
798
        return "promoter-inactive";
24349 amit.gupta 799
 
33990 tejus.loha 800
    }
24159 tejbeer 801
 
33990 tejus.loha 802
    @RequestMapping(value = "/getPaginatedPromoterInfo", method = RequestMethod.GET)
803
    public String getPaginatedPromoterInfo(HttpServletRequest request,
804
                                           @RequestParam(name = "offset", defaultValue = "0") int offset,
805
                                           @RequestParam(name = "limit", defaultValue = "10") int limit,
806
                                           @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
807
            throws ProfitMandiBusinessException {
808
        LOGGER.info("requested offset=[{}], limit = [{}]", offset, limit);
809
        List<Promoter> promoterInfo = null;
810
        if (fofoId != 0) {
811
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, true);
812
        } else {
813
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, true);
814
        }
815
        LOGGER.info("promoterInfo" + promoterInfo);
816
        if (!promoterInfo.isEmpty()) {
817
            Set<Integer> partnerIds = new HashSet<>();
24159 tejbeer 818
 
33990 tejus.loha 819
            for (Promoter promoterdetail : promoterInfo) {
820
                partnerIds.add(promoterdetail.getRetailerId());
821
            }
822
            Map<Integer, CustomRetailer> partnersMap = null;
823
            if (!partnerIds.equals(null)) {
824
                LOGGER.info("partnerIds" + partnerIds);
24349 amit.gupta 825
 
33990 tejus.loha 826
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
32887 shampa 827
 
33990 tejus.loha 828
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
829
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
24159 tejbeer 830
 
33990 tejus.loha 831
            }
30426 tejbeer 832
 
33990 tejus.loha 833
            LOGGER.info("partnerIds" + partnersMap);
834
            model.addAttribute("promoterInfo", promoterInfo);
835
            model.addAttribute("partnersMap", partnersMap);
836
            model.addAttribute("url", "/getPaginatedPromoterInfo");
837
        } else {
838
            model.addAttribute("promoterInfo", promoterInfo);
30426 tejbeer 839
 
33990 tejus.loha 840
        }
30426 tejbeer 841
 
33990 tejus.loha 842
        return "promoter-info-paginated";
843
    }
24349 amit.gupta 844
 
33990 tejus.loha 845
    @RequestMapping(value = "/getPaginatedPromoterInactiveInfo", method = RequestMethod.GET)
846
    public String getPaginatedPromoterInactiveInfo(HttpServletRequest request,
847
                                                   @RequestParam(name = "offset", defaultValue = "0") int offset,
848
                                                   @RequestParam(name = "limit", defaultValue = "10") int limit,
849
                                                   @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
850
            throws ProfitMandiBusinessException {
851
        LOGGER.info("requested offset=[{}], limit = [{}]", offset, limit);
852
        List<Promoter> promoterInfo = null;
853
        if (fofoId != 0) {
854
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, false);
855
        } else {
856
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, false);
857
        }
858
        LOGGER.info("promoterInfo" + promoterInfo);
859
        if (!promoterInfo.isEmpty()) {
860
            Set<Integer> partnerIds = new HashSet<>();
24159 tejbeer 861
 
33990 tejus.loha 862
            for (Promoter promoterdetail : promoterInfo) {
863
                partnerIds.add(promoterdetail.getRetailerId());
864
            }
865
            Map<Integer, CustomRetailer> partnersMap = null;
866
            if (!partnerIds.equals(null)) {
867
                LOGGER.info("partnerIds" + partnerIds);
24159 tejbeer 868
 
33990 tejus.loha 869
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
24159 tejbeer 870
 
33990 tejus.loha 871
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
872
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
32887 shampa 873
 
33990 tejus.loha 874
            }
32887 shampa 875
 
33990 tejus.loha 876
            LOGGER.info("partnerIds" + partnersMap);
877
            model.addAttribute("promoterInfo", promoterInfo);
878
            model.addAttribute("partnersMap", partnersMap);
879
            model.addAttribute("url", "/getPaginatedPromoterInactiveInfo");
880
        } else {
881
            model.addAttribute("promoterInfo", promoterInfo);
32887 shampa 882
 
33990 tejus.loha 883
        }
32887 shampa 884
 
33990 tejus.loha 885
        return "promoter-inactive-info-paginated";
886
    }
32887 shampa 887
 
33990 tejus.loha 888
    @RequestMapping(value = "/createPromoter", method = RequestMethod.POST)
889
    public String createPromoter(HttpServletRequest request, @RequestBody PromoterDetailModel promoterdetailModel,
890
                                 Model model) throws Exception {
891
        LOGGER.info("requested url : " + request.getRequestURL().toString());
892
        LOGGER.info("requested url : " + promoterdetailModel);
893
        Promoter promoter = promoterRepository.selectById(promoterdetailModel.getId());
894
        if (promoter == null) {
895
            promoter = new Promoter();
896
            promoter.setBrand(promoterdetailModel.getBrand());
897
            promoter.setRetailerId(promoterdetailModel.getRetailerId());
898
            promoter.setCreatedTimestamp(LocalDateTime.now());
899
            promoter.setEmail(promoterdetailModel.getEmail());
900
            promoter.setName(promoterdetailModel.getName());
901
            promoter.setMobile(promoterdetailModel.getMobile());
902
            promoter.setSdPortalAccess(promoterdetailModel.isSdPortalAccess());
903
            promoter.setStatus(promoterdetailModel.isStatus());
904
            promoterRepository.persist(promoter);
32887 shampa 905
 
33990 tejus.loha 906
            List<Promoter> promoters = promoterRepository.selectAllByRetailer(promoterdetailModel.getRetailerId());
907
            if (!promoters.isEmpty()) {
908
                FofoStore fs = fofoStoreRepository.selectByRetailerId(promoterdetailModel.getRetailerId());
909
                PartnerOnBoardingPanel pobp = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
910
                if (pobp != null) {
911
                    storeTimelineTatService.promoterComplete(pobp.getId());
912
                }
913
            }
32887 shampa 914
 
33990 tejus.loha 915
        } else {
916
            promoter.setEmail(promoterdetailModel.getEmail());
917
            promoter.setName(promoterdetailModel.getName());
918
            promoter.setMobile(promoterdetailModel.getMobile());
919
            promoter.setSdPortalAccess(promoterdetailModel.isSdPortalAccess());
920
            promoter.setStatus(promoterdetailModel.isStatus());
921
        }
922
        LOGGER.info("sdport" + promoterdetailModel.isStatus());
26131 tejbeer 923
 
33990 tejus.loha 924
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28908 tejbeer 925
 
33990 tejus.loha 926
        return "response";
24159 tejbeer 927
 
33990 tejus.loha 928
    }
24159 tejbeer 929
 
33990 tejus.loha 930
    @RequestMapping(value = "/setPromoterInActive", method = RequestMethod.POST)
931
    public String PromoterInActive(HttpServletRequest request, @RequestParam(name = "id", required = true, defaultValue = "0") int id, Model model) throws Exception {
24159 tejbeer 932
 
33990 tejus.loha 933
        Promoter promoter = promoterRepository.selectById(id);
24159 tejbeer 934
 
33990 tejus.loha 935
        promoter.setStatus(false);
32887 shampa 936
 
33990 tejus.loha 937
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 938
 
33990 tejus.loha 939
        return "response";
940
    }
32887 shampa 941
 
33990 tejus.loha 942
    @RequestMapping(value = "/removePromoterfromPartnerStore", method = RequestMethod.POST)
943
    public String removePromoterfromPartnerStore(HttpServletRequest request,
944
                                                 @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
32887 shampa 945
 
33990 tejus.loha 946
        Promoter promoter = promoterRepository.selectById(id);
947
        promoter.setStatus(false);
948
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 949
 
33990 tejus.loha 950
        return "response";
951
    }
24159 tejbeer 952
 
33990 tejus.loha 953
    @RequestMapping(value = "/activePromoterfromPartnerStore", method = RequestMethod.POST)
954
    public String activePromoterfromPartnerStore(HttpServletRequest request,
955
                                                 @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
24159 tejbeer 956
 
33990 tejus.loha 957
        Promoter promoter = promoterRepository.selectById(id);
958
        promoter.setStatus(true);
959
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 960
 
33990 tejus.loha 961
        return "response";
962
    }
24159 tejbeer 963
 
33990 tejus.loha 964
    @RequestMapping(value = "/addLocation", method = RequestMethod.POST)
965
    public String addLocation(HttpServletRequest request, @RequestBody AddLocationModel addLocationModel, Model model)
966
            throws Exception {
24159 tejbeer 967
 
33990 tejus.loha 968
        Location location = new Location();
969
        location.setName(addLocationModel.getName());
970
        location.setLine1(addLocationModel.getLine1());
971
        location.setLine2(addLocationModel.getLine2());
972
        location.setCity(addLocationModel.getCity());
973
        location.setState(addLocationModel.getState());
974
        location.setPin(addLocationModel.getPin());
24159 tejbeer 975
 
33990 tejus.loha 976
        LOGGER.info("PostLocation" + location);
977
        locationRepository.persist(location);
24159 tejbeer 978
 
33990 tejus.loha 979
        User user = userRepository.selectById(addLocationModel.getUserId());
980
        user.setLocation(location.getId());
981
        userRepository.persist(user);
24159 tejbeer 982
 
33990 tejus.loha 983
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
984
        return "response";
24159 tejbeer 985
 
33990 tejus.loha 986
    }
24159 tejbeer 987
 
33990 tejus.loha 988
    @RequestMapping(value = "/updateLocation", method = RequestMethod.POST)
989
    public String updateLocation(HttpServletRequest request, @RequestBody AddLocationModel addLocationModel,
990
                                 Model model) throws Exception {
24159 tejbeer 991
 
33990 tejus.loha 992
        Location userlocation = locationRepository.selectById(addLocationModel.getUserId());
24159 tejbeer 993
 
33990 tejus.loha 994
        userlocation.setName(addLocationModel.getName());
995
        userlocation.setCity(addLocationModel.getCity());
996
        userlocation.setLine1(addLocationModel.getLine1());
997
        userlocation.setLine2(addLocationModel.getLine2());
998
        userlocation.setPin(addLocationModel.getPin());
999
        userlocation.setState(addLocationModel.getState());
24159 tejbeer 1000
 
33990 tejus.loha 1001
        locationRepository.persist(userlocation);
24159 tejbeer 1002
 
33990 tejus.loha 1003
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
1004
        return "response";
24159 tejbeer 1005
 
33990 tejus.loha 1006
    }
24159 tejbeer 1007
 
33990 tejus.loha 1008
    @RequestMapping(value = "/getPartnerReadonlyInfo")
1009
    public String getPartnerReadonlyInfo(HttpServletRequest request, Model model) throws Exception {
24159 tejbeer 1010
 
33990 tejus.loha 1011
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1012
        AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
27231 tejbeer 1013
 
33990 tejus.loha 1014
        Map<Integer, List<Integer>> pp = csService.getAuthUserIdPartnerIdMapping();
27231 tejbeer 1015
 
35452 amit 1016
        List<Integer> fofoIds = pp.get(authUser.getId());
27231 tejbeer 1017
 
35452 amit 1018
        Map<Integer, CustomRetailer> customRetailersMap = retailerService.getFofoRetailers(fofoIds);
27231 tejbeer 1019
 
33990 tejus.loha 1020
        model.addAttribute("customRetailersMap", customRetailersMap);
27231 tejbeer 1021
 
33990 tejus.loha 1022
        return "partner-readonly-info";
27243 tejbeer 1023
 
33990 tejus.loha 1024
    }
27231 tejbeer 1025
 
33990 tejus.loha 1026
    @RequestMapping(value = "/getBlockBrandMapping")
1027
    public String getBlockBrandMapping(HttpServletRequest request, Model model) throws Exception {
27231 tejbeer 1028
 
33990 tejus.loha 1029
        int fofoId = Utils.SYSTEM_PARTNER_ID;
35236 amit 1030
        Set<String> brands = brandsService.getBrands(fofoId, null, 3).stream().map(x -> x.getName()).collect(Collectors.toSet());
28071 tejbeer 1031
 
33990 tejus.loha 1032
        LOGGER.info("brands" + brands);
1033
        model.addAttribute("brands", brands);
28071 tejbeer 1034
 
33990 tejus.loha 1035
        return "block-brand-mapping";
28071 tejbeer 1036
 
33990 tejus.loha 1037
    }
28071 tejbeer 1038
 
33990 tejus.loha 1039
    @RequestMapping(value = "/getBlockBrand")
1040
    public String getBlockBrand(HttpServletRequest request,
1041
                                @RequestParam(name = "brand", required = true, defaultValue = "0") String brand, Model model)
1042
            throws Exception {
28071 tejbeer 1043
 
33990 tejus.loha 1044
        List<RetailerBlockBrands> retailerBlockBrands = retailerBlockBrandsRepository.selectAllByBrands(brand);
28071 tejbeer 1045
 
33990 tejus.loha 1046
        List<Integer> blockBrandPartners = retailerBlockBrands.stream().map(x -> x.getFofoId())
1047
                .collect(Collectors.toList());
1048
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
28071 tejbeer 1049
 
33990 tejus.loha 1050
        LOGGER.info("retailerBlockBrands" + retailerBlockBrands);
1051
        model.addAttribute("blockBrandPartners", blockBrandPartners);
1052
        model.addAttribute("retailerBlockBrands", retailerBlockBrands);
1053
        model.addAttribute("customRetailers", customRetailers);
28272 tejbeer 1054
 
33990 tejus.loha 1055
        return "retailer-block-brand";
28071 tejbeer 1056
 
33990 tejus.loha 1057
    }
28071 tejbeer 1058
 
33990 tejus.loha 1059
    @RequestMapping(value = "/getRetailerBlockBrandMappping", method = RequestMethod.POST)
1060
    public String getBlockBrandMappping(HttpServletRequest request,
1061
                                        @RequestParam(name = "brand", required = true, defaultValue = "0") String brand,
1062
                                        @RequestParam(name = "fofoIds", required = true, defaultValue = "0") List<Integer> fofoIds, Model model)
1063
            throws Exception {
1064
        List<RetailerBlockBrands> retailerBlockBrands = retailerBlockBrandsRepository.selectAllByBrands(brand);
1065
        if (!retailerBlockBrands.isEmpty()) {
1066
            retailerBlockBrandsRepository.deleteAllbyBrands(brand);
1067
        }
28071 tejbeer 1068
 
33990 tejus.loha 1069
        for (int id : fofoIds) {
1070
            RetailerBlockBrands retailerBlockBrand = new RetailerBlockBrands();
1071
            retailerBlockBrand.setFofoId(id);
1072
            retailerBlockBrand.setBlockBrands(brand);
1073
            retailerBlockBrandsRepository.persist(retailerBlockBrand);
28071 tejbeer 1074
 
33990 tejus.loha 1075
        }
1076
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28071 tejbeer 1077
 
33990 tejus.loha 1078
        return "response";
1079
    }
28071 tejbeer 1080
 
33990 tejus.loha 1081
    @RequestMapping(value = "/getBrandslimit", method = RequestMethod.GET)
1082
    public String getBrandslimit(HttpServletRequest request, Model model) throws Exception {
28071 tejbeer 1083
 
33990 tejus.loha 1084
        int fofoId = Utils.SYSTEM_PARTNER_ID;
32731 ranu 1085
 
33990 tejus.loha 1086
        List<String> brands = brandsService.getBrandsToDisplay(3).stream().map(x -> x.getName()).collect(Collectors.toList());
1087
        model.addAttribute("brands", brands);
28272 tejbeer 1088
 
33990 tejus.loha 1089
        return "brands-limit";
28272 tejbeer 1090
 
33990 tejus.loha 1091
    }
28272 tejbeer 1092
 
33990 tejus.loha 1093
    @RequestMapping(value = "/setUpdateLimit", method = RequestMethod.POST)
1094
    public String getUpdateLimit(HttpServletRequest request,
1095
                                 @RequestParam(name = "brand", required = true, defaultValue = "0") String brand,
1096
                                 @RequestParam(name = "fofoId", required = true, defaultValue = "0") int fofoId,
1097
                                 @RequestParam(name = "limit", required = true, defaultValue = "0") float limit,
1098
                                 @RequestParam(name = "minStockLimit", required = true, defaultValue = "0") float minStockLimit,
1099
                                 @RequestParam(name = "preLimit", required = true, defaultValue = "0") float preLimit,
1100
                                 @RequestParam(name = "preStockLimit", required = true, defaultValue = "0") float preStockLimit, Model model)
1101
            throws Exception {
28272 tejbeer 1102
 
33990 tejus.loha 1103
        CustomRetailer cr = retailerService.getFofoRetailer(fofoId);
28272 tejbeer 1104
 
33990 tejus.loha 1105
        Map.Entry<Integer, CustomRetailer> customRetailers = new AbstractMap.SimpleEntry(cr.getPartnerId(), cr);
28272 tejbeer 1106
 
33990 tejus.loha 1107
        // Map<Integer, CustomRetailer> customRetailers =
1108
        // retailerService.getFofoRetailers(true);
28277 tejbeer 1109
 
33990 tejus.loha 1110
        RetailerBrandsLimit retailerBrands = retailerBrandsLimitRepository.selectLimitByBrandAndFofoId(fofoId, brand);
28277 tejbeer 1111
 
33990 tejus.loha 1112
        if (retailerBrands == null) {
1113
            retailerBrands = new RetailerBrandsLimit();
1114
            retailerBrands.setMinStockLimit(minStockLimit);
1115
            retailerBrands.setBrandLimit(limit);
1116
            retailerBrands.setIsUpdate(1);
1117
            retailerBrands.setCreatedTimestamp(LocalDateTime.now());
1118
            retailerBrands.setPartnerId(fofoId);
1119
            retailerBrands.setBrandName(brand);
1120
            retailerBrands.setUpdatedTimestamp(LocalDateTime.now());
1121
            retailerBrandsLimitRepository.persist(retailerBrands);
1122
        } else {
1123
            retailerBrands.setMinStockLimit(minStockLimit);
1124
            retailerBrands.setBrandLimit(limit);
1125
            retailerBrands.setIsUpdate(1);
1126
            retailerBrands.setUpdatedTimestamp(LocalDateTime.now());
1127
            retailerBrandsLimitRepository.persist(retailerBrands);
30028 manish 1128
 
33990 tejus.loha 1129
        }
1130
        retailerBrands = retailerBrandsLimitRepository.selectLimitByBrandAndFofoId(fofoId, brand);
28277 tejbeer 1131
 
33990 tejus.loha 1132
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = new HashMap<>();
28272 tejbeer 1133
 
33990 tejus.loha 1134
        retailerBrandsLimitMap.put(retailerBrands.getPartnerId(), retailerBrands);
28272 tejbeer 1135
 
33990 tejus.loha 1136
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brand);
28272 tejbeer 1137
 
33990 tejus.loha 1138
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1139
        model.addAttribute("brandLimit", brandLimit);
1140
        model.addAttribute("customRetailers", customRetailers);
28272 tejbeer 1141
 
33990 tejus.loha 1142
        model.addAttribute("brand", brand);
1143
        return "brands-limit-row-mapping";
28272 tejbeer 1144
 
33990 tejus.loha 1145
    }
28277 tejbeer 1146
 
33990 tejus.loha 1147
    @RequestMapping(value = "/getRetailerBrandslimitMapping", method = RequestMethod.GET)
1148
    public String getRetailerBrandslimit(HttpServletRequest request,
1149
                                         @RequestParam(name = "brand", required = true, defaultValue = "0") String brand, Model model)
1150
            throws Exception {
28272 tejbeer 1151
 
33990 tejus.loha 1152
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
1153
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brand);
1154
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1155
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
28272 tejbeer 1156
 
33990 tejus.loha 1157
        model.addAttribute("customRetailers", customRetailers);
1158
        model.addAttribute("brand", brand);
1159
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
28272 tejbeer 1160
 
33990 tejus.loha 1161
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brand);
28272 tejbeer 1162
 
33990 tejus.loha 1163
        model.addAttribute("brandLimit", brandLimit);
28272 tejbeer 1164
 
33990 tejus.loha 1165
        return "brands-limit-mapping";
28272 tejbeer 1166
 
33990 tejus.loha 1167
    }
28272 tejbeer 1168
 
33990 tejus.loha 1169
    @RequestMapping(value = "/setBrandWiseLimit", method = RequestMethod.POST)
1170
    public String brandwiseLimit(HttpServletRequest request,
1171
                                 @RequestParam(name = "brands", required = true, defaultValue = "") String brands,
1172
                                 @RequestParam(name = "limit", required = true, defaultValue = "") float limit, Model model)
1173
            throws Exception {
28272 tejbeer 1174
 
33990 tejus.loha 1175
        LOGGER.info("limit" + limit);
30426 tejbeer 1176
 
33990 tejus.loha 1177
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brands);
28272 tejbeer 1178
 
33990 tejus.loha 1179
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brands);
28272 tejbeer 1180
 
33990 tejus.loha 1181
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1182
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
28272 tejbeer 1183
 
33990 tejus.loha 1184
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
28272 tejbeer 1185
 
33990 tejus.loha 1186
        if (brandLimit == null) {
28272 tejbeer 1187
 
33990 tejus.loha 1188
            brandLimit = new BrandLimit();
1189
            brandLimit.setBrandLimit(limit);
1190
            brandLimit.setBrandName(brands);
1191
            brandLimit.setCreatedTimestamp(LocalDateTime.now());
1192
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1193
            brandLimitRepository.persist(brandLimit);
28272 tejbeer 1194
 
33990 tejus.loha 1195
        } else {
1196
            brandLimit.setBrandLimit(limit);
28272 tejbeer 1197
 
33990 tejus.loha 1198
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1199
            brandLimitRepository.persist(brandLimit);
28272 tejbeer 1200
 
33990 tejus.loha 1201
        }
1202
        brandLimit = brandLimitRepository.setLimitByBrands(brands);
30028 manish 1203
 
33990 tejus.loha 1204
        LOGGER.info("brandLimit" + brandLimit);
1205
        model.addAttribute("brand", brands);
1206
        model.addAttribute("brandLimit", brandLimit);
1207
        model.addAttribute("customRetailers", customRetailers);
1208
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1209
        return "brands-limit-mapping";
28272 tejbeer 1210
 
33990 tejus.loha 1211
    }
28272 tejbeer 1212
 
33990 tejus.loha 1213
    @RequestMapping(value = "/setBrandWiseStockLimit", method = RequestMethod.POST)
1214
    public String setBrandWiseStockLimit(HttpServletRequest request,
1215
                                         @RequestParam(name = "brands", required = true, defaultValue = "") String brands,
1216
                                         @RequestParam(name = "stockLimit", required = true, defaultValue = "") float stockLimit, Model model)
1217
            throws Exception {
28272 tejbeer 1218
 
33990 tejus.loha 1219
        LOGGER.info("limit" + stockLimit);
28272 tejbeer 1220
 
33990 tejus.loha 1221
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brands);
28825 tejbeer 1222
 
33990 tejus.loha 1223
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brands);
30028 manish 1224
 
33990 tejus.loha 1225
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1226
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
30028 manish 1227
 
33990 tejus.loha 1228
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
30028 manish 1229
 
33990 tejus.loha 1230
        if (brandLimit == null) {
30028 manish 1231
 
33990 tejus.loha 1232
            brandLimit = new BrandLimit();
1233
            brandLimit.setBrandLimit(0);
1234
            brandLimit.setBrandName(brands);
1235
            brandLimit.setStockLimit(stockLimit);
1236
            brandLimit.setCreatedTimestamp(LocalDateTime.now());
1237
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1238
            brandLimitRepository.persist(brandLimit);
30028 manish 1239
 
33990 tejus.loha 1240
        } else {
1241
            brandLimit.setStockLimit(stockLimit);
30028 manish 1242
 
33990 tejus.loha 1243
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1244
            brandLimitRepository.persist(brandLimit);
30028 manish 1245
 
33990 tejus.loha 1246
        }
1247
        brandLimit = brandLimitRepository.setLimitByBrands(brands);
30028 manish 1248
 
33990 tejus.loha 1249
        model.addAttribute("brand", brands);
1250
        model.addAttribute("brandLimit", brandLimit);
1251
        model.addAttribute("customRetailers", customRetailers);
1252
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1253
        return "brands-limit-mapping";
30028 manish 1254
 
33990 tejus.loha 1255
    }
30028 manish 1256
 
33990 tejus.loha 1257
    @RequestMapping(value = "/setPartnerPincode", method = RequestMethod.POST)
1258
    public String setPartnerPincode(HttpServletRequest request,
1259
                                    @RequestParam(name = "pincode", required = true, defaultValue = "") String pincode,
1260
                                    @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1261
            throws Exception {
30028 manish 1262
 
33990 tejus.loha 1263
        if (!pincode.equals("")) {
1264
            PincodePartner pinPartner = new PincodePartner();
1265
            pinPartner.setFofoId(fofoId);
1266
            pinPartner.setPincode(pincode);
1267
            pincodePartnerRepository.perist(pinPartner);
1268
        }
30028 manish 1269
 
33990 tejus.loha 1270
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(fofoId);
30028 manish 1271
 
33990 tejus.loha 1272
        LOGGER.info("partnerPincodeList" + partnerPincodeList);
30028 manish 1273
 
33990 tejus.loha 1274
        model.addAttribute("partnerPincodeList", partnerPincodeList);
1275
        return "pincode-partner-index";
28272 tejbeer 1276
 
33990 tejus.loha 1277
    }
28381 tejbeer 1278
 
33990 tejus.loha 1279
    @RequestMapping(value = "/removePartnerPincode", method = RequestMethod.POST)
1280
    public String removePartnerPincode(HttpServletRequest request, @RequestParam int id,
1281
                                       @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1282
            throws Exception {
28825 tejbeer 1283
 
33990 tejus.loha 1284
        pincodePartnerRepository.delete(id);
28825 tejbeer 1285
 
33990 tejus.loha 1286
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(fofoId);
28381 tejbeer 1287
 
33990 tejus.loha 1288
        LOGGER.info("partnerPincodeList" + partnerPincodeList);
28825 tejbeer 1289
 
33990 tejus.loha 1290
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1291
 
33990 tejus.loha 1292
        return "pincode-partner-index";
28381 tejbeer 1293
 
33990 tejus.loha 1294
    }
28825 tejbeer 1295
 
33990 tejus.loha 1296
    @RequestMapping(value = "/removeSearchPincode", method = RequestMethod.POST)
1297
    public String removeSearchPincode(HttpServletRequest request, @RequestParam int id,
1298
                                      @RequestParam(name = "pin", required = true, defaultValue = "") String pin,
1299
                                      @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1300
            throws Exception {
28825 tejbeer 1301
 
33990 tejus.loha 1302
        pincodePartnerRepository.delete(id);
28825 tejbeer 1303
 
33990 tejus.loha 1304
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectPartnersByPincode(pin);
28381 tejbeer 1305
 
33990 tejus.loha 1306
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
28825 tejbeer 1307
 
33990 tejus.loha 1308
        model.addAttribute("customRetailerMap", customRetailerMap);
28381 tejbeer 1309
 
33990 tejus.loha 1310
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1311
 
33990 tejus.loha 1312
        return "search-pincode-partner";
28381 tejbeer 1313
 
33990 tejus.loha 1314
    }
28825 tejbeer 1315
 
33990 tejus.loha 1316
    @RequestMapping(value = "/searchPincodePartner", method = RequestMethod.GET)
1317
    public String searchPincodePartner(HttpServletRequest request,
1318
                                       @RequestParam(name = "pincode", required = true, defaultValue = "") String pincode, Model model)
1319
            throws Exception {
28825 tejbeer 1320
 
33990 tejus.loha 1321
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectPartnersByPincode(pincode);
28825 tejbeer 1322
 
33990 tejus.loha 1323
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
28381 tejbeer 1324
 
33990 tejus.loha 1325
        model.addAttribute("customRetailerMap", customRetailerMap);
28825 tejbeer 1326
 
33990 tejus.loha 1327
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1328
 
33990 tejus.loha 1329
        return "search-pincode-partner";
28825 tejbeer 1330
 
33990 tejus.loha 1331
    }
28381 tejbeer 1332
 
33990 tejus.loha 1333
    @RequestMapping(value = "/showPartnerPincode", method = RequestMethod.GET)
1334
    public String showPartnerPincode(HttpServletRequest request,
1335
                                     @RequestParam(name = "partnerId", required = true, defaultValue = "") int partnerId, Model model)
1336
            throws Exception {
28825 tejbeer 1337
 
33990 tejus.loha 1338
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(partnerId);
28825 tejbeer 1339
 
33990 tejus.loha 1340
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28825 tejbeer 1341
 
33990 tejus.loha 1342
        return "pincode-partner-index";
28825 tejbeer 1343
 
33990 tejus.loha 1344
    }
28381 tejbeer 1345
 
33990 tejus.loha 1346
    @RequestMapping(value = "/getAllPartnerPincode", method = RequestMethod.GET)
1347
    public String getAllPartnerPincode(HttpServletRequest request, Model model) throws Exception {
1348
        return "add-partner-pincode";
1349
    }
28825 tejbeer 1350
 
33990 tejus.loha 1351
    @RequestMapping(value = "/alternateRetailerContacts", method = RequestMethod.GET)
1352
    public String alternateRetailerContacts(HttpServletRequest request, Model model) throws Exception {
1353
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1354
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
28825 tejbeer 1355
 
33990 tejus.loha 1356
        model.addAttribute("isAdmin", isAdmin);
35648 ranu 1357
        model.addAttribute("brands", brandsRepository.selectAll());
33990 tejus.loha 1358
        return "retailer-contacts";
1359
    }
28825 tejbeer 1360
 
33990 tejus.loha 1361
    @RequestMapping(value = "/retailer-contact-list", method = RequestMethod.GET)
1362
    public String getRetailerContactList(HttpServletRequest request, Model model, @RequestParam(defaultValue = "0") int fofoId)
1363
            throws Exception {
28825 tejbeer 1364
 
33990 tejus.loha 1365
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
32629 amit.gupta 1366
 
33990 tejus.loha 1367
        model.addAttribute("retailerContacts", retailerContacts);
35648 ranu 1368
        model.addAttribute("brands", brandsRepository.selectAll());
32667 raveendra. 1369
 
33990 tejus.loha 1370
        return "retailer-contact-list";
33814 ranu 1371
 
33990 tejus.loha 1372
    }
33814 ranu 1373
 
33990 tejus.loha 1374
    @RequestMapping(value = "/add-retailer-contact-list", method = RequestMethod.GET)
1375
    public String updateRetailerContactList(HttpServletRequest request, Model model,
1376
                                            @RequestParam(defaultValue = "0") int fofoId,
1377
                                            @RequestParam String contactName,
35648 ranu 1378
                                            @RequestParam String contactNumber,
1379
                                            @RequestParam String brandName,
1380
                                            @RequestParam String contactType) throws Exception {
33990 tejus.loha 1381
        RetailerContact retailerContact = new RetailerContact();
1382
        retailerContact.setFofoId(fofoId);
1383
        retailerContact.setName(contactName);
1384
        retailerContact.setMobile(contactNumber);
35648 ranu 1385
        retailerContact.setBrandName(brandName);
1386
        retailerContact.setContactType(contactType);
33990 tejus.loha 1387
        retailerContact.setActive(true);
1388
        retailerContact.setCreatedAt(LocalDateTime.now());
1389
        retailerContactRepository.persist(retailerContact);
33814 ranu 1390
 
33990 tejus.loha 1391
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
33814 ranu 1392
 
33990 tejus.loha 1393
        model.addAttribute("retailerContacts", retailerContacts);
35648 ranu 1394
        model.addAttribute("brands", brandsRepository.selectAll());
33814 ranu 1395
 
33990 tejus.loha 1396
        return "retailer-contact-list";
33814 ranu 1397
 
33990 tejus.loha 1398
    }
33814 ranu 1399
 
33990 tejus.loha 1400
    @RequestMapping(value = "/update-contact-status", method = RequestMethod.GET)
1401
    public String updateRetailerContactStatus(HttpServletRequest request, Model model,
1402
                                              @RequestParam(defaultValue = "0") int fofoId,
1403
                                              @RequestParam(defaultValue = "0") int contactId,
1404
                                              @RequestParam boolean active) throws Exception {
33814 ranu 1405
 
33990 tejus.loha 1406
        RetailerContact retailerContact = retailerContactRepository.selectById(contactId);
1407
        retailerContact.setActive(active);
33814 ranu 1408
 
33990 tejus.loha 1409
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
33814 ranu 1410
 
33990 tejus.loha 1411
        model.addAttribute("retailerContacts", retailerContacts);
33814 ranu 1412
 
33990 tejus.loha 1413
        return "retailer-contact-list";
33814 ranu 1414
 
33990 tejus.loha 1415
    }
33814 ranu 1416
 
1417
 
28272 tejbeer 1418
}