Subversion Repositories SmartDukaan

Rev

Rev 35509 | Go to most recent revision | 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,
472
                                        @RequestParam(name = "partnerType") PartnerType partnerType, Model model) throws Exception {
27797 tejbeer 473
 
35509 amit 474
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
475
 
33990 tejus.loha 476
        PartnerTypeChange ptc = new PartnerTypeChange();
477
        ptc.setFofoId(fofoId);
478
        ptc.setPartnerType(partnerType);
35509 amit 479
        ptc.setCreateTimestamp(LocalDate.now().withDayOfMonth(1).atStartOfDay());
480
        ptc.setSource(PartnerTypeSource.MANUAL);
481
        ptc.setUpgradedBy(loginDetails.getEmailId());
33990 tejus.loha 482
        partnerTypeChangeRepository.persist(ptc);
483
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
27797 tejbeer 484
 
33990 tejus.loha 485
        return "response";
486
    }
27797 tejbeer 487
 
33990 tejus.loha 488
    @GetMapping(value = "/partners")
489
    public String getStoreName(HttpServletRequest request, Model model, @RequestParam String query) throws Exception {
490
        model.addAttribute("response1",
491
                mvcResponseSender.createResponseString(retailerService.getFofoRetailers(false).values().stream()
492
                        .filter(x -> x.getDisplayName().toLowerCase().matches(".*?" + query.toLowerCase() + ".*?"))
493
                        .collect(Collectors.toList())));
494
        return "response";
495
    }
24349 amit.gupta 496
 
33990 tejus.loha 497
    @PostMapping(value = "/deactivateStore")
498
    public String deActivateStore(HttpServletRequest request,
499
                                  @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
500
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
501
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
502
        if (!Arrays
503
                .asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
34211 vikas.jang 504
                        "rahul.katyal@smartdukaan.com", "vikas.jangra@smartdukaan.com", "sm@smartdukaan.com")
33990 tejus.loha 505
                .contains(loginDetails.getEmailId())) {
506
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
507
                    "You are not authorise to deactivate retailer");
508
        }
509
        fofoStore.setActive(false);
510
        LOGGER.info("inserted into InActiveFofoStore successfully");
511
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
512
        return "response";
513
    }
28825 tejbeer 514
 
33990 tejus.loha 515
    @PostMapping(value = "/activateStoreForever")
516
    public String activateStoreForever(HttpServletRequest request,
517
                                       @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
518
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
519
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
520
        if (!Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
521
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com").contains(loginDetails.getEmailId())) {
522
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
523
                    "You are not authorise to activate retailer");
524
        }
525
        fofoStore.setActive(true);
526
        LOGGER.info("inserted into ActiveFofoStore successfully");
527
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
528
        return "response";
529
    }
28825 tejbeer 530
 
33990 tejus.loha 531
    @PostMapping(value = "/activateStoreTemporary")
532
    public String activateStoreTemporary(HttpServletRequest request,
533
                                         @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId,
534
                                         @RequestParam(name = "days", required = true) int days, Model model) throws Exception {
28825 tejbeer 535
 
33990 tejus.loha 536
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
537
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
538
        if (!Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
539
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com").contains(loginDetails.getEmailId())) {
540
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
541
                    "You are not authorise to deactivate retailer");
542
        }
28825 tejbeer 543
 
33990 tejus.loha 544
        LocalDateTime currentDate = LocalDate.now().atStartOfDay();
28825 tejbeer 545
 
33990 tejus.loha 546
        LocalDateTime EndDate = currentDate.plusDays(days);
547
        fofoStore.setActiveTimeStamp(EndDate);
28825 tejbeer 548
 
33990 tejus.loha 549
        LOGGER.info("EndDate" + EndDate);
550
        LOGGER.info("getActiveTimeStamp" + fofoStore.getActiveTimeStamp());
28825 tejbeer 551
 
33990 tejus.loha 552
        if (currentDate.isBefore(fofoStore.getActiveTimeStamp())) {
553
            fofoStore.setActive(true);
554
            LOGGER.info("inserted into InActiveFofoStore successfully");
555
        }
28825 tejbeer 556
 
33990 tejus.loha 557
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
558
        return "response";
559
    }
25276 amit.gupta 560
 
33990 tejus.loha 561
    @GetMapping(value = "/getAllInactiveStores")
33247 ranu 562
    public String getInactiveStores(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
33990 tejus.loha 563
        List<FofoStore> inActiveFofoStores = fofoStoreRepository.selectInActiveStore();
30426 tejbeer 564
 
33990 tejus.loha 565
        LOGGER.info("inActiveFofoStores {}", inActiveFofoStores);
566
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
30426 tejbeer 567
 
33990 tejus.loha 568
        List<Integer> fofoIds = inActiveFofoStores.stream().map(x -> x.getId()).collect(Collectors.toList());
30431 tejbeer 569
 
33990 tejus.loha 570
        Map<Integer, CustomRetailer> customRetailers = fofoIds.stream().map(x -> customRetailerMap.get(x))
571
                .filter(x -> x != null).collect(Collectors.toList()).stream()
572
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
573
        LOGGER.info("customRetailers {}", customRetailers);
30426 tejbeer 574
 
33990 tejus.loha 575
        model.addAttribute("inActiveFofoStores", inActiveFofoStores);
576
        model.addAttribute("customRetailers", customRetailers);
577
        return "inactive-stores";
578
    }
25276 amit.gupta 579
 
33990 tejus.loha 580
    // Extend billing for 2 days
581
    @PostMapping(value = "/extendBilling")
582
    public String extendBilling(HttpServletRequest request,
583
                                @RequestParam(name = ProfitMandiConstants.FOFO_ID) int fofoId, Model model) throws Exception {
584
        FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
585
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
586
        if (Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "amit.gupta@smartdukaan.com",
587
                "rahul.katyal@smartdukaan.com", "sm@smartdukaan.com", "mohit.gulati@smartdukaan.com", "chiranjib.sarkar@smartdukaan.com").contains(loginDetails.getEmailId())) {
588
            fofoStore.setGraceDate(LocalDate.now().plusDays(2));
589
            fofoStore.setGraceCount(fofoStore.getGraceCount() + 1);
590
            model.addAttribute("response1", mvcResponseSender.createResponseString(fofoStore.getGraceCount()));
591
        } else {
592
            throw new ProfitMandiBusinessException("Access Denied", "Unauthorised Access",
593
                    "You are not authorise to extend billing");
594
        }
