Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
25899 tejbeer 1
package com.spice.profitmandi.web.controller;
2
 
32978 amit.gupta 3
import com.mongodb.DBObject;
31677 amit.gupta 4
import com.spice.profitmandi.common.enumuration.ActivationType;
31249 tejbeer 5
import com.spice.profitmandi.common.enumuration.MessageType;
25899 tejbeer 6
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
25952 tejbeer 7
import com.spice.profitmandi.common.model.CustomRetailer;
27117 tejbeer 8
import com.spice.profitmandi.common.model.ProfitMandiConstants;
31249 tejbeer 9
import com.spice.profitmandi.common.model.SendNotificationModel;
30433 tejbeer 10
import com.spice.profitmandi.common.util.FileUtil;
25899 tejbeer 11
import com.spice.profitmandi.common.web.util.ResponseSender;
12
import com.spice.profitmandi.dao.entity.auth.AuthUser;
30077 tejbeer 13
import com.spice.profitmandi.dao.entity.auth.PartnerCollectionPlan;
30416 tejbeer 14
import com.spice.profitmandi.dao.entity.auth.PartnerCollectionRemark;
30077 tejbeer 15
import com.spice.profitmandi.dao.entity.auth.PartnerSecondaryPlan;
32978 amit.gupta 16
import com.spice.profitmandi.dao.entity.cs.Position;
25899 tejbeer 17
import com.spice.profitmandi.dao.entity.dtr.User;
25952 tejbeer 18
import com.spice.profitmandi.dao.entity.dtr.UserAccount;
34322 ranu 19
import com.spice.profitmandi.dao.entity.fofo.*;
32978 amit.gupta 20
import com.spice.profitmandi.dao.entity.user.*;
30416 tejbeer 21
import com.spice.profitmandi.dao.enumuration.auth.CollectionRemark;
32978 amit.gupta 22
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
23
import com.spice.profitmandi.dao.enumuration.dtr.*;
24
import com.spice.profitmandi.dao.model.*;
25
import com.spice.profitmandi.dao.repository.auth.*;
26
import com.spice.profitmandi.dao.repository.cs.*;
27
import com.spice.profitmandi.dao.repository.dtr.*;
30087 tejbeer 28
import com.spice.profitmandi.dao.repository.fofo.PartnerDailyInvestmentRepository;
35075 aman 29
import com.spice.profitmandi.dao.repository.fofo.PurchaseRepository;
34301 ranu 30
import com.spice.profitmandi.dao.repository.fofo.RbmRatingRepository;
34322 ranu 31
import com.spice.profitmandi.dao.repository.fofo.SalesRatingRepository;
30077 tejbeer 32
import com.spice.profitmandi.dao.repository.transaction.OrderRepository;
32978 amit.gupta 33
import com.spice.profitmandi.dao.repository.user.AddressRepository;
31249 tejbeer 34
import com.spice.profitmandi.service.AuthService;
35
import com.spice.profitmandi.service.NotificationService;
30348 tejbeer 36
import com.spice.profitmandi.service.PartnerCollectionService;
25952 tejbeer 37
import com.spice.profitmandi.service.user.RetailerService;
28935 tejbeer 38
import com.spice.profitmandi.service.user.StoreTimelineTatService;
25952 tejbeer 39
import com.spice.profitmandi.web.req.CreateFranchiseeRequest;
34322 ranu 40
import com.spice.profitmandi.web.req.RbmSalesRatingRequest;
25952 tejbeer 41
import com.spice.profitmandi.web.res.Partner;
25899 tejbeer 42
import io.swagger.annotations.ApiImplicitParam;
43
import io.swagger.annotations.ApiImplicitParams;
32978 amit.gupta 44
import org.apache.commons.csv.CSVRecord;
45
import org.apache.commons.io.output.ByteArrayOutputStream;
46
import org.apache.logging.log4j.LogManager;
47
import org.apache.logging.log4j.Logger;
48
import org.springframework.beans.factory.annotation.Autowired;
49
import org.springframework.format.annotation.DateTimeFormat;
50
import org.springframework.http.HttpHeaders;
51
import org.springframework.http.HttpStatus;
52
import org.springframework.http.MediaType;
53
import org.springframework.http.ResponseEntity;
54
import org.springframework.mail.javamail.JavaMailSender;
55
import org.springframework.stereotype.Controller;
56
import org.springframework.transaction.annotation.Transactional;
57
import org.springframework.ui.Model;
58
import org.springframework.web.bind.annotation.*;
59
import org.springframework.web.multipart.MultipartFile;
25899 tejbeer 60
 
32978 amit.gupta 61
import javax.servlet.http.HttpServletRequest;
62
import java.io.IOException;
63
import java.time.LocalDate;
64
import java.time.LocalDateTime;
34301 ranu 65
import java.time.YearMonth;
32978 amit.gupta 66
import java.time.format.DateTimeFormatter;
67
import java.util.*;
35415 amit 68
import java.util.HashSet;
32978 amit.gupta 69
import java.util.Map.Entry;
70
import java.util.stream.Collectors;
71
 
