Subversion Repositories SmartDukaan

Rev

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