595
        return "response";
25276 amit.gupta 596
 
33990 tejus.loha 597
    }
24124 govind 598
 
33990 tejus.loha 599
    @RequestMapping(value = "/getPromoterInfo", method = RequestMethod.GET)
32887 shampa 600
 
33990 tejus.loha 601
    public String getShowPromoterInfo(HttpServletRequest request,
602
                                      @RequestParam(name = "offset", defaultValue = "0") int offset,
603
                                      @RequestParam(name = "limit", defaultValue = "10") int limit,
604
                                      @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
605
            throws Exception {
606
        //LOGGER.info("requested url : " + request.getRequestURL().toString());
607
        List<Promoter> promoterInfo = null;
608
        long size = 0;
24159 tejbeer 609
 
33990 tejus.loha 610
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId())
611
                .collect(Collectors.toList());
32887 shampa 612
 
33990 tejus.loha 613
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
32887 shampa 614
 
33990 tejus.loha 615
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
616
                .filter(x -> x != null).collect(Collectors.toList()).stream()
617
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
618
        String customRetailers = JSONObject.valueToString(customRetailersMap.values());
619
        Set<String> brands = inventoryService.getAllTagListingBrands(ProfitMandiConstants.MOBILE_CATEGORY_ID);
620
        brands.add("Airtel");
621
        brands.add("Vodafone");
622
        brands.add("Idea");
623
        LOGGER.info("brands" + brands);
624
        model.addAttribute("customRetailers", customRetailers);
625
        model.addAttribute("brands", brands);
32887 shampa 626
 
33990 tejus.loha 627
        if (fofoId != 0) {
628
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, true);
32887 shampa 629
 
33990 tejus.loha 630
            //size = promoterRepository.selectPromoterCount(fofoId);
631
            size = promoterInfo.size();
632
        } else {
633
            //rkb
634
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, true);
32887 shampa 635
 
33990 tejus.loha 636
            //size = promoterRepository.selectAllCount();
637
            size = promoterInfo.size();
638
        }
639
        if (!promoterInfo.isEmpty()) {
640
            Set<Integer> partnerIds = new HashSet<>();
32887 shampa 641
 
33990 tejus.loha 642
            for (Promoter promoterdetail : promoterInfo) {
643
                partnerIds.add(promoterdetail.getRetailerId());
644
            }
645
            Map<Integer, CustomRetailer> partnersMap = null;
646
            if (!partnerIds.equals(null)) {
647
                LOGGER.info("partnerIds" + partnerIds);
32887 shampa 648
 
33990 tejus.loha 649
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
650
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
32887 shampa 651
 
33990 tejus.loha 652
            }
32887 shampa 653
 
33990 tejus.loha 654
            LOGGER.info("partnerIds" + partnersMap);
655
            model.addAttribute("promoterInfo", promoterInfo);
656
            model.addAttribute("partnersMap", partnersMap);
657
            model.addAttribute("start", offset + 1);
658
            model.addAttribute("size", size);
659
            model.addAttribute("url", "/getPaginatedPromoterInfo");
32887 shampa 660
 
33990 tejus.loha 661
            if (promoterInfo.size() < limit) {
662
                model.addAttribute("end", offset + promoterInfo.size());
663
            } else {
664
                model.addAttribute("end", offset + limit);
665
            }
666
        } else {
667
            model.addAttribute("promoterInfo", promoterInfo);
668
            model.addAttribute("size", size);
669
        }
670
        return "promoter-info";
32887 shampa 671
 
33990 tejus.loha 672
    }
32887 shampa 673
 
33990 tejus.loha 674
    @RequestMapping(value = "/getPromoterInactive", method = RequestMethod.GET)
32887 shampa 675
 
33990 tejus.loha 676
    public String getShowPromoterInactiveInfo(HttpServletRequest request,
677
                                              @RequestParam(name = "offset", defaultValue = "0") int offset,
678
                                              @RequestParam(name = "limit", defaultValue = "10") int limit,
679
                                              @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
680
            throws Exception {
681
        //LOGGER.info("requested url : " + request.getRequestURL().toString());
682
        List<Promoter> promoterInfo = null;
683
        long size = 0;
32887 shampa 684
 
33990 tejus.loha 685
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().map(x -> x.getId())
686
                .collect(Collectors.toList());
32887 shampa 687
 
33990 tejus.loha 688
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
27489 tejbeer 689
 
33990 tejus.loha 690
        Map<Integer, CustomRetailer> customRetailersMap = fofoIds.stream().map(x -> customRetailerMap.get(x))
691
                .filter(x -> x != null).collect(Collectors.toList()).stream()
692
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
693
        String customRetailers = JSONObject.valueToString(customRetailersMap.values());
694
        Set<String> brands = inventoryService.getAllTagListingBrands(ProfitMandiConstants.MOBILE_CATEGORY_ID);
695
        brands.add("Airtel");
696
        brands.add("Vodafone");
697
        brands.add("Idea");
698
        LOGGER.info("brands" + brands);
699
        model.addAttribute("customRetailers", customRetailers);
700
        model.addAttribute("brands", brands);
30426 tejbeer 701
 
33990 tejus.loha 702
        if (fofoId != 0) {
703
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, false);
30426 tejbeer 704
 
33990 tejus.loha 705
            //size = promoterRepository.selectPromoterCount(fofoId);
706
            size = promoterInfo.size();
24159 tejbeer 707
 
33990 tejus.loha 708
        } else {
709
            //rkb
710
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, false);
24159 tejbeer 711
 
33990 tejus.loha 712
            //size = promoterRepository.selectAllCount();
713
            size = promoterInfo.size();
27489 tejbeer 714
 
33990 tejus.loha 715
        }