25899 tejbeer 72
@Controller
73
@Transactional(rollbackFor = Throwable.class)
74
public class LeadController {
31677 amit.gupta 75
    private static final Logger LOGGER = LogManager.getLogger(LeadController.class);
76
    @Autowired
77
    private ResponseSender<?> responseSender;
25899 tejbeer 78
 
31677 amit.gupta 79
    @Autowired
80
    private AuthRepository authRepository;
25899 tejbeer 81
 
31677 amit.gupta 82
    @Autowired
83
    private LeadRepository leadRepository;
25899 tejbeer 84
 
31677 amit.gupta 85
    @Autowired
32923 ranu 86
    DocumentRepository documentRepository;
87
 
88
    @Autowired
89
    PositionRepository positionRepository;
90
 
91
    @Autowired
92
    private ActivityAttachmentRepository activityAttachmentRepository;
93
 
94
    @Autowired
31677 amit.gupta 95
    private CsService csService;
25952 tejbeer 96
 
31677 amit.gupta 97
    @Autowired
98
    private UserRepository userRepository;
25952 tejbeer 99
 
31677 amit.gupta 100
    @Autowired
32923 ranu 101
    private AddressRepository addressRepository;
102
 
103
    @Autowired
104
 
105
    private UserRoleRepository userRoleRepository;
106
 
107
    @Autowired
31677 amit.gupta 108
    private UserAccountRepository userAccountRepository;
25952 tejbeer 109
 
31677 amit.gupta 110
    @Autowired
111
    private com.spice.profitmandi.dao.repository.user.UserRepository userUserRepository;
25952 tejbeer 112
 
31677 amit.gupta 113
    @Autowired
114
    private RetailerService retailerService;
25952 tejbeer 115
 
31677 amit.gupta 116
    @Autowired
117
    private LeadActivityRepository leadActivityRepository;
25899 tejbeer 118
 
31677 amit.gupta 119
    @Autowired
120
    private FranchiseeVisitRepository franchiseeVisitRepository;
25952 tejbeer 121
 
31677 amit.gupta 122
    @Autowired
123
    private FranchiseeActivityRepository franchiseeActivityRepository;
25952 tejbeer 124
 
31677 amit.gupta 125
    @Autowired
126
    private PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
28935 tejbeer 127
 
31677 amit.gupta 128
    @Autowired
129
    private FofoStoreRepository fofoStoreRepository;
28935 tejbeer 130
 
31677 amit.gupta 131
    @Autowired
132
    private StoreTimelineTatService storeTimelineTatService;
28935 tejbeer 133
 
31677 amit.gupta 134
    @Autowired
135
    private PartnerCollectionService partnerCollectionService;
30348 tejbeer 136
 
31677 amit.gupta 137
    @Autowired
138
    private TicketRepository ticketRepository;
30416 tejbeer 139
 
31677 amit.gupta 140
    @Autowired
141
    private TicketCategoryRepository ticketCategoryRepository;
30416 tejbeer 142
 
31677 amit.gupta 143
    @Autowired
144
    private TicketSubCategoryRepository ticketSubCategoryRepository;
30416 tejbeer 145
 
31677 amit.gupta 146
    @Autowired
147
    private PartnerCollectionRemarkRepository partnerCollectionRemarkRepository;
30416 tejbeer 148
 
31677 amit.gupta 149
    @Autowired
150
    private Mongo mongoClient;
30487 tejbeer 151
 
31677 amit.gupta 152
    @Autowired
153
    private OrderRepository orderRepository;
30487 tejbeer 154
 
31677 amit.gupta 155
    @Autowired
156
    private PartnerCollectionPlanRepository partnerCollectionPlanRepository;
30487 tejbeer 157
 
31677 amit.gupta 158
    @Autowired
159
    private PartnerSecondaryPlanRepository partnerSecondaryPlanRepository;
30487 tejbeer 160
 
31677 amit.gupta 161
    @Autowired
162
    private PartnerDailyInvestmentRepository partnerDailyInvestmentRepository;
30487 tejbeer 163
 
31677 amit.gupta 164
    @Autowired
165
    private AuthUserPartnerMappingRepository authUserPartnerMappingRepository;
30487 tejbeer 166
 
31677 amit.gupta 167
    @Autowired
168
    private VisitRequestRepository visitRequestRepository;
31249 tejbeer 169
 
31677 amit.gupta 170
    @Autowired
171
    private AuthService authService;
31249 tejbeer 172
 
31677 amit.gupta 173
    @Autowired
174
    private NotificationService notificationService;
31249 tejbeer 175
 
32923 ranu 176
    @Autowired
177
    JavaMailSender mailSender;
178
 
179
    @Autowired
180
    private TicketAssignedRepository ticketAssignedRepository;
181
 
34124 tejus.loha 182
    @Autowired
183
    LeadDetailRepository leadDetailRepository;
184
 
35075 aman 185
    @Autowired
186
    PurchaseRepository purchaseRepository;
187
 
31677 amit.gupta 188
    @RequestMapping(value = "/lead", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
189
    @ApiImplicitParams({
190
            @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
34118 tejus.loha 191
 
192
    public ResponseEntity<?> LeadUser(@RequestBody CreateRefferalRequest createRefferalRequest) throws Exception {
35079 vikas 193
        LOGGER.info("CreateReferralRequest - " + createRefferalRequest);
34394 tejus.loha 194
        if (createRefferalRequest.getOutletName() == null || createRefferalRequest.getPotential() == 0) {
35079 vikas 195
            throw new Exception("Outlet should not be empty and potential should be greater > 0");
34386 ranu 196
        }
35288 amit 197
        Lead lead;
198
        AuthUser authUser = authRepository.selectByGmailId(createRefferalRequest.getReffereeEmail());
199
        if (createRefferalRequest.getId() > 0) {
200
            lead = leadRepository.selectById(createRefferalRequest.getId());
201
            lead.setAssignTo(authUser.getId());
31677 amit.gupta 202
        } else {
35288 amit 203
            lead = new Lead();
204
            lead.setFirstName(createRefferalRequest.getFirstName());
205
            lead.setLastName(createRefferalRequest.getLastName());
206
            lead.setLeadMobile(createRefferalRequest.getMobile());
207
            lead.setState(createRefferalRequest.getState());
208
            lead.setCity(createRefferalRequest.getCity());
209
            lead.setAddress(createRefferalRequest.getAddress());
210
            lead.setCreatedTimestamp(LocalDateTime.now());
211
            lead.setOutLetName(createRefferalRequest.getOutletName());
212
            lead.setUpdatedTimestamp(LocalDateTime.now());
213
            lead.setStatus(createRefferalRequest.getStatus());
214
            lead.setSource(createRefferalRequest.getSource());
215
            lead.setNotinterestedReason(createRefferalRequest.getReason());
216
            lead.setPotential(createRefferalRequest.getPotential());
217
            if (createRefferalRequest.getColorCheck() == true) {
218
                lead.setColor("Green");
219
            } else {
220
                lead.setColor("Yellow");
221
            }
222
            String authUserName = authUser.getFullName();
223
            lead.setAuthId(authUser.getId());
224
            lead.setAssignTo(authUser.getId());
35079 vikas 225
            lead.setCreatedBy(authUserName);
226
            leadRepository.persist(lead);
35288 amit 227
 
35079 vikas 228
        }
34118 tejus.loha 229
 
31677 amit.gupta 230
        LeadActivity leadActivity = new LeadActivity();
231
        leadActivity.setLeadId(lead.getId());
35288 amit 232
        leadActivity.setRemark((createRefferalRequest.getId() > 0 ? "Self Assigned." : "") + createRefferalRequest.getRemark());
31677 amit.gupta 233
        leadActivity.setAuthId(authUser.getId());
31249 tejbeer 234
 
31677 amit.gupta 235
        if (createRefferalRequest.getStatus().equals(LeadStatus.followUp)) {
236
            leadActivity.setSchelduleTimestamp(createRefferalRequest.getSchelduleTimestamp());
237
            leadActivity.setCommunicationType(createRefferalRequest.getCommunicationType());
31249 tejbeer 238
 
31677 amit.gupta 239
            if (leadActivity.getCommunicationType().equals(CommunicationType.VISIT)) {
31249 tejbeer 240
 
31677 amit.gupta 241
                visitRequestRepository.createVisitRequest(lead.getId(), "lead", lead.getAssignTo(),
242
                        createRefferalRequest.getSchelduleTimestamp());
243
            }
244
            //
245
            leadActivity.setClosureTimestamp(createRefferalRequest.getClosureTimestamp());
246
            lead.setClosureTimestamp(createRefferalRequest.getClosureTimestamp());
247
        } else {
248
            leadActivity.setSchelduleTimestamp(null);
249
            leadActivity.setClosureTimestamp(null);
250
            lead.setClosureTimestamp(null);
251
        }
252
        leadActivity.setCreatedTimestamp(LocalDateTime.now());
253
        leadActivityRepository.persist(leadActivity);
25899 tejbeer 254
 
31677 amit.gupta 255
        return responseSender.ok(true);
256
    }
25899 tejbeer 257
 
31677 amit.gupta 258
    @RequestMapping(value = "/lead-description", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
259
    @ApiImplicitParams({
260
            @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 261
    @Transactional(readOnly = true)
35288 amit 262
    public ResponseEntity<?> leadDescription(HttpServletRequest request, @RequestParam(name = "gmailId") String
263
                                                     gmailId,
31677 amit.gupta 264
                                             @RequestParam(name = "status") LeadStatus status) throws ProfitMandiBusinessException {
265
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
266
        List<Lead> leads = null;
267
        LOGGER.info("emails" + status);
31249 tejbeer 268
 
31677 amit.gupta 269
        List<VisitRequest> visitRequests = visitRequestRepository.selectByAuthIdAndDate(authUser.getId(),
270
                LocalDate.now());
271
        Map<Integer, List<VisitRequest>> visitRequestMap = null;
272
        if (!visitRequests.isEmpty()) {
273
            visitRequestMap = visitRequests.stream().collect(Collectors.groupingBy(x -> x.getVisitId()));
274
        }
275
        if (status.equals(LeadStatus.followUp)) {
30306 tejbeer 276
 
31677 amit.gupta 277
            leads = leadRepository.selectLeadsScheduledBetweenDate(Arrays.asList(authUser.getId()), null, null);
31249 tejbeer 278
 
31677 amit.gupta 279
            if (visitRequestMap != null) {
280
                for (Lead lead : leads) {
281
                    List<VisitRequest> visitRequest = visitRequestMap.get(lead.getId());
31249 tejbeer 282
 
31677 amit.gupta 283
                    if (visitRequest != null) {
284
                        if (visitRequest.size() > 1) {
31249 tejbeer 285
 
31677 amit.gupta 286
                            Comparator<VisitRequest> visitComparato = Comparator
287
                                    .comparing(VisitRequest::getCreatedTimestamp);
31249 tejbeer 288
 
31677 amit.gupta 289
                            VisitRequest youngestVisit = visitRequest.stream().max(visitComparato).get();
290
                            lead.setVisitStatus(youngestVisit.getStatus());
31249 tejbeer 291
 
31677 amit.gupta 292
                        } else {
293
                            lead.setVisitStatus(visitRequest.get(0).getStatus());
31249 tejbeer 294
 
31677 amit.gupta 295
                        }
296
                    }
31249 tejbeer 297
 
31677 amit.gupta 298
                }
299
            }
31249 tejbeer 300
 
31677 amit.gupta 301
            leads = leads.stream()
35079 vikas 302
                    .sorted(Comparator.comparing(Lead::getScheduledTimestamp, Comparator.nullsFirst(Comparator.reverseOrder())))
303
                    .collect(Collectors.toList());
304
            /*
31677 amit.gupta 305
             * Collections.sort(leads, (o1, o2) -> { if (o1.getScheduledTimestamp() != null
306
             * && o2.getScheduledTimestamp() != null) { return
307
             * o1.getScheduledTimestamp().isBefore(o2.getScheduledTimestamp()) ? -1 : 1; }
308
             * else if (o1.getScheduledTimestamp() != null) { return 1; } else { return -1;
309
             * } });
310
             */
30306 tejbeer 311
 
31677 amit.gupta 312
        } else {
313
            leads = leadRepository.selectByAssignAuthIdAndStatus(authUser.getId(), status);
30294 tejbeer 314
 
31677 amit.gupta 315
        }
25979 tejbeer 316
 
31677 amit.gupta 317
        return responseSender.ok(leads);
25899 tejbeer 318
 
31677 amit.gupta 319
    }
25899 tejbeer 320
 
31677 amit.gupta 321
    @RequestMapping(value = "/getlead", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35288 amit 322
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 323
    @Transactional(readOnly = true)
35288 amit 324
    public ResponseEntity<?> getLead(HttpServletRequest request, @RequestParam(name = "id") int id) throws
325
            ProfitMandiBusinessException {
25899 tejbeer 326
 
31677 amit.gupta 327
        List<LeadActivity> leadActivities = leadActivityRepository.selectBYLeadId(id);
328
        Lead lead = leadRepository.selectById(id);
329
        lead.setLeadActivities(leadActivities);
330
        return responseSender.ok(lead);
25899 tejbeer 331
 
31677 amit.gupta 332
    }
25899 tejbeer 333
 
35079 vikas 334
    @RequestMapping(value = "/check-existing-lead", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35288 amit 335
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 336
    @Transactional(readOnly = true)
35288 amit 337
    public ResponseEntity<?> getLeadByMobile(HttpServletRequest request, @RequestParam(name = "mobile") String
338
            mobile) throws ProfitMandiBusinessException {
35079 vikas 339
        int userId = (int) request.getAttribute("userId");
340
        LOGGER.info("userId: " + userId);
341
        Lead lead = leadRepository.selectByMobileNumber(mobile);
342
        return responseSender.ok(lead);
343
 
344
    }
345
 
31677 amit.gupta 346
    @RequestMapping(value = "/leadUpdate", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35288 amit 347
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
31677 amit.gupta 348
    public ResponseEntity<?> leadUpdate(HttpServletRequest request, @RequestParam(name = "id") int id,
35288 amit 349
                                        @RequestParam(name = "status") LeadStatus status, @RequestParam(name = "colorCheck") Boolean colorCheck,
350
                                        @RequestParam(name = "remark") String remark, @RequestParam(name = "reason") String reason,
351
                                        @RequestParam(name = "schelduleTimestamp") @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME) LocalDateTime schelduleTimestamp,
352
                                        @RequestParam(name = "closureTimestamp") @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME) LocalDateTime closureTimestamp,
353
                                        @RequestParam(name = "communicationType") CommunicationType communicationType) throws
354
            ProfitMandiBusinessException {
25899 tejbeer 355
 
31677 amit.gupta 356
        Lead lead = leadRepository.selectById(id);
25899 tejbeer 357
 
31677 amit.gupta 358
        LeadActivity leadActivity = new LeadActivity();
359
        lead.setStatus(status);
360
        lead.setNotinterestedReason(reason);
361
        leadActivity.setRemark(remark);
362
        leadActivity.setLeadId(id);
34394 tejus.loha 363
        leadActivity.setOutletName(lead.getOutLetName());
364
        leadActivity.setPotential(lead.getPotential());
31677 amit.gupta 365
        leadActivity.setCreatedTimestamp(LocalDateTime.now());
366
        leadActivity.setSchelduleTimestamp(null);
367
        leadActivity.setClosureTimestamp(null);
368
        leadActivity.setAuthId(lead.getAssignTo());
369
        lead.setUpdatedTimestamp(LocalDateTime.now());
370
        if (colorCheck == true) {
371
            lead.setColor("Green");
372
        } else {
373
            lead.setColor("Yellow");
374
        }
375
        if (status == LeadStatus.followUp) {
25899 tejbeer 376
 
31677 amit.gupta 377
            if (schelduleTimestamp != null) {
31249 tejbeer 378
 
31677 amit.gupta 379
                leadActivity.setCommunicationType(communicationType);
31249 tejbeer 380
 
31677 amit.gupta 381
                if (leadActivity.getCommunicationType().equals(CommunicationType.VISIT)) {
31249 tejbeer 382
 
35079 vikas 383
                    visitRequestRepository.createVisitRequest(lead.getId(), "lead", lead.getAssignTo(), schelduleTimestamp);
31677 amit.gupta 384
                }
31249 tejbeer 385
 
31677 amit.gupta 386
            }
387
            leadActivity.setSchelduleTimestamp(schelduleTimestamp);
388
            leadActivity.setClosureTimestamp(closureTimestamp);
389
            lead.setClosureTimestamp(closureTimestamp);
26250 tejbeer 390
 
31677 amit.gupta 391
        } else {
26250 tejbeer 392
 
31677 amit.gupta 393
            leadActivity.setSchelduleTimestamp(null);
394
            leadActivity.setClosureTimestamp(null);
395
            lead.setClosureTimestamp(null);
26244 tejbeer 396
 
31677 amit.gupta 397
        }
398
        leadActivityRepository.persist(leadActivity);
399
        return responseSender.ok(true);
25899 tejbeer 400
 
31677 amit.gupta 401
    }
25952 tejbeer 402
 
31677 amit.gupta 403
    @RequestMapping(value = ProfitMandiConstants.URL_NEW_LEAD, method = RequestMethod.POST)
35288 amit 404
    public ResponseEntity<?> newLead(HttpServletRequest request, @RequestBody CreateRefferalRequest
405
            createRefferalRequest) throws ProfitMandiBusinessException {
31677 amit.gupta 406
        LOGGER.info("requested url : " + request.getRequestURL().toString());
407
        Lead lead = new Lead();
408
        lead.setAddress(createRefferalRequest.getCity());
409
        Long.parseLong(createRefferalRequest.getMobile());
410
        if (createRefferalRequest.getMobile().length() != 10) {
35079 vikas 411
            throw new ProfitMandiBusinessException("Mobile Number", createRefferalRequest.getMobile(), "Number should be of 10 digits");
31677 amit.gupta 412
        }
413
        lead.setLeadMobile(createRefferalRequest.getMobile());
414
        lead.setCity(createRefferalRequest.getCity());
415
        lead.setState(createRefferalRequest.getState());
416
        lead.setLastName(createRefferalRequest.getLastName());
417
        if (lead.getState().equals("Uttar Pradesh")) {
418
            lead.setAssignTo(53);
419
        } else if (lead.getState().equals("Haryana")) {
420
            lead.setAssignTo(53);
421
        } else if (lead.getState().equals("Delhi")) {
422
            lead.setAssignTo(53);
423
        } else {
424
            // Assign to sm
425
            lead.setAssignTo(53);
426
            // Assign to neha
427
            // lead.setAssignTo(1);
428
        }
429
        lead.setAuthId(lead.getAssignTo());
430
        lead.setCreatedBy("daily-sync");
431
        lead.setSource("SD-WEB");
432
        lead.setFirstName(createRefferalRequest.getFirstName());
433
        lead.setStatus(LeadStatus.followUp);
434
        lead.setColor("yellow");
435
        lead.setCreatedTimestamp(LocalDateTime.now());
436
        lead.setUpdatedTimestamp(LocalDateTime.now());
437
        leadRepository.persist(lead);
27117 tejbeer 438
 
31677 amit.gupta 439
        return responseSender.ok(true);
27117 tejbeer 440
 
31677 amit.gupta 441
    }
27117 tejbeer 442
 
31677 amit.gupta 443
    @RequestMapping(value = "/getPartnersList", method = RequestMethod.GET)
35079 vikas 444
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 445
    @Transactional(readOnly = true)
31677 amit.gupta 446
    public ResponseEntity<?> getPartners(HttpServletRequest request, @RequestParam(name = "gmailId") String gmailId)
447
            throws ProfitMandiBusinessException {
25952 tejbeer 448
 
31677 amit.gupta 449
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
25952 tejbeer 450
 
31677 amit.gupta 451
        Map<String, Set<String>> storeGuyMap = csService.getAuthUserPartnerEmailMapping();
25952 tejbeer 452
 
31677 amit.gupta 453
        Set<String> emails = storeGuyMap.get(authUser.getEmailId());
454
        LOGGER.info("emails" + emails);
455
        List<User> users = userRepository.selectAllByEmailIds(new ArrayList<>(emails));
456
        List<Partner> partners = new ArrayList<>();
457
        for (User user : users) {
25952 tejbeer 458
 
31677 amit.gupta 459
            UserAccount uc = userAccountRepository.selectSaholicByUserId(user.getId());
460
            com.spice.profitmandi.dao.entity.user.User userInfo = userUserRepository.selectById(uc.getAccountKey());
461
            CustomRetailer customRetailer = retailerService.getFofoRetailer(userInfo.getId());
25952 tejbeer 462
 
31677 amit.gupta 463
            Partner partner = new Partner();
464
            partner.setBusinessName(customRetailer.getBusinessName());
465
            partner.setPartnerId(customRetailer.getPartnerId());
466
            partner.setCartId(customRetailer.getCartId());
467
            partner.setEmail(customRetailer.getEmail());
468
            partner.setGstNumber(customRetailer.getGstNumber());
469
            partner.setDisplayName(customRetailer.getDisplayName());
470
            partner.setCity(customRetailer.getAddress().getCity());
471
            partner.setUserId(user.getId());
472
            partners.add(partner);
473
        }
474
        LOGGER.info("partners" + partners);
475
        return responseSender.ok(partners);
476
    }
25952 tejbeer 477
 
31677 amit.gupta 478
    @RequestMapping(value = "/franchise-first-visit", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 479
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35288 amit 480
    public ResponseEntity<?> FranchiseFirstVisit(HttpServletRequest request, @RequestBody CreateFranchiseeRequest
481
            createFranchiseeRequest) throws Exception {
25952 tejbeer 482
 
31677 amit.gupta 483
        FranchiseeVisit franchiseeVisit = new FranchiseeVisit();
484
        franchiseeVisit.setFofoId(createFranchiseeRequest.getFofoId());
485
        CustomRetailer customRetailer = retailerService.getFofoRetailer(createFranchiseeRequest.getFofoId());
25952 tejbeer 486
 
31677 amit.gupta 487
        franchiseeVisit.setPartnerName(customRetailer.getBusinessName());
488
        franchiseeVisit.setAgenda(createFranchiseeRequest.getAgenda());
489
        franchiseeVisit.setCreatedTimestamp(LocalDateTime.now());
490
        franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
491
        franchiseeVisit.setStatus(FranchiseeVisitStatus.OPEN);
492
        franchiseeVisit.setScheduleTimestamp(createFranchiseeRequest.getFirstSchelduleTimestamp());
493
        // change
494
        AuthUser authUser = authRepository.selectByGmailId(createFranchiseeRequest.getCreatedBy());
25952 tejbeer 495
 
31677 amit.gupta 496
        String authUserName = authUser.getFirstName() + " " + authUser.getLastName();
497
        franchiseeVisit.setCreatedBy(authUserName);
498
        franchiseeVisit.setAuthId(authUser.getId());
25952 tejbeer 499
 
31677 amit.gupta 500
        franchiseeVisitRepository.persist(franchiseeVisit);
25952 tejbeer 501
 
31677 amit.gupta 502
        FranchiseeActivity franchiseeActivity = new FranchiseeActivity();
503
        franchiseeActivity.setAction(FranchiseeActivityStatus.FOLLOWUP);
504
        franchiseeActivity.setFranchiseeVisitd(franchiseeVisit.getId());
505
        franchiseeActivity.setResolution(createFranchiseeRequest.getResolution());
506
        franchiseeActivity.setSchelduleTimestamp(createFranchiseeRequest.getFirstSchelduleTimestamp());
31249 tejbeer 507
 
31677 amit.gupta 508
        franchiseeActivity.setCreatedTimestamp(LocalDateTime.now());
509
        franchiseeActivityRepository.persist(franchiseeActivity);
31249 tejbeer 510
 
31677 amit.gupta 511
        franchiseeVisit.setFranchiseActivityId(franchiseeActivity.getId());
31249 tejbeer 512
 
35079 vikas 513
        visitRequestRepository.createVisitRequest(franchiseeVisit.getId(), "franchiseeVisit", authUser.getId(), createFranchiseeRequest.getFirstSchelduleTimestamp());
31249 tejbeer 514
 
31677 amit.gupta 515
        return responseSender.ok(true);
516
    }
25952 tejbeer 517
 
31677 amit.gupta 518
    @RequestMapping(value = "/franchise-visit", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 519
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
31677 amit.gupta 520
    public ResponseEntity<?> FranchiseVisit(HttpServletRequest request,
521
                                            @RequestBody CreateFranchiseeRequest createFranchiseeRequest) throws Exception {
25952 tejbeer 522
 
34394 tejus.loha 523
        int rbmL1 = csService.getAuthUserId(ProfitMandiConstants.TICKET_CATEGORY_RBM, EscalationType.L1, createFranchiseeRequest.getFofoId());
34276 ranu 524
 
31677 amit.gupta 525
        FranchiseeVisit franchiseeVisit = franchiseeVisitRepository.selectById(createFranchiseeRequest.getId());
526
        franchiseeVisit.setFofoId(createFranchiseeRequest.getFofoId());
527
        CustomRetailer customRetailer = retailerService.getFofoRetailer(createFranchiseeRequest.getFofoId());
34394 tejus.loha 528
        LOGGER.info("rbmL1 {}", rbmL1);
31677 amit.gupta 529
        franchiseeVisit.setPartnerName(customRetailer.getBusinessName());
530
        franchiseeVisit.setAgenda(createFranchiseeRequest.getAgenda());
531
        franchiseeVisit.setPartnerRemark(createFranchiseeRequest.getPartnerRemark());
532
        franchiseeVisit.setOutsideVisibity(createFranchiseeRequest.getOutsideVisibity());
533
        franchiseeVisit.setInstoreVisibility(createFranchiseeRequest.getInstoreVisibility());
534
        franchiseeVisit.setOutsideStock(createFranchiseeRequest.getOutsideStock());
535
        franchiseeVisit.setSystemKnowledge(createFranchiseeRequest.getSystemKnowledge());
536
        franchiseeVisit.setWorkingDevice(createFranchiseeRequest.getWorkingDevice());
537
        franchiseeVisit.setWorkingPrinter(createFranchiseeRequest.getWorkingPrinter());
538
        franchiseeVisit.setCarryBags(createFranchiseeRequest.getCarryBags());
539
        franchiseeVisit.setSmartdukaanTshirt(createFranchiseeRequest.getSmartdukaanTshirt());
540
        franchiseeVisit.setLatestDummies(createFranchiseeRequest.getLatestDummies());
541
        franchiseeVisit.setInvestment(createFranchiseeRequest.getInvestment());
542
        franchiseeVisit.setMtd(createFranchiseeRequest.getMtd());
543
        franchiseeVisit.setHygiene(createFranchiseeRequest.getHygiene());
544
        franchiseeVisit.setCreatedTimestamp(LocalDateTime.now());
545
        franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
546
        franchiseeVisit.setInformedAboutOnline(createFranchiseeRequest.getOnline());
547
        franchiseeVisit.setPendingBilling(createFranchiseeRequest.getPendingBilling());
34276 ranu 548
        franchiseeVisit.setRbmId(rbmL1);
549
        franchiseeVisit.setRbmRating(createFranchiseeRequest.getRbmRating());
31677 amit.gupta 550
        if (createFranchiseeRequest.getAction().equals(FranchiseeActivityStatus.FOLLOWUP)) {
551
            franchiseeVisit.setStatus(FranchiseeVisitStatus.OPEN);
552
        } else {
553
            franchiseeVisit.setStatus(FranchiseeVisitStatus.CLOSE);
554
        }
25952 tejbeer 555
 
31677 amit.gupta 556
        // AuthUser authUser =
557
        // authRepository.selectByGmailId(createFranchiseeRequest.getCreatedBy());
558
        // change
559
        AuthUser authUser = authRepository.selectByGmailId(createFranchiseeRequest.getCreatedBy());
25952 tejbeer 560
 
31677 amit.gupta 561
        String authUserName = authUser.getFirstName() + " " + authUser.getLastName();
562
        franchiseeVisit.setCreatedBy(authUserName);
563
        franchiseeVisit.setAuthId(authUser.getId());
25952 tejbeer 564
 
31677 amit.gupta 565
        franchiseeVisitRepository.persist(franchiseeVisit);
25952 tejbeer 566
 
31677 amit.gupta 567
        FranchiseeActivity franchiseeActivity = new FranchiseeActivity();
568
        franchiseeActivity.setAction(createFranchiseeRequest.getAction());
569
        franchiseeActivity.setFranchiseeVisitd(franchiseeVisit.getId());
570
        franchiseeActivity.setResolution(createFranchiseeRequest.getResolution());
571
        if (createFranchiseeRequest.getAction().equals(FranchiseeActivityStatus.FOLLOWUP)) {
572
            franchiseeActivity.setSchelduleTimestamp(createFranchiseeRequest.getSchelduleTimestamp());
31249 tejbeer 573
 
31677 amit.gupta 574
            visitRequestRepository.createVisitRequest(franchiseeVisit.getId(), "franchiseeVisit",
575
                    franchiseeVisit.getAuthId(), createFranchiseeRequest.getSchelduleTimestamp());
576
        } else {
577
            franchiseeActivity.setSchelduleTimestamp(null);
578
        }
579
        franchiseeActivity.setCreatedTimestamp(LocalDateTime.now());
580
        franchiseeActivityRepository.persist(franchiseeActivity);
25952 tejbeer 581
 
31677 amit.gupta 582
        franchiseeVisit.setFranchiseActivityId(franchiseeActivity.getId());
34276 ranu 583
 
34394 tejus.loha 584
        if (!createFranchiseeRequest.getOutsideVisibityReason().isEmpty()) {
34288 ranu 585
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_DESIGN, ProfitMandiConstants.TICKET_CATEGORY_DESIGNING_BRANDING_EXTERNAL_VISIBILITY, createFranchiseeRequest.getOutsideVisibityReason(), authUser.getId());
34276 ranu 586
        }
587
 
34394 tejus.loha 588
        if (!createFranchiseeRequest.getInstoreVisibilityReason().isEmpty()) {
34288 ranu 589
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_DESIGN, ProfitMandiConstants.TICKET_CATEGORY_DESIGNING_BRANDING_INTERNAL_VISIBILITY, createFranchiseeRequest.getInstoreVisibilityReason(), authUser.getId());
34276 ranu 590
        }
591
 
34394 tejus.loha 592
        if (!createFranchiseeRequest.getOutsideStockReason().isEmpty()) {
34288 ranu 593
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_SALES_OUTSIDE_STOCK, createFranchiseeRequest.getOutsideStockReason(), authUser.getId());
34276 ranu 594
        }
595
 
34394 tejus.loha 596
        if (!createFranchiseeRequest.getSystemKnowledgeReason().isEmpty()) {
34288 ranu 597
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_TRAINING, ProfitMandiConstants.TICKET_CATEGORY_TRAINING_NEED, createFranchiseeRequest.getSystemKnowledgeReason(), authUser.getId());
34276 ranu 598
        }
599
 
34394 tejus.loha 600
        if (!createFranchiseeRequest.getLatestDummiesReason().isEmpty()) {
34288 ranu 601
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_MARKETING, ProfitMandiConstants.TICKET_CATEGORY_MARKETING_DUMMIES, createFranchiseeRequest.getLatestDummiesReason(), authUser.getId());
34276 ranu 602
        }
603
 
34394 tejus.loha 604
        if (!createFranchiseeRequest.getInvestmentReason().isEmpty()) {
34288 ranu 605
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_SALES_LOW_INVESTMENT, createFranchiseeRequest.getInvestmentReason(), authUser.getId());
34276 ranu 606
        }
607
 
34394 tejus.loha 608
        if (!createFranchiseeRequest.getHygieneReason().isEmpty()) {
34288 ranu 609
            csService.createTicket(createFranchiseeRequest.getFofoId(), ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_SALES_LOW_DATA_ACCURACY, createFranchiseeRequest.getHygieneReason(), authUser.getId());
610
        }
34276 ranu 611
 
31677 amit.gupta 612
        return responseSender.ok(true);
34276 ranu 613
 
31677 amit.gupta 614
    }
25952 tejbeer 615
 
31677 amit.gupta 616
    @RequestMapping(value = "/getFranchiseVisit", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 617
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 618
    @Transactional(readOnly = true)
31677 amit.gupta 619
    public ResponseEntity<?> getFranchiseVisit(HttpServletRequest request,
35288 amit 620
                                               @RequestParam(name = "gmailId") String gmailId, @RequestParam(name = "status") FranchiseeVisitStatus
621
                                                       status,
31677 amit.gupta 622
                                               @RequestParam(name = "offset", defaultValue = "0") int offset,
623
                                               @RequestParam(name = "limit", defaultValue = "10") int limit) throws ProfitMandiBusinessException {
624
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
35079 vikas 625
        List<VisitRequest> visitRequests = visitRequestRepository.selectByAuthIdAndDate(authUser.getId(), LocalDate.now());
31677 amit.gupta 626
        Map<Integer, List<VisitRequest>> visitRequestMap = null;
627
        if (!visitRequests.isEmpty()) {
628
            visitRequestMap = visitRequests.stream().collect(Collectors.groupingBy(x -> x.getVisitId()));
629
        }
35079 vikas 630
        List<FranchiseeVisit> franchiseeVisits = franchiseeVisitRepository.selectByAuthIdAndStatus(authUser.getId(), status, offset, limit);
25952 tejbeer 631
 
35415 amit 632
        // Batch fetch all FranchiseeActivity in one query instead of N+1
633
        List<Integer> activityIds = franchiseeVisits.stream()
634
                .filter(fv -> fv.getFranchiseActivityId() != 0)
635
                .map(FranchiseeVisit::getFranchiseActivityId)
636
                .collect(Collectors.toList());
637
        Map<Integer, FranchiseeActivity> activityMap = new HashMap<>();
638
        if (!activityIds.isEmpty()) {
639
            activityMap = franchiseeActivityRepository.selectByIds(activityIds).stream()
640
                    .collect(Collectors.toMap(FranchiseeActivity::getId, x -> x));
641
        }
642
 
31677 amit.gupta 643
        for (FranchiseeVisit fv : franchiseeVisits) {
644
            if (visitRequestMap != null) {
31249 tejbeer 645
 
31677 amit.gupta 646
                List<VisitRequest> visitRequest = visitRequestMap.get(fv.getId());
647
                if (visitRequest != null) {
648
                    if (visitRequest.size() > 1) {
31249 tejbeer 649
 
35079 vikas 650
                        Comparator<VisitRequest> visitComparato = Comparator.comparing(VisitRequest::getCreatedTimestamp);
31249 tejbeer 651
 
31677 amit.gupta 652
                        VisitRequest youngestVisit = visitRequest.stream().max(visitComparato).get();
653
                        fv.setVisitStatus(youngestVisit.getStatus());
31249 tejbeer 654
 
31677 amit.gupta 655
                    } else {
656
                        fv.setVisitStatus(visitRequest.get(0).getStatus());
31249 tejbeer 657
 
31677 amit.gupta 658
                    }
659
                }
660
            }
661
            if (fv.getFranchiseActivityId() != 0) {
35415 amit 662
                FranchiseeActivity fA = activityMap.get(fv.getFranchiseActivityId());
31677 amit.gupta 663
                fv.setFranchiseeActivity(fA);
664
            }
31249 tejbeer 665
 
31677 amit.gupta 666
        }
25952 tejbeer 667
 
31677 amit.gupta 668
        return responseSender.ok(franchiseeVisits);
25952 tejbeer 669
 
31677 amit.gupta 670
    }
25952 tejbeer 671
 
31677 amit.gupta 672
    @RequestMapping(value = "/getFranchiseActivity", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 673
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 674
    @Transactional(readOnly = true)
35288 amit 675
    public ResponseEntity<?> getFranchiseActivity(HttpServletRequest request, @RequestParam(name = "id") int id) throws
676
            ProfitMandiBusinessException {
25952 tejbeer 677
 
31677 amit.gupta 678
        List<FranchiseeActivity> franchiseeActivities = franchiseeActivityRepository.selectByFranchiseeVisitId(id);
679
        return responseSender.ok(franchiseeActivities);
25952 tejbeer 680
 
31677 amit.gupta 681
    }
25952 tejbeer 682
 
31677 amit.gupta 683
    @RequestMapping(value = "/getFranchiseeInfo", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 684
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 685
    @Transactional(readOnly = true)
35288 amit 686
    public ResponseEntity<?> getFranchiseeInfo(HttpServletRequest request, @RequestParam(name = "id") int id) throws
687
            ProfitMandiBusinessException {
31677 amit.gupta 688
        FranchiseeVisit franchiseeVisit = franchiseeVisitRepository.selectById(id);
25952 tejbeer 689
 
31677 amit.gupta 690
        List<DBObject> mobileBrands = mongoClient.getAllBrandsToDisplay(3);
30487 tejbeer 691
 
31677 amit.gupta 692
        List<String> brands = mobileBrands.stream().filter(x -> (boolean) x.get("active"))
693
                .map(x -> (String) x.get("name")).collect(Collectors.toList());
30487 tejbeer 694
 
31677 amit.gupta 695
        franchiseeVisit.setBrands(brands);
30487 tejbeer 696
 
31677 amit.gupta 697
        return responseSender.ok(franchiseeVisit);
25952 tejbeer 698
 
31677 amit.gupta 699
    }
25952 tejbeer 700
 
31677 amit.gupta 701
    @RequestMapping(value = "/franchise-visit-update", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 702
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35288 amit 703
    public ResponseEntity<?> franchiseVisitUpdate(HttpServletRequest request, @RequestParam(name = "id") int id,
704
                                                  @RequestParam(name = "action") FranchiseeActivityStatus action,
705
                                                  @RequestParam(name = "resolution") String resolution,
706
                                                  @RequestParam(name = "schelduleTimestamp") @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME) LocalDateTime schelduleTimestamp)
31677 amit.gupta 707
            throws ProfitMandiBusinessException {
708
        FranchiseeVisit franchiseeVisit = franchiseeVisitRepository.selectById(id);
25952 tejbeer 709
 
31677 amit.gupta 710
        FranchiseeActivity franchiseeActivity = new FranchiseeActivity();
25952 tejbeer 711
 
31677 amit.gupta 712
        if (action == FranchiseeActivityStatus.FOLLOWUP) {
30487 tejbeer 713
 
31677 amit.gupta 714
            if (schelduleTimestamp != null) {
31249 tejbeer 715
 
31677 amit.gupta 716
                visitRequestRepository.createVisitRequest(franchiseeVisit.getId(), "franchiseeVisit",
717
                        franchiseeVisit.getAuthId(), schelduleTimestamp);
718
            }
31249 tejbeer 719
 
31677 amit.gupta 720
            franchiseeActivity.setSchelduleTimestamp(schelduleTimestamp);
721
            franchiseeVisit.setStatus(FranchiseeVisitStatus.OPEN);
722
            franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
723
            franchiseeVisitRepository.persist(franchiseeVisit);
25952 tejbeer 724
 
31677 amit.gupta 725
        } else {
30487 tejbeer 726
 
31677 amit.gupta 727
            franchiseeActivity.setSchelduleTimestamp(null);
728
            franchiseeVisit.setFranchiseActivityId(franchiseeActivity.getId());
729
            franchiseeVisit.setStatus(FranchiseeVisitStatus.CLOSE);
730
            franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
731
            franchiseeVisitRepository.persist(franchiseeVisit);
25952 tejbeer 732
 
31677 amit.gupta 733
        }
25952 tejbeer 734
 
31677 amit.gupta 735
        franchiseeActivity.setResolution(resolution);
736
        franchiseeActivity.setFranchiseeVisitd(franchiseeVisit.getId());
737
        franchiseeActivity.setAction(action);
30487 tejbeer 738
 
31677 amit.gupta 739
        franchiseeActivity.setCreatedTimestamp(LocalDateTime.now());
740
        franchiseeActivityRepository.persist(franchiseeActivity);
30487 tejbeer 741
 
31677 amit.gupta 742
        franchiseeVisit.setFranchiseActivityId(franchiseeActivity.getId());
743
        franchiseeVisit.setStatus(FranchiseeVisitStatus.OPEN);
744
        franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
745
        franchiseeVisitRepository.persist(franchiseeVisit);
30487 tejbeer 746
 
31677 amit.gupta 747
        return responseSender.ok(true);
25952 tejbeer 748
 
31677 amit.gupta 749
    }
28935 tejbeer 750
 
31677 amit.gupta 751
    @RequestMapping(value = "/onBoardingTimelineStatus", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 752
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 753
    @Transactional(readOnly = true)
31677 amit.gupta 754
    public ResponseEntity<?> onBoardingTimelineStatus(HttpServletRequest request, Model model)
755
            throws ProfitMandiBusinessException {
35075 aman 756
        //This userId is of dtr.users
31677 amit.gupta 757
        int userId = (int) request.getAttribute("userId");
35075 aman 758
 
759
        //UserCart contains userId/retailerId in context of user.user as
760
        //uc contains retailerId and cartId of the retailerId that belongs to user schema
31677 amit.gupta 761
        UserCart uc = userAccountRepository.getUserCart(userId);
762
        FofoStore fs = fofoStoreRepository.selectByRetailerId(uc.getUserId());
763
        PartnerOnBoardingPanel partnerOnBoardingPanel = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
764
        Map<StoreTimeline, OnBoardingTimelineModel> timelineStatus = null;
765
        LOGGER.info("partnerOnBoardingPanel" + partnerOnBoardingPanel);
766
        if (partnerOnBoardingPanel != null) {
28935 tejbeer 767
 
31677 amit.gupta 768
            timelineStatus = storeTimelineTatService.getTimeline(partnerOnBoardingPanel.getId());
769
        }
770
        List<OnBoardingTimelineModel> onBoardingModel = new ArrayList<>();
771
        if (timelineStatus != null) {
772
            onBoardingModel = timelineStatus.values().stream().skip(2).map(x -> x).collect(Collectors.toList());
773
        }
774
        return responseSender.ok(onBoardingModel);
28935 tejbeer 775
 
31677 amit.gupta 776
    }
35288 amit 777
 
35075 aman 778
    @RequestMapping(value = "/purchaseExist", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
779
    @ApiImplicitParams({
780
            @ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 781
    @Transactional(readOnly = true)
35415 amit 782
    public ResponseEntity<?> purchaseExist(HttpServletRequest request) throws ProfitMandiBusinessException {
35075 aman 783
        int userId = (int) request.getAttribute("userId");
784
        UserCart uc = userAccountRepository.getUserCart(userId);
35415 amit 785
        return responseSender.ok(purchaseRepository.hasPurchaseForFofoId(uc.getUserId()));
35075 aman 786
    }
35288 amit 787
 
31677 amit.gupta 788
    @RequestMapping(value = "/onBoardingTimelineVisibility", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 789
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 790
    @Transactional(readOnly = true)
31677 amit.gupta 791
    public ResponseEntity<?> onBoardingTimelineVisibility(HttpServletRequest request, Model model)
792
            throws ProfitMandiBusinessException {
793
        int userId = (int) request.getAttribute("userId");
794
        UserCart uc = userAccountRepository.getUserCart(userId);
28982 tejbeer 795
 
31677 amit.gupta 796
        FofoStore fs = fofoStoreRepository.selectByRetailerId(uc.getUserId());
797
        PartnerOnBoardingPanel partnerOnBoardingPanel = partnerOnBoardingPanelRepository.selectByCode(fs.getCode());
798
        boolean status = true;
799
        if (partnerOnBoardingPanel != null) {
28982 tejbeer 800
 
31677 amit.gupta 801
            status = storeTimelineTatService.getTimelineCompleted(partnerOnBoardingPanel.getId());
802
        }
28982 tejbeer 803
 
31677 amit.gupta 804
        LOGGER.info("status" + status);
28983 tejbeer 805
 
31677 amit.gupta 806
        return responseSender.ok(status);
28982 tejbeer 807
 
31677 amit.gupta 808
    }
30077 tejbeer 809
 
31677 amit.gupta 810
    @RequestMapping(value = "/getPartnerTarget", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 811
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
35435 amit 812
    @Transactional(readOnly = true)
35288 amit 813
    public ResponseEntity<?> getPartnerTarget(HttpServletRequest request, @RequestParam String
814
            gmailId, @RequestParam String dayValue, @RequestParam ActivationType activationType) throws
815
            ProfitMandiBusinessException {
30077 tejbeer 816
 
31677 amit.gupta 817
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
818
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
819
        Set<Integer> fofoIds = storeGuyMap.get(authUser.getEmailId());
820
        List<String> brands = Arrays.asList("Vivo", "Samsung", "Oppo", "Itel", "Almost New", "Others");
30078 tejbeer 821
 
31677 amit.gupta 822
        float totalPartnerTargetSecondary = 0;
823
        float totalPartnerTargetCollection = 0;
824
        float totalPartnerAchievementSecondary = 0;
825
        float totalPartnerAchievementCollection = 0;
826
        TargetModel tm = new TargetModel();
827
        Map<Integer, PartnerDailyInvestment> partnerDailyInvestmentMap = new HashMap<>();
828
        Map<Integer, Long> partnerTicketCount = ticketRepository.selectAllOpenTicketsGroupByRetailer();
30416 tejbeer 829
 
31677 amit.gupta 830
        LOGGER.info("partnerTicketCount {}", partnerTicketCount);
30416 tejbeer 831
 
31677 amit.gupta 832
        List<PartnerTargetAchievementModel> ptams = new ArrayList<>();
30077 tejbeer 833
 
31677 amit.gupta 834
        if (fofoIds != null && fofoIds.size() > 0) {
32737 amit.gupta 835
            LOGGER.info("fofoIds {}", fofoIds);
31727 amit.gupta 836
            List<Integer> fofoIdList = fofoStoreRepository.selectByRetailerIds(new ArrayList<>(fofoIds)).stream()
31677 amit.gupta 837
                    .filter(x -> (!x.isInternal() && (activationType == null || x.getActivationType().equals(activationType))))
838
                    .map(x -> x.getId()).collect(Collectors.toList());
32737 amit.gupta 839
            LOGGER.info("fofoIdList {}", fofoIdList);
31677 amit.gupta 840
            LocalDateTime startDate = LocalDate.now().atStartOfDay();
30077 tejbeer 841
 
31677 amit.gupta 842
            if (dayValue.equals("previous")) {
843
                startDate = LocalDate.now().minusDays(1).atStartOfDay();
30138 tejbeer 844
 
31677 amit.gupta 845
            }
30087 tejbeer 846
 
31686 amit.gupta 847
            if (fofoIdList.size() > 0) {
30453 tejbeer 848
 
35079 vikas 849
                List<PartnerDailyInvestment> partnerDailyInvestments = partnerDailyInvestmentRepository.selectAll(fofoIdList, startDate.toLocalDate().minusDays(1));
30087 tejbeer 850
 
31686 amit.gupta 851
                if (!partnerDailyInvestments.isEmpty()) {
35079 vikas 852
                    partnerDailyInvestmentMap = partnerDailyInvestments.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31686 amit.gupta 853
                }
30077 tejbeer 854
 
31686 amit.gupta 855
                Map<Integer, CustomRetailer> customRetailerMap = retailerService.getAllFofoRetailers();
30426 tejbeer 856
 
31686 amit.gupta 857
                Map<Integer, CustomRetailer> customRetailers = fofoIdList.stream().map(x -> customRetailerMap.get(x))
858
                        .filter(x -> x != null).collect(Collectors.toList()).stream()
859
                        .collect(Collectors.toMap(x -> x.getPartnerId(), x -> x));
30330 tejbeer 860
 
31686 amit.gupta 861
                List<Integer> remarkIds = partnerCollectionRemarkRepository.selectMaxRemarkId(fofoIdList);
30453 tejbeer 862
 
31686 amit.gupta 863
                LOGGER.info("remarkIds {}", remarkIds);
30453 tejbeer 864
 
31686 amit.gupta 865
                long todayCollectionCount = 0;
866
                if (!remarkIds.isEmpty()) {
867
                    todayCollectionCount = partnerCollectionRemarkRepository
868
                            .selectByAuthIdAndIds(authUser.getId(), remarkIds).stream()
869
                            .filter(x -> x.getCreateTimestamp().toLocalDate().equals(LocalDate.now()))
870
                            .collect(Collectors.counting());
30453 tejbeer 871
 
31686 amit.gupta 872
                }
30330 tejbeer 873
 
35079 vikas 874
                Map<Integer, PartnerCollectionPlanModel> collectionMap = partnerCollectionService.getCollectionMap(fofoIdList, startDate);
30077 tejbeer 875
 
32978 amit.gupta 876
                Map<Integer, List<PartnerSecondaryPlanModel>> partnerSecondaryPlans = orderRepository
31686 amit.gupta 877
                        .selectPartnerSecondaryGroupByBrand(fofoIdList, startDate.toLocalDate()).stream()
878
                        .collect(Collectors.groupingBy(x -> x.getFofoId()));
30077 tejbeer 879
 
35415 amit 880
                // Pre-fetch all AuthUsers that might be needed (instead of N+1 queries)
881
                Set<Integer> allAuthIds = new HashSet<>();
882
                collectionMap.values().stream()
883
                        .map(PartnerCollectionPlanModel::getAuthId)
884
                        .filter(id -> id != null && id != authUser.getId())
885
                        .forEach(allAuthIds::add);
886
                partnerSecondaryPlans.values().stream()
887
                        .flatMap(List::stream)
888
                        .map(PartnerSecondaryPlanModel::getAuthId)
889
                        .filter(id -> id != null && id != authUser.getId())
890
                        .forEach(allAuthIds::add);
891
                Map<Integer, AuthUser> authUserMap = new HashMap<>();
892
                if (!allAuthIds.isEmpty()) {
893
                    authUserMap = authRepository.selectByIds(new ArrayList<>(allAuthIds)).stream()
894
                            .collect(Collectors.toMap(AuthUser::getId, x -> x));
895
                }
896
 
32978 amit.gupta 897
                LOGGER.info("partnerSecondayPlans {}", partnerSecondaryPlans);
31686 amit.gupta 898
                for (Entry<Integer, CustomRetailer> customRetailerEntry : customRetailers.entrySet()) {
899
                    int fofoId = customRetailerEntry.getKey();
900
                    CustomRetailer customRetailer = customRetailerEntry.getValue();
901
                    float totalSecondaryPlan = 0;
902
                    float totalSecondaryAchivement = 0;
30077 tejbeer 903
 
31686 amit.gupta 904
                    PartnerTargetAchievementModel ptam = new PartnerTargetAchievementModel();
905
                    ptam.setFofoId(fofoId);
906
                    ptam.setBusinessName(customRetailer.getBusinessName());
907
                    ptam.setMobile(customRetailer.getMobileNumber());
30087 tejbeer 908
 
31686 amit.gupta 909
                    if (partnerDailyInvestmentMap.get(fofoId) != null) {
910
                        ptam.setWalletAmount(partnerDailyInvestmentMap.get(fofoId).getWalletAmount());
911
                        ptam.setShortInvestment(partnerDailyInvestmentMap.get(fofoId).getShortInvestment());
912
                    }
30808 tejbeer 913
 
32978 amit.gupta 914
                    if (collectionMap.get(fofoId) != null) {
915
                        PartnerCollectionPlanModel collectionPlan = collectionMap.get(fofoId);
30330 tejbeer 916
 
31686 amit.gupta 917
                        ptam.setRemark(collectionPlan.getRemark());
918
                        ptam.setMessage(collectionPlan.getMessage());
919
                        ptam.setRemarkTimestamp(collectionPlan.getRemarkTimestamp());
920
                        ptam.setRank(collectionPlan.getRank());
921
                        Integer authId = collectionPlan.getAuthId();
30330 tejbeer 922
 
31686 amit.gupta 923
                        Map<Integer, String> rankColorMap = ProfitMandiConstants.Rank_Color_Map;
30416 tejbeer 924
 
31686 amit.gupta 925
                        ptam.setCollectionColor(rankColorMap.get(collectionPlan.getRank()));
30077 tejbeer 926
 
31686 amit.gupta 927
                        LOGGER.info("authId" + authId);
30137 tejbeer 928
 
31686 amit.gupta 929
                        if (collectionPlan.getTargetPlan() != null && collectionPlan.getCommittedDate() != null) {
930
                            float targetCollection = 0;
30330 tejbeer 931
 
31686 amit.gupta 932
                            if (collectionPlan.getRank() == 2 && collectionPlan.getAchievementPlan() != null) {
933
                                targetCollection = collectionPlan.getTargetPlan() - collectionPlan.getAchievementPlan();
934
                            } else {
935
                                targetCollection = collectionPlan.getTargetPlan();
31677 amit.gupta 936
                            }
30451 tejbeer 937
 
31677 amit.gupta 938
                            if (authId != null && authId == authUser.getId()) {
31686 amit.gupta 939
                                if (!collectionPlan.getCommittedDate().isAfter(startDate)) {
940
                                    totalPartnerTargetCollection += targetCollection;
941
                                }
31677 amit.gupta 942
                            }
31686 amit.gupta 943
                            ptam.setCollectionTarget(targetCollection);
944
                            if (collectionPlan.getRank() == 2 && collectionPlan.getAchievementPlan() != null
945
                                    && collectionPlan.getWalletTimestamp() != null
946
                                    && collectionPlan.getWalletTimestamp().toLocalDate().equals(startDate.toLocalDate())) {
947
                                if (authId != null && authId == authUser.getId()) {
948
                                    totalPartnerAchievementCollection += collectionPlan.getAchievementPlan();
949
                                }
950
                                ptam.setCollectionAchievement(collectionPlan.getAchievementPlan());
951
                            } else if (collectionPlan.getCommittedDate().toLocalDate().isEqual(startDate.toLocalDate())
952
                                    && collectionPlan.getAchievementPlan() != null) {
953
                                if (authId != null && authId == authUser.getId()) {
954
                                    totalPartnerAchievementCollection += collectionPlan.getAchievementPlan();
955
                                }
956
                                ptam.setCollectionAchievement(collectionPlan.getAchievementPlan());
957
 
31677 amit.gupta 958
                            }
31686 amit.gupta 959
                        }
30822 tejbeer 960
 
31686 amit.gupta 961
                        if (authId != null && authId != authUser.getId()) {
35415 amit 962
                            ptam.setAuthUser(authUserMap.get(authId));
31686 amit.gupta 963
 
31677 amit.gupta 964
                        }
30087 tejbeer 965
 
31686 amit.gupta 966
                        if (collectionPlan.getCommittedDate() != null) {
30087 tejbeer 967
 
31686 amit.gupta 968
                            ptam.setCollectionCommitmentDate(collectionPlan.getCommittedDate().toLocalDate());
969
                        }
30087 tejbeer 970
 
31677 amit.gupta 971
                    }
30821 tejbeer 972
 
31686 amit.gupta 973
                    // Secondary
30077 tejbeer 974
 
31686 amit.gupta 975
                    PartnerSecondaryPlanModel otherPartnerSecondaryPlanModel = null;
976
                    Map<String, PartnerSecondaryPlanModel> secondaryModelMap = new HashMap<>();
32978 amit.gupta 977
                    if (partnerSecondaryPlans.get(fofoId) != null) {
31686 amit.gupta 978
                        long otherBrandSecondary = 0;
32978 amit.gupta 979
                        for (PartnerSecondaryPlanModel pspm : partnerSecondaryPlans.get(fofoId)) {
31686 amit.gupta 980
                            Integer authId = pspm.getAuthId();
981
                            if (!brands.contains(pspm.getBrand())) {
982
                                if (pspm.getAchievementPlan() != null) {
983
                                    otherBrandSecondary += pspm.getAchievementPlan();
984
                                }
985
                            } else {
986
                                otherPartnerSecondaryPlanModel = pspm;
987
                            }
988
                            if (pspm.getTargetPlan() != null) {
989
                                totalSecondaryPlan += pspm.getTargetPlan();
990
                            }
30330 tejbeer 991
 
31677 amit.gupta 992
                            if (pspm.getAchievementPlan() != null) {
31686 amit.gupta 993
                                totalSecondaryAchivement += pspm.getAchievementPlan();
31677 amit.gupta 994
                            }
30087 tejbeer 995
 
31686 amit.gupta 996
                            if (pspm.getCommittedDate() != null) {
30137 tejbeer 997
 
31686 amit.gupta 998
                                ptam.setSecondaryCommitmentDate(pspm.getCommittedDate().toLocalDate());
999
                            }
1000
                            if (authId != null && authId == authUser.getId()) {
30137 tejbeer 1001
 
31686 amit.gupta 1002
                                if (pspm.getTargetPlan() != null && pspm.getCommittedDate() != null) {
30087 tejbeer 1003
 
31686 amit.gupta 1004
                                    if (pspm.getCommittedDate().isEqual(startDate)) {
1005
                                        totalPartnerTargetSecondary += pspm.getTargetPlan();
1006
                                    }
1007
                                }
30087 tejbeer 1008
 
31686 amit.gupta 1009
                                if (pspm.getAchievementPlan() != null) {
1010
                                    totalPartnerAchievementSecondary += pspm.getAchievementPlan();
31677 amit.gupta 1011
                                }
31686 amit.gupta 1012
 
31677 amit.gupta 1013
                            }
31686 amit.gupta 1014
                        }
1015
                        if (otherPartnerSecondaryPlanModel != null) {
1016
                            otherPartnerSecondaryPlanModel.setAchievementPlan(otherBrandSecondary);
1017
                        }
32978 amit.gupta 1018
                        secondaryModelMap = partnerSecondaryPlans.get(fofoId).stream()
31686 amit.gupta 1019
                                .filter(x -> brands.contains(x.getBrand()))
1020
                                .collect(Collectors.toMap(x -> x.getBrand(), x -> x));
30087 tejbeer 1021
 
31686 amit.gupta 1022
                        if (secondaryModelMap.containsKey("Others")) {
1023
                            PartnerSecondaryPlanModel psp = secondaryModelMap.get("Others");
1024
                            psp.setAchievementPlan(otherBrandSecondary);
1025
                        } else {
35079 vikas 1026
                            secondaryModelMap.put("Others", new PartnerSecondaryPlanModel(fofoId, "Others", (long) 0, otherBrandSecondary, authUser.getId(), null));
31686 amit.gupta 1027
                        }
1028
                        for (String brand : brands) {
1029
                            if (!secondaryModelMap.containsKey(brand)) {
35079 vikas 1030
                                secondaryModelMap.put(brand, new PartnerSecondaryPlanModel(fofoId, brand, (long) 0, (long) 0, authUser.getId(), null));
31677 amit.gupta 1031
                            }
31686 amit.gupta 1032
                        }
30087 tejbeer 1033
 
31686 amit.gupta 1034
                        for (Entry<String, PartnerSecondaryPlanModel> secondaryModelEntry : secondaryModelMap.entrySet()) {
1035
                            Integer authId = secondaryModelEntry.getValue().getAuthId();
1036
                            if (authId != null && authId != authUser.getId()) {
35415 amit 1037
                                secondaryModelEntry.getValue().setAuthUser(authUserMap.get(authId));
31686 amit.gupta 1038
                                ptam.setSecondaryColor("red");
1039
                            }
1040
 
31677 amit.gupta 1041
                        }
30077 tejbeer 1042
 
31686 amit.gupta 1043
                        ptam.setPartnerSecondaryModel(secondaryModelMap);
1044
                        ptam.setTotalSecondaryPlan(totalSecondaryPlan);
1045
                        ptam.setTotalSecondaryAchievement(totalSecondaryAchivement);
1046
                        // Secondary
1047
 
31677 amit.gupta 1048
                    } else {
31686 amit.gupta 1049
                        for (String brand : brands) {
1050
                            PartnerSecondaryPlanModel pspm = new PartnerSecondaryPlanModel();
1051
                            pspm.setAchievementPlan((long) 0);
1052
                            pspm.setTargetPlan((long) 0);
1053
                            pspm.setBrand(brand);
1054
                            pspm.setFofoId(fofoId);
1055
                            secondaryModelMap.put(brand, pspm);
31677 amit.gupta 1056
                        }
31686 amit.gupta 1057
                        ptam.setPartnerSecondaryModel(secondaryModelMap);
31677 amit.gupta 1058
                    }
30077 tejbeer 1059
 
31686 amit.gupta 1060
                    if (!partnerTicketCount.isEmpty()) {
1061
                        if (partnerTicketCount.get(fofoId) != null) {
1062
                            ptam.setTicketCount(partnerTicketCount.get(fofoId));
1063
                        } else {
1064
                            ptam.setTicketCount(0);
1065
 
31677 amit.gupta 1066
                        }
1067
                    }
30087 tejbeer 1068
 
31686 amit.gupta 1069
                    ptams.add(ptam);
30077 tejbeer 1070
 
31677 amit.gupta 1071
                }
32923 ranu 1072
                List<Position> positions = positionRepository.selectPositionByAuthId(authUser.getId()).stream().collect(Collectors.toList());
30077 tejbeer 1073
 
32923 ranu 1074
                LOGGER.info("positions {}", positions);
1075
 
35079 vikas 1076
                boolean isRBMAndL1 = positions.stream().anyMatch(position -> ProfitMandiConstants.TICKET_CATEGORY_RBM == position.getCategoryId() && EscalationType.L1.equals(position.getEscalationType()));
1077
                boolean isRBMAndNotL1 = positions.stream().anyMatch(position -> ProfitMandiConstants.TICKET_CATEGORY_RBM == position.getCategoryId() && !EscalationType.L1.equals(position.getEscalationType()));
32923 ranu 1078
 
34118 tejus.loha 1079
                LOGGER.info("isRBMAndL1{}", isRBMAndL1);
32923 ranu 1080
 
35079 vikas 1081
                boolean isSales = positions.stream().anyMatch(position -> ProfitMandiConstants.TICKET_CATEGORY_SALES == position.getCategoryId());
32923 ranu 1082
 
31686 amit.gupta 1083
                tm.setTotalPartnerTargetCollection(totalPartnerTargetCollection);
1084
                tm.setTotalPartnerTargetSecondary(totalPartnerTargetSecondary);
1085
                tm.setTotalPartnerSecondary(totalPartnerAchievementSecondary);
1086
                tm.setTotalPartnerCollection(totalPartnerAchievementCollection);
1087
                tm.setTodayCollectionCount((int) todayCollectionCount);
32923 ranu 1088
                List<PartnerTargetAchievementModel> filteredPtams;
30416 tejbeer 1089
 
32923 ranu 1090
                if (isRBMAndL1) {
34428 ranu 1091
                    filteredPtams = ptams;
1092
//                    as of now all party is showing to rbm
1093
                    /*filteredPtams = ptams.stream()
32978 amit.gupta 1094
                            .filter(ptam -> !(CollectionRemark.RBM_L2_ESCALATION.equals(ptam.getRemark()) || CollectionRemark.SALES_ESCALATION.equals(ptam.getRemark())))
34428 ranu 1095
                            .collect(Collectors.toList());*/
32923 ranu 1096
                } else if (isRBMAndNotL1) {
34429 ranu 1097
                    filteredPtams = ptams;
1098
                    /*filteredPtams = ptams.stream()
32923 ranu 1099
                            .filter(ptam -> !(CollectionRemark.SALES_ESCALATION.equals(ptam.getRemark())))
34429 ranu 1100
                            .collect(Collectors.toList());*/
33041 ranu 1101
                } else if (isSales) {
1102
                    filteredPtams = ptams.stream()
1103
                            .filter(ptam -> !(CollectionRemark.RBM_L2_ESCALATION.equals(ptam.getRemark())))
1104
                            .collect(Collectors.toList());
32923 ranu 1105
                } else {
1106
                    filteredPtams = ptams;
1107
                }
34428 ranu 1108
                tm.setRBMAndL1(isRBMAndL1);
1109
                tm.setRBMAndNotL1(isRBMAndNotL1);
1110
                tm.setSales(isSales);
34796 ranu 1111
                /*tm.setTargetAchievement(filteredPtams.stream().sorted(Comparator.comparing(PartnerTargetAchievementModel::getRank))
1112
                        .collect(Collectors.toList()));*/
1113
                tm.setTargetAchievement(filteredPtams.stream()
1114
                        .sorted(Comparator
1115
                                .comparing((PartnerTargetAchievementModel ptam) -> {
1116
                                    LocalDate remarkDate = ptam.getRemarkTimestamp() != null
1117
                                            ? ptam.getRemarkTimestamp().toLocalDate()
1118
                                            : null;
1119
                                    return remarkDate != null && remarkDate.equals(LocalDate.now());
1120
                                }) // false → comes first, true (today) → goes last
1121
                                .thenComparing(PartnerTargetAchievementModel::getRank)
1122
                        )
31686 amit.gupta 1123
                        .collect(Collectors.toList()));
30416 tejbeer 1124
 
34796 ranu 1125
 
31677 amit.gupta 1126
            }
30077 tejbeer 1127
 
31677 amit.gupta 1128
        }
1129
        return responseSender.ok(tm);
30077 tejbeer 1130
 
31677 amit.gupta 1131
    }
32737 amit.gupta 1132
 
1133
    //TODO:Amit
31677 amit.gupta 1134
    @RequestMapping(value = "/target", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35079 vikas 1135
    @ApiImplicitParams({@ApiImplicitParam(name = "Auth-Token", value = "Auth-Token", required = true, dataType = "string", paramType = "header")})
31677 amit.gupta 1136
    public ResponseEntity<?> createPartnerTarget(HttpServletRequest request,
1137
                                                 @RequestBody PartnerTargetAchievementModel ptam) throws ProfitMandiBusinessException {
30077 tejbeer 1138
 
31677 amit.gupta 1139
        LOGGER.info("ptam" + ptam);
30089 tejbeer 1140
 
31677 amit.gupta 1141
        AuthUser authUser = authRepository.selectByGmailId(ptam.getCreatedBy());
30077 tejbeer 1142
 
31677 amit.gupta 1143
        if (ptam.getCollectionCommitmentDate().isAfter(LocalDate.now())
1144
                || ptam.getCollectionCommitmentDate().isEqual(LocalDate.now())) {
1145
            PartnerCollectionPlan partnerCollectionPlan = partnerCollectionPlanRepository
1146
                    .selectByLocalDate(LocalDate.now(), ptam.getFofoId(), true);
1147
            LOGGER.info("pcp" + partnerCollectionPlan);
30077 tejbeer 1148
 
31677 amit.gupta 1149
            if (partnerCollectionPlan == null) {
1150
                if (ptam.getCollectionTarget() > 0) {
30087 tejbeer 1151
 
31677 amit.gupta 1152
                    partnerCollectionPlan = new PartnerCollectionPlan();
1153
                    partnerCollectionPlan.setCreateTimestamp(LocalDateTime.now());
1154
                    partnerCollectionPlan.setAuthId(authUser.getId());
1155
                    partnerCollectionPlan.setFofoId(ptam.getFofoId());
1156
                    partnerCollectionPlan.setActive(true);
1157
                    partnerCollectionPlan.setCollectionPlan(ptam.getCollectionTarget());
1158
                    partnerCollectionPlan.setUpdatedTimestamp(LocalDateTime.now());
1159
                    partnerCollectionPlan.setCommitedTimestamp(ptam.getCollectionCommitmentDate().atStartOfDay());
1160
                    partnerCollectionPlanRepository.persist(partnerCollectionPlan);
30416 tejbeer 1161
 
31677 amit.gupta 1162
                }
30087 tejbeer 1163
 
31677 amit.gupta 1164
            } else {
30087 tejbeer 1165
 
31677 amit.gupta 1166
                if (partnerCollectionPlan.getCollectionPlan() != ptam.getCollectionTarget()) {
1167
                    float totalCollectionPlan = partnerCollectionPlan.getCollectionPlan() + 10000;
1168
                    if (authUser.getId() == partnerCollectionPlan.getAuthId()) {
30087 tejbeer 1169
 
31677 amit.gupta 1170
                        if (authUser.getEmailId().equals("tarun.verma@smartdukaan.com")
1171
                                || authUser.getEmailId().equals("rakesh.sonawane@smartdukaan.com")
1172
                                || ptam.getCollectionTarget() >= totalCollectionPlan) {
1173
                            partnerCollectionPlan.setCollectionPlan(ptam.getCollectionTarget());
1174
                            partnerCollectionPlan.setActive(true);
1175
                            partnerCollectionPlan
1176
                                    .setCommitedTimestamp(ptam.getCollectionCommitmentDate().atStartOfDay());
1177
                            partnerCollectionPlan.setUpdatedTimestamp(LocalDateTime.now());
1178
                        } else {
1179
                            throw new ProfitMandiBusinessException("collection target", "",
1180
                                    "collection target should be more than " + totalCollectionPlan);
1181
                        }
30087 tejbeer 1182
 
31677 amit.gupta 1183
                    } else {
30137 tejbeer 1184
 
31677 amit.gupta 1185
                        if (authUser.getEmailId().equals("tarun.verma@smartdukaan.com")
1186
                                || authUser.getEmailId().equals("rakesh.sonawane@smartdukaan.com")
1187
                                || ptam.getCollectionTarget() >= totalCollectionPlan) {
30137 tejbeer 1188
 
31677 amit.gupta 1189
                            partnerCollectionPlan.setActive(false);
1190
                            partnerCollectionPlan.setUpdatedTimestamp(LocalDateTime.now());
1191
                            partnerCollectionPlan = new PartnerCollectionPlan();
1192
                            partnerCollectionPlan.setCreateTimestamp(LocalDateTime.now());
1193
                            partnerCollectionPlan.setAuthId(authUser.getId());
1194
                            partnerCollectionPlan.setFofoId(ptam.getFofoId());
1195
                            partnerCollectionPlan.setActive(true);
1196
                            partnerCollectionPlan
1197
                                    .setCommitedTimestamp(ptam.getSecondaryCommitmentDate().atStartOfDay());
1198
                            partnerCollectionPlan.setCollectionPlan(ptam.getCollectionTarget());
1199
                            partnerCollectionPlan.setUpdatedTimestamp(LocalDateTime.now());
1200
                            partnerCollectionPlanRepository.persist(partnerCollectionPlan);
1201
                        } else {
1202
                            throw new ProfitMandiBusinessException("collection target", "",
1203
                                    "collection target should be more than " + totalCollectionPlan);
1204
                        }
1205
                    }
1206
                }
30137 tejbeer 1207
 
31677 amit.gupta 1208
                if ((LocalDate.now().atStartOfDay().equals(ptam.getCollectionCommitmentDate().atStartOfDay())
1209
                        || ptam.getCollectionCommitmentDate().atStartOfDay().isAfter(LocalDate.now().atStartOfDay()))
1210
                        && partnerCollectionPlan.getCollectionPlan() == ptam.getCollectionTarget()) {
1211
                    partnerCollectionPlan.setCommitedTimestamp(ptam.getCollectionCommitmentDate().atStartOfDay());
1212
                    partnerCollectionPlan.setUpdatedTimestamp(LocalDateTime.now());
1213
                }
30416 tejbeer 1214
 
31677 amit.gupta 1215
            }
30433 tejbeer 1216
 
31677 amit.gupta 1217
            PartnerCollectionRemark pcr = new PartnerCollectionRemark();
1218
            pcr.setFofoId(ptam.getFofoId());
1219
            pcr.setAuthId(authUser.getId());
1220
            pcr.setMessage("Collection plan for" + ptam.getCollectionCommitmentDate());
1221
            pcr.setRemark(CollectionRemark.COLLECTION_PLAN);
1222
            pcr.setCreateTimestamp(LocalDateTime.now());
1223
            partnerCollectionRemarkRepository.persist(pcr);
1224
        } else {
1225
            throw new ProfitMandiBusinessException("Date", "",
1226
                    "you can't select the back date " + ptam.getCollectionCommitmentDate());
1227
        }
30077 tejbeer 1228
 
31677 amit.gupta 1229
        for (Entry<String, PartnerSecondaryPlanModel> pspm : ptam.getPartnerSecondaryModel().entrySet()) {
30087 tejbeer 1230
 
31677 amit.gupta 1231
            if (ptam.getCollectionCommitmentDate().isAfter(LocalDate.now())
1232
                    || ptam.getCollectionCommitmentDate().isEqual(LocalDate.now())) {
1233
                PartnerSecondaryPlanModel plan = pspm.getValue();
1234
                PartnerSecondaryPlan psp = partnerSecondaryPlanRepository.selectByLocalDateBrand(plan.getBrand(),
1235
                        LocalDate.now(), ptam.getFofoId(), true);
1236
                LOGGER.info("psp" + psp);
30087 tejbeer 1237
 
31677 amit.gupta 1238
                if (psp == null) {
1239
                    if (plan.getTargetPlan() != null && plan.getTargetPlan() > 0) {
30087 tejbeer 1240
 
31677 amit.gupta 1241
                        psp = new PartnerSecondaryPlan();
1242
                        psp.setAuthId(authUser.getId());
1243
                        psp.setBrand(pspm.getKey());
1244
                        psp.setFofoId(pspm.getValue().getFofoId());
1245
                        psp.setSecondaryPlan(pspm.getValue().getTargetPlan());
1246
                        psp.setCreateTimestamp(LocalDateTime.now());
1247
                        psp.setUpdatedTimestamp(LocalDateTime.now());
1248
                        psp.setCommitedTimestamp(ptam.getSecondaryCommitmentDate().atStartOfDay());
1249
                        psp.setActive(true);
1250
                        partnerSecondaryPlanRepository.persist(psp);
1251
                    }
30087 tejbeer 1252
 
31677 amit.gupta 1253
                } else {
1254
                    if (plan.getTargetPlan() != psp.getSecondaryPlan()) {
1255
                        float totalSecondaryPlan = psp.getSecondaryPlan() + 10000;
1256
                        if (authUser.getId() == plan.getAuthId()) {
1257
                            if (authUser.getEmailId().equals("tarun.verma@smartdukaan.com")
1258
                                    || authUser.getEmailId().equals("rakesh.sonawane@smartdukaan.com")
1259
                                    || plan.getTargetPlan() >= totalSecondaryPlan) {
1260
                                psp.setSecondaryPlan(pspm.getValue().getTargetPlan());
1261
                                psp.setCommitedTimestamp(ptam.getSecondaryCommitmentDate().atStartOfDay());
1262
                                psp.setUpdatedTimestamp(LocalDateTime.now());
1263
                                psp.setActive(true);
1264
                            } else {
1265
                                throw new ProfitMandiBusinessException("secondary target", "",
1266
                                        "secondary target should be more than " + totalSecondaryPlan);
1267
                            }
30087 tejbeer 1268
 
31677 amit.gupta 1269
                        } else {
30087 tejbeer 1270
 
31677 amit.gupta 1271
                            if (authUser.getEmailId().equals("tarun.verma@smartdukaan.com")
1272
                                    || authUser.getEmailId().equals("rakesh.sonawane@smartdukaan.com")
1273
                                    || plan.getTargetPlan() >= totalSecondaryPlan) {
30087 tejbeer 1274
 
31677 amit.gupta 1275
                                psp.setUpdatedTimestamp(LocalDateTime.now());
1276
                                psp.setActive(false);
1277
                                psp = new PartnerSecondaryPlan();
1278
                                psp.setAuthId(authUser.getId());
1279
                                psp.setBrand(pspm.getKey());
1280
                                psp.setFofoId(pspm.getValue().getFofoId());
1281
                                psp.setSecondaryPlan(pspm.getValue().getTargetPlan());
1282
                                psp.setCommitedTimestamp(ptam.getSecondaryCommitmentDate().atStartOfDay());
1283
                                psp.setCreateTimestamp(LocalDateTime.now());
1284
                                psp.setUpdatedTimestamp(LocalDateTime.now());
1285
                                psp.setActive(true);
1286
                                partnerSecondaryPlanRepository.persist(psp);
1287
                            } else {
1288
                                throw new ProfitMandiBusinessException("secondary target", "",
1289
                                        "secondary target should be more than " + totalSecondaryPlan);
1290
                            }
1291
                        }
1292
                    }
30137 tejbeer 1293
 
31677 amit.gupta 1294
                    if ((LocalDate.now().atStartOfDay().equals(ptam.getSecondaryCommitmentDate().atStartOfDay())
1295
                            || ptam.getSecondaryCommitmentDate().atStartOfDay().isAfter(LocalDate.now().atStartOfDay()))
1296
                            && plan.getTargetPlan() == psp.getSecondaryPlan()) {
1297
                        psp.setCommitedTimestamp(ptam.getSecondaryCommitmentDate().atStartOfDay());
1298
                        psp.setUpdatedTimestamp(LocalDateTime.now());
1299
                    }
30137 tejbeer 1300
 
31677 amit.gupta 1301
                }
1302
            } else {
1303
                throw new ProfitMandiBusinessException("Date", "",
1304
                        "you can't select the back date " + ptam.getSecondaryCommitmentDate());
1305
            }
30137 tejbeer 1306
 
31677 amit.gupta 1307
        }
30077 tejbeer 1308
 
31677 amit.gupta 1309
        return responseSender.ok(true);
30137 tejbeer 1310
 
31677 amit.gupta 1311
    }
30077 tejbeer 1312
 
31677 amit.gupta 1313
    @RequestMapping(value = "/uploadFranchiseeVisit", method = RequestMethod.POST)
35288 amit 1314
    public ResponseEntity<?> readCsvFileAndSetLead(HttpServletRequest request, @RequestPart MultipartFile
1315
            multipartFile) throws Throwable {
30433 tejbeer 1316
 
31677 amit.gupta 1317
        int id = (int) request.getAttribute("userId");
30433 tejbeer 1318
 
31677 amit.gupta 1319
        LOGGER.info("id" + id);
30433 tejbeer 1320
 
31677 amit.gupta 1321
        User user = userRepository.selectById(id);
30433 tejbeer 1322
 
31677 amit.gupta 1323
        AuthUser authUser = authRepository.selectByEmailOrMobile(user.getEmailId());
30433 tejbeer 1324
 
31677 amit.gupta 1325
        String fileName = multipartFile.getName();
1326
        String fileNames = multipartFile.getOriginalFilename();
30433 tejbeer 1327
 
31677 amit.gupta 1328
        LOGGER.info("fileName" + fileName);
1329
        LOGGER.info("fileNames" + fileNames);
30433 tejbeer 1330
 
31677 amit.gupta 1331
        List<CSVRecord> records = FileUtil.readFile(multipartFile);
30433 tejbeer 1332
 
31677 amit.gupta 1333
        for (CSVRecord record : records) {
1334
            FranchiseeVisit franchiseeVisit = new FranchiseeVisit();
1335
            franchiseeVisit.setFofoId(Integer.parseInt(record.get(0)));
1336
            CustomRetailer customRetailer = retailerService.getFofoRetailer(Integer.parseInt(record.get(0)));
30433 tejbeer 1337
 
31677 amit.gupta 1338
            franchiseeVisit.setPartnerName(customRetailer.getBusinessName());
1339
            franchiseeVisit.setAgenda(record.get(1));
1340
            franchiseeVisit.setCreatedTimestamp(LocalDateTime.now());
1341
            franchiseeVisit.setUpdatedTimestamp(LocalDateTime.now());
1342
            franchiseeVisit.setStatus(FranchiseeVisitStatus.OPEN);
30433 tejbeer 1343
 
31677 amit.gupta 1344
            DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd-MM-yyyy");
1345
            LOGGER.info(record.get(1));
1346
            LocalDate dateTime = LocalDate.parse(record.get(2), formatter);
30433 tejbeer 1347
 
31677 amit.gupta 1348
            franchiseeVisit.setScheduleTimestamp(dateTime.atStartOfDay());
1349
            // change
30433 tejbeer 1350
 
31677 amit.gupta 1351
            String authUserName = authUser.getFirstName() + " " + authUser.getLastName();
1352
            franchiseeVisit.setCreatedBy(authUserName);
1353
            franchiseeVisit.setAuthId(authUser.getId());
30433 tejbeer 1354
 
31677 amit.gupta 1355
            franchiseeVisitRepository.persist(franchiseeVisit);
30433 tejbeer 1356
 
31677 amit.gupta 1357
            return responseSender.ok(true);
1358
        }
30433 tejbeer 1359
 
31677 amit.gupta 1360
        return responseSender.ok(true);
30433 tejbeer 1361
 
31677 amit.gupta 1362
    }
30487 tejbeer 1363
 
31677 amit.gupta 1364
    @RequestMapping(value = "/downloadFranchiseeVisitTemplate", method = RequestMethod.GET)
35435 amit 1365
    @Transactional(readOnly = true)
31677 amit.gupta 1366
    public ResponseEntity<?> downloadFranchiseeVisitTemplate(HttpServletRequest request) throws Exception {
30487 tejbeer 1367
 
31677 amit.gupta 1368
        // ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
30487 tejbeer 1369
 
31677 amit.gupta 1370
        List<List<?>> rows = new ArrayList<>();
30487 tejbeer 1371
 
32923 ranu 1372
        ByteArrayOutputStream byteArrayOutputStream = FileUtil
31677 amit.gupta 1373
                .getCSVByteStream(Arrays.asList("Partner Id", "Agenda", "Schedule Timestamp"), rows);
30487 tejbeer 1374
 
31677 amit.gupta 1375
        try {
1376
            byteArrayOutputStream.close();
1377
        } catch (IOException e) {
1378
            // TODO Auto-generated catch block
1379
            e.printStackTrace();
1380
        }
30487 tejbeer 1381
 
31677 amit.gupta 1382
        String filename = "template.csv";
1383
        HttpHeaders headers = new HttpHeaders();
1384
        headers.add("Content-Type", "application/csv");
1385
        headers.setContentDispositionFormData(filename, filename);
30487 tejbeer 1386
 
31677 amit.gupta 1387
        headers.setCacheControl("must-revalidate, post-check=0, pre-check=0");
30487 tejbeer 1388
 
31677 amit.gupta 1389
        ResponseEntity<byte[]> response = new ResponseEntity<byte[]>(byteArrayOutputStream.toByteArray(), headers,
1390
                HttpStatus.OK);
1391
        return response;
30544 tejbeer 1392
 
31677 amit.gupta 1393
    }
30542 tejbeer 1394
 
31677 amit.gupta 1395
    @RequestMapping(value = "/markVisitAttendance", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
1396
    public ResponseEntity<?> markVisitAttendance(HttpServletRequest request, @RequestParam(name = "id") int id)
1397
            throws ProfitMandiBusinessException {
1398
        FranchiseeVisit franchiseeVisit = franchiseeVisitRepository.selectById(id);
30542 tejbeer 1399
 
31677 amit.gupta 1400
        franchiseeVisit.setVisitTimestamp(LocalDateTime.now());
30542 tejbeer 1401
 
31677 amit.gupta 1402
        return responseSender.ok(true);
30542 tejbeer 1403
 
31677 amit.gupta 1404
    }
31249 tejbeer 1405
 
31677 amit.gupta 1406
    @RequestMapping(value = "/getVisitRequests", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
35435 amit 1407
    @Transactional(readOnly = true)
31677 amit.gupta 1408
    public ResponseEntity<?> getVisitRequests(HttpServletRequest request,
1409
                                              @RequestParam(name = "gmailId") String gmailId, Model model) throws Exception {
31249 tejbeer 1410
 
31677 amit.gupta 1411
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
31249 tejbeer 1412
 
31677 amit.gupta 1413
        List<Integer> authUserIds = authService.getAllReportees(authUser.getId());
1414
        List<VisitSummaryModel> visitSummary = new ArrayList<>();
31249 tejbeer 1415
 
31677 amit.gupta 1416
        if (!authUserIds.isEmpty()) {
35397 amit 1417
            List<AuthUser> authUsers = authRepository.selectByIds(authUserIds);
31249 tejbeer 1418
 
31677 amit.gupta 1419
            List<VisitRequest> allVisitRequests = visitRequestRepository.selectByAuthIdsAndDate(authUserIds,
1420
                    LocalDate.now().minusDays(7), Arrays.asList(VisitStatus.approved, VisitStatus.pending));
1421
            LOGGER.info("allVisitRequests {}", allVisitRequests);
31249 tejbeer 1422
 
31677 amit.gupta 1423
            if (!allVisitRequests.isEmpty()) {
31249 tejbeer 1424
 
31677 amit.gupta 1425
                List<Integer> leadIds = allVisitRequests.stream().filter(x -> x.getVisitType().equals("lead"))
1426
                        .map(x -> x.getVisitId()).collect(Collectors.toList());
1427
                List<Lead> leads = new ArrayList<>();
1428
                if (!leadIds.isEmpty()) {
1429
                    leads = leadRepository.selectAllByIds(leadIds);
31249 tejbeer 1430
 
35415 amit 1431
                    // Batch fetch all LeadActivities instead of N+1
1432
                    List<LeadActivity> allLeadActivities = leadActivityRepository.selectAllByleadIds(leadIds);
1433
                    Map<Integer, List<LeadActivity>> leadActivityMap = allLeadActivities.stream()
1434
                            .collect(Collectors.groupingBy(LeadActivity::getLeadId));
1435
 
31677 amit.gupta 1436
                    for (Lead lead : leads) {
35415 amit 1437
                        List<LeadActivity> leadActivities = leadActivityMap.get(lead.getId());
1438
                        if (leadActivities != null && !leadActivities.isEmpty()) {
1439
                            lead.setScheduledTimestamp(leadActivities.get(0).getSchelduleTimestamp());
1440
                            lead.setLeadActivity(leadActivities.get(0));
1441
                        }
31677 amit.gupta 1442
                    }
1443
                }
1444
                List<Integer> franchiseeIds = allVisitRequests.stream()
1445
                        .filter(x -> x.getVisitType().equals("franchiseeVisit")).map(x -> x.getVisitId())
1446
                        .collect(Collectors.toList());
1447
                List<FranchiseeVisit> franchiseeVisits = new ArrayList<>();
1448
                if (!franchiseeIds.isEmpty()) {
1449
                    franchiseeVisits = franchiseeVisitRepository.selectAllByIds(franchiseeIds);
1450
                    LOGGER.info("franchiseeVisits {}", franchiseeVisits);
31249 tejbeer 1451
 
35415 amit 1452
                    // Batch fetch all FranchiseeActivities instead of N+1
1453
                    List<FranchiseeActivity> allFranchiseeActivities = franchiseeActivityRepository
1454
                            .selectByFranchiseeVisitIds(franchiseeIds);
1455
                    Map<Integer, List<FranchiseeActivity>> franchiseeActivityMap = allFranchiseeActivities.stream()
1456
                            .collect(Collectors.groupingBy(FranchiseeActivity::getFranchiseeVisitd));
1457
 
31677 amit.gupta 1458
                    for (FranchiseeVisit franchiseeVisit : franchiseeVisits) {
35415 amit 1459
                        List<FranchiseeActivity> franchiseeActivities = franchiseeActivityMap.get(franchiseeVisit.getId());
31677 amit.gupta 1460
                        LOGGER.info("franchiseeActivities {}", franchiseeActivities);
31249 tejbeer 1461
 
35415 amit 1462
                        if (franchiseeActivities != null && !franchiseeActivities.isEmpty()) {
1463
                            franchiseeVisit.setScheduleTimestamp(franchiseeActivities.get(0).getSchelduleTimestamp());
1464
                            franchiseeVisit.setFranchiseeActivity(franchiseeActivities.get(0));
1465
                        }
31677 amit.gupta 1466
                    }
31249 tejbeer 1467
 
31677 amit.gupta 1468
                }
31249 tejbeer 1469
 
35415 amit 1470
                // Pre-fetch all retailers using cached method (instead of N+1 getFofoRetailer calls)
1471
                Map<Integer, CustomRetailer> allRetailersMap = retailerService.getAllFofoRetailers();
1472
 
31677 amit.gupta 1473
                Map<LocalDate, List<VisitRequest>> dateWiseVisitRequest = allVisitRequests.stream()
1474
                        .collect(Collectors.groupingBy(x -> x.getScheduleTimestamp().toLocalDate()));
31249 tejbeer 1475
 
31677 amit.gupta 1476
                for (Entry<LocalDate, List<VisitRequest>> visitEntry : dateWiseVisitRequest.entrySet()) {
31249 tejbeer 1477
 
31677 amit.gupta 1478
                    LocalDate date = visitEntry.getKey();
1479
                    List<VisitRequest> visitRequests = visitEntry.getValue();
31249 tejbeer 1480
 
31677 amit.gupta 1481
                    VisitSummaryModel visitSummaryModel = new VisitSummaryModel();
31249 tejbeer 1482
 
31677 amit.gupta 1483
                    visitSummaryModel.setDate(date);
1484
                    List<Integer> dateWiseLeadEntry = visitRequests.stream()
1485
                            .filter(x -> x.getVisitType().equals("lead")).map(x -> x.getVisitId())
1486
                            .collect(Collectors.toList());
31249 tejbeer 1487
 
31677 amit.gupta 1488
                    List<Integer> dateWiseFranchiseeIds = visitRequests.stream()
1489
                            .filter(x -> x.getVisitType().equals("franchiseeVisit")).map(x -> x.getVisitId())
1490
                            .collect(Collectors.toList());
31249 tejbeer 1491
 
31677 amit.gupta 1492
                    Map<Integer, List<Lead>> filteredLeadsMap = null;
1493
                    if (!leads.isEmpty()) {
1494
                        filteredLeadsMap = leads.stream().filter(x -> dateWiseLeadEntry.contains(x.getId()))
1495
                                .collect(Collectors.groupingBy(x -> x.getAssignTo()));
31249 tejbeer 1496
 
31677 amit.gupta 1497
                    }
31249 tejbeer 1498
 
31677 amit.gupta 1499
                    Map<Integer, List<FranchiseeVisit>> filteredFranchiseeVisitsMap = null;
31249 tejbeer 1500
 
31677 amit.gupta 1501
                    if (!franchiseeVisits.isEmpty()) {
1502
                        filteredFranchiseeVisitsMap = franchiseeVisits.stream()
1503
                                .filter(x -> dateWiseFranchiseeIds.contains(x.getId()))
1504
                                .collect(Collectors.groupingBy(x -> x.getAuthId()));
31249 tejbeer 1505
 
31677 amit.gupta 1506
                    }
31249 tejbeer 1507
 
31677 amit.gupta 1508
                    List<UserVisitModel> userVisits = new ArrayList<>();
31249 tejbeer 1509
 
31677 amit.gupta 1510
                    for (AuthUser auth : authUsers) {
1511
                        UserVisitModel userVisitModel = new UserVisitModel();
1512
                        List<VisitDescriptionModel> visitDescriptions = new ArrayList<>();
31249 tejbeer 1513
 
31677 amit.gupta 1514
                        List<Lead> authLeads = new ArrayList<>();
1515
                        if (filteredLeadsMap != null) {
1516
                            authLeads = filteredLeadsMap.get(auth.getId());
31249 tejbeer 1517
 
31677 amit.gupta 1518
                        }
31249 tejbeer 1519
 
31677 amit.gupta 1520
                        if (authLeads != null && !authLeads.isEmpty()) {
1521
                            userVisitModel.setAuthUser(auth.getFullName());
31249 tejbeer 1522
 
31677 amit.gupta 1523
                            for (Lead lead : authLeads) {
31249 tejbeer 1524
 
31677 amit.gupta 1525
                                VisitRequest visitRequest = visitRequests.stream().filter(
1526
                                                x -> x.getVisitId() == lead.getId() && x.getCreatedBy() == lead.getAssignTo())
1527
                                        .findAny().orElse(null);
1528
                                VisitDescriptionModel visitDescriptionModel = new VisitDescriptionModel();
1529
                                visitDescriptionModel.setVisitId(visitRequest.getId());
1530
                                visitDescriptionModel.setVisitName(lead.getFirstName());
1531
                                visitDescriptionModel.setCity(lead.getCity());
1532
                                visitDescriptionModel.setState(lead.getState());
1533
                                visitDescriptionModel.setScheduleTime(lead.getScheduledTimestamp());
1534
                                visitDescriptionModel.setStatus(visitRequest.getStatus());
1535
                                visitDescriptionModel.setRemarks(lead.getLeadActivity().getRemark());
1536
                                visitDescriptionModel.setVisitType(visitRequest.getVisitType());
1537
                                visitDescriptions.add(visitDescriptionModel);
31249 tejbeer 1538
 
31677 amit.gupta 1539
                            }
1540
                        }
31249 tejbeer 1541
 
31677 amit.gupta 1542
                        List<FranchiseeVisit> authfranchiseeVisit = new ArrayList<>();
1543
                        if (filteredFranchiseeVisitsMap != null) {
1544
                            authfranchiseeVisit = filteredFranchiseeVisitsMap.get(auth.getId());
31249 tejbeer 1545
 
31677 amit.gupta 1546
                        }
31249 tejbeer 1547
 
31677 amit.gupta 1548
                        if (authfranchiseeVisit != null && !authfranchiseeVisit.isEmpty()) {
1549
                            userVisitModel.setAuthUser(auth.getFullName());
31249 tejbeer 1550
 
31677 amit.gupta 1551
                            for (FranchiseeVisit franchiseeVisit : authfranchiseeVisit) {
31249 tejbeer 1552
 
31677 amit.gupta 1553
                                VisitRequest visitRequest = visitRequests.stream()
1554
                                        .filter(x -> x.getVisitId() == franchiseeVisit.getId()
1555
                                                && x.getCreatedBy() == franchiseeVisit.getAuthId())
1556
                                        .findAny().orElse(null);
31249 tejbeer 1557
 
35415 amit 1558
                                CustomRetailer customRetailer = allRetailersMap.get(franchiseeVisit.getFofoId());
31677 amit.gupta 1559
                                VisitDescriptionModel visitDescriptionModel = new VisitDescriptionModel();
1560
                                visitDescriptionModel.setVisitId(visitRequest.getId());
1561
                                visitDescriptionModel.setVisitName(franchiseeVisit.getPartnerName());
35415 amit 1562
                                if (customRetailer != null && customRetailer.getAddress() != null) {
1563
                                    visitDescriptionModel.setCity(customRetailer.getAddress().getCity());
1564
                                    visitDescriptionModel.setState(customRetailer.getAddress().getState());
1565
                                }
31677 amit.gupta 1566
                                visitDescriptionModel.setScheduleTime(
1567
                                        franchiseeVisit.getFranchiseeActivity().getSchelduleTimestamp());
1568
                                visitDescriptionModel.setStatus(visitRequest.getStatus());
1569
                                visitDescriptionModel.setRemarks(franchiseeVisit.getAgenda());
1570
                                visitDescriptionModel.setVisitType(visitRequest.getVisitType());
31249 tejbeer 1571
 
31677 amit.gupta 1572
                                visitDescriptions.add(visitDescriptionModel);
31249 tejbeer 1573
 
31677 amit.gupta 1574
                            }
1575
                        }
31249 tejbeer 1576
 
31677 amit.gupta 1577
                        userVisitModel.setVisitDescriptions(visitDescriptions);
1578
                        LOGGER.info("userVisit {}", userVisitModel);
31249 tejbeer 1579
 
31677 amit.gupta 1580
                        if (userVisitModel.getAuthUser() != null) {
1581
                            userVisits.add(userVisitModel);
1582
                        }
31249 tejbeer 1583
 
31677 amit.gupta 1584
                    }
31249 tejbeer 1585
 
31677 amit.gupta 1586
                    visitSummaryModel.setUserVisits(userVisits);
31249 tejbeer 1587
 
31677 amit.gupta 1588
                    visitSummary.add(visitSummaryModel);
31249 tejbeer 1589
 
31677 amit.gupta 1590
                }
31249 tejbeer 1591
 
31677 amit.gupta 1592
            }
31249 tejbeer 1593
 
31677 amit.gupta 1594
        }
1595
        return responseSender.ok(visitSummary);
31249 tejbeer 1596
 
31677 amit.gupta 1597
    }
31249 tejbeer 1598
 
31677 amit.gupta 1599
    @RequestMapping(value = "/visitRequest", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35288 amit 1600
    public ResponseEntity<?> visitRequest(HttpServletRequest request, @RequestParam(name = "gmailId") String
1601
                                                  gmailId,
31677 amit.gupta 1602
                                          @RequestParam(name = "visitId") int visitId, @RequestParam(name = "status") VisitStatus status, Model model)
1603
            throws Exception {
1604
        AuthUser authUser = authRepository.selectByGmailId(gmailId);
31249 tejbeer 1605
 
31677 amit.gupta 1606
        VisitRequest visitRequest = visitRequestRepository.selectById(visitId);
1607
        visitRequest.setActionedBy(authUser.getId());
1608
        visitRequest.setStatus(status);
1609
        visitRequest.setUpdatedTimestamp(LocalDateTime.now());
1610
        if (status.equals(VisitStatus.approved)) {
1611
            visitRequest.setApprovedTimestamp(LocalDateTime.now());
1612
        }
31249 tejbeer 1613
 
31677 amit.gupta 1614
        SendNotificationModel sendNotificationModel = new SendNotificationModel();
1615
        sendNotificationModel.setCampaignName("Visit Request");
1616
        sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(1));
1617
        sendNotificationModel.setTitle("Visit Request");
1618
        String message = "Visit Request has been " + status + " for scheduled time on "
1619
                + visitRequest.getScheduleTimestamp().toLocalDate();
31249 tejbeer 1620
 
31677 amit.gupta 1621
        sendNotificationModel.setMessage(message);
1622
        sendNotificationModel.setMessageType(MessageType.notification);
1623
        User user = userRepository.selectByEmailId(gmailId);
1624
        sendNotificationModel.setUserIds(new ArrayList<>(user.getId()));
31249 tejbeer 1625
 
31677 amit.gupta 1626
        notificationService.sendNotificationToAll(sendNotificationModel);
31249 tejbeer 1627
 
31677 amit.gupta 1628
        return responseSender.ok(true);
31249 tejbeer 1629
 
31677 amit.gupta 1630
    }
31249 tejbeer 1631
 
34301 ranu 1632
    @Autowired
1633
    RbmRatingRepository rbmRatingRepository;
1634
 
34322 ranu 1635
    @Autowired
1636
    SalesRatingRepository salesRatingRepository;
1637
 
34301 ranu 1638
    @RequestMapping(value = "/rbmRating", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
35288 amit 1639
    public ResponseEntity<?> rbmRating(HttpServletRequest request, @RequestBody RbmSalesRatingRequest
1640
            rbmSalesRatingRequest, Model model) throws Exception {
34301 ranu 1641
        int userId = (int) request.getAttribute(ProfitMandiConstants.USER_ID);
1642
        UserCart uc = userAccountRepository.getUserCart(userId);
1643
        int fofoId = uc.getUserId();
34322 ranu 1644
 
34301 ranu 1645
        int rbmL1 = csService.getAuthUserId(ProfitMandiConstants.TICKET_CATEGORY_RBM, EscalationType.L1, fofoId);
34322 ranu 1646
        int salesL1Id = csService.getAuthUserId(ProfitMandiConstants.TICKET_CATEGORY_SALES, EscalationType.L1, fofoId);
34301 ranu 1647
 
1648
        YearMonth currentMonth = YearMonth.now();
1649
        LocalDateTime startOfMonth = currentMonth.atDay(1).atStartOfDay();
1650
        LocalDateTime endOfMonth = currentMonth.atEndOfMonth().atTime(23, 59, 59);
1651
 
34322 ranu 1652
        // Check if RBM rating already exists
1653
        List<RbmRating> existingRbmRatings = rbmRatingRepository.findByFofoIdAndRbmIdForCurrentMonth(fofoId, rbmL1, startOfMonth, endOfMonth);
1654
        if (!existingRbmRatings.isEmpty()) {
34301 ranu 1655
            return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Rating for this month already exists.");
1656
        }
1657
 
34322 ranu 1658
        // Check if Sales Person rating exists (optional check)
1659
        List<SalesRating> existingSalesRatings = salesRatingRepository.findByFofoIdAndSalesL1IdForCurrentMonth(fofoId, salesL1Id, startOfMonth, endOfMonth);
1660
        if (!existingSalesRatings.isEmpty()) {
1661
            return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Rating for this month already exists.");
1662
        }
34301 ranu 1663
 
34322 ranu 1664
        // Save RBM rating
34301 ranu 1665
        RbmRating rbmRating = new RbmRating();
34322 ranu 1666
        rbmRating.setComment(rbmSalesRatingRequest.getRbmComment());
1667
        rbmRating.setRating(rbmSalesRatingRequest.getRbmRating());
34301 ranu 1668
        rbmRating.setFofoId(fofoId);
1669
        rbmRating.setRbmId(rbmL1);
1670
        rbmRating.setCreateTimeStamp(LocalDateTime.now());
1671
        rbmRatingRepository.persist(rbmRating);
1672
 
34322 ranu 1673
        // Save Sales Person rating
1674
        SalesRating salesRating = new SalesRating();
1675
        salesRating.setComment(rbmSalesRatingRequest.getSalesComment());
1676
        salesRating.setRating(rbmSalesRatingRequest.getSalesRating());
1677
        salesRating.setFofoId(fofoId);
1678
        salesRating.setSalesL1Id(salesL1Id);
1679
        salesRating.setCreateTimeStamp(LocalDateTime.now());
1680
        salesRatingRepository.persist(salesRating);
1681
 
1682
        return responseSender.ok("Rating submitted successfully.");
34301 ranu 1683
    }
1684
 
1685
 
30077 tejbeer 1686
}