Subversion Repositories SmartDukaan

Rev

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

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