716
        if (!promoterInfo.isEmpty()) {
717
            Set<Integer> partnerIds = new HashSet<>();
27489 tejbeer 718
 
33990 tejus.loha 719
            for (Promoter promoterdetail : promoterInfo) {
720
                partnerIds.add(promoterdetail.getRetailerId());
721
            }
722
            Map<Integer, CustomRetailer> partnersMap = null;
723
            if (!partnerIds.equals(null)) {
724
                LOGGER.info("partnerIds" + partnerIds);
27489 tejbeer 725
 
33990 tejus.loha 726
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
727
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
24159 tejbeer 728
 
33990 tejus.loha 729
            }
30426 tejbeer 730
 
33990 tejus.loha 731
            LOGGER.info("partnerIds" + partnersMap);
732
            model.addAttribute("promoterInfo", promoterInfo);
733
            model.addAttribute("partnersMap", partnersMap);
734
            model.addAttribute("start", offset + 1);
735
            model.addAttribute("size", size);
736
            model.addAttribute("url", "/getPaginatedPromoterInactiveInfo");
30426 tejbeer 737
 
33990 tejus.loha 738
            if (promoterInfo.size() < limit) {
739
                model.addAttribute("end", offset + promoterInfo.size());
740
            } else {
741
                model.addAttribute("end", offset + limit);
742
            }
743
        } else {
744
            model.addAttribute("promoterInfo", promoterInfo);
745
            model.addAttribute("size", size);
746
        }
747
        return "promoter-inactive";
24349 amit.gupta 748
 
33990 tejus.loha 749
    }
24159 tejbeer 750
 
33990 tejus.loha 751
    @RequestMapping(value = "/getPaginatedPromoterInfo", method = RequestMethod.GET)
752
    public String getPaginatedPromoterInfo(HttpServletRequest request,
753
                                           @RequestParam(name = "offset", defaultValue = "0") int offset,
754
                                           @RequestParam(name = "limit", defaultValue = "10") int limit,
755
                                           @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
756
            throws ProfitMandiBusinessException {
757
        LOGGER.info("requested offset=[{}], limit = [{}]", offset, limit);
758
        List<Promoter> promoterInfo = null;
759
        if (fofoId != 0) {
760
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, true);
761
        } else {
762
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, true);
763
        }
764
        LOGGER.info("promoterInfo" + promoterInfo);
765
        if (!promoterInfo.isEmpty()) {
766
            Set<Integer> partnerIds = new HashSet<>();
24159 tejbeer 767
 
33990 tejus.loha 768
            for (Promoter promoterdetail : promoterInfo) {
769
                partnerIds.add(promoterdetail.getRetailerId());
770
            }
771
            Map<Integer, CustomRetailer> partnersMap = null;
772
            if (!partnerIds.equals(null)) {
773
                LOGGER.info("partnerIds" + partnerIds);
24349 amit.gupta 774
 
33990 tejus.loha 775
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
32887 shampa 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("url", "/getPaginatedPromoterInfo");
786
        } else {
787
            model.addAttribute("promoterInfo", promoterInfo);
30426 tejbeer 788
 
33990 tejus.loha 789
        }
30426 tejbeer 790
 
33990 tejus.loha 791
        return "promoter-info-paginated";
792
    }
24349 amit.gupta 793
 
33990 tejus.loha 794
    @RequestMapping(value = "/getPaginatedPromoterInactiveInfo", method = RequestMethod.GET)
795
    public String getPaginatedPromoterInactiveInfo(HttpServletRequest request,
796
                                                   @RequestParam(name = "offset", defaultValue = "0") int offset,
797
                                                   @RequestParam(name = "limit", defaultValue = "10") int limit,
798
                                                   @RequestParam(name = "fofoId", required = false, defaultValue = "0") int fofoId, Model model)
799
            throws ProfitMandiBusinessException {
800
        LOGGER.info("requested offset=[{}], limit = [{}]", offset, limit);
801
        List<Promoter> promoterInfo = null;
802
        if (fofoId != 0) {
803
            promoterInfo = promoterRepository.selectAllPromoterByFofoIdStatus(fofoId, offset, limit, false);
804
        } else {
805
            promoterInfo = promoterRepository.selectAllPromoterStatus(offset, limit, false);
806
        }
807
        LOGGER.info("promoterInfo" + promoterInfo);
808
        if (!promoterInfo.isEmpty()) {
809
            Set<Integer> partnerIds = new HashSet<>();
24159 tejbeer 810
 
33990 tejus.loha 811
            for (Promoter promoterdetail : promoterInfo) {
812
                partnerIds.add(promoterdetail.getRetailerId());
813
            }
814
            Map<Integer, CustomRetailer> partnersMap = null;
815
            if (!partnerIds.equals(null)) {
816
                LOGGER.info("partnerIds" + partnerIds);
24159 tejbeer 817
 
33990 tejus.loha 818
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
24159 tejbeer 819
 
33990 tejus.loha 820
                partnersMap = partnerIds.stream().map(x -> customRetailerMap.get(x)).filter(x -> x != null)
821
                        .collect(Collectors.toList()).stream().collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
32887 shampa 822
 
33990 tejus.loha 823
            }
32887 shampa 824
 
33990 tejus.loha 825
            LOGGER.info("partnerIds" + partnersMap);
826
            model.addAttribute("promoterInfo", promoterInfo);
827
            model.addAttribute("partnersMap", partnersMap);
828
            model.addAttribute("url", "/getPaginatedPromoterInactiveInfo");
829
        } else {
830
            model.addAttribute("promoterInfo", promoterInfo);
32887 shampa 831
 
33990 tejus.loha 832
        }
32887 shampa 833
 
33990 tejus.loha 834
        return "promoter-inactive-info-paginated";
835
    }
32887 shampa 836
 
33990 tejus.loha 837
    @RequestMapping(value = "/createPromoter", method = RequestMethod.POST)
