Subversion Repositories SmartDukaan

Rev

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