838
    public String createPromoter(HttpServletRequest request, @RequestBody PromoterDetailModel promoterdetailModel,
839
                                 Model model) throws Exception {
840
        LOGGER.info("requested url : " + request.getRequestURL().toString());
841
        LOGGER.info("requested url : " + promoterdetailModel);
842
        Promoter promoter = promoterRepository.selectById(promoterdetailModel.getId());
843
        if (promoter == null) {
844
            promoter = new Promoter();
845
            promoter.setBrand(promoterdetailModel.getBrand());
846
            promoter.setRetailerId(promoterdetailModel.getRetailerId());
847
            promoter.setCreatedTimestamp(LocalDateTime.now());
848
            promoter.setEmail(promoterdetailModel.getEmail());
849
            promoter.setName(promoterdetailModel.getName());
850
            promoter.setMobile(promoterdetailModel.getMobile());
851
            promoter.setSdPortalAccess(promoterdetailModel.isSdPortalAccess());
852
            promoter.setStatus(promoterdetailModel.isStatus());
853
            promoterRepository.persist(promoter);
32887 shampa 854
 
33990 tejus.loha 855
            List<Promoter> promoters = promoterRepository.selectAllByRetailer(promoterdetailModel.getRetailerId());
856
            if (!promoters.isEmpty()) {
857
                FofoStore fs = fofoStoreRepository.selectByRetailerId(promoterdetailModel.getRetailerId());
858
                PartnerOnBoardingPanel pobp = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
859
                if (pobp != null) {
860
                    storeTimelineTatService.promoterComplete(pobp.getId());
861
                }
862
            }
32887 shampa 863
 
33990 tejus.loha 864
        } else {
865
            promoter.setEmail(promoterdetailModel.getEmail());
866
            promoter.setName(promoterdetailModel.getName());
867
            promoter.setMobile(promoterdetailModel.getMobile());
868
            promoter.setSdPortalAccess(promoterdetailModel.isSdPortalAccess());
869
            promoter.setStatus(promoterdetailModel.isStatus());
870
        }
871
        LOGGER.info("sdport" + promoterdetailModel.isStatus());
26131 tejbeer 872
 
33990 tejus.loha 873
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28908 tejbeer 874
 
33990 tejus.loha 875
        return "response";
24159 tejbeer 876
 
33990 tejus.loha 877
    }
24159 tejbeer 878
 
33990 tejus.loha 879
    @RequestMapping(value = "/setPromoterInActive", method = RequestMethod.POST)
880
    public String PromoterInActive(HttpServletRequest request, @RequestParam(name = "id", required = true, defaultValue = "0") int id, Model model) throws Exception {
24159 tejbeer 881
 
33990 tejus.loha 882
        Promoter promoter = promoterRepository.selectById(id);
24159 tejbeer 883
 
33990 tejus.loha 884
        promoter.setStatus(false);
32887 shampa 885
 
33990 tejus.loha 886
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 887
 
33990 tejus.loha 888
        return "response";
889
    }
32887 shampa 890
 
33990 tejus.loha 891
    @RequestMapping(value = "/removePromoterfromPartnerStore", method = RequestMethod.POST)
892
    public String removePromoterfromPartnerStore(HttpServletRequest request,
893
                                                 @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
32887 shampa 894
 
33990 tejus.loha 895
        Promoter promoter = promoterRepository.selectById(id);
896
        promoter.setStatus(false);
897
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 898
 
33990 tejus.loha 899
        return "response";
900
    }
24159 tejbeer 901
 
33990 tejus.loha 902
    @RequestMapping(value = "/activePromoterfromPartnerStore", method = RequestMethod.POST)
903
    public String activePromoterfromPartnerStore(HttpServletRequest request,
904
                                                 @RequestParam(name = "id", defaultValue = "0") int id, Model model) throws Exception {
24159 tejbeer 905
 
33990 tejus.loha 906
        Promoter promoter = promoterRepository.selectById(id);
907
        promoter.setStatus(true);
908
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
32887 shampa 909
 
33990 tejus.loha 910
        return "response";
911
    }
24159 tejbeer 912
 
33990 tejus.loha 913
    @RequestMapping(value = "/addLocation", method = RequestMethod.POST)
914
    public String addLocation(HttpServletRequest request, @RequestBody AddLocationModel addLocationModel, Model model)
915
            throws Exception {
24159 tejbeer 916
 
33990 tejus.loha 917
        Location location = new Location();
918
        location.setName(addLocationModel.getName());
919
        location.setLine1(addLocationModel.getLine1());
920
        location.setLine2(addLocationModel.getLine2());
921
        location.setCity(addLocationModel.getCity());
922
        location.setState(addLocationModel.getState());
923
        location.setPin(addLocationModel.getPin());
24159 tejbeer 924
 
33990 tejus.loha 925
        LOGGER.info("PostLocation" + location);
926
        locationRepository.persist(location);
24159 tejbeer 927
 
33990 tejus.loha 928
        User user = userRepository.selectById(addLocationModel.getUserId());
929
        user.setLocation(location.getId());
930
        userRepository.persist(user);
24159 tejbeer 931
 
33990 tejus.loha 932
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
933
        return "response";
24159 tejbeer 934
 
33990 tejus.loha 935
    }
24159 tejbeer 936
 
33990 tejus.loha 937
    @RequestMapping(value = "/updateLocation", method = RequestMethod.POST)
938
    public String updateLocation(HttpServletRequest request, @RequestBody AddLocationModel addLocationModel,
939
                                 Model model) throws Exception {
24159 tejbeer 940
 
33990 tejus.loha 941
        Location userlocation = locationRepository.selectById(addLocationModel.getUserId());
24159 tejbeer 942
 
33990 tejus.loha 943
        userlocation.setName(addLocationModel.getName());
944
        userlocation.setCity(addLocationModel.getCity());
945
        userlocation.setLine1(addLocationModel.getLine1());
946
        userlocation.setLine2(addLocationModel.getLine2());
947
        userlocation.setPin(addLocationModel.getPin());
948
        userlocation.setState(addLocationModel.getState());
24159 tejbeer 949
 
33990 tejus.loha 950
        locationRepository.persist(userlocation);
24159 tejbeer 951
 
33990 tejus.loha 952
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
953
        return "response";
24159 tejbeer 954
 
33990 tejus.loha 955
    }
24159 tejbeer 956
 
33990 tejus.loha 957
    @RequestMapping(value = "/getPartnerReadonlyInfo")
958
    public String getPartnerReadonlyInfo(HttpServletRequest request, Model model) throws Exception {
24159 tejbeer 959
 
33990 tejus.loha 960
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
961
        AuthUser authUser = authRepository.selectByEmailOrMobile(loginDetails.getEmailId());
27231 tejbeer 962
 
33990 tejus.loha 963
        Map<Integer, List<Integer>> pp = csService.getAuthUserIdPartnerIdMapping();
27231 tejbeer 964
 
35452 amit 965
        List<Integer> fofoIds = pp.get(authUser.getId());
27231 tejbeer 966
 
35452 amit 967
        Map<Integer, CustomRetailer> customRetailersMap = retailerService.getFofoRetailers(fofoIds);
27231 tejbeer 968
 
33990 tejus.loha 969
        model.addAttribute("customRetailersMap", customRetailersMap);
27231 tejbeer 970
 
33990 tejus.loha 971
        return "partner-readonly-info";
27243 tejbeer 972
 
33990 tejus.loha 973
    }
27231 tejbeer 974
 
33990 tejus.loha 975
    @RequestMapping(value = "/getBlockBrandMapping")
976
    public String getBlockBrandMapping(HttpServletRequest request, Model model) throws Exception {
27231 tejbeer 977
 
33990 tejus.loha 978
        int fofoId = Utils.SYSTEM_PARTNER_ID;
35236 amit 979
        Set<String> brands = brandsService.getBrands(fofoId, null, 3).stream().map(x -> x.getName()).collect(Collectors.toSet());
28071 tejbeer 980
 
33990 tejus.loha 981
        LOGGER.info("brands" + brands);
982
        model.addAttribute("brands", brands);
28071 tejbeer 983
 
33990 tejus.loha 984
        return "block-brand-mapping";
28071 tejbeer 985
 
33990 tejus.loha 986
    }
28071 tejbeer 987
 
33990 tejus.loha 988
    @RequestMapping(value = "/getBlockBrand")
989
    public String getBlockBrand(HttpServletRequest request,
990
                                @RequestParam(name = "brand", required = true, defaultValue = "0") String brand, Model model)
991
            throws Exception {
28071 tejbeer 992
 
33990 tejus.loha 993
        List<RetailerBlockBrands> retailerBlockBrands = retailerBlockBrandsRepository.selectAllByBrands(brand);
28071 tejbeer 994
 
33990 tejus.loha 995
        List<Integer> blockBrandPartners = retailerBlockBrands.stream().map(x -> x.getFofoId())
996
                .collect(Collectors.toList());
997
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
28071 tejbeer 998
 
33990 tejus.loha 999
        LOGGER.info("retailerBlockBrands" + retailerBlockBrands);
1000
        model.addAttribute("blockBrandPartners", blockBrandPartners);
1001
        model.addAttribute("retailerBlockBrands", retailerBlockBrands);
1002
        model.addAttribute("customRetailers", customRetailers);
28272 tejbeer 1003
 
33990 tejus.loha 1004
        return "retailer-block-brand";
28071 tejbeer 1005
 
33990 tejus.loha 1006
    }
28071 tejbeer 1007
 
33990 tejus.loha 1008
    @RequestMapping(value = "/getRetailerBlockBrandMappping", method = RequestMethod.POST)
1009
    public String getBlockBrandMappping(HttpServletRequest request,
1010
                                        @RequestParam(name = "brand", required = true, defaultValue = "0") String brand,
1011
                                        @RequestParam(name = "fofoIds", required = true, defaultValue = "0") List<Integer> fofoIds, Model model)
1012
            throws Exception {
1013
        List<RetailerBlockBrands> retailerBlockBrands = retailerBlockBrandsRepository.selectAllByBrands(brand);
1014
        if (!retailerBlockBrands.isEmpty()) {
1015
            retailerBlockBrandsRepository.deleteAllbyBrands(brand);
1016
        }
28071 tejbeer 1017
 
33990 tejus.loha 1018
        for (int id : fofoIds) {
1019
            RetailerBlockBrands retailerBlockBrand = new RetailerBlockBrands();
1020
            retailerBlockBrand.setFofoId(id);
1021
            retailerBlockBrand.setBlockBrands(brand);
1022
            retailerBlockBrandsRepository.persist(retailerBlockBrand);
28071 tejbeer 1023
 
33990 tejus.loha 1024
        }
1025
        model.addAttribute("response1", mvcResponseSender.createResponseString(true));
28071 tejbeer 1026
 
33990 tejus.loha 1027
        return "response";
1028
    }
28071 tejbeer 1029
 
33990 tejus.loha 1030
    @RequestMapping(value = "/getBrandslimit", method = RequestMethod.GET)
1031
    public String getBrandslimit(HttpServletRequest request, Model model) throws Exception {
28071 tejbeer 1032
 
33990 tejus.loha 1033
        int fofoId = Utils.SYSTEM_PARTNER_ID;
32731 ranu 1034
 
33990 tejus.loha 1035
        List<String> brands = brandsService.getBrandsToDisplay(3).stream().map(x -> x.getName()).collect(Collectors.toList());
1036
        model.addAttribute("brands", brands);
28272 tejbeer 1037
 
33990 tejus.loha 1038
        return "brands-limit";
28272 tejbeer 1039
 
33990 tejus.loha 1040
    }
28272 tejbeer 1041
 
33990 tejus.loha 1042
    @RequestMapping(value = "/setUpdateLimit", method = RequestMethod.POST)
1043
    public String getUpdateLimit(HttpServletRequest request,
1044
                                 @RequestParam(name = "brand", required = true, defaultValue = "0") String brand,
1045
                                 @RequestParam(name = "fofoId", required = true, defaultValue = "0") int fofoId,
1046
                                 @RequestParam(name = "limit", required = true, defaultValue = "0") float limit,
1047
                                 @RequestParam(name = "minStockLimit", required = true, defaultValue = "0") float minStockLimit,
1048
                                 @RequestParam(name = "preLimit", required = true, defaultValue = "0") float preLimit,
1049
                                 @RequestParam(name = "preStockLimit", required = true, defaultValue = "0") float preStockLimit, Model model)
1050
            throws Exception {
28272 tejbeer 1051
 
33990 tejus.loha 1052
        CustomRetailer cr = retailerService.getFofoRetailer(fofoId);
28272 tejbeer 1053
 
33990 tejus.loha 1054
        Map.Entry<Integer, CustomRetailer> customRetailers = new AbstractMap.SimpleEntry(cr.getPartnerId(), cr);
28272 tejbeer 1055
 
33990 tejus.loha 1056
        // Map<Integer, CustomRetailer> customRetailers =
1057
        // retailerService.getFofoRetailers(true);
28277 tejbeer 1058
 
33990 tejus.loha 1059
        RetailerBrandsLimit retailerBrands = retailerBrandsLimitRepository.selectLimitByBrandAndFofoId(fofoId, brand);
28277 tejbeer 1060
 
33990 tejus.loha 1061
        if (retailerBrands == null) {
1062
            retailerBrands = new RetailerBrandsLimit();
1063
            retailerBrands.setMinStockLimit(minStockLimit);
1064
            retailerBrands.setBrandLimit(limit);
1065
            retailerBrands.setIsUpdate(1);
1066
            retailerBrands.setCreatedTimestamp(LocalDateTime.now());
1067
            retailerBrands.setPartnerId(fofoId);
1068
            retailerBrands.setBrandName(brand);
1069
            retailerBrands.setUpdatedTimestamp(LocalDateTime.now());
1070
            retailerBrandsLimitRepository.persist(retailerBrands);
1071
        } else {
1072
            retailerBrands.setMinStockLimit(minStockLimit);
1073
            retailerBrands.setBrandLimit(limit);
1074
            retailerBrands.setIsUpdate(1);
1075
            retailerBrands.setUpdatedTimestamp(LocalDateTime.now());
1076
            retailerBrandsLimitRepository.persist(retailerBrands);
30028 manish 1077
 
33990 tejus.loha 1078
        }
1079
        retailerBrands = retailerBrandsLimitRepository.selectLimitByBrandAndFofoId(fofoId, brand);
28277 tejbeer 1080
 
33990 tejus.loha 1081
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = new HashMap<>();
28272 tejbeer 1082
 
33990 tejus.loha 1083
        retailerBrandsLimitMap.put(retailerBrands.getPartnerId(), retailerBrands);
28272 tejbeer 1084
 
33990 tejus.loha 1085
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brand);
28272 tejbeer 1086
 
33990 tejus.loha 1087
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1088
        model.addAttribute("brandLimit", brandLimit);
1089
        model.addAttribute("customRetailers", customRetailers);
28272 tejbeer 1090
 
33990 tejus.loha 1091
        model.addAttribute("brand", brand);
1092
        return "brands-limit-row-mapping";
28272 tejbeer 1093
 
33990 tejus.loha 1094
    }
28277 tejbeer 1095
 
33990 tejus.loha 1096
    @RequestMapping(value = "/getRetailerBrandslimitMapping", method = RequestMethod.GET)
1097
    public String getRetailerBrandslimit(HttpServletRequest request,
1098
                                         @RequestParam(name = "brand", required = true, defaultValue = "0") String brand, Model model)
1099
            throws Exception {
28272 tejbeer 1100
 
33990 tejus.loha 1101
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
1102
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brand);
1103
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1104
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
28272 tejbeer 1105
 
33990 tejus.loha 1106
        model.addAttribute("customRetailers", customRetailers);
1107
        model.addAttribute("brand", brand);
1108
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
28272 tejbeer 1109
 
33990 tejus.loha 1110
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brand);
28272 tejbeer 1111
 
33990 tejus.loha 1112
        model.addAttribute("brandLimit", brandLimit);
28272 tejbeer 1113
 
33990 tejus.loha 1114
        return "brands-limit-mapping";
28272 tejbeer 1115
 
33990 tejus.loha 1116
    }
28272 tejbeer 1117
 
33990 tejus.loha 1118
    @RequestMapping(value = "/setBrandWiseLimit", method = RequestMethod.POST)
1119
    public String brandwiseLimit(HttpServletRequest request,
1120
                                 @RequestParam(name = "brands", required = true, defaultValue = "") String brands,
1121
                                 @RequestParam(name = "limit", required = true, defaultValue = "") float limit, Model model)
1122
            throws Exception {
28272 tejbeer 1123
 
33990 tejus.loha 1124
        LOGGER.info("limit" + limit);
30426 tejbeer 1125
 
33990 tejus.loha 1126
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brands);
28272 tejbeer 1127
 
33990 tejus.loha 1128
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brands);
28272 tejbeer 1129
 
33990 tejus.loha 1130
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1131
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
28272 tejbeer 1132
 
33990 tejus.loha 1133
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
28272 tejbeer 1134
 
33990 tejus.loha 1135
        if (brandLimit == null) {
28272 tejbeer 1136
 
33990 tejus.loha 1137
            brandLimit = new BrandLimit();
1138
            brandLimit.setBrandLimit(limit);
1139
            brandLimit.setBrandName(brands);
1140
            brandLimit.setCreatedTimestamp(LocalDateTime.now());
1141
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1142
            brandLimitRepository.persist(brandLimit);
28272 tejbeer 1143
 
33990 tejus.loha 1144
        } else {
1145
            brandLimit.setBrandLimit(limit);
28272 tejbeer 1146
 
33990 tejus.loha 1147
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1148
            brandLimitRepository.persist(brandLimit);
28272 tejbeer 1149
 
33990 tejus.loha 1150
        }
1151
        brandLimit = brandLimitRepository.setLimitByBrands(brands);
30028 manish 1152
 
33990 tejus.loha 1153
        LOGGER.info("brandLimit" + brandLimit);
1154
        model.addAttribute("brand", brands);
1155
        model.addAttribute("brandLimit", brandLimit);
1156
        model.addAttribute("customRetailers", customRetailers);
1157
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1158
        return "brands-limit-mapping";
28272 tejbeer 1159
 
33990 tejus.loha 1160
    }
28272 tejbeer 1161
 
33990 tejus.loha 1162
    @RequestMapping(value = "/setBrandWiseStockLimit", method = RequestMethod.POST)
1163
    public String setBrandWiseStockLimit(HttpServletRequest request,
1164
                                         @RequestParam(name = "brands", required = true, defaultValue = "") String brands,
1165
                                         @RequestParam(name = "stockLimit", required = true, defaultValue = "") float stockLimit, Model model)
1166
            throws Exception {
28272 tejbeer 1167
 
33990 tejus.loha 1168
        LOGGER.info("limit" + stockLimit);
28272 tejbeer 1169
 
33990 tejus.loha 1170
        BrandLimit brandLimit = brandLimitRepository.setLimitByBrands(brands);
28825 tejbeer 1171
 
33990 tejus.loha 1172
        List<RetailerBrandsLimit> retailerBrandsLimit = retailerBrandsLimitRepository.setAllLimitByBrand(brands);
30028 manish 1173
 
33990 tejus.loha 1174
        Map<Integer, RetailerBrandsLimit> retailerBrandsLimitMap = retailerBrandsLimit.stream()
1175
                .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
30028 manish 1176
 
33990 tejus.loha 1177
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
30028 manish 1178
 
33990 tejus.loha 1179
        if (brandLimit == null) {
30028 manish 1180
 
33990 tejus.loha 1181
            brandLimit = new BrandLimit();
1182
            brandLimit.setBrandLimit(0);
1183
            brandLimit.setBrandName(brands);
1184
            brandLimit.setStockLimit(stockLimit);
1185
            brandLimit.setCreatedTimestamp(LocalDateTime.now());
1186
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1187
            brandLimitRepository.persist(brandLimit);
30028 manish 1188
 
33990 tejus.loha 1189
        } else {
1190
            brandLimit.setStockLimit(stockLimit);
30028 manish 1191
 
33990 tejus.loha 1192
            brandLimit.setUpdatedTimestamp(LocalDateTime.now());
1193
            brandLimitRepository.persist(brandLimit);
30028 manish 1194
 
33990 tejus.loha 1195
        }
1196
        brandLimit = brandLimitRepository.setLimitByBrands(brands);
30028 manish 1197
 
33990 tejus.loha 1198
        model.addAttribute("brand", brands);
1199
        model.addAttribute("brandLimit", brandLimit);
1200
        model.addAttribute("customRetailers", customRetailers);
1201
        model.addAttribute("retailerBrandsLimitMap", retailerBrandsLimitMap);
1202
        return "brands-limit-mapping";
30028 manish 1203
 
33990 tejus.loha 1204
    }
30028 manish 1205
 
33990 tejus.loha 1206
    @RequestMapping(value = "/setPartnerPincode", method = RequestMethod.POST)
1207
    public String setPartnerPincode(HttpServletRequest request,
1208
                                    @RequestParam(name = "pincode", required = true, defaultValue = "") String pincode,
1209
                                    @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1210
            throws Exception {
30028 manish 1211
 
33990 tejus.loha 1212
        if (!pincode.equals("")) {
1213
            PincodePartner pinPartner = new PincodePartner();
1214
            pinPartner.setFofoId(fofoId);
1215
            pinPartner.setPincode(pincode);
1216
            pincodePartnerRepository.perist(pinPartner);
1217
        }
30028 manish 1218
 
33990 tejus.loha 1219
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(fofoId);
30028 manish 1220
 
33990 tejus.loha 1221
        LOGGER.info("partnerPincodeList" + partnerPincodeList);
30028 manish 1222
 
33990 tejus.loha 1223
        model.addAttribute("partnerPincodeList", partnerPincodeList);
1224
        return "pincode-partner-index";
28272 tejbeer 1225
 
33990 tejus.loha 1226
    }
28381 tejbeer 1227
 
33990 tejus.loha 1228
    @RequestMapping(value = "/removePartnerPincode", method = RequestMethod.POST)
1229
    public String removePartnerPincode(HttpServletRequest request, @RequestParam int id,
1230
                                       @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1231
            throws Exception {
28825 tejbeer 1232
 
33990 tejus.loha 1233
        pincodePartnerRepository.delete(id);
28825 tejbeer 1234
 
33990 tejus.loha 1235
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(fofoId);
28381 tejbeer 1236
 
33990 tejus.loha 1237
        LOGGER.info("partnerPincodeList" + partnerPincodeList);
28825 tejbeer 1238
 
33990 tejus.loha 1239
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1240
 
33990 tejus.loha 1241
        return "pincode-partner-index";
28381 tejbeer 1242
 
33990 tejus.loha 1243
    }
28825 tejbeer 1244
 
33990 tejus.loha 1245
    @RequestMapping(value = "/removeSearchPincode", method = RequestMethod.POST)
1246
    public String removeSearchPincode(HttpServletRequest request, @RequestParam int id,
1247
                                      @RequestParam(name = "pin", required = true, defaultValue = "") String pin,
1248
                                      @RequestParam(name = "fofoId", required = true, defaultValue = "") int fofoId, Model model)
1249
            throws Exception {
28825 tejbeer 1250
 
33990 tejus.loha 1251
        pincodePartnerRepository.delete(id);
28825 tejbeer 1252
 
33990 tejus.loha 1253
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectPartnersByPincode(pin);
28381 tejbeer 1254
 
33990 tejus.loha 1255
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
28825 tejbeer 1256
 
33990 tejus.loha 1257
        model.addAttribute("customRetailerMap", customRetailerMap);
28381 tejbeer 1258
 
33990 tejus.loha 1259
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1260
 
33990 tejus.loha 1261
        return "search-pincode-partner";
28381 tejbeer 1262
 
33990 tejus.loha 1263
    }
28825 tejbeer 1264
 
33990 tejus.loha 1265
    @RequestMapping(value = "/searchPincodePartner", method = RequestMethod.GET)
1266
    public String searchPincodePartner(HttpServletRequest request,
1267
                                       @RequestParam(name = "pincode", required = true, defaultValue = "") String pincode, Model model)
1268
            throws Exception {
28825 tejbeer 1269
 
33990 tejus.loha 1270
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectPartnersByPincode(pincode);
28825 tejbeer 1271
 
33990 tejus.loha 1272
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
28381 tejbeer 1273
 
33990 tejus.loha 1274
        model.addAttribute("customRetailerMap", customRetailerMap);
28825 tejbeer 1275
 
33990 tejus.loha 1276
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28381 tejbeer 1277
 
33990 tejus.loha 1278
        return "search-pincode-partner";
28825 tejbeer 1279
 
33990 tejus.loha 1280
    }
28381 tejbeer 1281
 
33990 tejus.loha 1282
    @RequestMapping(value = "/showPartnerPincode", method = RequestMethod.GET)
1283
    public String showPartnerPincode(HttpServletRequest request,
1284
                                     @RequestParam(name = "partnerId", required = true, defaultValue = "") int partnerId, Model model)
1285
            throws Exception {
28825 tejbeer 1286
 
33990 tejus.loha 1287
        List<PincodePartner> partnerPincodeList = pincodePartnerRepository.selectByPartnerId(partnerId);
28825 tejbeer 1288
 
33990 tejus.loha 1289
        model.addAttribute("partnerPincodeList", partnerPincodeList);
28825 tejbeer 1290
 
33990 tejus.loha 1291
        return "pincode-partner-index";
28825 tejbeer 1292
 
33990 tejus.loha 1293
    }
28381 tejbeer 1294
 
33990 tejus.loha 1295
    @RequestMapping(value = "/getAllPartnerPincode", method = RequestMethod.GET)
1296
    public String getAllPartnerPincode(HttpServletRequest request, Model model) throws Exception {
1297
        return "add-partner-pincode";
1298
    }
28825 tejbeer 1299
 
33990 tejus.loha 1300
    @RequestMapping(value = "/alternateRetailerContacts", method = RequestMethod.GET)
1301
    public String alternateRetailerContacts(HttpServletRequest request, Model model) throws Exception {
1302
        LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
1303
        boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
28825 tejbeer 1304
 
33990 tejus.loha 1305
        model.addAttribute("isAdmin", isAdmin);
35648 ranu 1306
        model.addAttribute("brands", brandsRepository.selectAll());
33990 tejus.loha 1307
        return "retailer-contacts";
1308
    }
28825 tejbeer 1309
 
33990 tejus.loha 1310
    @RequestMapping(value = "/retailer-contact-list", method = RequestMethod.GET)
1311
    public String getRetailerContactList(HttpServletRequest request, Model model, @RequestParam(defaultValue = "0") int fofoId)
1312
            throws Exception {
28825 tejbeer 1313
 
33990 tejus.loha 1314
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
32629 amit.gupta 1315
 
33990 tejus.loha 1316
        model.addAttribute("retailerContacts", retailerContacts);
35648 ranu 1317
        model.addAttribute("brands", brandsRepository.selectAll());
32667 raveendra. 1318
 
33990 tejus.loha 1319
        return "retailer-contact-list";
33814 ranu 1320
 
33990 tejus.loha 1321
    }
33814 ranu 1322
 
33990 tejus.loha 1323
    @RequestMapping(value = "/add-retailer-contact-list", method = RequestMethod.GET)
1324
    public String updateRetailerContactList(HttpServletRequest request, Model model,
1325
                                            @RequestParam(defaultValue = "0") int fofoId,
1326
                                            @RequestParam String contactName,
35648 ranu 1327
                                            @RequestParam String contactNumber,
1328
                                            @RequestParam String brandName,
1329
                                            @RequestParam String contactType) throws Exception {
33990 tejus.loha 1330
        RetailerContact retailerContact = new RetailerContact();
1331
        retailerContact.setFofoId(fofoId);
1332
        retailerContact.setName(contactName);
1333
        retailerContact.setMobile(contactNumber);
35648 ranu 1334
        retailerContact.setBrandName(brandName);
1335
        retailerContact.setContactType(contactType);
33990 tejus.loha 1336
        retailerContact.setActive(true);
1337
        retailerContact.setCreatedAt(LocalDateTime.now());
1338
        retailerContactRepository.persist(retailerContact);
33814 ranu 1339
 
33990 tejus.loha 1340
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
33814 ranu 1341
 
33990 tejus.loha 1342
        model.addAttribute("retailerContacts", retailerContacts);
35648 ranu 1343
        model.addAttribute("brands", brandsRepository.selectAll());
33814 ranu 1344
 
33990 tejus.loha 1345
        return "retailer-contact-list";
33814 ranu 1346
 
33990 tejus.loha 1347
    }
33814 ranu 1348
 
33990 tejus.loha 1349
    @RequestMapping(value = "/update-contact-status", method = RequestMethod.GET)
1350
    public String updateRetailerContactStatus(HttpServletRequest request, Model model,
1351
                                              @RequestParam(defaultValue = "0") int fofoId,
1352
                                              @RequestParam(defaultValue = "0") int contactId,
1353
                                              @RequestParam boolean active) throws Exception {
33814 ranu 1354
 
33990 tejus.loha 1355
        RetailerContact retailerContact = retailerContactRepository.selectById(contactId);
1356
        retailerContact.setActive(active);
33814 ranu 1357
 
33990 tejus.loha 1358
        List<RetailerContact> retailerContacts = retailerContactRepository.selectAllByRetailerId(fofoId);
33814 ranu 1359
 
33990 tejus.loha 1360
        model.addAttribute("retailerContacts", retailerContacts);
33814 ranu 1361
 
33990 tejus.loha 1362
        return "retailer-contact-list";
33814 ranu 1363
 
33990 tejus.loha 1364
    }
33814 ranu 1365
 
1366
 
28272 tejbeer 1367
}