Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
28217 tejbeer 1
package com.smartdukaan.cron.scheduled;
23723 amit.gupta 2
 
24542 amit.gupta 3
import com.google.common.collect.Lists;
25300 tejbeer 4
import com.google.gson.Gson;
29488 manish 5
import com.razorpay.Payment;
32421 amit.gupta 6
import com.smartdukaan.cron.itelImeiActivation.ItelImeiActivationNewService;
29488 manish 7
import com.smartdukaan.cron.itelImeiActivation.ItelImeiActivationService;
8
import com.smartdukaan.cron.itelImeiActivation.TecnoImeiActivation;
32482 amit.gupta 9
import com.smartdukaan.cron.scheduled.runnables.PurchaseMigration;
32511 amit.gupta 10
import com.spice.profitmandi.common.enumuration.*;
24121 govind 11
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
32421 amit.gupta 12
import com.spice.profitmandi.common.model.*;
24681 amit.gupta 13
import com.spice.profitmandi.common.services.ReporticoService;
29814 tejbeer 14
import com.spice.profitmandi.common.services.mandii.AccountStatusResponseOut;
15
import com.spice.profitmandi.common.services.mandii.EligibilityStatusEnum;
16
import com.spice.profitmandi.common.services.mandii.MandiiService;
24002 amit.gupta 17
import com.spice.profitmandi.common.util.FileUtil;
23929 amit.gupta 18
import com.spice.profitmandi.common.util.FormattingUtils;
27678 amit.gupta 19
import com.spice.profitmandi.common.util.PdfUtils;
23929 amit.gupta 20
import com.spice.profitmandi.common.util.Utils;
24592 amit.gupta 21
import com.spice.profitmandi.common.util.Utils.Attachment;
29308 tejbeer 22
import com.spice.profitmandi.common.web.client.RestClient;
25300 tejbeer 23
import com.spice.profitmandi.dao.Interface.Campaign;
32511 amit.gupta 24
import com.spice.profitmandi.dao.cart.CartService;
25590 amit.gupta 25
import com.spice.profitmandi.dao.entity.auth.AuthUser;
30421 tejbeer 26
import com.spice.profitmandi.dao.entity.auth.PartnerCollectionRemark;
25800 tejbeer 27
import com.spice.profitmandi.dao.entity.catalog.FocusedModel;
25609 amit.gupta 28
import com.spice.profitmandi.dao.entity.catalog.Item;
24590 amit.gupta 29
import com.spice.profitmandi.dao.entity.catalog.Scheme;
31388 amit.gupta 30
import com.spice.profitmandi.dao.entity.catalog.TagListing;
25590 amit.gupta 31
import com.spice.profitmandi.dao.entity.cs.Position;
26283 tejbeer 32
import com.spice.profitmandi.dao.entity.cs.Ticket;
28769 amit.gupta 33
import com.spice.profitmandi.dao.entity.dtr.User;
32421 amit.gupta 34
import com.spice.profitmandi.dao.entity.dtr.*;
35
import com.spice.profitmandi.dao.entity.fofo.*;
36
import com.spice.profitmandi.dao.entity.inventory.*;
37
import com.spice.profitmandi.dao.entity.transaction.*;
38
import com.spice.profitmandi.dao.entity.user.*;
32511 amit.gupta 39
import com.spice.profitmandi.dao.entity.warehouse.WarehouseInventoryItem;
40
import com.spice.profitmandi.dao.entity.warehouse.WarehouseScan;
30421 tejbeer 41
import com.spice.profitmandi.dao.enumuration.auth.CollectionRemark;
24250 amit.gupta 42
import com.spice.profitmandi.dao.enumuration.catalog.SchemeType;
25598 amit.gupta 43
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
26790 tejbeer 44
import com.spice.profitmandi.dao.enumuration.dtr.RefferalStatus;
29814 tejbeer 45
import com.spice.profitmandi.dao.enumuration.fofo.Gateway;
31332 amit.gupta 46
import com.spice.profitmandi.dao.enumuration.fofo.PaymentStatus;
32511 amit.gupta 47
import com.spice.profitmandi.dao.enumuration.fofo.ReturnType;
24242 amit.gupta 48
import com.spice.profitmandi.dao.enumuration.fofo.ScanType;
32081 tejbeer 49
import com.spice.profitmandi.dao.enumuration.inventory.VendorCatalogPricingStatus;
30913 tejbeer 50
import com.spice.profitmandi.dao.enumuration.transaction.CreditRisk;
30859 tejbeer 51
import com.spice.profitmandi.dao.enumuration.transaction.LoanReferenceType;
25609 amit.gupta 52
import com.spice.profitmandi.dao.enumuration.transaction.PriceDropImeiStatus;
32421 amit.gupta 53
import com.spice.profitmandi.dao.enumuration.transaction.SchemePayoutStatus;
54
import com.spice.profitmandi.dao.model.*;
25590 amit.gupta 55
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
30421 tejbeer 56
import com.spice.profitmandi.dao.repository.auth.PartnerCollectionRemarkRepository;
32421 amit.gupta 57
import com.spice.profitmandi.dao.repository.catalog.*;
58
import com.spice.profitmandi.dao.repository.cs.*;
59
import com.spice.profitmandi.dao.repository.dtr.*;
60
import com.spice.profitmandi.dao.repository.fofo.*;
61
import com.spice.profitmandi.dao.repository.inventory.*;
62
import com.spice.profitmandi.dao.repository.transaction.*;
24542 amit.gupta 63
import com.spice.profitmandi.dao.repository.user.AddressRepository;
25721 tejbeer 64
import com.spice.profitmandi.dao.repository.user.UserRepository;
32421 amit.gupta 65
import com.spice.profitmandi.dao.repository.warehouse.*;
31604 tejbeer 66
import com.spice.profitmandi.dao.service.solr.FofoSolr;
32421 amit.gupta 67
import com.spice.profitmandi.service.*;
31332 amit.gupta 68
import com.spice.profitmandi.service.integrations.CCAvenuePaymentService;
28368 tejbeer 69
import com.spice.profitmandi.service.integrations.RazorpayPaymentService;
30858 amit.gupta 70
import com.spice.profitmandi.service.integrations.bharti.model.BAGInsuranceModel;
25694 amit.gupta 71
import com.spice.profitmandi.service.integrations.toffee.ToffeeService;
32421 amit.gupta 72
import com.spice.profitmandi.service.inventory.*;
31746 amit.gupta 73
import com.spice.profitmandi.service.offers.OfferService;
25335 amit.gupta 74
import com.spice.profitmandi.service.order.OrderService;
24431 amit.gupta 75
import com.spice.profitmandi.service.pricing.PriceDropService;
23724 amit.gupta 76
import com.spice.profitmandi.service.recharge.provider.OxigenRechargeProviderService;
77
import com.spice.profitmandi.service.recharge.provider.ThinkWalnutDigitalRechargeProviderService;
78
import com.spice.profitmandi.service.scheme.SchemeService;
29668 tejbeer 79
import com.spice.profitmandi.service.serviceConfig.ServiceConfigService;
31008 amit.gupta 80
import com.spice.profitmandi.service.transaction.CreditNoteService;
30859 tejbeer 81
import com.spice.profitmandi.service.transaction.SDCreditService;
23929 amit.gupta 82
import com.spice.profitmandi.service.transaction.TransactionService;
83
import com.spice.profitmandi.service.user.RetailerService;
32511 amit.gupta 84
import com.spice.profitmandi.service.wallet.CommonPaymentService;
23739 amit.gupta 85
import com.spice.profitmandi.service.wallet.WalletService;
32421 amit.gupta 86
import com.spice.profitmandi.service.warehouse.PurchaseOrderService;
32511 amit.gupta 87
import com.spice.profitmandi.service.warehouse.WarehouseInventoryService;
25721 tejbeer 88
import in.shop2020.model.v1.order.OrderStatus;
29308 tejbeer 89
import in.shop2020.model.v1.order.WalletReferenceType;
90
import okhttp3.OkHttpClient;
91
import okhttp3.Request;
30119 amit.gupta 92
import okhttp3.Response;
32421 amit.gupta 93
import org.apache.commons.io.output.ByteArrayOutputStream;
94
import org.apache.commons.lang.StringUtils;
95
import org.apache.http.client.methods.CloseableHttpResponse;
96
import org.apache.http.client.methods.HttpPost;
97
import org.apache.http.conn.HttpHostConnectException;
98
import org.apache.http.entity.StringEntity;
99
import org.apache.http.impl.client.CloseableHttpClient;
100
import org.apache.http.impl.client.HttpClients;
101
import org.apache.logging.log4j.LogManager;
102
import org.apache.logging.log4j.Logger;
103
import org.hibernate.Session;
104
import org.hibernate.SessionFactory;
105
import org.hibernate.query.NativeQuery;
106
import org.json.JSONArray;
107
import org.json.JSONObject;
108
import org.json.XML;
109
import org.springframework.beans.factory.annotation.Autowired;
110
import org.springframework.beans.factory.annotation.Qualifier;
111
import org.springframework.beans.factory.annotation.Value;
112
import org.springframework.core.io.ByteArrayResource;
113
import org.springframework.core.io.InputStreamSource;
114
import org.springframework.mail.javamail.JavaMailSender;
115
import org.springframework.mail.javamail.MimeMessageHelper;
116
import org.springframework.stereotype.Component;
117
import org.springframework.transaction.annotation.Transactional;
31640 tejbeer 118
 
32421 amit.gupta 119
import javax.mail.MessagingException;
120
import javax.mail.internet.InternetAddress;
121
import javax.mail.internet.MimeMessage;
122
import java.io.*;
123
import java.math.BigDecimal;
124
import java.math.RoundingMode;
125
import java.nio.file.Files;
126
import java.nio.file.Paths;
127
import java.sql.Timestamp;
128
import java.text.DecimalFormat;
129
import java.time.*;
130
import java.time.format.DateTimeFormatter;
131
import java.time.temporal.ChronoField;
132
import java.time.temporal.ChronoUnit;
133
import java.util.*;
134
import java.util.Map.Entry;
135
import java.util.stream.Collectors;
136
import java.util.stream.Stream;
32060 amit.gupta 137
 
32439 tejbeer 138
 
32421 amit.gupta 139
import static java.util.stream.Collectors.groupingBy;
140
import static java.util.stream.Collectors.mapping;
141
 
142
 
23723 amit.gupta 143
@Component
23724 amit.gupta 144
@Transactional(rollbackFor = Throwable.class)
23723 amit.gupta 145
public class ScheduledTasks {
146
 
31697 amit.gupta 147
    @Value("${oxigen.recharge.transaction.url}")
148
    private String oxigenRechargeTransactionUrl;
23723 amit.gupta 149
 
31697 amit.gupta 150
    @Value("${oxigen.recharge.enquiry.url}")
151
    private String oxigenRechargeEnquiryUrl;
24533 govind 152
 
31697 amit.gupta 153
    @Autowired
32482 amit.gupta 154
    PurchaseMigration purchaseMigration;
155
 
156
    @Autowired
31697 amit.gupta 157
    private RegionRepository regionRepository;
29668 tejbeer 158
 
31697 amit.gupta 159
    @Autowired
160
    private ServiceConfigService serviceConfigService;
29801 manish 161
 
31697 amit.gupta 162
    @Autowired
163
    private TecnoImeiActivation tecnoImeiActivation;
28205 tejbeer 164
 
31697 amit.gupta 165
    private static final DateTimeFormatter leadTimeFormatter = DateTimeFormatter.ofPattern("d LLL, hh:mm a");
27088 tejbeer 166
 
31697 amit.gupta 167
    @Autowired
168
    private PartnerRegionRepository partnerRegionRepository;
28790 amit.gupta 169
 
31697 amit.gupta 170
    @Autowired
171
    private EmployeeAttendanceRepository employeeAttendanceRepository;
27088 tejbeer 172
 
31697 amit.gupta 173
    @Autowired
174
    VivoImeiActivationService vivoImeiActivationService;
29488 manish 175
 
31697 amit.gupta 176
    @Autowired
177
    ItelImeiActivationService itelImeiActivationService;
29488 manish 178
 
31697 amit.gupta 179
    @Autowired
180
    private PartnerTypeChangeService partnerTypeChangeService;
25598 amit.gupta 181
 
31697 amit.gupta 182
    @Autowired
183
    private ActivatedImeiRepository activatedImeiRepository;
26408 amit.gupta 184
 
31697 amit.gupta 185
    @Autowired
186
    private LineItemRepository lineItemRepository;
29451 manish 187
 
31697 amit.gupta 188
    @Autowired
189
    private LeadRepository leadRepository;
25927 amit.gupta 190
 
31697 amit.gupta 191
    @Autowired
192
    private AuthRepository authRepository;
25503 amit.gupta 193
 
31697 amit.gupta 194
    @Autowired
195
    private PriceDropService priceDropService;
26283 tejbeer 196
 
31697 amit.gupta 197
    @Autowired
198
    private FranchiseeVisitRepository franchiseeVisitRepository;
26790 tejbeer 199
 
31697 amit.gupta 200
    @Autowired
201
    private FranchiseeActivityRepository franchiseeActivityRepository;
26790 tejbeer 202
 
31697 amit.gupta 203
    @Autowired
204
    private HdfcPaymentRepository hdfcPaymentRepository;
26790 tejbeer 205
 
31697 amit.gupta 206
    @Autowired
207
    private CsService csService;
25846 amit.gupta 208
 
31697 amit.gupta 209
    @Autowired
210
    private SaholicInventoryService saholicInventoryService;
27208 tejbeer 211
 
31697 amit.gupta 212
    @Autowired
213
    private InsurancePolicyRepository insurancePolicyRepository;
23723 amit.gupta 214
 
31697 amit.gupta 215
    @Autowired
216
    private ToffeeService toffeeService;
25694 amit.gupta 217
 
31697 amit.gupta 218
    @Value("${oxigen.recharge.auth.key}")
219
    private String oxigenRechargeAuthKey;
23724 amit.gupta 220
 
31697 amit.gupta 221
    @Value("${oxigen.recharge.validation.url}")
222
    private String oxigenRechargeValidationUrl;
23724 amit.gupta 223
 
31697 amit.gupta 224
    @Value("${oxigen.recharge.validation.auth.key}")
225
    private String oxigenRechargeValidationAuthKey;
23724 amit.gupta 226
 
31697 amit.gupta 227
    @Value("${think.walnut.digital.recharge.transaction.mobile.url}")
228
    private String thinkWalnutDigitalRechargeTransactionMobileUrl;
23724 amit.gupta 229
 
31697 amit.gupta 230
    @Value("${think.walnut.digital.recharge.transaction.dth.url}")
231
    private String thinkWalnutDigitalRechargeTransactionDthUrl;
23724 amit.gupta 232
 
31697 amit.gupta 233
    @Value("${think.walnut.digital.recharge.enquiry.url}")
234
    private String thinkWalnutDigitalRechargeEnquiryUrl;
23724 amit.gupta 235
 
31697 amit.gupta 236
    @Value("${think.walnut.digital.recharge.balance.url}")
237
    private String thinkWalnutDigitalRechargeBalanceUrl;
23724 amit.gupta 238
 
31697 amit.gupta 239
    @Value("${think.walnut.digital.recharge.username}")
240
    private String thinkWalnutDigitalRechargeUserName;
23724 amit.gupta 241
 
31697 amit.gupta 242
    @Value("${think.walnut.digital.recharge.password}")
243
    private String thinkWalnutDigitalRechargePassword;
23724 amit.gupta 244
 
31697 amit.gupta 245
    @Value("${think.walnut.digital.recharge.auth.key}")
246
    private String thinkWalnutDigitalRechargeAuthKey;
23724 amit.gupta 247
 
31697 amit.gupta 248
    @Autowired
249
    private PurchaseRepository purchaseRepository;
23724 amit.gupta 250
 
31697 amit.gupta 251
    @Autowired
252
    private PriceDropIMEIRepository priceDropIMEIRepository;
25609 amit.gupta 253
 
31697 amit.gupta 254
    @Autowired
255
    PriceDropRepository priceDropRepository;
25609 amit.gupta 256
 
31697 amit.gupta 257
    @Autowired
258
    private PartnerTypeChangeRepository partnerTypeChangeRepository;
28368 tejbeer 259
 
31697 amit.gupta 260
    @Autowired
261
    private SchemeService schemeService;
24683 amit.gupta 262
 
31697 amit.gupta 263
    @Autowired
264
    private ServiceConfigRepository serviceConfigRepository;
29668 tejbeer 265
 
32061 amit.gupta 266
    @Autowired
267
    private RetailerBlockBrandsRepository retailerBlockBrandsRepository;
268
 
31697 amit.gupta 269
    @Value("${delhivery.tracking.token}")
270
    private String token;
29308 tejbeer 271
 
31886 tejbeer 272
    private static final String[] STOCK_AGEING_MAIL_LIST = new String[]{"uday.singh@smartudkaan.com", "mohinder.mutreja@smartdukaan.com", "ankit.bhatia@smartdukaan.com", "tarun.verma@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "manish.gupta@smartdukaan.com"};
25609 amit.gupta 273
 
31886 tejbeer 274
    private static final String[] ITEMWISE_PENDING_INDENT_MAIL_LIST = new String[]{"kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "uday.singh@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "niranjan.kala@smartdukaan.com"};
25609 amit.gupta 275
 
32580 amit.gupta 276
    private static final String[] INDENT_TERTIARY_MAIL_LIST = new String[]{"uday.singh@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "nishant.ohri@smartdukaan.com"};
28709 amit.gupta 277
 
31886 tejbeer 278
    private static final String[] EMPLOYEE_ATTENDANCE_MAIL_LIST = new String[]{"sm@smartdukaan.com", "sm@smartdukaan.com"};
28790 amit.gupta 279
 
31697 amit.gupta 280
    private List<OrderStatus> orderStatusList = Arrays.asList(OrderStatus.SUBMITTED_FOR_PROCESSING);
25721 tejbeer 281
 
31697 amit.gupta 282
    @Autowired
283
    private ReporticoService reporticoService;
23724 amit.gupta 284
 
31697 amit.gupta 285
    @Autowired
286
    private PartnerInvestmentService partnerInvestmentService;
25598 amit.gupta 287
 
31697 amit.gupta 288
    @Autowired
289
    private PositionRepository positionRepository;
24337 amit.gupta 290
 
31697 amit.gupta 291
    @Autowired
292
    private FofoOrderItemRepository fofoOrderItemRepository;
25865 amit.gupta 293
 
31697 amit.gupta 294
    @Autowired
295
    private NotificationService notificationService;
24542 amit.gupta 296
 
31697 amit.gupta 297
    @Autowired
298
    private PartnerDailyInvestmentRepository partnerDailyInvestmentRepository;
24277 amit.gupta 299
 
31697 amit.gupta 300
    @Autowired
301
    private SchemeInOutRepository schemeInOutRepository;
24241 amit.gupta 302
 
31697 amit.gupta 303
    @Autowired
304
    private RechargeTransactionRepository rechargeTransactionRepository;
23724 amit.gupta 305
 
31697 amit.gupta 306
    @Autowired
307
    private CustomerAddressRepository customerAddressRepository;
24542 amit.gupta 308
 
31697 amit.gupta 309
    @Autowired
310
    private RechargeProviderCreditWalletHistoryRepository rechargeProviderCreditWalletHistoryRepository;
23724 amit.gupta 311
 
31697 amit.gupta 312
    @Autowired
313
    private FofoLineItemRepository fofoLineItemRepository;
24590 amit.gupta 314
 
31697 amit.gupta 315
    @Autowired
316
    private FofoOrderRepository fofoOrderRepository;
24587 amit.gupta 317
 
31697 amit.gupta 318
    @Autowired
319
    private UserWalletHistoryRepository userWalletHistoryRepository;
24250 amit.gupta 320
 
31697 amit.gupta 321
    @Autowired
322
    private UserWalletRepository userWalletRepository;
24587 amit.gupta 323
 
31697 amit.gupta 324
    @Autowired
325
    private InventoryItemRepository inventoryItemRepository;
23929 amit.gupta 326
 
31697 amit.gupta 327
    @Autowired
328
    private WalletService walletService;
23724 amit.gupta 329
 
31697 amit.gupta 330
    @Autowired
331
    private ThinkWalnutDigitalRechargeProviderService thinkWalnutDigitalRechargeProviderService;
23724 amit.gupta 332
 
31697 amit.gupta 333
    @Autowired
334
    private OxigenRechargeProviderService oxigenRechargeProviderService;
23724 amit.gupta 335
 
31697 amit.gupta 336
    @Autowired
337
    private RechargeProviderRepository rechargeProviderRepository;
23724 amit.gupta 338
 
31697 amit.gupta 339
    @Autowired
340
    private ScanRecordRepository scanRecordRepository;
24242 amit.gupta 341
 
31697 amit.gupta 342
    @Autowired
343
    private DailyRechargeRepository dailyRechargeRepository;
23724 amit.gupta 344
 
31697 amit.gupta 345
    @Autowired
346
    private FofoStoreRepository fofoStoreRepository;
24177 govind 347
 
31697 amit.gupta 348
    @Value("${prod}")
349
    private boolean prod;
26945 amit.gupta 350
 
31697 amit.gupta 351
    @Autowired
352
    private StateGstRateRepository stateGstRateRepository;
23724 amit.gupta 353
 
31697 amit.gupta 354
    @Autowired
355
    private RetailerService retailerService;
23929 amit.gupta 356
 
31697 amit.gupta 357
    @Autowired
358
    private TransactionService transactionService;
24250 amit.gupta 359
 
31697 amit.gupta 360
    @Autowired
361
    private ItemRepository itemRepository;
23929 amit.gupta 362
 
31697 amit.gupta 363
    @Autowired
364
    private OrderRepository orderRepository;
25351 tejbeer 365
 
31697 amit.gupta 366
    @Autowired
367
    private OrderService orderService;
23929 amit.gupta 368
 
31697 amit.gupta 369
    @Autowired
370
    private SchemeRepository schemeRepository;
24241 amit.gupta 371
 
31697 amit.gupta 372
    @Autowired
373
    private SchemeItemRepository schemeItemRepository;
31612 tejbeer 374
 
31697 amit.gupta 375
    @Autowired
376
    private JavaMailSender mailSender;
24177 govind 377
 
31697 amit.gupta 378
    @Autowired
379
    private PartnerTargetRepository partnerTargetRepository;
24002 amit.gupta 380
 
31697 amit.gupta 381
    @Autowired
382
    @Qualifier(value = "googleMailSender")
383
    private JavaMailSender googleMailSender;
23929 amit.gupta 384
 
31697 amit.gupta 385
    @Autowired
386
    private InventoryService inventoryService;
23929 amit.gupta 387
 
31697 amit.gupta 388
    @Autowired
389
    private AddressRepository addressRepository;
24542 amit.gupta 390
 
31697 amit.gupta 391
    @Autowired
392
    private RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
24542 amit.gupta 393
 
31697 amit.gupta 394
    @Autowired
395
    private Mongo mongoClient;
24683 amit.gupta 396
 
31697 amit.gupta 397
    @Autowired
398
    private DeviceRepository deviceRepository;
25300 tejbeer 399
 
31697 amit.gupta 400
    @Autowired
401
    private PushNotificationRepository pushNotificationRepository;
25300 tejbeer 402
 
31697 amit.gupta 403
    @Autowired
404
    private NotificationCampaignRepository notificationCampaignRepository;
25300 tejbeer 405
 
31697 amit.gupta 406
    @Autowired
407
    private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
25721 tejbeer 408
 
31697 amit.gupta 409
    @Autowired
410
    private FocusedModelRepository focusedModelRepository;
25721 tejbeer 411
 
31697 amit.gupta 412
    @Autowired
413
    private UserAccountRepository userAccountRepository;
24653 govind 414
 
31697 amit.gupta 415
    @Autowired
416
    private UserRepository userUserRepository;
25721 tejbeer 417
 
31697 amit.gupta 418
    @Autowired
419
    private com.spice.profitmandi.dao.repository.dtr.UserRepository dtrUserRepository;
25927 amit.gupta 420
 
31697 amit.gupta 421
    @Autowired
422
    private UserCampaignRepository userCampaignRepository;
25721 tejbeer 423
 
31697 amit.gupta 424
    @Autowired
425
    private Gson gson;
25721 tejbeer 426
 
31697 amit.gupta 427
    @Autowired
428
    private TicketRepository ticketRepository;
26283 tejbeer 429
 
31697 amit.gupta 430
    @Autowired
431
    private RefferalRepository refferalRepository;
26790 tejbeer 432
 
31697 amit.gupta 433
    @Autowired
434
    private PartnerProblemRepository partnerProblemRepository;
28205 tejbeer 435
 
31697 amit.gupta 436
    @Autowired
437
    private PendingOrderRepository pendingOrderRepository;
28368 tejbeer 438
 
31697 amit.gupta 439
    @Autowired
440
    private PendingOrderItemRepository pendingOrderItemRepository;
28368 tejbeer 441
 
31697 amit.gupta 442
    @Value("${razorpay.account.keyId}")
443
    private String keyId;
28368 tejbeer 444
 
31697 amit.gupta 445
    @Value("${razorpay.account.keySecret}")
446
    private String keySecret;
28368 tejbeer 447
 
31697 amit.gupta 448
    @Autowired
449
    private RazorpayPaymentService razorPaymentService;
28369 tejbeer 450
 
31697 amit.gupta 451
    @Autowired
452
    private RazorPayRepository razorPayRepository;
28369 tejbeer 453
 
31697 amit.gupta 454
    @Autowired
455
    private PendingOrderService pendingOrderService;
28377 tejbeer 456
 
31697 amit.gupta 457
    @Autowired
458
    private CustomerRepository customerRepository;
28377 tejbeer 459
 
31697 amit.gupta 460
    @Autowired
461
    private RestClient restClient;
29308 tejbeer 462
 
31697 amit.gupta 463
    @Autowired
464
    private MandiiService mandiiService;
29814 tejbeer 465
 
31697 amit.gupta 466
    @Autowired
467
    CreditAccountRepository creditAccountRepository;
31604 tejbeer 468
 
31697 amit.gupta 469
    @Autowired
470
    CustomerOfferRepository customerOfferRepository;
31612 tejbeer 471
 
31697 amit.gupta 472
    @Autowired
473
    CustomerOfferItemRepository customerOfferItemRepository;
474
    @Autowired
475
    private FofoSolr fofoSolr;
23724 amit.gupta 476
 
25300 tejbeer 477
 
31697 amit.gupta 478
    private static final Logger LOGGER = LogManager.getLogger(ScheduledTasks.class);
31388 amit.gupta 479
 
31697 amit.gupta 480
    private String FCM_URL = "https://fcm.googleapis.com/fcm/send";
481
    private String FCM_API_KEY = "AAAASAjNcn4:APA91bG6fWRIgYJI0L9gCjP5ynaXz2hJHYKtD9dfH7Depdv31Nd9APJwhx-OPkAJ1WSz4BGNYG8lHThLFSjDGFxIwUZv241YcAJEGDLgt86mxq9FXJe-yBRu-S0_ZwHqmX-QaVKl5F_A";
23724 amit.gupta 482
 
31697 amit.gupta 483
    @Autowired
484
    private TagListingRepository tagListingRepository;
23724 amit.gupta 485
 
31697 amit.gupta 486
    public void generateDailyRecharge() {
31886 tejbeer 487
        List<RechargeProviderCreditWalletHistory> allCreditHistory = rechargeProviderCreditWalletHistoryRepository.selectAll(0, 2000);
31697 amit.gupta 488
        List<RechargeProvider> rechargeProviders = rechargeProviderRepository.selectAll();
489
        rechargeProviders.stream().forEach(x -> x.setAmount(0));
23724 amit.gupta 490
 
31697 amit.gupta 491
        rechargeProviders.stream().forEach(x -> {
31886 tejbeer 492
            Map<LocalDate, List<RechargeProviderCreditWalletHistory>> dateWiseProviderCreditsMap = allCreditHistory.stream().filter(z -> z.getProviderId() == x.getId()).collect(groupingBy(x1 -> x1.getReceiveTimestamp().toLocalDate()));
23724 amit.gupta 493
 
31697 amit.gupta 494
            LOGGER.info("dateWiseProviderCreditsMap -{}", dateWiseProviderCreditsMap);
495
            LocalDate endDate = LocalDate.now().plusDays(1);
496
            float previousDayClosing = 0;
497
            LocalDate date = LocalDate.of(2018, 4, 6);
498
            while (date.isBefore(endDate)) {
31886 tejbeer 499
                List<RechargeTransaction> dateWiseRechargeTransactions = rechargeTransactionRepository.selectAllBetweenTimestamp(Arrays.asList(RechargeStatus.values()), date.atStartOfDay(), date.plusDays(1).atStartOfDay());
23724 amit.gupta 500
 
31886 tejbeer 501
                List<RechargeTransaction> successfulTransactions = dateWiseRechargeTransactions.stream().filter(y -> y.getStatus().equals(RechargeStatus.SUCCESS)).collect(Collectors.toList());
23724 amit.gupta 502
 
31697 amit.gupta 503
                float dailyAmount = 0;
504
                float totalCommission = 0;
505
                for (RechargeTransaction rechargeTransaction : successfulTransactions) {
506
                    if (rechargeTransaction.getProviderId() == x.getId()) {
507
                        dailyAmount += rechargeTransaction.getAmount();
508
                        totalCommission += rechargeTransaction.getCommission();
509
                    }
510
                }
28205 tejbeer 511
 
31697 amit.gupta 512
                List<RechargeProviderCreditWalletHistory> rechargeHistoryList = dateWiseProviderCreditsMap.get(date);
513
                float dailyWalletRecharge = 0;
514
                if (rechargeHistoryList != null) {
515
                    for (RechargeProviderCreditWalletHistory rechargeProviderCreditWalletHistory : rechargeHistoryList) {
516
                        if (rechargeProviderCreditWalletHistory.getProviderId() == x.getId()) {
517
                            dailyWalletRecharge += rechargeProviderCreditWalletHistory.getAmount();
518
                        }
519
                    }
520
                }
521
                if (dailyAmount > 0 || dailyWalletRecharge > 0) {
522
                    DailyRecharge dailyRecharge = null;
523
                    try {
524
                        dailyRecharge = dailyRechargeRepository.selectByProviderIdAndCreateDate(x.getId(), date);
525
                    } catch (Exception e) {
526
                        LOGGER.info("Could not find Recharge entry");
527
                    }
528
                    if (dailyRecharge == null) {
529
                        dailyRecharge = new DailyRecharge();
530
                        dailyRecharge.setCreateDate(date);
531
                    }
532
                    dailyRecharge.setOpeningBalance(previousDayClosing);
533
                    dailyRecharge.setProviderId(x.getId());
534
                    dailyRecharge.setWalletRechargeAmount(dailyWalletRecharge);
535
                    dailyRecharge.setTotalAmount(dailyAmount);
536
                    dailyRecharge.setTotalCommission(totalCommission);
537
                    float closingBalance = dailyRecharge.getOpeningBalance() + dailyWalletRecharge - dailyAmount;
538
                    dailyRecharge.setClosingBalance(closingBalance);
539
                    dailyRechargeRepository.persist(dailyRecharge);
540
                    x.setAmount(x.getAmount() + dailyRecharge.getClosingBalance() - dailyRecharge.getOpeningBalance());
541
                    previousDayClosing = dailyRecharge.getClosingBalance();
542
                }
543
                date = date.plusDays(1);
544
            }
545
            rechargeProviderRepository.persist(x);
546
        });
547
        LOGGER.info("finished generating daily recharge");
548
    }
24240 amit.gupta 549
 
31697 amit.gupta 550
    public void reconcileRecharge() throws Exception {
551
        LocalDateTime fromDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS).minusDays(30);
552
        LocalDateTime toDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS);
553
        List<RechargeStatus> nonSuccessRechargeStatuses = new ArrayList<>(Arrays.asList(RechargeStatus.values()));
554
        LOGGER.info("nonSuccessRechargeStatuses {} ", nonSuccessRechargeStatuses);
555
        nonSuccessRechargeStatuses.remove(RechargeStatus.SUCCESS);
556
        nonSuccessRechargeStatuses.remove(RechargeStatus.FAILED);
557
        RechargeCredential thinkWalnutDigitalRechargeEnquiryCredential = new RechargeCredential();
558
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeUrl(thinkWalnutDigitalRechargeEnquiryUrl);
559
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeUserName(thinkWalnutDigitalRechargeUserName);
560
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargePassword(thinkWalnutDigitalRechargePassword);
561
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeAuthKey(thinkWalnutDigitalRechargeAuthKey);
562
        Map<String, RechargeStatus> requestRechargeStatusChanged = new HashMap<>();
31886 tejbeer 563
        List<RechargeTransaction> rechargeTransactions = rechargeTransactionRepository.selectAllBetweenTimestamp(nonSuccessRechargeStatuses, fromDate, toDate);
31697 amit.gupta 564
        for (RechargeTransaction rechargeTransaction : rechargeTransactions) {
565
            try {
566
                int providerId = rechargeTransaction.getProviderId();
567
                if (providerId == 1) {
31886 tejbeer 568
                    oxigenRechargeProviderService.doCheckStatusRequest(oxigenRechargeEnquiryUrl, oxigenRechargeAuthKey, rechargeTransaction);
31697 amit.gupta 569
                } else if (providerId == 2) {
31886 tejbeer 570
                    thinkWalnutDigitalRechargeProviderService.doCheckStatusRequest(thinkWalnutDigitalRechargeEnquiryCredential, rechargeTransaction);
31697 amit.gupta 571
                }
31886 tejbeer 572
                if (rechargeTransaction.getStatus().equals(RechargeStatus.SUCCESS) || rechargeTransaction.getStatus().equals(RechargeStatus.FAILED)) {
573
                    requestRechargeStatusChanged.put(rechargeTransaction.getRequestId(), rechargeTransaction.getStatus());
31697 amit.gupta 574
                }
575
            } catch (Exception e) {
576
                LOGGER.info("Could not check status for Request {}", rechargeTransaction.getRequestId());
577
            }
578
        }
579
        LOGGER.info("Reconcile recharge ran successfully");
580
    }
24241 amit.gupta 581
 
31697 amit.gupta 582
    public void processActivation() throws Exception {
583
        schemeService.processActivation();
584
    }
24241 amit.gupta 585
 
31697 amit.gupta 586
    // TemporaryMethod
587
    public void migrateInvoice() {
588
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectFromSaleDate(LocalDateTime.now().minusDays(3));
589
        Map<Integer, List<FofoOrder>> partnerOrdersMap = new HashMap<>();
31886 tejbeer 590
        partnerOrdersMap = fofoOrders.stream().collect(groupingBy(FofoOrder::getFofoId, Collectors.toList()));
31697 amit.gupta 591
        for (List<FofoOrder> orderList : partnerOrdersMap.values()) {
592
            int sequence = 0;
593
            String prefix = "";
31886 tejbeer 594
            List<FofoOrder> sortedList = orderList.stream().sorted((x1, x2) -> x1.getId() - x2.getId()).collect(Collectors.toList());
31697 amit.gupta 595
            for (FofoOrder order : sortedList) {
23724 amit.gupta 596
 
31697 amit.gupta 597
                LOGGER.info("Order Id is {}, partner Id is {}", order.getId(), order.getFofoId());
598
                if (!order.getInvoiceNumber().contains("SEC")) {
599
                    sequence = Integer.parseInt(order.getInvoiceNumber().split("/")[1]);
600
                    prefix = order.getInvoiceNumber().split("/")[0];
601
                } else {
602
                    sequence += 1;
603
                    String invoiceNumber = prefix + "/" + sequence;
604
                    order.setInvoiceNumber(invoiceNumber);
605
                    fofoOrderRepository.persist(order);
606
                }
607
            }
24252 amit.gupta 608
 
31697 amit.gupta 609
        }
610
    }
28205 tejbeer 611
 
31697 amit.gupta 612
    @Autowired
613
    private ReporticoCacheTableRepository reporticoCacheTableRepository;
28205 tejbeer 614
 
31697 amit.gupta 615
    public void processScheme(int offset, boolean dryRun) throws Exception {
616
        LocalDateTime startDate = LocalDateTime.of(LocalDate.now(), LocalTime.MIDNIGHT).minusDays(offset);
617
        LocalDateTime endDate = startDate.plusDays(30);
618
        processScheme(startDate, endDate, dryRun);
619
    }
24533 govind 620
 
31697 amit.gupta 621
    public void processSchemeOut(List<String> invoiceNumbers) throws Exception {
622
        for (String invoiceNumber : invoiceNumbers) {
623
            System.out.println("Invoice Number - " + invoiceNumber);
624
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
32147 amit.gupta 625
            //orderService.reverseScheme(fofoOrder);
31697 amit.gupta 626
            schemeService.processSchemeOut(fofoOrder.getId(), fofoOrder.getFofoId());
627
        }
628
    }
24271 amit.gupta 629
 
31697 amit.gupta 630
    public void processSchemeIn(List<String> invoiceNumbers) throws Exception {
631
        for (String invoiceNumber : invoiceNumbers) {
632
            System.out.println("Invoice Number - " + invoiceNumber);
633
            Purchase purchase = purchaseRepository.selectByPurchaseReference(invoiceNumber);
634
            schemeService.processSchemeIn(purchase.getId(), purchase.getFofoId());
635
        }
636
    }
24271 amit.gupta 637
 
31697 amit.gupta 638
    public void processScheme(int offset, int durationDays, boolean dryRun) throws Exception {
639
        LocalDateTime startDate = LocalDateTime.of(LocalDate.now(), LocalTime.MIDNIGHT).minusDays(offset);
640
        LocalDateTime endDate = startDate.plusDays(durationDays);
641
        processScheme(startDate, endDate, dryRun);
642
    }
24271 amit.gupta 643
 
31697 amit.gupta 644
    public void processScheme(boolean dryRun) throws Exception {
645
        LocalDateTime fromDate = LocalDateTime.now().minusDays(30);
646
        processScheme(fromDate, LocalDateTime.now(), dryRun);
647
    }
23929 amit.gupta 648
 
31697 amit.gupta 649
    public void processScheme(LocalDateTime startDate, LocalDateTime endDate, boolean dryRun) throws Exception {
650
        LOGGER.info("Started execution at {}", LocalDateTime.now());
651
        System.out.println(
652
                "InventoryId\tSerialNumber\tItem Id\tScheme Id\tScheme Name\tScheme Type\tAmount Type\tDP\tTaxable\tScheme Amount\tAmount Paid");
653
        try {
654
            List<Purchase> purchases = purchaseRepository.selectAllBetweenPurchaseDate(startDate, endDate);
655
            for (Purchase purchase : purchases) {
656
                schemeService.processSchemeIn(purchase.getId(), purchase.getFofoId());
657
            }
29160 amit.gupta 658
 
31697 amit.gupta 659
            List<FofoOrder> fofoOrders = fofoOrderRepository.selectBetweenSaleDate(startDate, endDate);
660
            for (FofoOrder fofoOrder : fofoOrders) {
661
                schemeService.processSchemeOut(fofoOrder.getId(), fofoOrder.getFofoId());
662
            }
663
        } catch (Exception e) {
664
            e.printStackTrace();
665
            throw e;
666
        }
31886 tejbeer 667
        List<UserWalletHistory> uwhs = userWalletHistoryRepository.selectAllByDateType(LocalDate.now().atStartOfDay(), endDate, Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT));
31697 amit.gupta 668
        System.out.println("Amount\tReference\tReferenceType\tTimestamp\tDescription");
669
        for (UserWalletHistory uwh : uwhs) {
31886 tejbeer 670
            System.out.println(String.format("%d\t%d\t%s\t%s\t%s", uwh.getAmount(), uwh.getReference(), uwh.getReferenceType(), uwh.getTimestamp().toString(), uwh.getDescription()));
31697 amit.gupta 671
        }
672
        LOGGER.info("Schemes processed successfully.");
673
        if (dryRun) {
674
            throw new Exception();
675
        }
676
    }
29160 amit.gupta 677
 
31697 amit.gupta 678
    public void processRechargeCashback() throws Throwable {
679
        LocalDateTime cashbackTime = LocalDateTime.now();
680
        int referenceId = (int) Timestamp.valueOf(cashbackTime).getTime() / 1000;
31886 tejbeer 681
        List<RechargeTransaction> pendingTransactions = rechargeTransactionRepository.getPendingCashBackRehargeTransactions();
31697 amit.gupta 682
        Map<Object, Double> totalRetailerCashbacks = pendingTransactions.stream().collect(
31724 amit.gupta 683
                groupingBy(x -> x.getRetailerId(), Collectors.summingDouble(x -> x.getCommission())));
31697 amit.gupta 684
        for (Map.Entry<Object, Double> totalRetailerCashback : totalRetailerCashbacks.entrySet()) {
685
            int retailerId = (Integer) totalRetailerCashback.getKey();
686
            float amount = totalRetailerCashback.getValue().floatValue();
687
            if (Math.round(amount) > 0) {
31886 tejbeer 688
                walletService.addAmountToWallet(retailerId, referenceId, WalletReferenceType.CASHBACK, "Recharge Cashback", Math.round(amount), LocalDateTime.now());
31697 amit.gupta 689
            }
690
        }
691
        for (RechargeTransaction rt : pendingTransactions) {
692
            rt.setCashbackTimestamp(cashbackTime);
693
            rt.setCashbackReference(referenceId);
694
            rechargeTransactionRepository.persist(rt);
695
        }
696
        LOGGER.info("Cashbacks for Recharge processed Successfully");
697
    }
29160 amit.gupta 698
 
31697 amit.gupta 699
    public void rollOutUpgardedMarginsNextMonth() throws Exception {
700
        LocalDate startOfPreviousMonth = LocalDate.now().with(ChronoField.DAY_OF_MONTH, 1).minusMonths(1);
29160 amit.gupta 701
 
31697 amit.gupta 702
        List<FofoStore> stores = fofoStoreRepository.selectActiveStores();
703
        for (FofoStore store : stores) {
32003 amit.gupta 704
            this.rolloutMarginForStoreOnMonth(store, startOfPreviousMonth);
705
        }
706
    }
29252 amit.gupta 707
 
32003 amit.gupta 708
    public void rolloutMarginForStoreOnMonth(FofoStore store, LocalDate startOfMonth) throws ProfitMandiBusinessException {
709
        int fofoId = store.getId();
29252 amit.gupta 710
 
32003 amit.gupta 711
        PartnerType startOfPreviousMonthPartnerType = partnerTypeChangeService.getTypeOnDate(fofoId, startOfMonth);
712
        PartnerType todayPartnerType = partnerTypeChangeService.getTypeOnMonth(fofoId, YearMonth.from(startOfMonth.atStartOfDay()));
713
        if (!startOfPreviousMonthPartnerType.nextPartnerTypes().contains(todayPartnerType)) {
714
            return;
715
        }
716
        if (!startOfPreviousMonthPartnerType.equals(todayPartnerType)) {
717
            LOGGER.info("Partner Type has been changed for code {} from {} to {}", store.getCode(), startOfPreviousMonthPartnerType, todayPartnerType);
718
            List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startOfMonth.atStartOfDay(), startOfMonth.plusMonths(1).atStartOfDay(), 0, 0);
719
            for (FofoOrder fofoOrder : fofoOrders) {
720
                schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
31697 amit.gupta 721
            }
722
        }
723
    }
29252 amit.gupta 724
 
32003 amit.gupta 725
 
31697 amit.gupta 726
    public void rollOutUpgardedMargins() throws Exception {
727
        LocalDate today = LocalDate.now();
728
        LocalDate yesterday = today.minusDays(1);
729
        int upgradedCount = 0;
730
        List<FofoStore> stores = fofoStoreRepository.selectActiveStores();
731
        StringBuilder sb = new StringBuilder();
732
        for (FofoStore store : stores) {
733
            int fofoId = store.getId();
23724 amit.gupta 734
 
31697 amit.gupta 735
            PartnerType yesterdayPartnerType = partnerTypeChangeService.getTypeOnDate(fofoId, yesterday);
736
            PartnerType todayPartnerType = partnerTypeChangeService.getTypeOnDate(fofoId, today);
737
            if (!yesterdayPartnerType.nextPartnerTypes().contains(todayPartnerType)) {
738
                continue;
739
            }
740
            if (!yesterdayPartnerType.equals(todayPartnerType)) {
741
                upgradedCount++;
31886 tejbeer 742
                sb.append(String.format("Partner Type has been changed for code %s from %s to %s", store.getCode(), yesterdayPartnerType.toString(), todayPartnerType.toString()));
31697 amit.gupta 743
                sb.append("<br>");
31886 tejbeer 744
                LOGGER.info("Partner Type has been changed for code {} from {} to {}", store.getCode(), yesterdayPartnerType, todayPartnerType);
745
                List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, yesterday.withDayOfMonth(1).atStartOfDay(), yesterday.atStartOfDay(), 0, 0);
31697 amit.gupta 746
                for (FofoOrder fofoOrder : fofoOrders) {
747
                    schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
748
                }
30390 amit.gupta 749
 
31697 amit.gupta 750
            }
751
        }
752
        if (upgradedCount > 0) {
32439 tejbeer 753
            sendMailOfHtmlFormat(googleMailSender, new String[]{"amit.gupta@smartdukaan.com", "tarun.verma@smartdukaan.com", "neeraj.gupta@smartdukaan.com"}, sb.toString(), null, "Few Partners Category have been Upgraded");
31697 amit.gupta 754
        } else {
32439 tejbeer 755
            sendMailOfHtmlFormat(googleMailSender, new String[]{"amit.gupta@smartdukaan.com", "tarun.verma@smartdukaan.com", "neeraj.gupta@smartdukaan.com"}, sb.toString(), null, "No partners Category have been upgraded today");
31697 amit.gupta 756
        }
757
    }
30393 amit.gupta 758
 
31697 amit.gupta 759
    @Autowired
760
    private PartnerStatsService partnerStatsService;
30393 amit.gupta 761
 
31697 amit.gupta 762
    // Temporary Method
763
    public void evaluateExcessSchemeOut() throws Exception {
764
        Map<Integer, String> userNameMap = retailerService.getAllFofoRetailerIdNameMap();
765
        Map<Integer, Float> userAmountMap = new HashMap<>();
30393 amit.gupta 766
 
31697 amit.gupta 767
        List<List<?>> rows = new ArrayList<>();
31886 tejbeer 768
        List<String> headers = Arrays.asList("Scheme", "Item", "Partner", "Amount", "Credited On", "Invoice Number", "Sale On", "Scheme Start", "Scheme End", "Active On", "Expired On");
31697 amit.gupta 769
        schemeRepository.selectAll().stream().forEach(x -> {
770
            if (x.getType().equals(SchemeType.OUT)) {
31886 tejbeer 771
                List<SchemeInOut> sioList = schemeInOutRepository.selectBySchemeIds(new HashSet<>(Arrays.asList(x.getId())));
31697 amit.gupta 772
                if (x.getActiveTimestamp() != null) {
773
                    LocalDateTime endDateTime = x.getEndDateTime();
774
                    if (x.getExpireTimestamp() != null && x.getExpireTimestamp().isBefore(x.getEndDateTime())) {
775
                        endDateTime = x.getExpireTimestamp();
776
                    }
777
                    for (SchemeInOut sio : sioList) {
778
                        InventoryItem inventoryItem = null;
779
                        inventoryItem = inventoryItemRepository.selectById(sio.getInventoryItemId());
780
                        FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndSerialNumber(
781
                                inventoryItem.getFofoId(), inventoryItem.getSerialNumber(), null, null, 0, 1).get(0);
31886 tejbeer 782
                        Optional<ScanRecord> record = scanRecordRepository.selectByInventoryItemId(sio.getInventoryItemId()).stream().filter(y -> y.getType().equals(ScanType.SALE)).findFirst();
31697 amit.gupta 783
                        if (record.isPresent()) {
784
                            int fofoId = record.get().getFofoId();
31886 tejbeer 785
                            if (record.get().getCreateTimestamp().isAfter(endDateTime) || record.get().getCreateTimestamp().isBefore(x.getStartDateTime())) {
31697 amit.gupta 786
                                if (!userAmountMap.containsKey(fofoId)) {
787
                                    userAmountMap.put(fofoId, 0f);
788
                                }
789
                                userAmountMap.put(fofoId, sio.getAmount() + userAmountMap.get(fofoId));
790
                                try {
31886 tejbeer 791
                                    rows.add(Arrays.asList(x.getDescription(), itemRepository.selectById(inventoryItem.getItemId()).getItemDescription(), userNameMap.get(fofoId), sio.getAmount(), FormattingUtils.formatDate(sio.getCreateTimestamp()), fofoOrder.getInvoiceNumber(), FormattingUtils.formatDate(record.get().getCreateTimestamp()), FormattingUtils.formatDate(x.getStartDateTime()), FormattingUtils.formatDate(x.getEndDateTime()), FormattingUtils.formatDate(x.getActiveTimestamp()), FormattingUtils.formatDate(x.getExpireTimestamp())));
31697 amit.gupta 792
                                } catch (Exception e) {
793
                                    e.printStackTrace();
794
                                }
795
                            }
796
                        }
797
                    }
798
                }
799
            }
800
        });
31886 tejbeer 801
        userAmountMap.entrySet().stream().forEach(x -> LOGGER.info("{} to be deducted from {}({}) for wrongly disbursed due to technical error.", x.getValue(), userNameMap.get(x.getKey())));
30393 amit.gupta 802
 
31697 amit.gupta 803
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, rows);
31886 tejbeer 804
        Utils.sendMailWithAttachment(googleMailSender, new String[]{"amit.gupta@shop2020.in"}, null, "Partner Excess Amount", "PFA", "ListofSchemes.csv", new ByteArrayResource(baos.toByteArray()));
30390 amit.gupta 805
 
31697 amit.gupta 806
    }
30390 amit.gupta 807
 
31697 amit.gupta 808
    public void fetchParnterStats() throws Exception {
809
        Map<Integer, PartnerDetailModel> partnerStats = partnerStatsService.getAllPartnerStats();
810
        ObjectOutputStream oos = null;
811
        FileOutputStream fout = null;
812
        try {
813
            fout = new FileOutputStream("/tmp/partnerStat.tmp", false);
814
            oos = new ObjectOutputStream(fout);
815
            oos.writeObject(partnerStats);
30637 amit.gupta 816
 
31697 amit.gupta 817
        } catch (Exception ex) {
818
            ex.printStackTrace();
819
        } finally {
820
            if (oos != null) {
821
                oos.close();
822
            }
823
        }
32421 amit.gupta 824
        ReporticoCacheTable reporticoCacheTable = reporticoCacheTableRepository.selectByTableName("partnerStat");
825
        if (reporticoCacheTable == null) {
826
            reporticoCacheTable = new ReporticoCacheTable();
827
            reporticoCacheTable.setTableName("partnerStat");
828
            reporticoCacheTable.setLastCreatedTimestamp(LocalDateTime.now());
829
            reporticoCacheTableRepository.persist(reporticoCacheTable);
31697 amit.gupta 830
        } else {
32421 amit.gupta 831
            reporticoCacheTable.setLastCreatedTimestamp(LocalDateTime.now());
31697 amit.gupta 832
        }
833
    }
31008 amit.gupta 834
 
31697 amit.gupta 835
    public void processPriceDrop() throws Exception {
31886 tejbeer 836
        List<PriceDrop> priceDrops = priceDropRepository.selectAllByDatesBetween(LocalDateTime.now(), LocalDateTime.now().minusYears(1));
31697 amit.gupta 837
        for (PriceDrop priceDrop : priceDrops) {
838
            if (priceDrop.getDropAmount() > 0) {
839
                priceDropService.processPriceDrop(priceDrop.getId(), true);
840
            }
841
        }
842
    }
31008 amit.gupta 843
 
31697 amit.gupta 844
    @Autowired
845
    CreditNoteService creditNoteService;
25598 amit.gupta 846
 
31697 amit.gupta 847
    public void sendCreditNote(YearMonth yearMonth) throws Exception {
848
        creditNoteService.issueMonthlyMarginsCN(yearMonth);
849
    }
25598 amit.gupta 850
 
31918 amit.gupta 851
    @Autowired
852
    BrandAgeingLimitRepository brandAgeingLimitRepository;
853
 
854
    @Autowired
855
    AgeingService ageingService;
856
 
857
    public void sendMailForAgeingAlert() throws Exception {
858
        //brandAgeingLimitRepository.selectAll();
859
        Map<String, AgeingModel> ageingModelMap = ageingService.getAllAgeingForSecondary();
860
 
861
        System.out.println(ageingModelMap.size());
862
        List<PartnerAgeingModel> partnerAgeingModels = ageingService.getAllAgeingForTertiary();
863
 
864
 
32084 tejbeer 865
        org.apache.commons.io.output.ByteArrayOutputStream byteArrayOutputStream = FileUtil.getCSVByteStream(Arrays.asList("InventoryItemId", "Serial Number", "Item Id", "Brand", "Model Name", "ModelNumber", "Color", "Exceed Days", "Last ScanType", "Supplier Name", "Current Warehouse", "First Warehouse", "Invoice Number", "Invoice Date"), ageingModelMap.values().stream().map(x -> Arrays.asList(x.getInventoryItemId(), x.getSerialNumber(), x.getItemId(), x.getBrand(), x.getModelName(), x.getModelNumber(), x.getColor(), x.getExceedDays(), x.getLastScanType(), x.getSupplierName(), x.getCurrentWarehouse(), x.getFirstWarehouse(), x.getInvoiceNumber(), FormattingUtils.formatDate(x.getInvoiceDate()))).collect(Collectors.toList()));
31918 amit.gupta 866
 
32084 tejbeer 867
        org.apache.commons.io.output.ByteArrayOutputStream byteArrayOutputStream2 = FileUtil.getCSVByteStream(Arrays.asList("InventoryItemId", "Serial Number", "Item Id", "Brand", "Model Name", "ModelNumber", "Color", "Partner Id", "Partner Code", "Partner Name", "Activation Type", "City", "State", "Billing Date", "Exceed Days", "Max Ageing", "Activation Date"), partnerAgeingModels.stream().map(x -> Arrays.asList(x.getInventoryItemId(), x.getSerialNumber(), x.getItemId(), x.getBrand(), x.getModelName(), x.getModelNumber(), x.getColor(), x.getFofoId(), x.getFofoCode(), x.getFofoName(), x.getActivationType(), x.getFofoCity(), x.getFofoState(), FormattingUtils.formatDate(x.getBillingDate()), x.getExceedDays(), x.getMaxAgeingDays(), x.getActivationDate())).collect(Collectors.toList()));
31918 amit.gupta 868
        Utils.Attachment attachment1 = new Utils.Attachment("secondary-alert.csv", new ByteArrayResource(byteArrayOutputStream.toByteArray()));
869
        Utils.Attachment attachment2 = new Utils.Attachment("tertiary-alert.csv", new ByteArrayResource(byteArrayOutputStream2.toByteArray()));
870
 
871
        String mailSubject = "Stock ageing Alert";
872
        Utils.sendMailWithAttachments(mailSender, new String[]{"deena.nath@smartdukaan.com"}, null, mailSubject, "PFA", attachment1, attachment2);
873
    }
874
 
31697 amit.gupta 875
    private class SaleRoles {
25598 amit.gupta 876
 
31697 amit.gupta 877
        private List<String> l1;
878
        private List<String> l2;
25598 amit.gupta 879
 
31697 amit.gupta 880
        public SaleRoles() {
881
            l1 = new ArrayList<>();
882
            l2 = new ArrayList<>();
883
        }
25598 amit.gupta 884
 
31697 amit.gupta 885
        public List<String> getL1() {
886
            return l1;
887
        }
25598 amit.gupta 888
 
31697 amit.gupta 889
        public List<String> getL2() {
890
            return l2;
891
        }
26945 amit.gupta 892
 
31697 amit.gupta 893
    }
26945 amit.gupta 894
 
31697 amit.gupta 895
    private class FofoReportingModel {
896
        private String code;
897
        private int fofoId;
898
        private String businessName;
899
        private String territoryManager;
900
        private String regionalManager;
901
        private String businessManager;
26945 amit.gupta 902
 
31697 amit.gupta 903
        public String getCode() {
904
            return code;
905
        }
26945 amit.gupta 906
 
31697 amit.gupta 907
        public void setCode(String code) {
908
            this.code = code;
909
        }
26945 amit.gupta 910
 
31697 amit.gupta 911
        public String getBusinessName() {
912
            return businessName;
913
        }
26945 amit.gupta 914
 
31697 amit.gupta 915
        public void setBusinessName(String businessName) {
916
            this.businessName = businessName;
917
        }
26945 amit.gupta 918
 
31697 amit.gupta 919
        public String getTerritoryManager() {
920
            return territoryManager;
921
        }
26945 amit.gupta 922
 
31697 amit.gupta 923
        public void setTerritoryManager(String territoryManager) {
924
            this.territoryManager = territoryManager;
925
        }
26945 amit.gupta 926
 
31697 amit.gupta 927
        public String getRegionalManager() {
928
            return regionalManager;
929
        }
26945 amit.gupta 930
 
31697 amit.gupta 931
        public void setRegionalManager(String regionalManager) {
932
            this.regionalManager = regionalManager;
933
        }
26945 amit.gupta 934
 
31697 amit.gupta 935
        private ScheduledTasks getOuterType() {
936
            return ScheduledTasks.this;
937
        }
26945 amit.gupta 938
 
31697 amit.gupta 939
        @Override
940
        public String toString() {
31886 tejbeer 941
            return "FofoReportingModel{" + "code='" + code + '\'' + ", fofoId=" + fofoId + ", businessName='" + businessName + '\'' + ", territoryManager='" + territoryManager + '\'' + ", regionalManager='" + regionalManager + '\'' + ", businessManager='" + businessManager + '\'' + '}';
31697 amit.gupta 942
        }
26945 amit.gupta 943
 
31697 amit.gupta 944
        @Override
945
        public boolean equals(Object o) {
946
            if (this == o) return true;
947
            if (o == null || getClass() != o.getClass()) return false;
948
            FofoReportingModel that = (FofoReportingModel) o;
949
            return fofoId == that.fofoId && Objects.equals(code, that.code) && Objects.equals(businessName, that.businessName) && Objects.equals(territoryManager, that.territoryManager) && Objects.equals(regionalManager, that.regionalManager) && Objects.equals(businessManager, that.businessManager);
950
        }
26945 amit.gupta 951
 
31697 amit.gupta 952
        @Override
953
        public int hashCode() {
954
            return Objects.hash(code, fofoId, businessName, territoryManager, regionalManager, businessManager);
955
        }
26945 amit.gupta 956
 
31697 amit.gupta 957
        public String getBusinessManager() {
958
            return businessManager;
959
        }
26945 amit.gupta 960
 
31697 amit.gupta 961
        public void setBusinessManager(String businessManager) {
962
            this.businessManager = businessManager;
963
        }
25351 tejbeer 964
 
31697 amit.gupta 965
        public int getFofoId() {
966
            return fofoId;
967
        }
25598 amit.gupta 968
 
31697 amit.gupta 969
        public void setFofoId(int fofoId) {
970
            this.fofoId = fofoId;
971
        }
25598 amit.gupta 972
 
31697 amit.gupta 973
    }
26945 amit.gupta 974
 
31697 amit.gupta 975
    @Autowired
976
    WarehouseInventoryItemRepository warehouseInventoryItemRepository;
26945 amit.gupta 977
 
31746 amit.gupta 978
    @Autowired
979
    OfferService offerService;
980
 
981
    @Autowired
982
    PurchaseReturnItemRepository purchaseReturnItemRepository;
983
 
31918 amit.gupta 984
    @Autowired
985
    BrandRegionMappingRepository brandRegionMappingRepository;
986
 
32161 tejbeer 987
    @Autowired
988
    StandAlone standAlone;
32214 jai.hind 989
    @Autowired
990
    ItelImeiActivationNewService itelImeiActivationNewService;
32350 amit.gupta 991
 
992
    public void checkItelImeiActivationNew(LocalDate date, Integer day) throws Exception {
32063 amit.gupta 993
        try {
32223 amit.gupta 994
            itelImeiActivationNewService.checkItelImeiActivationNew(date, day);
32063 amit.gupta 995
        } catch (Throwable e) {
996
            throw new Exception(e);
997
        }
32223 amit.gupta 998
    }
32062 amit.gupta 999
 
32511 amit.gupta 1000
    @Autowired
1001
    PurchaseReturnService purchaseReturnService;
1002
 
32682 amit.gupta 1003
    @Autowired
1004
    JavaMailSender javaMailSender;
1005
 
32223 amit.gupta 1006
    public void test() throws Exception {
32682 amit.gupta 1007
        sendMailOfHtmlFormat(javaMailSender, new String[]{"amit.gupta@smartdukaan.com"}, "hello", null, "Hello");
32511 amit.gupta 1008
        //Create return
32600 amit.gupta 1009
        //this.updatePartnerLimit();
32607 ranu 1010
        //creditNoteService.sendCnMails(YearMonth.now().minusMonths(2));
1011
        orderService.createMissingScratchOffers();
32513 amit.gupta 1012
 
32533 amit.gupta 1013
 
1014
        /*for (Entry<Integer, Set<String>> fofoIdImeiReturnEntry : fofoIdImeiReturnMap.entrySet()) {
32511 amit.gupta 1015
            int fofoId = fofoIdImeiReturnEntry.getKey();
1016
            Set<String> imeis = fofoIdImeiReturnEntry.getValue();
1017
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(fofoId, imeis, true);
1018
            for (InventoryItem inventoryItem : inventoryItems) {
1019
                //inventoryItem.getId();
1020
                purchaseReturnService.returnInventoryItem(fofoId, true, inventoryItem.getId(), ReturnType.GOOD);
1021
                //Approve return
1022
                PurchaseReturnItem purchaseReturnItem = purchaseReturnItemRepository.selectByInventoryItemId(inventoryItem.getId());
1023
                purchaseReturnItem.setStatus(PurchaseReturnStatus.APPROVED);
1024
                purchaseReturnItem.setApproveTimestamp(LocalDateTime.now());
1025
            }
1026
            Map<Purchase, List<InventoryItem>> purchaseInventoryItemsMap = purchaseReturnService.getPurchaseMapForApprovedReturns(fofoId);
1027
            int walletAmount = walletService.getWalletAmount(fofoId);
1028
            List<DebitNote> debitNotes = purchaseReturnService.generateDebitNotes(purchaseInventoryItemsMap);
1029
            int walletDiff = walletAmount - walletService.getWalletAmount(fofoId);
1030
            if (walletDiff > 0) {
1031
                int reference = walletService.getManualReference(WalletReferenceType.OTHERS);
32514 amit.gupta 1032
                walletService.addAmountToWallet(fofoId, reference, WalletReferenceType.ADVANCE_AMOUNT, "Sytematically added for internal PO", (float) walletDiff + 5000, LocalDateTime.now());
32511 amit.gupta 1033
            }
32421 amit.gupta 1034
 
32511 amit.gupta 1035
            for (DebitNote debitNote : debitNotes) {
1036
                debitNote.setCreateTimestamp(LocalDate.of(2023, Month.SEPTEMBER, 30).atStartOfDay());
1037
                //Try to refund amount per debit note
1038
                this.refundDnAmount(debitNote);
1039
            }
32223 amit.gupta 1040
 
32511 amit.gupta 1041
            //List<DebitNotePdfModel> debitNotePdfModels = purchaseReturnService.generateDebitNotes(purchaseInventoryMap, warehouseId);
31918 amit.gupta 1042
        }*/
31697 amit.gupta 1043
    }
32048 tejbeer 1044
 
32564 amit.gupta 1045
    //TODO:Important method for Order return refund and reordering
1046
    private void importantMethodCo() {
1047
        Map<Integer, Set<String>> fofoIdImeiReturnMap = new TreeMap<>();
1048
        fofoIdImeiReturnMap.put(175139496, new HashSet<>(Arrays.asList("350386305879537", "860695063378810", "863879062651750", "864920069103590", "865037066073517", "865210064600017", "865279067176432", "865865062952171", "866807068662916", "866807069402130", "867158063179178", "867492063171996", "868905065232135")));
1049
        List<String> serialNumbers = fofoIdImeiReturnMap.entrySet().stream().flatMap(x -> x.getValue().stream()).collect(Collectors.toList());
1050
        List<WarehouseInventoryItem> warehouseInventoryItems = warehouseInventoryItemRepository.selectWarehouseInventoryItemBySerailNumbers(serialNumbers);
1051
        for (WarehouseInventoryItem warehouseInventoryItem : warehouseInventoryItems) {
1052
            if (warehouseInventoryItem.getCurrentQuantity() - warehouseInventoryItem.getInitialQuantity() >= 0) {
1053
                int diff = 1 + warehouseInventoryItem.getCurrentQuantity() - warehouseInventoryItem.getInitialQuantity();
1054
                System.out.println(warehouseInventoryItem.getId() + " --- " + diff);
1055
                List<WarehouseScan> warehouseScans = warehouseScanRepository.selectAllByInventoryItemIds(Arrays.asList(warehouseInventoryItem.getId()));
1056
                WarehouseScan previousSaleScan = warehouseScans.stream().filter(x->x.getType().equals(in.shop2020.warehouse.ScanType.SALE)).sorted(Comparator.comparingInt(WarehouseScan::getOrderId).reversed()).skip(1).findFirst().get();
1057
                List<WarehouseScan> scansToDelete = warehouseScans.stream().filter(x -> x.getType().equals(in.shop2020.warehouse.ScanType.SALE_RET) && x.getSupplierWarehouseId()==0).skip(1).collect(Collectors.toList());
1058
                if(scansToDelete.size() > 0) {
1059
                    WarehouseScan warehouseScan = warehouseScans.stream().filter(x -> x.getType().equals(in.shop2020.warehouse.ScanType.SALE_RET)).findFirst().get();
1060
                    warehouseScan.setSupplierWarehouseId(warehouseInventoryItem.getCurrentWarehouseId());
1061
                    warehouseScan.setOrderId(previousSaleScan.getOrderId());
1062
                    System.out.println(scansToDelete.toString());
1063
                    for (WarehouseScan scan : scansToDelete) {
1064
                        warehouseScanRepository.delete(scan);
1065
                    }
1066
                    warehouseInventoryService.addQuantity(warehouseInventoryItem.getId(), -diff);
1067
                }
1068
            }
1069
        }
1070
    }
1071
 
32384 amit.gupta 1072
    @Autowired
32511 amit.gupta 1073
    CartService cartService;
1074
    @Autowired
1075
    UserRepository userRepository;
1076
 
1077
    @Autowired
1078
    WarehouseScanRepository warehouseScanRepository;
1079
 
1080
    @Autowired
1081
    WarehouseInventoryService warehouseInventoryService;
1082
 
1083
    @Autowired
1084
    CommonPaymentService commonPaymentService;
1085
 
32533 amit.gupta 1086
    @Autowired
1087
    LineItemImeisRepository lineItemImeisRepository;
1088
 
32511 amit.gupta 1089
    //Also create order
32533 amit.gupta 1090
    private void refundDnAmount(DebitNote debitNote, boolean createOrder) throws ProfitMandiBusinessException {
32511 amit.gupta 1091
        List<Integer> inventoryItemIds = purchaseReturnItemRepository.selectAllByDebitNoteId(debitNote.getId()).stream().map(x -> x.getInventoryItemId()).collect(Collectors.toList());
1092
        Map<Integer, Long> inventoryItemCountMap = inventoryItemIds.stream().collect(Collectors.groupingBy(x -> x, Collectors.counting()));
1093
        List<InventoryItem> inventoryItems = inventoryItemRepository.selectAllByIds(new ArrayList<>(inventoryItemCountMap.keySet()));
1094
        Purchase purchase = purchaseRepository.selectById(inventoryItems.get(0).getPurchaseId());
32533 amit.gupta 1095
        List<String> serialNumbers = inventoryItems.stream().map(x -> x.getSerialNumber()).collect(Collectors.toList());
32511 amit.gupta 1096
        String invoice = purchase.getPurchaseReference();
1097
        List<Order> orders = orderRepository.selectByInvoiceNumber(invoice);
32533 amit.gupta 1098
        List<Integer> lineItemIds = orders.stream().map(x -> x.getLineItem().getId()).collect(Collectors.toList());
1099
        List<LineItemImei> lineItemImeis = lineItemImeisRepository.selectByLineItemIdsSerialNumbers(lineItemIds, serialNumbers);
32511 amit.gupta 1100
        Set<Integer> orderIds = orders.stream().map(x -> x.getId()).collect(Collectors.toSet());
1101
        Order order = orders.get(0);
1102
        float totalAmount = 0;
1103
        float walletTotalAmount = 0;
1104
        int totalQty = 0;
1105
        Map<Integer, CartItem> itemIdCartItemMap = new HashMap<>();
1106
 
1107
        List<CartItem> cartItems = new ArrayList<>();
1108
        for (InventoryItem inventoryItem : inventoryItems) {
1109
            TagListing tagListing = tagListingRepository.selectByItemId(inventoryItem.getItemId());
1110
            long quantity = inventoryItemCountMap.get(inventoryItem.getId());
1111
            totalAmount += inventoryItem.getUnitPrice() * quantity;
1112
            walletTotalAmount += tagListing.getSellingPrice() * quantity;
1113
            totalQty += quantity;
1114
            if (!itemIdCartItemMap.containsKey(inventoryItem.getItemId())) {
1115
                CartItem cartItem = new CartItem();
1116
                cartItem.setItemId(inventoryItem.getItemId());
1117
                cartItem.setSellingPrice(tagListing.getSellingPrice());
1118
                cartItems.add(cartItem);
1119
                itemIdCartItemMap.put(inventoryItem.getItemId(), cartItem);
1120
            }
1121
            CartItem cartItem = itemIdCartItemMap.get(inventoryItem.getItemId());
1122
            cartItem.setQuantity((int) quantity + cartItem.getQuantity());
1123
        }
1124
        String rollbackDescription = String.format("Refunded against DN %s, %d pc(s)", debitNote.getDebitNoteNumber(), totalQty);
1125
        walletService.addAmountToWallet(debitNote.getFofoId(), order.getTransactionId(), WalletReferenceType.PURCHASE, rollbackDescription, totalAmount, LocalDateTime.now());
1126
        //Before creating order lets try to in the stock
1127
 
1128
        //All scans pertaining to specific Invoices
1129
        List<WarehouseScan> warehouseScans = warehouseScanRepository.selectAllByOrderIds(new ArrayList<>(orderIds));
1130
        Map<Integer, Integer> inventoryItemIdOrderIdMap = warehouseScans.stream().collect(Collectors.toMap(x -> x.getInventoryItemId(), x -> x.getQuantity()));
1131
        List<Integer> warehouseInventoryItemIds = warehouseScans.stream().filter(x -> !(x.getType().equals(in.shop2020.warehouse.ScanType.SALE_RET) || x.getType().equals(in.shop2020.warehouse.ScanType.SALE_RET_UNUSABLE)))
1132
                .map(x -> x.getInventoryItemId()).collect(Collectors.toList());
1133
        List<WarehouseInventoryItem> warehouseInventoryItems = warehouseInventoryItemRepository.selectAllByIds(warehouseInventoryItemIds);
1134
 
1135
        Map<String, WarehouseInventoryItem> serialNumberWarehouseInventoryItemMap = warehouseInventoryItems.stream().filter(x -> StringUtils.isNotBlank(x.getSerialNumber())).collect(Collectors.toMap(x -> x.getSerialNumber(), x -> x));
1136
        Map<Integer, List<WarehouseInventoryItem>> itemIdWarehouseInventoryItemsMap = warehouseInventoryItems.stream().filter(x -> StringUtils.isBlank(x.getSerialNumber())).collect(Collectors.groupingBy(x -> x.getItemId(), Collectors.toList()));
1137
 
1138
        for (InventoryItem inventoryItem : inventoryItems) {
1139
            if (StringUtils.isBlank(inventoryItem.getSerialNumber())) {
1140
                //As of now this should be happening as  dn are specifically for serialized devices
1141
                /*int returnQty = inventoryItemCountMap.get(inventoryItem.getId()).intValue();
1142
                List<WarehouseInventoryItem> warehouseInventoryItemList = itemIdWarehouseInventoryItemsMap.get(inventoryItem.getItemId());
1143
                warehouseInventoryService.returnNonSerializedQty(warehouseInventoryItem)*/
1144
            } else if (StringUtils.isNotBlank(inventoryItem.getSerialNumber())) {
1145
                String serialNumber = inventoryItem.getSerialNumber();
1146
                WarehouseInventoryItem warehouseInventoryItem = serialNumberWarehouseInventoryItemMap.get(serialNumber);
1147
                warehouseInventoryItem.setLastScanType(in.shop2020.warehouse.ScanType.SALE_RET);
1148
                warehouseInventoryService.addQuantity(warehouseInventoryItem.getId(), 1);
1149
                WarehouseScan warehouseScan = new WarehouseScan();
1150
                warehouseScan.setInventoryItemId(warehouseInventoryItem.getId());
1151
                warehouseScan.setQuantity(1);
1152
                warehouseScan.setOrderId(inventoryItemIdOrderIdMap.get(warehouseInventoryItem.getItemId()));
1153
                warehouseScan.setScannedAt(LocalDateTime.now());
1154
                warehouseScan.setType(in.shop2020.warehouse.ScanType.SALE_RET);
1155
                warehouseScanRepository.persist(warehouseScan);
1156
 
1157
            }
1158
        }
1159
 
1160
        //Create Order as well
1161
        com.spice.profitmandi.dao.entity.user.User user = userRepository.selectById(debitNote.getFofoId());
1162
        cartService.clearCart(user.getActiveCartId());
1163
        cartService.addItemsToCart(user.getActiveCartId(), cartItems);
1164
 
1165
        UserCart userCart = new UserCart();
1166
        userCart.setCartId(user.getActiveCartId());
1167
        userCart.setUserId(user.getId());
1168
 
1169
        int transactionId = transactionService.createTransactionInternally(userCart, walletTotalAmount, order.getWarehouseId());
1170
        commonPaymentService.payThroughWallet(transactionId);
1171
        transactionService.processTransaction(transactionId);
1172
    }
1173
 
1174
    @Autowired
32384 amit.gupta 1175
    WarehouseDebitNoteRepository warehouseDebitNoteRepository;
1176
    @Autowired
1177
    WarehouseDebitNoteLineRepository warehouseDebitNoteLineRepository;
1178
 
1179
    @Autowired
1180
    WarehouseInvoiceItemRepository warehouseInvoiceItemRepository;
1181
    @Autowired
1182
    WarehouseSupplierInvoiceRepository warehouseSupplierInvoiceRepository;
1183
 
1184
    @Autowired
1185
    PurchaseOrderService purchaseOrderService;
1186
 
32482 amit.gupta 1187
    @Autowired
1188
    VendorCatalogPricingLogRepository vendorCatalogPricingLogRepository;
32384 amit.gupta 1189
 
32214 jai.hind 1190
//    private void checkItelImeiActivationNew(LocalDate now, int i) {
1191
//    }
1192
 
32169 amit.gupta 1193
    @Autowired
1194
    SessionFactory sessionFactory;
1195
 
1196
    private void checkAllPayoutsDuplicate() throws Exception {
1197
        final Session session = sessionFactory.getCurrentSession();
32439 tejbeer 1198
        final NativeQuery<Object[]> nativeQuery = session.createNativeQuery("select sio.inventory_item_id, sio.scheme_id, sio.status, count(*) c\n" + "from fofo.scheme_in_out sio\n" + "         join catalog.scheme s on s.id = sio.scheme_id\n" + "where (sio.status = 'CREDITED'\n" + "    or sio.status = 'PENDING')\n" + "  and s.type != 'INVESTMENT'\n" + " and sio.create_timestamp >= '2023-01-01' " + "group by sio.inventory_item_id, sio.scheme_id, sio.status\n" + "having c > 1");
32169 amit.gupta 1199
        List<Object[]> resultList = nativeQuery.getResultList();
1200
        for (Object[] tuple : resultList) {
1201
            LOGGER.info("RESULT -- {}, {}, {}", tuple[0], tuple[1], tuple[2]);
1202
            int inventoryItemId = (Integer) tuple[0];
1203
            int schemeId = (Integer) tuple[1];
1204
            SchemePayoutStatus schemePayoutStatus = SchemePayoutStatus.valueOf((String) tuple[2]);
1205
            List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectByScheme(schemeId, inventoryItemId);
1206
            List<SchemeInOut> statusSpecificSchemeInOuts = schemeInOuts.stream().filter(x -> x.getStatus().equals(schemePayoutStatus)).collect(Collectors.toList());
1207
            if (statusSpecificSchemeInOuts.size() > 0) {
1208
                InventoryItem inventoryItem = inventoryItemRepository.selectById(inventoryItemId);
1209
                Scheme scheme = schemeRepository.selectById(schemeId);
1210
                List<ScanRecord> scanRecords = scanRecordRepository.selectByInventoryItemId(inventoryItemId);
1211
                if (scheme.getType().equals(SchemeType.IN)) {
1212
                    LOGGER.info("Skipping -- {}", inventoryItem.getSerialNumber());
1213
                } else {
1214
                    int fofoOrderId = scanRecords.stream().filter(x -> x.getOrderId() != 0).max(Comparator.comparing(x -> x.getOrderId())).get().getOrderId();
1215
                    WalletReferenceType walletReferenceType = SchemeType.ACTIVATION.equals(scheme.getType()) ? WalletReferenceType.ACTIVATION_SCHEME : SchemeType.SPECIAL_SUPPORT.equals(scheme.getType()) ? WalletReferenceType.SPECIAL_SUPPORT : WalletReferenceType.SCHEME_OUT;
1216
                    List<UserWalletHistory> userWalletHistoryList = userWalletHistoryRepository.selectAllByreferenceIdandreferenceType(fofoOrderId, walletReferenceType).stream().filter(x -> x.getAmount() == Math.round(statusSpecificSchemeInOuts.get(0).getAmount())).collect(Collectors.toList());
1217
                    LOGGER.info("UserwalletHistory Entry --> {}, Sios --> {}", userWalletHistoryList.size(), statusSpecificSchemeInOuts.size());
1218
                    if (userWalletHistoryList.size() != statusSpecificSchemeInOuts.size()) {
1219
                        //Skipping them in first run as it is the special casw of upgrade where mismatch has happend.
1220
                        LOGGER.info("problem with {}, sio status - {}, inventoryItem id {}, schemeID {} ", fofoOrderId, statusSpecificSchemeInOuts.stream().map(x -> x.getStatus()).collect(Collectors.toList()), inventoryItemId, schemeId);
1221
                        //Primarily multiple pending cases
1222
                        statusSpecificSchemeInOuts.stream().skip(1).forEach(schemeInOut -> {
1223
                            schemeInOut.setStatus(SchemePayoutStatus.REJECTED);
1224
                            schemeInOut.setStatusDescription("Rejected as entry is duplicate");
1225
                        });
1226
                    } else {
1227
                        userWalletHistoryList.stream().skip(1).forEach(userWalletHistory -> {
1228
                            try {
1229
                                walletService.rollbackAmountFromWallet(inventoryItem.getFofoId(), userWalletHistory.getAmount(), userWalletHistory.getReference(), userWalletHistory.getReferenceType(), "Reversal as multiple entries created", userWalletHistory.getBusinessTimestamp());
1230
                            } catch (ProfitMandiBusinessException e) {
1231
                                throw new RuntimeException(e);
1232
                            }
1233
                        });
1234
 
1235
                        statusSpecificSchemeInOuts.stream().skip(1).forEach(schemeInOut -> {
1236
                            schemeInOut.setStatus(SchemePayoutStatus.REJECTED);
1237
                            if (schemePayoutStatus.equals(SchemePayoutStatus.CREDITED)) {
1238
                                schemeInOut.setRolledBackTimestamp(LocalDateTime.now());
1239
                                schemeInOut.setStatusDescription("Rolled back as entry is duplicate");
1240
                            } else {
1241
                                LOGGER.info("This seems higly unreachable should not come here");
1242
                                schemeInOut.setStatusDescription("Rejected as entry is duplicate");
1243
                            }
1244
                        });
1245
                    }
1246
                }
1247
            }
1248
        }
1249
    }
1250
 
32009 amit.gupta 1251
    public void test1() throws Exception {
1252
        System.out.println("Starting test");
32048 tejbeer 1253
        processScheme(LocalDate.of(2023, 05, 06).atStartOfDay(), LocalDate.of(2023, 05, 9).atStartOfDay(), false);
32009 amit.gupta 1254
        /*partnerTypeChangeService.getTypeOnDate(175139287, LocalDate.of(2023,02, 01));
1255
        partnerTypeChangeService.getTypeOnDate(175139287, LocalDate.of(2023,03, 01));
1256
        partnerTypeChangeService.getTypeOnDate(175139287, LocalDate.of(2023,04, 01));
1257
        FofoStore fs = fofoStoreRepository.selectByRetailerId(175139287);
1258
        this.rolloutMarginForStoreOnMonth(fs, LocalDate.of(2023, 2, 1));
1259
        this.rolloutMarginForStoreOnMonth(fs, LocalDate.of(2023, 3, 1));*/
25598 amit.gupta 1260
 
32009 amit.gupta 1261
        //this.sendMailForSamsungRebilling();
1262
        /*List<PurchaseReturnItem> purchaseReturnItems = purchaseReturnItemRepository.selectPurchaseReturnByStatuses(Arrays.asList(PurchaseReturnStatus.DEBIT_NOTE_CREATED));
1263
        Map<Integer, List<PurchaseReturnItem>> inventoryItemsMap = purchaseReturnItems.stream().collect(Collectors.groupingBy(x -> x.getDebitNoteId()));
1264
        for (Map.Entry<Integer, List<PurchaseReturnItem>> debitNotePurcahseReturnMap : inventoryItemsMap.entrySet()) {
1265
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectAllByIds(debitNotePurcahseReturnMap.getValue().stream().map(x -> x.getInventoryItemId()).collect(Collectors.toList()));
1266
            offerService.reverseAdditionalSelloutSchemes(debitNotePurcahseReturnMap.getValue().get(0).getFofoId(), inventoryItems);
1267
        }*/
1268
        //this.sendMailForAgeingAlert();
1269
        //this.sendMailForAgeingAlert();
1270
        //System.out.println(brandRegionMappingRepository.getAvailabilityToVendorWarehouse(Arrays.asList(33353), 7720));
1271
 
1272
    }
1273
 
31697 amit.gupta 1274
    public void sendMailForSamsungRebilling() throws Exception {
1275
        List<BilledImeiModel> samsungModels = warehouseInventoryItemRepository.findByBillingDateBrand(LocalDate.now(), "Samsung");
1276
        LOGGER.info("SamsungModels {}", samsungModels);
1277
        samsungModels = samsungModels.stream().sorted(Comparator.comparing(x -> x.getPcmDate() == null ? -1 : 1)).collect(Collectors.toList());
1278
        if (samsungModels.size() > 0) {
1279
            List<String> headers = Arrays.asList("Partner Id", "Code", "Name", "City", "Brand", "Model Name", "Model Number", "Color", "Serial Number", "Remarks");
1280
            List<List<?>> rows = new ArrayList<>();
1281
            for (BilledImeiModel billedImeiModel : samsungModels) {
31886 tejbeer 1282
                List<Serializable> row = Arrays.asList(billedImeiModel.getFofoId(), billedImeiModel.getStoreCode(), billedImeiModel.getStoreName(), billedImeiModel.getStoreCity(), billedImeiModel.getBrand(), billedImeiModel.getModelName(), billedImeiModel.getModelNumber(), billedImeiModel.getColor(), billedImeiModel.getSerialNumber(), billedImeiModel.getPcmDate() == null ? "PCM date Missing" : "Rebill Imeis");
31697 amit.gupta 1283
                rows.add(row);
1284
            }
1285
            ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, rows);
1286
            String[] sendToArray = new String[]{"kamini.sharma@smartdukaan.com", "praveen.sharma@smartdukaan.com"};
1287
            String fileName = "Imeis need Rebilling -" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
31886 tejbeer 1288
            Utils.sendMailWithAttachment(googleMailSender, sendToArray, new String[]{"tarun.verma@smartdukaan.com"}, "Samsung Rebilling IMEI Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
31697 amit.gupta 1289
        }
1290
    }
24002 amit.gupta 1291
 
31697 amit.gupta 1292
    public void sendPartnerInvestmentDetails(List<String> sendTo) throws Exception {
1293
        LocalDate yesterDay = LocalDate.now().minusDays(1);
1294
        List<FofoStore> fofoStores = fofoStoreRepository.selectActiveStores();
31886 tejbeer 1295
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(fofoStores.stream().map(x -> x.getId()).collect(Collectors.toList()));
25312 amit.gupta 1296
 
32169 amit.gupta 1297
        List<String> headers = Arrays.asList("Code", "Outlet name", "State Manager", "Territory/Team Lead", "Wallet Amount", "In Stock Amount", "Activated Stock", "Return In Transit Stock", "Unbilled Amount", "Grn Pending Amount", "Min Investment", "Investment Amount", "Investment Short", "Unbilled Qty", "Short Days");
31697 amit.gupta 1298
        List<List<?>> rows = new ArrayList<>();
1299
        Map<Integer, List<?>> partnerRowsMap = new HashMap<>();
25598 amit.gupta 1300
 
31697 amit.gupta 1301
        Map<Integer, FofoReportingModel> partnerIdSalesHeaderMap = this.getPartnerIdSalesHeaders();
25312 amit.gupta 1302
 
31886 tejbeer 1303
        Map<Integer, Integer> shortDaysMap = partnerDailyInvestmentRepository.selectAll(LocalDate.now().withDayOfMonth(1), LocalDate.now()).stream().collect(groupingBy(
1304
                x -> x.getFofoId(), Collectors.summingInt(x -> x.getShortPercentage() > 10 ? 1 : 0)));
24271 amit.gupta 1305
 
31697 amit.gupta 1306
        for (FofoStore fofoStore : fofoStores) {
1307
            LOGGER.info("Fofo Store {},  {}", fofoStore.getId(), fofoStore.getCode());
1308
            int fofoId = fofoStore.getId();
1309
            PartnerDailyInvestment partnerDailyInvestment = partnerInvestmentService.getInvestment(fofoId, 1);
1310
            partnerDailyInvestment.setDate(yesterDay);
24177 govind 1311
 
31697 amit.gupta 1312
            try {
1313
                partnerDailyInvestmentRepository.persist(partnerDailyInvestment);
31886 tejbeer 1314
                shortDaysMap.put(fofoId, shortDaysMap.get(fofoId) + (partnerDailyInvestment.getShortPercentage() > 10 ? 1 : 0));
31697 amit.gupta 1315
            } catch (Exception e) {
1316
                // ignore the exceptions during persist
1317
            }
25598 amit.gupta 1318
 
31697 amit.gupta 1319
            CustomRetailer retailer = customRetailerMap.get(fofoStore.getId());
1320
            if (retailer == null || partnerIdSalesHeaderMap.get(fofoStore.getId()) == null) {
1321
                LOGGER.info("Could not find retailer with retailer Id {}", fofoStore.getId());
1322
                continue;
1323
            }
1324
            FofoReportingModel reportingModel = partnerIdSalesHeaderMap.get(fofoStore.getId());
1325
            List<Serializable> row = new ArrayList<>();
31886 tejbeer 1326
            row.addAll(Arrays.asList(reportingModel.getCode(), reportingModel.getBusinessName(), reportingModel.getRegionalManager(), reportingModel.getTerritoryManager()));
31697 amit.gupta 1327
            row.addAll(
31886 tejbeer 1328
                    Arrays.asList(partnerDailyInvestment.getWalletAmount(), partnerDailyInvestment.getInStockAmount(), partnerDailyInvestment.getActivatedStockAmount() == 0 ? "-" : "(" + partnerDailyInvestment.getActivatedStockAmount() + ")", 0, partnerDailyInvestment.getUnbilledAmount(), partnerDailyInvestment.getGrnPendingAmount(), partnerDailyInvestment.getMinInvestment(), partnerDailyInvestment.getTotalInvestment(), partnerDailyInvestment.getShortInvestment(), partnerDailyInvestment.getUnbilledQty(), shortDaysMap.get(fofoId)));
31697 amit.gupta 1329
            partnerRowsMap.put(fofoStore.getId(), row);
1330
            rows.add(row);
25837 amit.gupta 1331
 
31697 amit.gupta 1332
        }
25837 amit.gupta 1333
 
31697 amit.gupta 1334
        String fileName = "InvestmentSummary-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
25837 amit.gupta 1335
 
31697 amit.gupta 1336
        if (sendTo == null) {
1337
            for (Map.Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMapping().entrySet()) {
31886 tejbeer 1338
                List<List<?>> filteredRows = storeGuyEntry.getValue().stream().map(x -> partnerRowsMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
31697 amit.gupta 1339
                ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, filteredRows);
1340
                String[] sendToArray = new String[]{storeGuyEntry.getKey()};
31886 tejbeer 1341
                Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Franchise Investment Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
31697 amit.gupta 1342
            }
31886 tejbeer 1343
            sendTo = Arrays.asList("tarun.verma@smartdukaan.com", "kamini.sharma@smartdukaan.com", "neeraj.gupta@smartdukaan.com", "amit.gupta@shop2020.in", "manish.gupta@smartdukaan.com", "niranjan.kala@smartdukaan.com");
31697 amit.gupta 1344
        }
25837 amit.gupta 1345
 
31697 amit.gupta 1346
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, rows);
1347
        String[] sendToArray = sendTo.toArray(new String[sendTo.size()]);
31886 tejbeer 1348
        Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Franchise Investment Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
25837 amit.gupta 1349
 
31697 amit.gupta 1350
    }
25598 amit.gupta 1351
 
31697 amit.gupta 1352
    private Map<Integer, FofoReportingModel> getPartnerIdSalesHeaders() {
1353
        Map<String, SaleRoles> partnerEmailSalesMap = new HashMap<>();
1354
        Map<String, SaleRoles> partnerEmailRBMMap = new HashMap<>();
24271 amit.gupta 1355
 
31886 tejbeer 1356
        List<Position> positions = positionRepository.selectPositionByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_RBM));
1357
        Map<Integer, AuthUser> authUsersMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
31697 amit.gupta 1358
        Map<Integer, List<CustomRetailer>> positionIdRetailerMap = csService.getPositionCustomRetailerMap(positions);
1359
        for (Position position : positions) {
1360
            List<CustomRetailer> crList = positionIdRetailerMap.get(position.getId());
1361
            if (crList == null)
1362
                continue;
1363
            if (position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_SALES) {
1364
                for (CustomRetailer cr : crList) {
1365
                    if (!partnerEmailSalesMap.containsKey(cr.getEmail())) {
1366
                        partnerEmailSalesMap.put(cr.getEmail(), new SaleRoles());
1367
                    }
1368
                    SaleRoles saleRoles = partnerEmailSalesMap.get(cr.getEmail());
1369
                    AuthUser authUser = authUsersMap.get(position.getAuthUserId());
1370
                    if (authUser == null) {
1371
                        continue;
1372
                    }
1373
                    String name = authUser.getFirstName() + " " + authUser.getLastName();
1374
                    if (position.getEscalationType().equals(EscalationType.L1)) {
1375
                        saleRoles.getL1().add(name);
1376
                    } else if (position.getEscalationType().equals(EscalationType.L2)) {
1377
                        saleRoles.getL2().add(name);
1378
                    }
1379
                }
1380
            }
1381
            if (position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_RBM) {
1382
                for (CustomRetailer cr : crList) {
1383
                    if (!partnerEmailRBMMap.containsKey(cr.getEmail())) {
1384
                        partnerEmailRBMMap.put(cr.getEmail(), new SaleRoles());
1385
                    }
1386
                    SaleRoles saleRoles = partnerEmailRBMMap.get(cr.getEmail());
1387
                    AuthUser authUser = authUsersMap.get(position.getAuthUserId());
1388
                    if (authUser == null) {
1389
                        continue;
1390
                    }
1391
                    String name = authUser.getFirstName() + " " + authUser.getLastName();
1392
                    if (position.getEscalationType().equals(EscalationType.L1) || position.getEscalationType().equals(EscalationType.L1)) {
1393
                        saleRoles.getL1().add(name);
1394
                    }
1395
                    /*else if (position.getEscalationType().equals(EscalationType.L2)) {
1396
                        saleRoles.getL2().add(name);
1397
                    }*/
1398
                }
1399
            }
24692 amit.gupta 1400
 
31697 amit.gupta 1401
        }
25418 amit.gupta 1402
 
31697 amit.gupta 1403
        Set<CustomRetailer> allCrList = new HashSet<>();
1404
        for (List<CustomRetailer> cr : positionIdRetailerMap.values()) {
1405
            allCrList.addAll(cr);
1406
        }
25609 amit.gupta 1407
 
31886 tejbeer 1408
        Map<Integer, FofoStore> fofoStoresMap = fofoStoreRepository.selectActiveStores().stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
25503 amit.gupta 1409
 
31697 amit.gupta 1410
        Map<Integer, FofoReportingModel> partnerIdSalesHeadersMap = new HashMap<>();
25503 amit.gupta 1411
 
31697 amit.gupta 1412
        for (CustomRetailer cr : allCrList) {
1413
            FofoStore fofoStore = fofoStoresMap.get(cr.getPartnerId());
1414
            if (fofoStore == null) {
1415
                LOGGER.info("Could not find Store {} in active Store", cr.getBusinessName());
1416
                continue;
1417
            }
1418
            String code = fofoStore.getCode();
1419
            // String storeName = "SmartDukaan-" +
1420
            // fofoStore.getCode().replaceAll("[a-zA-Z]", "");
1421
            String businessName = cr.getBusinessName();
1422
            try {
1423
                String stateManager = StringUtils.join(partnerEmailSalesMap.get(cr.getEmail()).getL2(), ", ");
1424
                String territoryManager = StringUtils.join(partnerEmailSalesMap.get(cr.getEmail()).getL1(), ", ");
1425
                String bdm = StringUtils.join(partnerEmailRBMMap.get(cr.getEmail()).getL1(), ", ");
1426
                FofoReportingModel reportingModel = new FofoReportingModel();
1427
                reportingModel.setBusinessName(businessName);
1428
                reportingModel.setCode(code);
1429
                reportingModel.setFofoId(fofoStore.getId());
1430
                reportingModel.setRegionalManager(stateManager);
1431
                reportingModel.setTerritoryManager(territoryManager);
1432
                reportingModel.setBusinessManager(bdm);
1433
                partnerIdSalesHeadersMap.put(fofoStore.getId(), reportingModel);
1434
            } catch (Exception e) {
1435
                LOGGER.warn("Could not find partner with email - {}", cr.getEmail());
1436
            }
1437
        }
1438
        return partnerIdSalesHeadersMap;
24533 govind 1439
 
31697 amit.gupta 1440
    }
28709 amit.gupta 1441
 
31697 amit.gupta 1442
    public void sendPartnerInvestmentDetails() throws Exception {
1443
        this.sendPartnerInvestmentDetails(null);
1444
    }
28709 amit.gupta 1445
 
31697 amit.gupta 1446
    public void sendAgeingReport(String... sendTo) throws Exception {
28790 amit.gupta 1447
 
31886 tejbeer 1448
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.WAREHOUSENEW, "itemstockageing.xml");
1449
        InputStreamSource isr1 = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "ItemwiseOverallPendingIndent.xml");
31697 amit.gupta 1450
        Attachment attachment = new Attachment(
1451
                "ageing-report-" + FormattingUtils.formatDate(LocalDateTime.now().minusDays(1)) + ".csv", isr);
1452
        Attachment attachment1 = new Attachment(
1453
                "pending-indent-" + FormattingUtils.formatDate(LocalDateTime.now().minusDays(1)) + ".csv", isr1);
28790 amit.gupta 1454
 
31886 tejbeer 1455
        Utils.sendMailWithAttachments(googleMailSender, STOCK_AGEING_MAIL_LIST, null, "Stock Ageing Report", "PFA", attachment);
1456
        Utils.sendMailWithAttachments(googleMailSender, ITEMWISE_PENDING_INDENT_MAIL_LIST, null, "Itemwise Pending indent", "PFA", attachment1);
28790 amit.gupta 1457
 
31697 amit.gupta 1458
        // Reports to be sent to mapped partners
1459
        Map<String, Set<String>> storeGuysMap = csService.getAuthUserPartnerEmailMapping();
28790 amit.gupta 1460
 
31697 amit.gupta 1461
        for (Map.Entry<String, Set<String>> storeGuyEntry : storeGuysMap.entrySet()) {
1462
            Map<String, String> params = new HashMap<>();
1463
            if (storeGuyEntry.getValue().size() == 0)
1464
                continue;
1465
            params.put("MANUAL_email", String.join(",", storeGuyEntry.getValue()));
31886 tejbeer 1466
            InputStreamSource isr3 = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "focostockreport.xml", params);
31697 amit.gupta 1467
            Attachment attache = new Attachment(
1468
                    "Franchise-stock-report" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr3);
1469
            System.out.println(storeGuyEntry.getValue());
31886 tejbeer 1470
            Utils.sendMailWithAttachments(googleMailSender, new String[]{storeGuyEntry.getKey()}, null, "Franchise Stock Report", "PFA", attache);
31697 amit.gupta 1471
        }
28839 tejbeer 1472
 
31697 amit.gupta 1473
    }
28839 tejbeer 1474
 
31697 amit.gupta 1475
    public void sendIndentTertiary() throws Exception {
28790 amit.gupta 1476
 
31886 tejbeer 1477
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "indentandtertiary.xml");
31697 amit.gupta 1478
        Attachment attachment = new Attachment(
1479
                "indentandtertiary-report-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr);
31886 tejbeer 1480
        Utils.sendMailWithAttachments(googleMailSender, INDENT_TERTIARY_MAIL_LIST, null, "Indent Tertiary Report", "PFA", attachment);
28790 amit.gupta 1481
 
31697 amit.gupta 1482
    }
28790 amit.gupta 1483
 
31697 amit.gupta 1484
    public void sendAttendanceMorningAlert() throws Exception {
1485
        LocalDateTime moriningTime = LocalDate.now().atTime(10, 31);
1486
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
31886 tejbeer 1487
        Map<String, AuthUser> authUserEmailMap = authUsers.stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28775 amit.gupta 1488
 
31697 amit.gupta 1489
        List<User> users = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.keySet()));
1490
        Map<String, User> userMap = users.stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28790 amit.gupta 1491
 
31886 tejbeer 1492
        List<EmployeeAttendance> employeeAttendances = employeeAttendanceRepository.selectAllByDatesBetween(LocalDate.now().atStartOfDay(), LocalDateTime.now());
28784 amit.gupta 1493
 
31886 tejbeer 1494
        Map<Integer, Optional<EmployeeAttendance>> employeeMorningAttendance = employeeAttendances.stream().collect(groupingBy(EmployeeAttendance::getUserId, Collectors.minBy(Comparator.comparing(EmployeeAttendance::getCreateTimestamp))));
31697 amit.gupta 1495
        for (AuthUser authUser : authUsers) {
1496
            User user = userMap.get(authUser.getEmailId());
1497
            Optional<EmployeeAttendance> employeeAttendanceOptional = employeeMorningAttendance.get(user.getId());
1498
            LOGGER.info("AuthUser - {}, employeeAttendanceOptional {}", authUser.getName(), employeeAttendanceOptional);
1499
            if (employeeAttendanceOptional != null) {
1500
                LOGGER.info("employeeAttendanceOptional.orElse {}", employeeAttendanceOptional.orElse(null));
1501
                if (employeeAttendanceOptional.orElse(null) != null) {
31886 tejbeer 1502
                    LOGGER.info("employeeAttendanceOptional.get().getCreateTimestamp() {}", employeeAttendanceOptional.get().getCreateTimestamp());
31697 amit.gupta 1503
                }
1504
            }
31886 tejbeer 1505
            if (employeeAttendanceOptional == null || employeeAttendanceOptional.orElse(null) == null || employeeAttendanceOptional.get().getCreateTimestamp().isAfter(moriningTime)) {
31697 amit.gupta 1506
                LOGGER.info("Will Send Email to {}", authUser.getFullName());
1507
                String body = String.format(
31886 tejbeer 1508
                        "Dear %s,\n Pls note that you haven't punched your attendance by 10:30am%s. You have been marked absent for half the day.\n\nRegards\nHR Team", authUser.getFullName(), (employeeAttendanceOptional == null || employeeAttendanceOptional.orElse(null) == null) ? "" : "(Punched at " + FormattingUtils.format(employeeAttendanceOptional.get().getCreateTimestamp()) + ")");
28790 amit.gupta 1509
 
31886 tejbeer 1510
                Utils.sendMailWithAttachments(googleMailSender, new String[]{authUser.getEmailId()}, new String[]{"kangan.monga@smartdukaan.com"}, "Attendance Alert", body);
28790 amit.gupta 1511
 
31697 amit.gupta 1512
            }
1513
        }
28790 amit.gupta 1514
 
31697 amit.gupta 1515
    }
28790 amit.gupta 1516
 
31697 amit.gupta 1517
    public void sendAttendanceEveningAlert() throws Exception {
1518
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
31886 tejbeer 1519
        Map<String, AuthUser> authUserEmailMap = authUsers.stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28709 amit.gupta 1520
 
31697 amit.gupta 1521
        List<User> users = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.keySet()));
1522
        Map<String, User> userMap = users.stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28709 amit.gupta 1523
 
31886 tejbeer 1524
        Map<Integer, List<EmployeeAttendance>> employeeAttendancesMap = employeeAttendanceRepository.selectAllByDatesBetween(LocalDate.now().atStartOfDay(), LocalDateTime.now()).stream().collect(groupingBy(x -> x.getUserId()));
28709 amit.gupta 1525
 
31697 amit.gupta 1526
        for (AuthUser authUser : authUsers) {
1527
            User user = userMap.get(authUser.getEmailId());
1528
            String body = null;
1529
            List<EmployeeAttendance> employeeAttendances = employeeAttendancesMap.get(user.getId());
1530
            if (employeeAttendances == null) {
1531
                body = String.format(
31886 tejbeer 1532
                        "Dear %s,\n No attendance has been registered by you today. You have been marked absent for the day.\n\nRegards\nHR Team", authUser.getFullName());
31697 amit.gupta 1533
            } else {
31886 tejbeer 1534
                List<LocalDateTime> punchTimes = employeeAttendances.stream().sorted(Comparator.comparing(EmployeeAttendance::getCreateTimestamp)).map(x -> x.getCreateTimestamp()).collect(Collectors.toList());
31697 amit.gupta 1535
                if (punchTimes.size() == 1) {
1536
                    // body = String.format("Dear %s,\n Pls note that you haven't punched out yet.
1537
                    // You have been marked absent for half the day. You may contact your manager
1538
                    // and get it regularise.\n\nRegards\nHR Team", authUser.getFullName());
1539
                } else {
1540
                    LocalDateTime firstPunch = punchTimes.get(0);
1541
                    LocalDateTime lastPunch = punchTimes.get(punchTimes.size() - 1);
1542
                    Duration duration = Duration.between(firstPunch, lastPunch);
1543
                    boolean hoursCompleted = lastPunch.isAfter(firstPunch.plusHours(8).plusMinutes(30));
1544
                    if (!hoursCompleted) {
1545
                        body = String.format(
31886 tejbeer 1546
                                "Dear %s,\n Pls note that you haven't completed 8.30 Hrs (%d.%d Hrs). You have been marked absent for half the day.\n\nRegards\nHR Team", authUser.getFullName(), duration.toHours(), duration.toMinutes() - duration.toHours() * 60);
31697 amit.gupta 1547
                    }
1548
                }
28709 amit.gupta 1549
 
31697 amit.gupta 1550
            }
1551
            if (body != null) {
31886 tejbeer 1552
                Utils.sendMailWithAttachments(googleMailSender, new String[]{authUser.getEmailId()}, new String[]{"kangan.monga@smartdukaan.com"}, "Attendance Alert", body);
31697 amit.gupta 1553
            }
1554
        }
28709 amit.gupta 1555
 
31697 amit.gupta 1556
        this.sendMailToHR();
28709 amit.gupta 1557
 
31697 amit.gupta 1558
    }
28709 amit.gupta 1559
 
31697 amit.gupta 1560
    private void sendMailToHR() throws Exception {
1561
        Map<String, String> map = new HashMap<>();
1562
        String reporticoDate = FormattingUtils.formatReporitcoDate(LocalDateTime.now());
1563
        map.put("MANUAL_datesBetween_FROMDATE", reporticoDate);
1564
        map.put("MANUAL_datesBetween_FROMDATE", reporticoDate);
31886 tejbeer 1565
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "employeeattendance.xml");
1566
        Attachment attachment = new Attachment("attendance-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr);
1567
        Utils.sendMailWithAttachments(googleMailSender, EMPLOYEE_ATTENDANCE_MAIL_LIST, null, "Attendance - " + FormattingUtils.formatDate(LocalDateTime.now()), "PFA Attendance", attachment);
31697 amit.gupta 1568
    }
28709 amit.gupta 1569
 
31697 amit.gupta 1570
    public void checkPartnerActiveStore() throws Exception {
24697 amit.gupta 1571
 
31697 amit.gupta 1572
        List<FofoStore> fofoStores = fofoStoreRepository.selectByStatus(true);
23929 amit.gupta 1573
 
31697 amit.gupta 1574
        LocalDateTime currentDate = LocalDate.now().atStartOfDay();
1575
        if (!fofoStores.isEmpty()) {
1576
            for (FofoStore fofoStore : fofoStores) {
24551 amit.gupta 1577
 
31697 amit.gupta 1578
                if (currentDate.isBefore(fofoStore.getActiveTimeStamp())) {
24542 amit.gupta 1579
 
31697 amit.gupta 1580
                    fofoStore.setActive(true);
1581
                    fofoStoreRepository.persist(fofoStore);
1582
                    LOGGER.info("inserted into InActiveFofoStore successfully");
29160 amit.gupta 1583
 
31697 amit.gupta 1584
                } else {
1585
                    fofoStore.setActive(false);
1586
                    fofoStore.setActiveTimeStamp(null);
1587
                    fofoStoreRepository.persist(fofoStore);
1588
                    LOGGER.info("inserted into InActiveFofoStore successfully");
1589
                }
24542 amit.gupta 1590
 
31697 amit.gupta 1591
            }
1592
        }
24542 amit.gupta 1593
 
31697 amit.gupta 1594
    }
24548 amit.gupta 1595
 
31697 amit.gupta 1596
    public void sendAgeingReport() throws Exception {
31886 tejbeer 1597
        sendAgeingReport("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "niranjan.kala@smartdukaan.com", "manish.gupta@smartdukaan.com", "kuldeep.kumar@smartdukaan.com");
31697 amit.gupta 1598
    }
24542 amit.gupta 1599
 
31697 amit.gupta 1600
    public void moveImeisToPriceDropImeis() throws Exception {
1601
        List<PriceDrop> priceDrops = priceDropRepository.selectAll();
1602
        for (PriceDrop priceDrop : priceDrops) {
1603
            priceDropService.priceDropStatus(priceDrop.getId());
1604
        }
1605
    }
29160 amit.gupta 1606
 
31697 amit.gupta 1607
    public void walletmismatch() throws Exception {
1608
        LocalDate curDate = LocalDate.now();
1609
        List<PartnerDailyInvestment> pdis = partnerDailyInvestmentRepository.selectAll(curDate.minusDays(2));
1610
        System.out.println(pdis.size());
1611
        for (PartnerDailyInvestment pdi : pdis) {
1612
            int fofoId = pdi.getFofoId();
31886 tejbeer 1613
            for (PartnerDailyInvestment investment : Lists.reverse(partnerDailyInvestmentRepository.selectAll(fofoId, null, null))) {
1614
                float statementAmount = walletService.getOpeningTill(fofoId, investment.getDate().plusDays(1).atTime(LocalTime.of(4, 0)));
31697 amit.gupta 1615
                CustomRetailer retailer = retailerService.getFofoRetailer(fofoId);
31886 tejbeer 1616
                LOGGER.info("{}\t{}\t{}\t{}\t{}", fofoId, retailer.getBusinessName(), retailer.getMobileNumber(), investment.getDate().toString(), investment.getWalletAmount(), statementAmount);
29160 amit.gupta 1617
 
31697 amit.gupta 1618
            }
1619
        }
29160 amit.gupta 1620
 
31697 amit.gupta 1621
    }
29160 amit.gupta 1622
 
31697 amit.gupta 1623
    @Autowired
1624
    StateRepository stateRepository;
29160 amit.gupta 1625
 
31697 amit.gupta 1626
    public void gst() throws Exception {
31886 tejbeer 1627
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectBetweenSaleDate(LocalDate.of(2021, 8, 16).atStartOfDay(), LocalDateTime.now());
31697 amit.gupta 1628
        for (FofoOrder fofoOrder : fofoOrders) {
31886 tejbeer 1629
            int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(fofoOrder.getFofoId());
24548 amit.gupta 1630
 
31697 amit.gupta 1631
            Address retailerAddress = addressRepository.selectById(retailerAddressId);
1632
            CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
1633
            Integer stateId = null;
1634
            if (customerAddress.getState().equals(retailerAddress.getState())) {
1635
                try {
1636
                    stateId = stateRepository.selectByName(customerAddress.getState()).getId();
1637
                } catch (Exception e) {
1638
                    LOGGER.error("Cannot found state named {}", customerAddress.getState());
1639
                    continue;
1640
                }
1641
            }
1642
            Map<Integer, GstRate> itemIdStateTaxRateMap = null;
24542 amit.gupta 1643
 
31697 amit.gupta 1644
            List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
1645
            List<Integer> itemIds = fofoOrderItems.stream().map(x -> x.getItemId()).collect(Collectors.toList());
1646
            if (stateId != null) {
1647
                itemIdStateTaxRateMap = stateGstRateRepository.getStateTaxRate(itemIds, stateId);
1648
            } else {
32145 tejbeer 1649
                itemIdStateTaxRateMap = stateGstRateRepository.getIgstTaxRate(itemIds);
31697 amit.gupta 1650
            }
24580 amit.gupta 1651
 
31697 amit.gupta 1652
            for (FofoOrderItem foi : fofoOrderItems) {
1653
                float sgstRate = foi.getSgstRate();
1654
                float cgstRate = foi.getCgstRate();
1655
                float igstRate = foi.getIgstRate();
32145 tejbeer 1656
                foi.setCgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getCgstRate());
1657
                foi.setSgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getSgstRate());
1658
                foi.setIgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getIgstRate());
24587 amit.gupta 1659
 
32145 tejbeer 1660
                LOGGER.info("Invoice {}, Date {}", fofoOrder.getInvoiceNumber(), fofoOrder.getCreateTimestamp());
1661
                LOGGER.info("customerAddress.getState() {}, retailerAddress.getState() {}", customerAddress.getState(), retailerAddress.getState());
1662
                LOGGER.info("Rates getIgstRate() {}", itemIdStateTaxRateMap.get(foi.getItemId()).getIgstRate());
1663
                LOGGER.info("Rates getCgstRate() {}, getSgstRate() {}", itemIdStateTaxRateMap.get(foi.getItemId()).getCgstRate(), itemIdStateTaxRateMap.get(foi.getItemId()).getSgstRate());
24587 amit.gupta 1664
 
1665
 
31697 amit.gupta 1666
            }
1667
        }
26092 amit.gupta 1668
 
31697 amit.gupta 1669
    }
24590 amit.gupta 1670
 
31697 amit.gupta 1671
    public void schemewalletmismatch() {
1672
        LocalDate dateToReconcile = LocalDate.of(2018, 4, 1);
1673
        while (dateToReconcile.isBefore(LocalDate.now())) {
1674
            reconcileSchemes(dateToReconcile);
1675
            // reconcileOrders(dateTime);
1676
            // reconcileRecharges(dateTime);
1677
            dateToReconcile = dateToReconcile.plusDays(1);
1678
        }
1679
    }
24587 amit.gupta 1680
 
31697 amit.gupta 1681
    private void reconcileSchemes(LocalDate date) {
1682
        LocalDateTime startDate = date.atStartOfDay();
1683
        LocalDateTime endDate = startDate.plusDays(1);
1684
        List<SchemeInOut> siosCreated = schemeInOutRepository.selectAllByCreateDate(startDate, endDate);
1685
        List<SchemeInOut> siosRefunded = schemeInOutRepository.selectAllByRefundDate(startDate, endDate);
1686
        double totalSchemeDisbursed = siosCreated.stream().mapToDouble(x -> x.getAmount()).sum();
1687
        double totalSchemeRolledback = siosRefunded.stream().mapToDouble(x -> x.getAmount()).sum();
1688
        double netSchemeDisbursed = totalSchemeDisbursed - totalSchemeRolledback;
31886 tejbeer 1689
        List<WalletReferenceType> walletReferenceTypes = Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT);
1690
        List<UserWalletHistory> history = userWalletHistoryRepository.selectAllByDateType(startDate, endDate, walletReferenceTypes);
31697 amit.gupta 1691
        double schemeAmountWalletTotal = history.stream().mapToDouble(x -> x.getAmount()).sum();
1692
        if (Math.abs(netSchemeDisbursed - schemeAmountWalletTotal) > 10d) {
1693
            LOGGER.info("Scheme Amount mismatched for Date {}", date);
24590 amit.gupta 1694
 
31724 amit.gupta 1695
            Map<Integer, Double> inventoryItemSchemeIO = siosCreated.stream().collect(groupingBy(x -> x.getInventoryItemId(), Collectors.summingDouble(SchemeInOut::getAmount)));
24635 amit.gupta 1696
 
31886 tejbeer 1697
            Map<Integer, Double> userSchemeMap = inventoryItemRepository.selectByIds(inventoryItemSchemeIO.keySet()).stream().collect(groupingBy(x -> x.getFofoId(), Collectors.summingDouble(x -> inventoryItemSchemeIO.get(x.getId()))));
24635 amit.gupta 1698
 
31724 amit.gupta 1699
            Map<Integer, Double> inventoryItemSchemeIORefunded = siosRefunded.stream().collect(groupingBy(x -> x.getInventoryItemId(), Collectors.summingDouble(SchemeInOut::getAmount)));
24635 amit.gupta 1700
 
31886 tejbeer 1701
            Map<Integer, Double> userSchemeRefundedMap = inventoryItemRepository.selectByIds(inventoryItemSchemeIORefunded.keySet()).stream().collect(groupingBy(x -> x.getFofoId(), Collectors.summingDouble(x -> inventoryItemSchemeIORefunded.get(x.getId()))));
24635 amit.gupta 1702
 
31697 amit.gupta 1703
            Map<Integer, Double> finalUserSchemeAmountMap = new HashMap<>();
24635 amit.gupta 1704
 
31697 amit.gupta 1705
            for (Map.Entry<Integer, Double> schemeAmount : userSchemeRefundedMap.entrySet()) {
1706
                if (!finalUserSchemeAmountMap.containsKey(schemeAmount.getKey())) {
1707
                    finalUserSchemeAmountMap.put(schemeAmount.getKey(), schemeAmount.getValue());
1708
                } else {
31886 tejbeer 1709
                    finalUserSchemeAmountMap.put(schemeAmount.getKey(), finalUserSchemeAmountMap.get(schemeAmount.getKey()) + schemeAmount.getValue());
31697 amit.gupta 1710
                }
1711
            }
31886 tejbeer 1712
            Map<Integer, Integer> userWalletMap = userWalletRepository.selectByRetailerIds(finalUserSchemeAmountMap.keySet()).stream().collect(Collectors.toMap(UserWallet::getUserId, UserWallet::getId));
24635 amit.gupta 1713
 
31724 amit.gupta 1714
            Map<Integer, Double> walletAmountMap = history.stream().collect(groupingBy(
31697 amit.gupta 1715
                    UserWalletHistory::getWalletId, Collectors.summingDouble((UserWalletHistory::getAmount))));
1716
            for (Map.Entry<Integer, Double> userAmount : walletAmountMap.entrySet()) {
1717
                double diff = Math.abs(finalUserSchemeAmountMap.get(userAmount.getKey()) - userAmount.getValue());
1718
                if (diff > 5) {
1719
                    LOGGER.info("Partner scheme mismatched for Userid {}", userWalletMap.get(userAmount.getKey()));
1720
                }
1721
            }
1722
        }
24635 amit.gupta 1723
 
31697 amit.gupta 1724
    }
24635 amit.gupta 1725
 
31697 amit.gupta 1726
    public void dryRunSchemeReco() throws Exception {
31886 tejbeer 1727
        Map<Integer, Integer> userWalletMap = userWalletRepository.selectAll().stream().collect(Collectors.toMap(UserWallet::getUserId, UserWallet::getId));
24635 amit.gupta 1728
 
31697 amit.gupta 1729
        List<UserWalletHistory> userWalletHistory = new ArrayList<>();
1730
        List<SchemeInOut> rolledbackSios = new ArrayList<>();
31886 tejbeer 1731
        Map<Integer, SchemeType> schemeTypeMap = schemeRepository.selectAll().stream().collect(Collectors.toMap(Scheme::getId, Scheme::getType));
31697 amit.gupta 1732
        Set<String> serialNumbersConsidered = new HashSet<>();
24631 amit.gupta 1733
 
31697 amit.gupta 1734
        LocalDateTime startDate = LocalDate.of(2018, 3, 1).atStartOfDay();
1735
        LocalDateTime endDate = LocalDate.now().atStartOfDay();
1736
        List<Purchase> purchases = purchaseRepository.selectAllBetweenPurchaseDate(startDate, endDate);
24598 amit.gupta 1737
 
31697 amit.gupta 1738
        Map<Integer, String> storeNameMap = fofoStoreRepository.getStoresMap();
1739
        purchases.stream().forEach(purchase -> {
1740
            float amountToRollback = 0;
31886 tejbeer 1741
            String description = "Adjustment of Duplicate Scheme for Purchase Invoice " + purchase.getPurchaseReference();
1742
            Map<Integer, String> inventorySerialNumberMap = inventoryItemRepository.selectByPurchaseId(purchase.getId()).stream().filter(ii -> ii.getSerialNumber() != null).collect(Collectors.toMap(InventoryItem::getId, InventoryItem::getSerialNumber));
31697 amit.gupta 1743
            if (inventorySerialNumberMap.size() > 0) {
1744
                for (Map.Entry<Integer, String> inventorySerialNumberEntry : inventorySerialNumberMap.entrySet()) {
1745
                    String serialNumber = inventorySerialNumberEntry.getValue();
1746
                    int inventoryItemId = inventorySerialNumberEntry.getKey();
1747
                    if (serialNumbersConsidered.contains(serialNumber)) {
1748
                        // This will rollback scheme for differenct orders for same serial
31886 tejbeer 1749
                        List<SchemeInOut> sios = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(inventoryItemId))).stream().filter(x -> x.getRolledBackTimestamp() == null && schemeTypeMap.get(x.getSchemeId()).equals(SchemeType.IN)).collect(Collectors.toList());
31697 amit.gupta 1750
                        Collections.reverse(sios);
1751
                        for (SchemeInOut sio : sios) {
1752
                            sio.setRolledBackTimestamp(LocalDateTime.now());
1753
                            amountToRollback += sio.getAmount();
1754
                            // sio.setSchemeType(SchemeType.OUT);
1755
                            sio.setSerialNumber(serialNumber);
1756
                            rolledbackSios.add(sio);
1757
                        }
1758
                        description = description.concat(" " + serialNumber + " ");
1759
                    } else {
1760
                        serialNumbersConsidered.add(serialNumber);
1761
                        List<Integer> schemesConsidered = new ArrayList<>();
31886 tejbeer 1762
                        List<SchemeInOut> sios = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(inventoryItemId))).stream().filter(x -> x.getRolledBackTimestamp() == null && schemeTypeMap.get(x.getSchemeId()).equals(SchemeType.IN)).collect(Collectors.toList());
31697 amit.gupta 1763
                        Collections.reverse(sios);
1764
                        for (SchemeInOut sio : sios) {
1765
                            if (!schemesConsidered.contains(sio.getSchemeId())) {
1766
                                schemesConsidered.add(sio.getSchemeId());
1767
                                continue;
1768
                            }
1769
                            sio.setRolledBackTimestamp(LocalDateTime.now());
1770
                            amountToRollback += sio.getAmount();
1771
                            // sio.setSchemeType(SchemeType.OUT);
1772
                            sio.setSerialNumber(serialNumber);
1773
                            sio.setStoreCode(storeNameMap.get(purchase.getFofoId()));
1774
                            sio.setReference(purchase.getId());
1775
                            rolledbackSios.add(sio);
1776
                        }
1777
                    }
24592 amit.gupta 1778
 
31697 amit.gupta 1779
                }
1780
            }
1781
            if (amountToRollback > 0) {
1782
                // Address address =
1783
                // addressRepository.selectAllByRetailerId(purchase.getFofoId(), 0, 10).get(0);
1784
                UserWalletHistory uwh = new UserWalletHistory();
1785
                uwh.setAmount(Math.round(amountToRollback));
1786
                uwh.setDescription(description);
1787
                uwh.setTimestamp(LocalDateTime.now());
1788
                uwh.setReferenceType(WalletReferenceType.SCHEME_IN);
1789
                uwh.setReference(purchase.getId());
1790
                uwh.setWalletId(userWalletMap.get(purchase.getFofoId()));
1791
                uwh.setFofoId(purchase.getFofoId());
1792
                uwh.setStoreCode(storeNameMap.get(purchase.getFofoId()));
1793
                userWalletHistory.add(uwh);
1794
            }
1795
        });
1796
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(
31886 tejbeer 1797
                Arrays.asList("User Id", "Store Code", "Reference Type", "Reference", "Amount", "Description", "Timestamp"), userWalletHistory.stream().map(x -> Arrays.asList(x.getWalletId(), x.getStoreCode(), x.getReferenceType(), x.getReference(), x.getAmount(), x.getDescription(), x.getTimestamp())).collect(Collectors.toList()));
24592 amit.gupta 1798
 
31697 amit.gupta 1799
        ByteArrayOutputStream baosOuts = FileUtil.getCSVByteStream(
31886 tejbeer 1800
                Arrays.asList("Scheme ID", "SchemeType", "Reference", "Store Code", "Serial Number", "Amount", "Created", "Rolledback"), rolledbackSios.stream().map(x -> Arrays.asList(x.getSchemeId(), x.getSchemeType(), x.getReference(), x.getStoreCode(), x.getSerialNumber(), x.getAmount(), x.getCreateTimestamp(), x.getRolledBackTimestamp())).collect(Collectors.toList()));
24631 amit.gupta 1801
 
31886 tejbeer 1802
        Utils.sendMailWithAttachments(googleMailSender, new String[]{"amit.gupta@shop2020.in"}, null, "Partner Excess Amount Scheme In", "PFA", new Attachment[]{new Attachment("WalletSummary.csv", new ByteArrayResource(baos.toByteArray())), new Attachment("SchemeInRolledback.csv", new ByteArrayResource(baosOuts.toByteArray()))});
24615 amit.gupta 1803
 
31697 amit.gupta 1804
        throw new Exception();
24615 amit.gupta 1805
 
31697 amit.gupta 1806
    }
24615 amit.gupta 1807
 
31697 amit.gupta 1808
    public void dryRunOutSchemeReco() throws Exception {
1809
        List<UserWalletHistory> userWalletHistory = new ArrayList<>();
1810
        List<SchemeInOut> rolledbackSios = new ArrayList<>();
31886 tejbeer 1811
        Map<Integer, Integer> userWalletMap = userWalletRepository.selectAll().stream().collect(Collectors.toMap(UserWallet::getUserId, UserWallet::getId));
1812
        Map<Integer, SchemeType> schemeTypeMap = schemeRepository.selectAll().stream().collect(Collectors.toMap(Scheme::getId, Scheme::getType));
31697 amit.gupta 1813
        LocalDateTime startDate = LocalDate.of(2019, 5, 1).atStartOfDay();
1814
        LocalDateTime endDate = LocalDate.now().atStartOfDay();
1815
        List<FofoOrder> allOrders = fofoOrderRepository.selectBetweenSaleDate(startDate, endDate);
1816
        // Collections.reverse(allOrders);
1817
        // List<FofoOrder> allOrders =
1818
        // List<FofoOrder> allOrders =
1819
        // Arrays.asList(fofoOrderRepository.selectByInvoiceNumber("UPGZ019/25"));
1820
        Set<String> serialNumbersConsidered = new HashSet<>();
1821
        allOrders.stream().forEach(fofoOrder -> {
1822
            String description = "Adjustment of Duplicate Scheme for Sale Invoice " + fofoOrder.getInvoiceNumber();
1823
            Map<Integer, String> inventorySerialNumberMap = new HashMap<>();
1824
            float amountToRollback = 0;
1825
            List<FofoOrderItem> orderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
1826
            orderItems.forEach(x -> {
31886 tejbeer 1827
                inventorySerialNumberMap.putAll(x.getFofoLineItems().stream().filter(li -> li.getSerialNumber() != null).collect(Collectors.toMap(FofoLineItem::getInventoryItemId, FofoLineItem::getSerialNumber)));
31697 amit.gupta 1828
            });
1829
            if (inventorySerialNumberMap.size() > 0) {
1830
                for (Map.Entry<Integer, String> inventorySerialNumberEntry : inventorySerialNumberMap.entrySet()) {
1831
                    String serialNumber = inventorySerialNumberEntry.getValue();
1832
                    int inventoryItemId = inventorySerialNumberEntry.getKey();
1833
                    if (serialNumbersConsidered.contains(serialNumber)) {
1834
                        // This will rollback scheme for differenct orders for same serial
31886 tejbeer 1835
                        List<SchemeInOut> sios = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(inventoryItemId))).stream().filter(x -> x.getRolledBackTimestamp() == null && schemeTypeMap.get(x.getSchemeId()).equals(SchemeType.OUT)).collect(Collectors.toList());
31697 amit.gupta 1836
                        Collections.reverse(sios);
1837
                        for (SchemeInOut sio : sios) {
1838
                            sio.setRolledBackTimestamp(LocalDateTime.now());
1839
                            amountToRollback += sio.getAmount();
1840
                            // sio.setSchemeType(SchemeType.OUT);
1841
                            sio.setSerialNumber(serialNumber);
1842
                            sio.setStoreCode(fofoOrder.getInvoiceNumber().split("/")[0]);
1843
                            sio.setReference(fofoOrder.getId());
1844
                            rolledbackSios.add(sio);
1845
                        }
1846
                        description = description.concat(" " + serialNumber + " ");
1847
                    } else {
1848
                        serialNumbersConsidered.add(serialNumber);
1849
                        List<Integer> schemesConsidered = new ArrayList<>();
31886 tejbeer 1850
                        List<SchemeInOut> sios = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(inventoryItemId))).stream().filter(x -> x.getRolledBackTimestamp() == null && schemeTypeMap.get(x.getSchemeId()).equals(SchemeType.OUT)).collect(Collectors.toList());
31697 amit.gupta 1851
                        Collections.reverse(sios);
1852
                        for (SchemeInOut sio : sios) {
1853
                            if (!schemesConsidered.contains(sio.getSchemeId())) {
1854
                                schemesConsidered.add(sio.getSchemeId());
1855
                                continue;
1856
                            }
1857
                            sio.setRolledBackTimestamp(LocalDateTime.now());
1858
                            amountToRollback += sio.getAmount();
1859
                            // sio.setSchemeType(SchemeType.OUT);
1860
                            sio.setReference(fofoOrder.getId());
1861
                            sio.setSerialNumber(serialNumber);
1862
                            sio.setStoreCode(fofoOrder.getInvoiceNumber().split("/")[0]);
1863
                            rolledbackSios.add(sio);
1864
                        }
1865
                    }
24615 amit.gupta 1866
 
31697 amit.gupta 1867
                }
1868
            }
1869
            if (amountToRollback > 0) {
1870
                UserWalletHistory uwh = new UserWalletHistory();
1871
                uwh.setAmount(Math.round(amountToRollback));
1872
                uwh.setDescription(description);
1873
                uwh.setTimestamp(LocalDateTime.now());
1874
                uwh.setReferenceType(WalletReferenceType.SCHEME_OUT);
1875
                uwh.setReference(fofoOrder.getId());
1876
                uwh.setWalletId(userWalletMap.get(fofoOrder.getFofoId()));
1877
                uwh.setFofoId(fofoOrder.getFofoId());
1878
                uwh.setStoreCode(fofoOrder.getInvoiceNumber().split("/")[0]);
1879
                userWalletHistory.add(uwh);
1880
            }
1881
        });
24615 amit.gupta 1882
 
31697 amit.gupta 1883
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(
31886 tejbeer 1884
                Arrays.asList("Wallet Id", "Store Code", "Reference Type", "Reference", "Amount", "Description", "Timestamp"), userWalletHistory.stream().map(x -> Arrays.asList(x.getWalletId(), x.getStoreCode(), x.getReferenceType(), x.getReference(), x.getAmount(), x.getDescription(), x.getTimestamp())).collect(Collectors.toList()));
24615 amit.gupta 1885
 
31697 amit.gupta 1886
        ByteArrayOutputStream baosOuts = FileUtil.getCSVByteStream(
31886 tejbeer 1887
                Arrays.asList("Scheme ID", "SchemeType", "Store Code", "Serial Number", "Amount", "Created", "Rolledback"), rolledbackSios.stream().map(x -> Arrays.asList(x.getSchemeId(), x.getSchemeType(), x.getStoreCode(), x.getSerialNumber(), x.getAmount(), x.getCreateTimestamp(), x.getRolledBackTimestamp())).collect(Collectors.toList()));
24631 amit.gupta 1888
 
31886 tejbeer 1889
        Utils.sendMailWithAttachments(googleMailSender, new String[]{"amit.gupta@shop2020.in"}, null, "Partner Excess Amount Scheme Out", "PFA", new Attachment[]{new Attachment("WalletSummary.csv", new ByteArrayResource(baos.toByteArray())), new Attachment("SchemeOutRolledback.csv", new ByteArrayResource(baosOuts.toByteArray()))});
24615 amit.gupta 1890
 
31697 amit.gupta 1891
        throw new Exception();
1892
    }
24615 amit.gupta 1893
 
31697 amit.gupta 1894
    public void dryRunSchemeOutReco1() throws Exception {
1895
        List<Integer> references = Arrays.asList(6744, 7347, 8320, 8891, 9124, 9217, 9263, 9379);
1896
        List<UserWalletHistory> userWalletHistory = new ArrayList<>();
1897
        List<SchemeInOut> rolledbackSios = new ArrayList<>();
31886 tejbeer 1898
        Map<Integer, Integer> userWalletMap = userWalletRepository.selectAll().stream().collect(Collectors.toMap(UserWallet::getUserId, UserWallet::getId));
1899
        Map<Integer, SchemeType> schemeTypeMap = schemeRepository.selectAll().stream().collect(Collectors.toMap(Scheme::getId, Scheme::getType));
31697 amit.gupta 1900
        references.stream().forEach(reference -> {
1901
            FofoOrder fofoOrder = null;
1902
            try {
1903
                fofoOrder = fofoOrderRepository.selectByOrderId(reference);
1904
            } catch (Exception e) {
25927 amit.gupta 1905
 
31697 amit.gupta 1906
            }
1907
            String description = "Adjustment of Duplicate Scheme for Sale Invoice " + fofoOrder.getInvoiceNumber();
1908
            Map<Integer, String> inventorySerialNumberMap = new HashMap<>();
1909
            float amountToRollback = 0;
1910
            List<FofoOrderItem> orderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
1911
            orderItems.forEach(x -> {
31886 tejbeer 1912
                inventorySerialNumberMap.putAll(x.getFofoLineItems().stream().filter(li -> li.getSerialNumber() != null).collect(Collectors.toMap(FofoLineItem::getInventoryItemId, FofoLineItem::getSerialNumber)));
31697 amit.gupta 1913
            });
1914
            if (inventorySerialNumberMap.size() > 0) {
31886 tejbeer 1915
                List<SchemeInOut> sios = schemeInOutRepository.selectByInventoryItemIds(inventorySerialNumberMap.keySet()).stream().filter(x -> schemeTypeMap.get(x.getSchemeId()).equals(SchemeType.OUT)).collect(Collectors.toList());
31697 amit.gupta 1916
                LOGGER.info("Found {} duplicate schemeouts for Orderid {}", sios.size(), fofoOrder.getId());
1917
                UserWalletHistory uwh = new UserWalletHistory();
31886 tejbeer 1918
                Map<Integer, List<SchemeInOut>> inventoryIdSouts = sios.stream().collect(groupingBy(SchemeInOut::getInventoryItemId, Collectors.toList()));
31697 amit.gupta 1919
                for (Map.Entry<Integer, List<SchemeInOut>> inventorySioEntry : inventoryIdSouts.entrySet()) {
1920
                    List<SchemeInOut> outList = inventorySioEntry.getValue();
1921
                    if (outList.size() > 1) {
24683 amit.gupta 1922
 
31697 amit.gupta 1923
                    }
1924
                }
1925
                uwh.setAmount(Math.round(amountToRollback));
1926
                uwh.setDescription(description);
1927
                uwh.setTimestamp(LocalDateTime.now());
1928
                uwh.setReferenceType(WalletReferenceType.SCHEME_OUT);
1929
                uwh.setReference(fofoOrder.getId());
1930
                uwh.setWalletId(userWalletMap.get(fofoOrder.getFofoId()));
1931
                uwh.setFofoId(fofoOrder.getFofoId());
1932
                uwh.setStoreCode(fofoOrder.getInvoiceNumber().split("/")[0]);
1933
                userWalletHistory.add(uwh);
1934
            }
1935
        });
26945 amit.gupta 1936
 
31697 amit.gupta 1937
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(
31886 tejbeer 1938
                Arrays.asList("User Id", "Reference Type", "Reference", "Amount", "Description", "Timestamp"), userWalletHistory.stream().map(x -> Arrays.asList(x.getWalletId(), x.getReferenceType(), x.getReference(), x.getAmount(), x.getDescription(), x.getTimestamp())).collect(Collectors.toList()));
26945 amit.gupta 1939
 
31697 amit.gupta 1940
        ByteArrayOutputStream baosOuts = FileUtil.getCSVByteStream(
31886 tejbeer 1941
                Arrays.asList("Scheme ID", "SchemeType", "Store Code", "Serial Number", "Amount", "Created", "Rolledback"), rolledbackSios.stream().map(x -> Arrays.asList(x.getSchemeId(), x.getSchemeType(), x.getStoreCode(), x.getSerialNumber(), x.getAmount(), x.getCreateTimestamp(), x.getRolledBackTimestamp())).collect(Collectors.toList()));
26941 amit.gupta 1942
 
31886 tejbeer 1943
        Utils.sendMailWithAttachments(googleMailSender, new String[]{"amit.gupta@shop2020.in", "neeraj.gupta@smartdukaan.com"}, null, "Partner Excess Amount", "PFA", new Attachment[]{new Attachment("WalletSummary.csv", new ByteArrayResource(baos.toByteArray())), new Attachment("SchemeOutRolledback.csv", new ByteArrayResource(baosOuts.toByteArray()))});
26945 amit.gupta 1944
 
31697 amit.gupta 1945
        throw new Exception();
25880 amit.gupta 1946
 
31697 amit.gupta 1947
    }
30982 tejbeer 1948
 
31697 amit.gupta 1949
    public void sendDailySalesNotificationToPartner(Integer fofoIdInt) throws Exception {
30982 tejbeer 1950
 
31697 amit.gupta 1951
        LocalDateTime now = LocalDateTime.now();
1952
        LocalDateTime from = now.with(LocalTime.MIN);
1953
        String timeString = "Today %s";
1954
        // Send yesterday's report
1955
        /*
1956
         * if (now.getHour() < 13) { timeString = "Yesterday %s"; from =
1957
         * now.minusDays(1).; now = from.with(LocalTime.MAX);
1958
         *
1959
         * }
1960
         */
30982 tejbeer 1961
 
31697 amit.gupta 1962
        List<Integer> fofoIds = null;
31886 tejbeer 1963
        Map<Integer, FofoStore> fofoStoreMap = fofoStoreRepository.selectAll().stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getId(), x -> x));
30982 tejbeer 1964
 
24653 govind 1965
 
31697 amit.gupta 1966
        if (fofoIdInt == null) {
1967
            fofoIds = new ArrayList<>(fofoStoreMap.keySet());
1968
        } else {
1969
            fofoIds = Arrays.asList(fofoIdInt);
1970
        }
1971
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("h:m a");
28368 tejbeer 1972
 
31886 tejbeer 1973
        Map<Integer, Float> partnerPolicyAmountMap = insurancePolicyRepository.selectAmountSumGroupByRetailerId(now, null);
31697 amit.gupta 1974
        Map<Integer, Long> partnerPolicyQtyMap = insurancePolicyRepository.selectQtyGroupByRetailerId(now, null);
28368 tejbeer 1975
 
31886 tejbeer 1976
        Map<Integer, Double> spPartnerOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from, now, 0, true);
28377 tejbeer 1977
 
31886 tejbeer 1978
        Map<Integer, Double> spPartner3DaysOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from.minusDays(3), now, 0, true);
31697 amit.gupta 1979
        Map<Integer, Long> spPartnerOrderQtyMap = fofoOrderItemRepository.selectQtyGroupByRetailer(from, now, 0, true);
28368 tejbeer 1980
 
31886 tejbeer 1981
        Map<Integer, Double> partnerOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from, now, 0, false);
31697 amit.gupta 1982
        Map<Integer, Long> partnerOrderQtyMap = fofoOrderItemRepository.selectQtyGroupByRetailer(from, now, 0, false);
28377 tejbeer 1983
 
31697 amit.gupta 1984
        //4 days + current day running
1985
        Map<Integer, Double> partnerBilledValueMap = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(from.minusDays(4), now);
28377 tejbeer 1986
 
31697 amit.gupta 1987
        Map<Integer, SaleTargetReportModel> saleTargetReportModelMap = new HashMap<>();
1988
        for (int fofoId : fofoIds) {
1989
            SaleTargetReportModel model = new SaleTargetReportModel();
1990
            model.setInsuranceSale(
1991
                    partnerPolicyAmountMap.containsKey(fofoId) ? partnerPolicyAmountMap.get(fofoId).doubleValue() : 0);
1992
            model.setInsruanceQty(partnerPolicyQtyMap.containsKey(fofoId) ? partnerPolicyQtyMap.get(fofoId) : 0);
1993
            model.setSecondary(partnerBilledValueMap.containsKey(fofoId) ? partnerBilledValueMap.get(fofoId) : 0);
1994
            model.setSmartphoneSale(spPartnerOrderValMap.containsKey(fofoId) ? spPartnerOrderValMap.get(fofoId) : 0);
1995
            model.setSmartphoneQty(spPartnerOrderQtyMap.containsKey(fofoId) ? spPartnerOrderQtyMap.get(fofoId) : 0);
1996
            model.setTotalSale(partnerOrderValMap.containsKey(fofoId) ? partnerOrderValMap.get(fofoId) : 0);
1997
            model.setTotalQty(partnerOrderQtyMap.containsKey(fofoId) ? partnerOrderQtyMap.get(fofoId) : 0);
1998
            model.setPast3daysSale(
1999
                    spPartner3DaysOrderValMap.containsKey(fofoId) ? spPartner3DaysOrderValMap.get(fofoId) : 0);
2000
            model.setFofoId(fofoId);
2001
            model.setCode(fofoStoreMap.get(fofoId).getCode());
31724 amit.gupta 2002
            model.setActivationType(fofoStoreMap.get(fofoId).getActivationType());
31697 amit.gupta 2003
            saleTargetReportModelMap.put(fofoId, model);
2004
        }
28377 tejbeer 2005
 
31697 amit.gupta 2006
        Map<Integer, FofoReportingModel> partnerSalesHeadersMap = this.getPartnerIdSalesHeaders();
2007
        for (Integer fofoId : fofoIds) {
2008
            SaleTargetReportModel model = saleTargetReportModelMap.get(fofoId);
28368 tejbeer 2009
 
31697 amit.gupta 2010
            // com.spice.profitmandi.dao.entity.user.User user =
2011
            // userUserRepository.selectById(fofoId);
28377 tejbeer 2012
 
31697 amit.gupta 2013
            // Address address = addressRepository.selectById(user.getAddressId());
28377 tejbeer 2014
 
31697 amit.gupta 2015
            String title = "Sale Update";
31886 tejbeer 2016
            String messageTemplate = String.format("Smartphones Rs.%.0f, Insurance Rs.%.0f, Total Rs.%.0f till %s.", model.getSmartphoneSale(), model.getInsuranceSale(), model.getTotalSale(), String.format(timeString, now.format(timeFormatter)));
31697 amit.gupta 2017
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
2018
            sendNotificationModel.setCampaignName("Sales update alert");
2019
            sendNotificationModel.setTitle(title);
2020
            sendNotificationModel.setMessage(messageTemplate);
2021
            sendNotificationModel.setType("url");
2022
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
2023
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(1));
2024
            sendNotificationModel.setMessageType(MessageType.notification);
2025
            int userId = userAccountRepository.selectUserIdByRetailerId(fofoId);
2026
            sendNotificationModel.setUserIds(Arrays.asList(userId));
2027
            notificationService.sendNotification(sendNotificationModel);
2028
            String whatsappMessageTemplate = String.format(
31886 tejbeer 2029
                    "Dear Partner, Your sale update is Smartphones Rs.%.0f, Insurance Rs.%.0f, Total Rs.%.0f till %s.", model.getSmartphoneSale(), model.getInsuranceSale(), model.getTotalSale(), String.format(timeString, now.format(timeFormatter)));
31697 amit.gupta 2030
            // notificationService.sendWhatsappMessage(whatsappMessageTemplate, title,
2031
            // address.getPhoneNumber());
28377 tejbeer 2032
 
31697 amit.gupta 2033
        }
2034
        // String saleReport = this.getDailySalesReportHtml(partnerSalesHeadersMap,
2035
        // saleTargetReportModelMap);
2036
        this.getStateWiseSales(saleTargetReportModelMap, partnerSalesHeadersMap);
2037
    }
28377 tejbeer 2038
 
31697 amit.gupta 2039
    public void checkRazorPayPaymentStatus() throws Exception {
31886 tejbeer 2040
        List<PendingOrder> pendingOrder = pendingOrderRepository.selectAllByStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PENDING);
28377 tejbeer 2041
 
31697 amit.gupta 2042
        for (PendingOrder po : pendingOrder) {
2043
            RazorPay razorPay = razorPayRepository.selectByOrdeId(po.getId());
2044
            List<PendingOrderItem> poItems = pendingOrderItemRepository.selectByOrderId(po.getId());
28369 tejbeer 2045
 
31697 amit.gupta 2046
            LOGGER.info("razorPay" + razorPay);
2047
            if (razorPay != null) {
2048
                List<Payment> payments = razorPaymentService.fetchOrderForPayment(razorPay.getRazorOrderId());
28368 tejbeer 2049
 
31697 amit.gupta 2050
                if (!payments.isEmpty()) {
2051
                    List<String> statusList = new ArrayList<>();
2052
                    for (Payment payment : payments) {
25880 amit.gupta 2053
 
31697 amit.gupta 2054
                        JSONObject jsonObj = new JSONObject(payment.toString());
25880 amit.gupta 2055
 
31697 amit.gupta 2056
                        String status = jsonObj.getString("status");
25880 amit.gupta 2057
 
31697 amit.gupta 2058
                        statusList.add(status);
25865 amit.gupta 2059
 
31697 amit.gupta 2060
                    }
2061
                    LOGGER.info("statusList" + statusList);
26941 amit.gupta 2062
 
31697 amit.gupta 2063
                    if (statusList.contains("authorized") || statusList.contains("captured")) {
2064
                        po.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PROCESSING);
2065
                        po.setPaidAmount(po.getTotalAmount());
2066
                        for (PendingOrderItem poi : poItems) {
2067
                            poi.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PROCESSING);
2068
                        }
2069
                        Map<String, Object> emailModel = pendingOrderService.sendCreateOrderMail(po);
26941 amit.gupta 2070
 
31697 amit.gupta 2071
                        CustomRetailer customRetailer = retailerService.getFofoRetailer(po.getFofoId());
2072
                        Customer customer = customerRepository.selectById(po.getCustomerId());
2073
                        String[] customerEmail = null;
2074
                        if (customer.getEmailId() != null) {
2075
                            customerEmail = new String[]{customer.getEmailId()};
2076
                        }
31886 tejbeer 2077
                        List<String> bccTo = Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "niranjan.kala@smartdukaan.com", "sm@smartdukaan.com", "tejbeer.kaur@shop2020.in", customRetailer.getEmail());
31697 amit.gupta 2078
                        List<String> authUserEmails = csService.getAuthUserByPartnerId(customRetailer.getPartnerId());
2079
                        if (authUserEmails != null) {
2080
                            authUserEmails = new ArrayList<>();
2081
                        }
2082
                        authUserEmails.addAll(bccTo);
26945 amit.gupta 2083
 
31697 amit.gupta 2084
                        // emailService.sendMailWithAttachments("Order Created with SmartDukaan",
2085
                        // "order-confirm.vm",
2086
                        // emailModel, customerEmail, null, authUserEmails.toArray(new String[0]));
26945 amit.gupta 2087
 
31697 amit.gupta 2088
                    } else if (statusList.contains("refunded") || statusList.contains("failed")) {
2089
                        for (PendingOrderItem poi : poItems) {
2090
                            poi.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.FAILED);
2091
                        }
25865 amit.gupta 2092
 
31697 amit.gupta 2093
                        po.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.FAILED);
2094
                    }
25865 amit.gupta 2095
 
31697 amit.gupta 2096
                }
2097
                // LOGGER.info("payment" + payments);
25865 amit.gupta 2098
 
31697 amit.gupta 2099
            }
2100
        }
2101
    }
25865 amit.gupta 2102
 
31697 amit.gupta 2103
    public static class SaleTargetReportModel {
2104
        private double totalSale;
2105
        private long totalQty;
2106
        private double past3daysSale;
2107
        private int fofoId;
2108
        private String code;
31724 amit.gupta 2109
        private ActivationType activationType;
25865 amit.gupta 2110
 
31724 amit.gupta 2111
 
2112
        @Override
2113
        public boolean equals(Object o) {
2114
            if (this == o) return true;
2115
            if (o == null || getClass() != o.getClass()) return false;
2116
            SaleTargetReportModel that = (SaleTargetReportModel) o;
2117
            return Double.compare(that.totalSale, totalSale) == 0 && totalQty == that.totalQty && Double.compare(that.past3daysSale, past3daysSale) == 0 && fofoId == that.fofoId && Double.compare(that.secondary, secondary) == 0 && Double.compare(that.smartphoneSale, smartphoneSale) == 0 && smartphoneQty == that.smartphoneQty && Double.compare(that.insuranceSale, insuranceSale) == 0 && insruanceQty == that.insruanceQty && Objects.equals(code, that.code) && activationType == that.activationType;
2118
        }
2119
 
2120
        @Override
2121
        public int hashCode() {
2122
            return Objects.hash(totalSale, totalQty, past3daysSale, fofoId, code, activationType, secondary, smartphoneSale, smartphoneQty, insuranceSale, insruanceQty);
2123
        }
2124
 
2125
        public ActivationType getActivationType() {
2126
            return activationType;
2127
        }
2128
 
2129
        public void setActivationType(ActivationType activationType) {
2130
            this.activationType = activationType;
2131
        }
2132
 
31697 amit.gupta 2133
        public double getSecondary() {
2134
            return secondary;
2135
        }
25865 amit.gupta 2136
 
31697 amit.gupta 2137
        public void setSecondary(double secondary) {
2138
            this.secondary = secondary;
2139
        }
25865 amit.gupta 2140
 
31697 amit.gupta 2141
        private double secondary;
25865 amit.gupta 2142
 
31697 amit.gupta 2143
        public int getFofoId() {
2144
            return fofoId;
2145
        }
25865 amit.gupta 2146
 
31697 amit.gupta 2147
        @Override
2148
        public String toString() {
31886 tejbeer 2149
            return "SaleTargetReportModel{" + "totalSale=" + totalSale + ", totalQty=" + totalQty + ", past3daysSale=" + past3daysSale + ", fofoId=" + fofoId + ", code='" + code + '\'' + ", secondary=" + secondary + ", smartphoneSale=" + smartphoneSale + ", smartphoneQty=" + smartphoneQty + ", insuranceSale=" + insuranceSale + ", insruanceQty=" + insruanceQty + '}';
31697 amit.gupta 2150
        }
25865 amit.gupta 2151
 
31697 amit.gupta 2152
        public String getCode() {
2153
            return code;
2154
        }
25865 amit.gupta 2155
 
31697 amit.gupta 2156
        public void setCode(String code) {
2157
            this.code = code;
2158
        }
25865 amit.gupta 2159
 
31697 amit.gupta 2160
        public void setFofoId(int fofoId) {
2161
            this.fofoId = fofoId;
2162
        }
25872 tejbeer 2163
 
31697 amit.gupta 2164
        private double smartphoneSale;
2165
        private long smartphoneQty;
2166
        private double insuranceSale;
2167
        private long insruanceQty;
26945 amit.gupta 2168
 
31697 amit.gupta 2169
        public long getTotalQty() {
2170
            return totalQty;
2171
        }
30765 tejbeer 2172
 
31697 amit.gupta 2173
        public void setTotalQty(long totalQty) {
2174
            this.totalQty = totalQty;
2175
        }
2176
 
2177
        public double getPast3daysSale() {
2178
            return past3daysSale;
2179
        }
2180
 
2181
        public void setPast3daysSale(double past3daysSale) {
2182
            this.past3daysSale = past3daysSale;
2183
        }
2184
 
2185
        public double getTotalSale() {
2186
            return totalSale;
2187
        }
2188
 
2189
        public void setTotalSale(double totalSale) {
2190
            this.totalSale = totalSale;
2191
        }
2192
 
2193
        public double getSmartphoneSale() {
2194
            return smartphoneSale;
2195
        }
2196
 
2197
        public void setSmartphoneSale(double smartphoneSale) {
2198
            this.smartphoneSale = smartphoneSale;
2199
        }
2200
 
2201
        public long getSmartphoneQty() {
2202
            return smartphoneQty;
2203
        }
2204
 
2205
        public void setSmartphoneQty(long smartphoneQty) {
2206
            this.smartphoneQty = smartphoneQty;
2207
        }
2208
 
2209
        public double getInsuranceSale() {
2210
            return insuranceSale;
2211
        }
2212
 
2213
        public void setInsuranceSale(double insuranceSale) {
2214
            this.insuranceSale = insuranceSale;
2215
        }
2216
 
2217
        public long getInsruanceQty() {
2218
            return insruanceQty;
2219
        }
2220
 
2221
        public void setInsruanceQty(long insruanceQty) {
2222
            this.insruanceQty = insruanceQty;
2223
        }
2224
 
2225
    }
2226
 
32482 amit.gupta 2227
    private void getStateWiseSales
2228
            (Map<Integer, SaleTargetReportModel> saleTargetReportModelMap, Map<Integer, FofoReportingModel> partnerSalesHeadersMap) throws
2229
            Exception {
31697 amit.gupta 2230
        String timeString = "Today %s";
2231
        LocalDateTime now = LocalDateTime.now();
2232
 
2233
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("h:m a");
31886 tejbeer 2234
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_LOGISTICS, ProfitMandiConstants.TICKET_CATEGORY_FINANCIAL_SERVICES, ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_MARKETING, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT, ProfitMandiConstants.TICKET_CATEGORY_TECHNOLOGY);
31697 amit.gupta 2235
 
2236
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false);
2237
 
31746 amit.gupta 2238
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
2239
            String email = storeGuyEntry.getKey();
2240
            Set<Integer> fofoIds = storeGuyEntry.getValue();
2241
            LOGGER.info("fofoIds {}", fofoIds);
24683 amit.gupta 2242
 
31746 amit.gupta 2243
            if (!fofoIds.isEmpty()) {
31886 tejbeer 2244
                List<FofoStore> stores = fofoStoreRepository.selectActivePartnersByRetailerIds(new ArrayList<>(fofoIds));
26945 amit.gupta 2245
 
31724 amit.gupta 2246
                Map<String, List<Integer>> stateMap = stores.stream().collect(groupingBy(
2247
                        x -> x.getCode().substring(0, 2), mapping(x -> x.getId(), Collectors.toList())));
31697 amit.gupta 2248
                List<List<Serializable>> stateWiseSales = new ArrayList<>();
2249
                for (Map.Entry<String, List<Integer>> stateMapEntry : stateMap.entrySet()) {
31886 tejbeer 2250
                    long totalQty = stateMapEntry.getValue().stream().collect(Collectors.summingLong(x -> saleTargetReportModelMap.get(x).getTotalQty()));
2251
                    double totalSale = stateMapEntry.getValue().stream().collect(Collectors.summingDouble(x -> saleTargetReportModelMap.get(x).getTotalSale()));
2252
                    long smartPhoneQty = stateMapEntry.getValue().stream().collect(Collectors.summingLong(x -> saleTargetReportModelMap.get(x).getSmartphoneQty()));
31697 amit.gupta 2253
                    double smartPhoneSale = stateMapEntry.getValue().stream().collect(
2254
                            Collectors.summingDouble(x -> saleTargetReportModelMap.get(x).getSmartphoneSale()));
2255
                    stateWiseSales.add(
2256
                            Arrays.asList(stateMapEntry.getKey(), smartPhoneQty, smartPhoneSale, totalQty, totalSale));
2257
                }
2258
                StringBuilder sb = new StringBuilder();
2259
                sb.append("<html><body>");
2260
                sb.append("<p>Statewise Sale Report:</p><br/><table style=\"border-collapse: collapse;\">");
31886 tejbeer 2261
                sb.append("<tbody>\n" + "	    <tr>" + "	    					<th style='border:1px solid black;padding: 5px'>State</th>" + "	    					<th style='border:1px solid black;padding: 5px'>SmartPhone Qty</th>" + "	    					<th style='border:1px solid black;padding: 5px'>SmartPhone Value</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Total Qty</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Total Value</th>" + "	    				</tr>");
31697 amit.gupta 2262
                for (List<Serializable> stateSale : stateWiseSales) {
2263
                    sb.append("<tr>");
2264
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(0) + "</td>");
2265
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(1) + "</td>");
2266
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(2) + "</td>");
2267
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(3) + "</td>");
2268
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(4) + "</td>");
2269
                    sb.append("</tr>");
2270
                }
2271
                sb.append("</tbody></table><br><br>");
26945 amit.gupta 2272
 
31697 amit.gupta 2273
                sb.append("<p>Partnerwise Report:</p><br/><table style=\"border-collapse: collapse;\">");
31886 tejbeer 2274
                sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Code</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Business Name</th>" + "	    					<th style='border:1px solid black;padding: 5px'>BDM Name</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Regional Manager</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Territory Manager</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Billed(4 days)</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Sale</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Smartphone Sale</th>" + "	    					<th style='border:1px solid black;padding: 5px'>SmartPhone Qty</th>" + "	    				</tr>");
31169 tejbeer 2275
 
2276
 
31886 tejbeer 2277
                List<Integer> sortedSaleTargetReport = saleTargetReportModelMap.values().stream().filter(x -> fofoIds.contains(x.getFofoId())).sorted(Comparator.comparing(SaleTargetReportModel::getCode).thenComparing(SaleTargetReportModel::getSecondary)).map(SaleTargetReportModel::getFofoId).collect(Collectors.toList());
31169 tejbeer 2278
 
31697 amit.gupta 2279
                String subject = String.format("Sale till %s", String.format(timeString, now.format(timeFormatter)));
31169 tejbeer 2280
 
31886 tejbeer 2281
                List<String> headers = Arrays.asList("Store Id", "Store Code", "Store Name", "Activation Type", "BDM Name", "Regional Manager", "Territory Manager", "Secondary(4 days)", "Sale", "Smartphone Value", "Smartphone Qty");
31697 amit.gupta 2282
                List<List<?>> rows = new ArrayList<>();
2283
                for (Integer fofoId : sortedSaleTargetReport) {
2284
                    FofoReportingModel fofoReportingModel = partnerSalesHeadersMap.get(fofoId);
31886 tejbeer 2285
                    rows.add(Arrays.asList(fofoId, fofoReportingModel.getCode(), fofoReportingModel.getBusinessName(), saleTargetReportModelMap.get(fofoId).getActivationType(), fofoReportingModel.getBusinessManager(), fofoReportingModel.getRegionalManager(), fofoReportingModel.getTerritoryManager(), saleTargetReportModelMap.get(fofoId).getSecondary(), saleTargetReportModelMap.get(fofoId).getTotalSale(), saleTargetReportModelMap.get(fofoId).getSmartphoneSale(), saleTargetReportModelMap.get(fofoId).getSmartphoneQty()
31697 amit.gupta 2286
                    ));
31169 tejbeer 2287
 
31724 amit.gupta 2288
                    //Now try to populate html rows
2289
                    if (!saleTargetReportModelMap.get(fofoId).getActivationType().equals(ActivationType.ACTIVE)) {
31697 amit.gupta 2290
                        continue;
2291
                    }
2292
                    if (saleTargetReportModelMap.get(fofoId).getSecondary() == 0) {
2293
                        sb.append("<tr style='background-color:#D21F3C;color:white'>");
2294
                    } else {
2295
                        sb.append("<tr>");
2296
                    }
31886 tejbeer 2297
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getCode() + "</td>");
2298
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getBusinessName() + "</td>");
2299
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getBusinessManager() + "</td>");
2300
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getRegionalManager() + "</td>");
2301
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getTerritoryManager() + "</td>");
2302
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSecondary() + "</td>");
2303
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getTotalSale() + "</td>");
2304
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSmartphoneSale() + "</td>");
2305
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSmartphoneQty() + "</td>");
31697 amit.gupta 2306
                    sb.append("</tr>");
24841 govind 2307
 
25300 tejbeer 2308
 
31697 amit.gupta 2309
                }
2310
                sb.append("</tr>");
2311
                sb.append("</body></html>");
2312
                String statewiseSaleReport = sb.toString();
25300 tejbeer 2313
 
2314
 
31697 amit.gupta 2315
                ByteArrayOutputStream baos = null;
2316
                try {
2317
                    baos = FileUtil.getCSVByteStream(headers, rows);
2318
                } catch (Exception e2) {
2319
                    e2.printStackTrace();
2320
                }
2321
                Attachment attachment = new Attachment("PartnerSalePerformance.csv", new ByteArrayResource(baos.toByteArray()));
2322
                Utils.sendHtmlMailWithAttachments(googleMailSender, new String[]{email}, null, "Statewise " + subject, statewiseSaleReport, attachment);
2323
            }
2324
        }
2325
    }
29668 tejbeer 2326
 
32350 amit.gupta 2327
 
32482 amit.gupta 2328
    private void sendMailOfHtmlFormat(JavaMailSender sender, String[] email, String body, String cc[], String subject) throws
2329
            MessagingException, ProfitMandiBusinessException, IOException {
32350 amit.gupta 2330
        MimeMessage message = sender.createMimeMessage();
31697 amit.gupta 2331
        MimeMessageHelper helper = new MimeMessageHelper(message);
2332
        helper.setSubject(subject);
2333
        helper.setText(body, true);
2334
        helper.setTo(email);
2335
        if (cc != null) {
2336
            helper.setCc(cc);
2337
        }
2338
        InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smart Dukaan");
2339
        helper.setFrom(senderAddress);
2340
        mailSender.send(message);
2341
    }
25694 amit.gupta 2342
 
31697 amit.gupta 2343
    public void sendNotification() throws Exception {
32610 amit.gupta 2344
        List<PushNotifications> pushNotifications = pushNotificationRepository.selectAllPendingNotifications();
31697 amit.gupta 2345
        if (!pushNotifications.isEmpty()) {
2346
            for (PushNotifications pushNotification : pushNotifications) {
2347
                Device device = deviceRepository.selectById(pushNotification.getDeviceId());
31886 tejbeer 2348
                NotificationCampaign notificationCampaign = notificationCampaignRepository.selectById(pushNotification.getNotificationCampaignid());
2349
                SimpleCampaignParams scp = gson.fromJson(notificationCampaign.getImplementationParams(), SimpleCampaignParams.class);
31697 amit.gupta 2350
                Campaign campaign = new SimpleCampaign(scp);
2351
                String result_url = campaign.getUrl() + "&user_id=" + device.getUser_id();
2352
                JSONObject json = new JSONObject();
2353
                json.put("to", device.getFcmId());
2354
                JSONObject jsonObj = new JSONObject();
2355
                jsonObj.put("message", campaign.getMessage());
2356
                jsonObj.put("title", campaign.getTitle());
2357
                jsonObj.put("type", campaign.getType());
2358
                jsonObj.put("url", result_url);
2359
                jsonObj.put("time_to_live", campaign.getExpireTimestamp());
2360
                jsonObj.put("image", campaign.getImageUrl());
2361
                jsonObj.put("largeIcon", "large_icon");
2362
                jsonObj.put("smallIcon", "small_icon");
2363
                jsonObj.put("vibrate", 1);
2364
                jsonObj.put("pid", pushNotification.getId());
2365
                jsonObj.put("sound", 1);
2366
                jsonObj.put("priority", "high");
2367
                json.put("data", jsonObj);
2368
                try {
2369
                    CloseableHttpClient client = HttpClients.createDefault();
2370
                    HttpPost httpPost = new HttpPost(FCM_URL);
25694 amit.gupta 2371
 
31697 amit.gupta 2372
                    httpPost.setHeader("Content-Type", "application/json; utf-8");
2373
                    httpPost.setHeader("authorization", "key=" + FCM_API_KEY);
2374
                    StringEntity entity = new StringEntity(json.toString());
2375
                    httpPost.setEntity(entity);
2376
                    CloseableHttpResponse response = client.execute(httpPost);
30858 amit.gupta 2377
 
31697 amit.gupta 2378
                    if (response.getStatusLine().getStatusCode() == 200) {
2379
                        pushNotification.setSentTimestamp(LocalDateTime.now());
2380
                    } else {
2381
                        pushNotification.setSentTimestamp(LocalDateTime.of(1970, 1, 1, 00, 00));
2382
                        LOGGER.info("message" + "not sent");
2383
                        response.toString();
2384
                    }
25694 amit.gupta 2385
 
31697 amit.gupta 2386
                } catch (Exception e) {
2387
                    e.printStackTrace();
2388
                    pushNotification.setSentTimestamp(LocalDateTime.of(1970, 1, 1, 00, 00));
2389
                    LOGGER.info("message " + "not sent " + e.getMessage());
2390
                }
2391
            }
2392
        }
2393
    }
25721 tejbeer 2394
 
31697 amit.gupta 2395
    public void grouping() throws Exception {
2396
        DateTimeFormatter dtf = DateTimeFormatter.ofPattern("MM-dd-yyyy hh:mm");
2397
        List<PriceDropIMEI> priceDropImeis = priceDropIMEIRepository.selectByStatus(PriceDropImeiStatus.APPROVED);
31886 tejbeer 2398
        System.out.println(String.join("\t", Arrays.asList("IMEI", "ItemId", "Brand", "Model Name", "Model Number", "Franchise Id", "Franchise Name", "Grn On", "Price Dropped On", "Approved On", "Returned On", "Price Drop Paid", "Is Doa")));
31697 amit.gupta 2399
        Map<Integer, CustomRetailer> retailersMap = retailerService.getFofoRetailers(false);
2400
        for (PriceDropIMEI priceDropIMEI : priceDropImeis) {
2401
            if (priceDropIMEI.getPartnerId() == 0)
2402
                continue;
2403
            HashSet<String> imeis = new HashSet<>();
2404
            PriceDrop priceDrop = priceDropRepository.selectById(priceDropIMEI.getPriceDropId());
2405
            imeis.add(priceDropIMEI.getImei());
31886 tejbeer 2406
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(priceDropIMEI.getPartnerId(), imeis, false);
31697 amit.gupta 2407
            if (inventoryItems.size() == 0) {
2408
                LOGGER.info("Need to investigate partnerId - {} imeis - {}", priceDropIMEI.getPartnerId(), imeis);
2409
                continue;
2410
            }
2411
            InventoryItem inventoryItem = inventoryItems.get(0);
2412
            CustomRetailer customRetailer = retailersMap.get(inventoryItem.getFofoId());
31886 tejbeer 2413
            if (inventoryItem.getLastScanType().equals(ScanType.DOA_OUT) || inventoryItem.getLastScanType().equals(ScanType.PURCHASE_RET)) {
31697 amit.gupta 2414
                // check if pricedrop has been rolled out
31886 tejbeer 2415
                List<UserWalletHistory> uwh = walletService.getAllByReference(inventoryItem.getFofoId(), priceDropIMEI.getPriceDropId(), WalletReferenceType.PRICE_DROP);
31697 amit.gupta 2416
                if (uwh.size() > 0) {
2417
                    Item item = itemRepository.selectById(inventoryItem.getItemId());
31886 tejbeer 2418
                    System.out.println(String.join("\t", Arrays.asList(priceDropIMEI.getImei(), inventoryItem.getItemId() + "", item.getBrand(), item.getModelName(), item.getModelNumber(), inventoryItem.getFofoId() + "", customRetailer.getBusinessName(), inventoryItem.getCreateTimestamp().format(dtf), priceDrop.getAffectedOn().format(dtf), priceDropIMEI.getUpdateTimestamp().format(dtf), inventoryItem.getUpdateTimestamp().format(dtf), priceDrop.getAutoPartnerPayout(inventoryItem.getUpdateTimestamp()) + "", inventoryItem.getLastScanType().equals(ScanType.DOA_OUT) + "")));
31697 amit.gupta 2419
                }
2420
            }
2421
        }
2422
    }
25721 tejbeer 2423
 
31697 amit.gupta 2424
    public void toffeeRollback() throws Exception {
2425
        toffeeService.cancelPolicyCopy("110143521986");
2426
        toffeeService.getOrderId("110143521986");
2427
    }
27212 tejbeer 2428
 
31697 amit.gupta 2429
    public void attachToffeeInvoices() throws Exception {
31886 tejbeer 2430
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectAllByProviderId(3, Optional.of(false));
31697 amit.gupta 2431
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
2432
            String invoiceNumber = insurancePolicy.getInvoiceNumber();
2433
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
2434
            InvoicePdfModel pdfModel = orderService.getInvoicePdfModel(fofoOrder.getId());
2435
            java.io.ByteArrayOutputStream byteArrayOutputStream = new java.io.ByteArrayOutputStream();
2436
            PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
31886 tejbeer 2437
            String pdfInvoiceString = "data:application/pdf;base64," + Base64.getEncoder().encodeToString(byteArrayOutputStream.toByteArray());
2438
            boolean attached = toffeeService.attachInvoice(insurancePolicy.getPolicyNumber().split("#")[1], pdfInvoiceString);
31697 amit.gupta 2439
            if (attached) {
2440
                insurancePolicy.setPosted(true);
2441
            }
2442
        }
2443
    }
25721 tejbeer 2444
 
31697 amit.gupta 2445
    public void sendBAGPendingPolicies() throws Exception {
31886 tejbeer 2446
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectAllByProviderId(4, Optional.of(false));
31697 amit.gupta 2447
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
2448
            String invoiceNumber = insurancePolicy.getInvoiceNumber();
2449
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
2450
            FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId()).get(0);
2451
            CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
2452
            Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
2453
            BAGInsuranceModel bagInsuranceModel = new BAGInsuranceModel();
2454
            // bagInsuranceModel.setModelId();
2455
            bagInsuranceModel.setAddressLine1(customerAddress.getLine1());
2456
            bagInsuranceModel.setAddressLine2(customerAddress.getLine2());
2457
            bagInsuranceModel.setCity(customerAddress.getCity());
2458
            bagInsuranceModel.setBrandWarranty("1 Year");
2459
            Item item = itemRepository.selectById(fofoOrderItem.getId());
2460
            bagInsuranceModel.setModelName(item.getItemDescription());
2461
            bagInsuranceModel.setDateOfPurchase(fofoOrder.getFormattedDate());
2462
            bagInsuranceModel.setEmail(customer.getEmailId());
2463
            bagInsuranceModel.setImei1(insurancePolicy.getSerialNumber());
2464
            bagInsuranceModel.setFirstName(customer.getFirstName());
2465
            bagInsuranceModel.setLastName(customer.getLastName());
2466
            bagInsuranceModel.setMobileNumber(customer.getMobileNumber());
2467
            bagInsuranceModel.setPlanId("");
2468
            insurancePolicy.setPosted(true);
2469
        }
2470
    }
25721 tejbeer 2471
 
31697 amit.gupta 2472
    public void schemeRollback(List<String> schemeIds) throws Exception {
2473
        List<Integer> schemeIdsInt = schemeIds.stream().map(x -> Integer.parseInt(x)).collect(Collectors.toList());
31886 tejbeer 2474
        Map<Integer, Scheme> schemesMap = schemeRepository.selectBySchemeIds(schemeIdsInt, 0, schemeIds.size()).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
31697 amit.gupta 2475
        List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectBySchemeIds(new HashSet<>(schemeIdsInt));
2476
        for (SchemeInOut sio : schemeInOuts) {
2477
            Scheme scheme = schemesMap.get(sio.getSchemeId());
2478
            if (scheme.getType().equals(SchemeType.IN)) {
25721 tejbeer 2479
 
31697 amit.gupta 2480
            } else if (scheme.getType().equals(SchemeType.OUT)) {
2481
                InventoryItem inventoryItem = inventoryItemRepository.selectById(sio.getInventoryItemId());
2482
                List<ScanRecord> sr = scanRecordRepository.selectByInventoryItemId(sio.getInventoryItemId());
31886 tejbeer 2483
                ScanRecord scanRecord = sr.stream().filter(x -> x.getType().equals(ScanType.SALE)).max((x1, x2) -> x1.getCreateTimestamp().compareTo(x2.getCreateTimestamp())).get();
2484
                if (scanRecord.getCreateTimestamp().isAfter(scheme.getEndDateTime()) || scanRecord.getCreateTimestamp().isBefore(scheme.getStartDateTime())) {
31697 amit.gupta 2485
                    sio.setRolledBackTimestamp(LocalDateTime.now());
2486
                    FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(scanRecord.getOrderId());
31886 tejbeer 2487
                    String rollbackReason = "Scheme reversed for " + itemRepository.selectById(inventoryItem.getItemId()).getItemDescription() + "/Inv - " + fofoOrder.getInvoiceNumber();
2488
                    walletService.rollbackAmountFromWallet(scanRecord.getFofoId(), sio.getAmount(), scanRecord.getOrderId(), WalletReferenceType.SCHEME_OUT, rollbackReason, LocalDateTime.now());
2489
                    System.out.printf("Amount %f,SchemeId %d,Reason %s\n", sio.getAmount(), sio.getSchemeId(), rollbackReason);
31697 amit.gupta 2490
                }
2491
            }
2492
        }
2493
        // throw new Exception();
2494
    }
25721 tejbeer 2495
 
31697 amit.gupta 2496
    public void checkfocusedModelInPartnerStock() throws Exception {
25721 tejbeer 2497
 
31886 tejbeer 2498
        List<Integer> fofoIds = fofoStoreRepository.selectAll().stream().filter(x -> x.isActive()).map(x -> x.getId()).collect(Collectors.toList());
2499
        Map<Integer, Map<Integer, List<SaholicCIS>>> warehouseItemAvailabilityMap = saholicInventoryService.getSaholicStock();
31697 amit.gupta 2500
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
2501
        Map<Integer, FofoReportingModel> partnerIdSalesHeadersMap = this.getPartnerIdSalesHeaders();
25721 tejbeer 2502
 
31886 tejbeer 2503
        Map<Integer, Map<Integer, List<SaholicPOItem>>> warehousePoItemAvailabilityMap = saholicInventoryService.getSaholicPOItems();
31697 amit.gupta 2504
        Map<Integer, List<FocusedModelShortageModel>> focusedModelShortageReportMap = new HashMap<>();
2505
        for (Integer fofoId : fofoIds) {
2506
            List<FocusedModelShortageModel> focusedModelShortageList = new ArrayList<>();
2507
            focusedModelShortageReportMap.put(fofoId, focusedModelShortageList);
2508
            CustomRetailer customRetailer = retailerService.getFofoRetailer(fofoId);
2509
            Map<Integer, Integer> processingOrderMap = null;
2510
            Map<Integer, Integer> catalogIdAndQtyMap = null;
2511
            Map<Integer, Integer> grnPendingOrdersMap = null;
25721 tejbeer 2512
 
31886 tejbeer 2513
            Map<Integer, Integer> currentInventorySnapshot = currentInventorySnapshotRepository.selectByFofoId(fofoId).stream().collect(Collectors.toMap(x -> x.getItemId(), x -> x.getAvailability()));
25721 tejbeer 2514
 
31697 amit.gupta 2515
            if (!currentInventorySnapshot.isEmpty()) {
31886 tejbeer 2516
                catalogIdAndQtyMap = itemRepository.selectByIds(currentInventorySnapshot.keySet()).stream().collect(groupingBy(x -> x.getCatalogItemId(), Collectors.summingInt(x -> currentInventorySnapshot.get(x.getId()))));
25800 tejbeer 2517
 
31697 amit.gupta 2518
            }
25800 tejbeer 2519
 
31886 tejbeer 2520
            Map<Integer, Integer> grnPendingOrders = orderRepository.selectPendingGrnOrders(fofoId).stream().collect(groupingBy(x -> x.getLineItem().getItemId(), Collectors.summingInt(x -> x.getLineItem().getQuantity())));
31697 amit.gupta 2521
            if (!grnPendingOrders.isEmpty()) {
31886 tejbeer 2522
                grnPendingOrdersMap = itemRepository.selectByIds(grnPendingOrders.keySet()).stream().collect(groupingBy(x -> x.getCatalogItemId(), Collectors.summingInt(x -> grnPendingOrders.get(x.getId()))));
25721 tejbeer 2523
 
31697 amit.gupta 2524
            }
25721 tejbeer 2525
 
31886 tejbeer 2526
            Map<Integer, Integer> processingOrder = orderRepository.selectOrders(fofoId, orderStatusList).stream().collect(groupingBy(x -> x.getLineItem().getItemId(), Collectors.summingInt(x -> x.getLineItem().getQuantity())));
31697 amit.gupta 2527
            if (!processingOrder.isEmpty()) {
31886 tejbeer 2528
                processingOrderMap = itemRepository.selectByIds(processingOrder.keySet()).stream().collect(groupingBy(x -> x.getCatalogItemId(), Collectors.summingInt(x -> processingOrder.get(x.getId()))));
25721 tejbeer 2529
 
31697 amit.gupta 2530
            }
25721 tejbeer 2531
 
31886 tejbeer 2532
            List<String> brands = mongoClient.getMongoBrands(fofoId, null, 3).stream().map(x -> (String) x.get("name")).collect(Collectors.toList());
28526 tejbeer 2533
 
31886 tejbeer 2534
            List<Integer> regionIds = partnerRegionRepository.selectByfofoId(fofoId).stream().map(x -> x.getRegionId()).collect(Collectors.toList());
31697 amit.gupta 2535
            LOGGER.info("regionIds" + regionIds);
2536
            if (regionIds.size() == 0) {
2537
                LOGGER.info("No region found for partner {}", fofoId);
2538
                continue;
2539
            }
31886 tejbeer 2540
            Map<Integer, Optional<Integer>> focusedCatalogIdAndQtyMap = focusedModelRepository.selectAllByRegionIds(regionIds).stream().collect(groupingBy(FocusedModel::getCatalogId, mapping(FocusedModel::getObsMinimumQty, Collectors.maxBy(Integer::compareTo))));
25721 tejbeer 2541
 
31697 amit.gupta 2542
            LOGGER.info("focusedCatalogIdAndQtyMap" + focusedCatalogIdAndQtyMap);
32060 amit.gupta 2543
 
32048 tejbeer 2544
            Map<String, RetailerBlockBrands> retailerBlockBrands = retailerBlockBrandsRepository.selectAllByRetailer(fofoId).stream().collect(Collectors.toMap(x -> x.getBlockBrands(), x -> x));
31388 amit.gupta 2545
 
32048 tejbeer 2546
 
31697 amit.gupta 2547
            for (Map.Entry<Integer, Optional<Integer>> entry : focusedCatalogIdAndQtyMap.entrySet()) {
2548
                int minQty = entry.getValue().get();
2549
                int inStockQty = 0;
2550
                int processingQty = 0;
2551
                int grnPendingQty = 0;
2552
                int allColorNetAvailability = 0;
2553
                int allColorPoAvailability = 0;
2554
                if (processingOrderMap != null) {
31886 tejbeer 2555
                    processingQty = (processingOrderMap.get(entry.getKey()) == null) ? 0 : processingOrderMap.get(entry.getKey());
31388 amit.gupta 2556
 
31697 amit.gupta 2557
                }
2558
                if (grnPendingOrdersMap != null) {
31886 tejbeer 2559
                    grnPendingQty = (grnPendingOrdersMap.get(entry.getKey()) == null) ? 0 : grnPendingOrdersMap.get(entry.getKey());
25721 tejbeer 2560
 
31697 amit.gupta 2561
                }
2562
                if (catalogIdAndQtyMap != null) {
31886 tejbeer 2563
                    inStockQty = (catalogIdAndQtyMap.get(entry.getKey()) == null) ? 0 : catalogIdAndQtyMap.get(entry.getKey());
27213 tejbeer 2564
 
31697 amit.gupta 2565
                }
25721 tejbeer 2566
 
31697 amit.gupta 2567
                int grnStockQty = grnPendingQty + inStockQty;
2568
                int totalQty = processingQty + grnPendingQty + inStockQty;
27208 tejbeer 2569
 
31697 amit.gupta 2570
                int shortageQty = minQty - totalQty;
2571
                List<Item> items = itemRepository.selectAllByCatalogItemId(entry.getKey());
28528 tejbeer 2572
 
31697 amit.gupta 2573
                TagListing tagListing = tagListingRepository.selectByCatalogId(entry.getKey());
27208 tejbeer 2574
 
31697 amit.gupta 2575
                FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
25721 tejbeer 2576
 
31886 tejbeer 2577
                Map<Integer, List<SaholicCIS>> itemAvailabilityMap = warehouseItemAvailabilityMap.get(fofoStore.getWarehouseId());
27233 tejbeer 2578
 
31886 tejbeer 2579
                Map<Integer, List<SaholicPOItem>> poItemAvailabilityMap = warehousePoItemAvailabilityMap.get(fofoStore.getWarehouseId());
29801 manish 2580
 
31697 amit.gupta 2581
                for (Item item : items) {
2582
                    List<SaholicCIS> currentAvailability = null;
2583
                    List<SaholicPOItem> poItemAvailability = null;
2584
                    if (itemAvailabilityMap != null) {
2585
                        currentAvailability = itemAvailabilityMap.get(item.getId());
2586
                    }
25721 tejbeer 2587
 
31697 amit.gupta 2588
                    if (poItemAvailabilityMap != null) {
2589
                        poItemAvailability = poItemAvailabilityMap.get(item.getId());
2590
                    }
2591
                    if (currentAvailability != null) {
31886 tejbeer 2592
                        allColorNetAvailability += currentAvailability.stream().collect(Collectors.summingInt(SaholicCIS::getNetavailability));
31697 amit.gupta 2593
                    }
25800 tejbeer 2594
 
31697 amit.gupta 2595
                    if (poItemAvailability != null) {
31886 tejbeer 2596
                        allColorPoAvailability += poItemAvailability.stream().collect(Collectors.summingInt(SaholicPOItem::getUnfulfilledQty));
31697 amit.gupta 2597
                    }
25800 tejbeer 2598
 
31697 amit.gupta 2599
                }
25721 tejbeer 2600
 
31697 amit.gupta 2601
                FocusedModelShortageModel fm = new FocusedModelShortageModel();
2602
                fm.setFofoId(fofoId);
2603
                fm.setStoreCode(fofoStore.getCode());
2604
                fm.setStoreName(customRetailer.getBusinessName());
2605
                fm.setBrandName(items.get(0).getBrand());
2606
                fm.setModelName(items.get(0).getModelName());
2607
                fm.setModelNumber(items.get(0).getModelNumber());
2608
                fm.setGrnStockQty(grnStockQty);
2609
                fm.setPendingIndentQty(processingQty);
2610
                fm.setShortageQty(shortageQty);
2611
                fm.setPoAvailability(allColorPoAvailability);
2612
                fm.setDp(tagListing.getSellingPrice());
2613
                fm.setWarehouseName(warehouseMap.get(customRetailer.getWarehouseId()));
2614
                fm.setStateManager(partnerIdSalesHeadersMap.get(fofoId).getRegionalManager());
2615
                fm.setTerritoryManager(partnerIdSalesHeadersMap.get(fofoId).getTerritoryManager());
2616
                fm.setItemName(items.get(0).getBrand() + items.get(0).getModelNumber() + items.get(0).getModelName());
2617
                fm.setAvailability(allColorNetAvailability);
25721 tejbeer 2618
 
31697 amit.gupta 2619
                focusedModelShortageList.add(fm);
2620
            }
25721 tejbeer 2621
 
31697 amit.gupta 2622
        }
2623
        if (!focusedModelShortageReportMap.isEmpty()) {
2624
            String fileName = "Stock Alert-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
2625
            Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
2626
            Map<String, List<List<?>>> emailRowsMap = new HashMap<>();
25721 tejbeer 2627
 
31697 amit.gupta 2628
            focusedModelShortageReportMap.entrySet().forEach(x -> {
2629
                storeGuyMap.entrySet().forEach(y -> {
28526 tejbeer 2630
 
31697 amit.gupta 2631
                    if (y.getValue().contains(x.getKey())) {
2632
                        if (!emailRowsMap.containsKey(y.getKey())) {
2633
                            emailRowsMap.put(y.getKey(), new ArrayList<>());
2634
                        }
31886 tejbeer 2635
                        List<List<? extends Serializable>> fms = x.getValue().stream().map(r -> Arrays.asList(r.getStoreCode(), r.getStoreName(), r.getBrandName(), r.getModelName(), r.getModelNumber(), r.getDp(), r.getWarehouseName(), r.getStateManager(), r.getTerritoryManager(), r.getPendingIndentQty(), r.getGrnStockQty(), r.getShortageQty(), r.getAvailability())).collect(Collectors.toList());
31697 amit.gupta 2636
                        emailRowsMap.get(y.getKey()).addAll(fms);
29995 tejbeer 2637
 
31697 amit.gupta 2638
                    }
29995 tejbeer 2639
 
31697 amit.gupta 2640
                });
25721 tejbeer 2641
 
31697 amit.gupta 2642
            });
25721 tejbeer 2643
 
31886 tejbeer 2644
            List<String> headers = Arrays.asList("Store Code", "Store Name", "Brand", "Model Name", "Model Number", "DP", "Warehouse Name", "State Manager", "Territory Manager", "Pending Indent", "InStock", "Shortage Qty", "Availability");
31697 amit.gupta 2645
            emailRowsMap.entrySet().forEach(entry -> {
25721 tejbeer 2646
 
31697 amit.gupta 2647
                ByteArrayOutputStream baos = null;
2648
                try {
2649
                    baos = FileUtil.getCSVByteStream(headers, entry.getValue());
2650
                } catch (Exception e2) {
2651
                    e2.printStackTrace();
2652
                }
2653
                String[] sendToArray = new String[]{
25721 tejbeer 2654
 
31886 tejbeer 2655
                        entry.getKey(), "apurve.shrivastava@smartdukaan.com", "puneet.bisht@smartdukaan.com"
25721 tejbeer 2656
 
31697 amit.gupta 2657
                };
25721 tejbeer 2658
 
31886 tejbeer 2659
 
31697 amit.gupta 2660
                try {
31886 tejbeer 2661
                    Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Stock Alert", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
31697 amit.gupta 2662
                } catch (Exception e1) { // TODO Auto-generated catch block
2663
                    e1.printStackTrace();
2664
                }
25721 tejbeer 2665
 
31697 amit.gupta 2666
            });
2667
        }
2668
    }
25721 tejbeer 2669
 
31697 amit.gupta 2670
    private String getNotificationMessage(List<FocusedModelShortageModel> focusedModelShortageModel) {
2671
        StringBuilder sb = new StringBuilder();
2672
        sb.append("Focused Model Shortage in Your Stock : \n");
2673
        for (FocusedModelShortageModel entry : focusedModelShortageModel) {
25721 tejbeer 2674
 
31697 amit.gupta 2675
            sb.append(entry.getItemName() + "-" + entry.getShortageQty());
2676
            sb.append(String.format("%n", ""));
2677
        }
2678
        return sb.toString();
2679
    }
25721 tejbeer 2680
 
31697 amit.gupta 2681
    private void sendMailWithAttachments(String subject, String messageText, String email) throws Exception {
2682
        MimeMessage message = mailSender.createMimeMessage();
2683
        MimeMessageHelper helper = new MimeMessageHelper(message, true);
25721 tejbeer 2684
 
31697 amit.gupta 2685
        helper.setSubject(subject);
2686
        helper.setText(messageText, true);
2687
        helper.setTo(email);
2688
        InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
2689
        helper.setFrom(senderAddress);
2690
        mailSender.send(message);
25721 tejbeer 2691
 
31697 amit.gupta 2692
    }
25721 tejbeer 2693
 
31697 amit.gupta 2694
    private String getMessage(List<FocusedModelShortageModel> focusedModelShortageModel) {
2695
        StringBuilder sb = new StringBuilder();
31886 tejbeer 2696
        sb.append("<html><body><p>Alert</p><p>Focused Model Shortage in Your Stock:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
2697
        sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Item</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Shortage Qty</th>\n" + "	    				</tr>");
31697 amit.gupta 2698
        for (FocusedModelShortageModel entry : focusedModelShortageModel) {
25721 tejbeer 2699
 
31697 amit.gupta 2700
            sb.append("<tr>");
2701
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getItemName() + "</td>");
25936 amit.gupta 2702
 
31697 amit.gupta 2703
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getShortageQty() + "</td>");
26790 tejbeer 2704
 
31697 amit.gupta 2705
            sb.append("</tr>");
25927 amit.gupta 2706
 
31697 amit.gupta 2707
        }
26790 tejbeer 2708
 
31697 amit.gupta 2709
        sb.append("</tbody></table></body></html>");
26945 amit.gupta 2710
 
31697 amit.gupta 2711
        return sb.toString();
2712
    }
26945 amit.gupta 2713
 
31697 amit.gupta 2714
    public void notifyLead() throws Exception {
31886 tejbeer 2715
        List<Lead> leadsToNotify = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDateTime.now().minusDays(15), LocalDateTime.now().plusHours(4));
2716
        Map<Integer, String> authUserEmailMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x.getEmailId()));
31697 amit.gupta 2717
        LOGGER.info("authUserEmailMap {}", authUserEmailMap);
31886 tejbeer 2718
        Map<String, Integer> dtrEmailMap = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.values())).stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x.getId()));
25982 amit.gupta 2719
 
31697 amit.gupta 2720
        LOGGER.info("dtrEmailMap {}", dtrEmailMap);
26283 tejbeer 2721
 
31697 amit.gupta 2722
        Map<Integer, Integer> authUserKeyMap = new HashMap<>();
26283 tejbeer 2723
 
31697 amit.gupta 2724
        for (Map.Entry<Integer, String> authUserEmail : authUserEmailMap.entrySet()) {
2725
            int authId = authUserEmail.getKey();
2726
            String email = authUserEmail.getValue();
2727
            authUserKeyMap.put(authId, dtrEmailMap.get(email));
2728
        }
2729
        LOGGER.info("authUserKeyMap", authUserKeyMap);
2730
        LOGGER.info("leadsToNotify {}", leadsToNotify);
26283 tejbeer 2731
 
31697 amit.gupta 2732
        String templateMessage = "Lead followup for %s %s, %s, %s is due by %s";
2733
        for (Lead lead : leadsToNotify) {
2734
            if (authUserKeyMap.get(lead.getAssignTo()) == null) {
2735
                LOGGER.info("Assignee no longer part of system {}", lead.getAssignTo());
2736
                continue;
2737
            }
2738
            String title = "Leads followup Reminder";
31886 tejbeer 2739
            String notificationMessage = String.format(templateMessage, lead.getFirstName(), lead.getLastName(), lead.getAddress(), lead.getLeadMobile(), leadTimeFormatter.format(lead.getScheduledTimestamp()));
31697 amit.gupta 2740
            String url = "https://app.smartdukaan.com/pages/home/leadUpdate?leadId=" + lead.getId();
2741
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
2742
            sendNotificationModel.setCampaignName("Lead Reminder");
2743
            sendNotificationModel.setTitle(title);
2744
            sendNotificationModel.setMessage(notificationMessage);
2745
            sendNotificationModel.setType("url");
2746
            sendNotificationModel.setUrl(url);
2747
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
2748
            sendNotificationModel.setMessageType(MessageType.reminder);
2749
            sendNotificationModel.setUserIds(Arrays.asList(authUserKeyMap.get(lead.getAssignTo())));
2750
            System.out.println(sendNotificationModel);
2751
            notificationService.sendNotification(sendNotificationModel);
2752
        }
2753
    }
26790 tejbeer 2754
 
32350 amit.gupta 2755
    @Autowired
2756
    AuthService authService;
2757
 
2758
    public void sendUnscheduledFollowUpMail() throws Exception {
2759
        List<Lead> missedScheduleLeads = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDate.now().atStartOfDay().minusDays(30), LocalDateTime.now().toLocalDate().atStartOfDay());
2760
        List<Lead> leadsScheduledForToday = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDate.now().atStartOfDay(), LocalDate.now().atTime(LocalTime.MAX));
2761
        List<Integer> authIds = missedScheduleLeads.stream().map(x -> x.getAssignTo()).distinct().collect(Collectors.toList());
2762
        LOGGER.info(authIds.size());
2763
        Map<Integer, AuthUser> authUserMap = authRepository.selectAllAuthUserByIds(authIds).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
2764
        LOGGER.info(authUserMap.size());
2765
        //if(true) return;
2766
 
2767
        missedScheduleLeads = missedScheduleLeads.stream().sorted(Comparator.comparing(Lead::getState, String.CASE_INSENSITIVE_ORDER).thenComparing(Lead::getAssignTo).thenComparing(Lead::getScheduledTimestamp)).collect(Collectors.toList());
2768
        //leadsScheduledForToday
2769
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
2770
        LOGGER.info("Auth Users Size - {}", authUsers.size());
2771
        for (AuthUser authUser : authUsers) {
2772
            LOGGER.info("Auth Name - {}", authUser.getFullName());
2773
            List<Integer> reporteeAuthIds = authService.getAllReportees(authUser.getId());
2774
            reporteeAuthIds.add(authUser.getId());
2775
            StringBuilder sb = new StringBuilder();
2776
            sb.append("<html><body>");
2777
            List<Lead> authMissedScheduledLeads = missedScheduleLeads.stream().filter(x -> reporteeAuthIds.contains(x.getAssignTo())).collect(Collectors.toList());
2778
            LOGGER.info("authMissedScheduledLeads {}", authMissedScheduledLeads.size());
2779
            if (authMissedScheduledLeads.size() > 0) {
2780
                addMissedScheduledLeadsTable(sb, authMissedScheduledLeads, authUserMap);
2781
                sb.append("</body></html>");
2782
 
2783
                String subject = "Lead Updates Summary";
32421 amit.gupta 2784
                String[] email = Arrays.asList(authUser.getEmailId()).toArray(new String[1]);
2785
                //String[] email = Arrays.asList("amit.gupta@smartdukaan.com").toArray(new String[1]);
32350 amit.gupta 2786
                this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
32421 amit.gupta 2787
                //break;
32350 amit.gupta 2788
            }
2789
        }
2790
 
2791
    }
2792
 
32482 amit.gupta 2793
    private void addMissedScheduledLeadsTable(StringBuilder
2794
                                                      sb, List<Lead> missedScheduleLeads, Map<Integer, AuthUser> authUserMap) {
32350 amit.gupta 2795
        sb.append("<h3>Leads That Missed the schedule</h3>");
32439 tejbeer 2796
        sb.append("<table style='border:1px solid black' cellspacing='0'>").append("<tr>").append("<th style='border:1px solid black;padding: 5px'>").append("Lead Id").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("Lead Name").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("Mobile No").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("City").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("State").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("Created On").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("Assigned To").append("</th>").append("<th style='border:1px solid black;padding: 5px'>").append("Scheduled On").append("</th>").append("</tr>");
32350 amit.gupta 2797
        for (Lead lead : missedScheduleLeads) {
32439 tejbeer 2798
            sb.append("<tr style='background-color:").append(lead.getColor()).append("'>").append("<td style='border:1px solid black;padding: 5px'>").append(lead.getId()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(lead.getFullName()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(lead.getLeadMobile()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(lead.getCity()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(lead.getState()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(FormattingUtils.formatDate(lead.getCreatedTimestamp())).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(
2799
                    authUserMap.containsKey(lead.getAssignTo()) ? authUserMap.get(lead.getAssignTo()).getFullName() : lead.getAssignTo()).append("</td>").append("<td style='border:1px solid black;padding: 5px'>").append(FormattingUtils.formatDate(lead.getScheduledTimestamp())).append("</td>").append("</tr>");
32350 amit.gupta 2800
        }
2801
        sb.append("</table>");
2802
    }
2803
 
31697 amit.gupta 2804
    public void notifyVisits() throws Exception {
31886 tejbeer 2805
        List<FranchiseeVisit> franchiseeVisits = franchiseeVisitRepository.selectVisitsScheduledBetweenDate(LocalDateTime.now().minusDays(15), LocalDateTime.now().plusHours(4));
2806
        Map<Integer, String> authUserEmailMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x.getEmailId()));
2807
        Map<String, Integer> dtrEmailMap = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.values())).stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x.getId()));
31697 amit.gupta 2808
        Map<Integer, Integer> authUserKeyMap = new HashMap<>();
26790 tejbeer 2809
 
31697 amit.gupta 2810
        for (Map.Entry<Integer, String> authUserEmail : authUserEmailMap.entrySet()) {
2811
            int authId = authUserEmail.getKey();
2812
            String email = authUserEmail.getValue();
2813
            authUserKeyMap.put(authId, dtrEmailMap.get(email));
2814
        }
2815
        String visitTemplate = "Planned visit to franchisee %s is due by %s";
2816
        String followupTemplate = "Lead followup for franchisee %s is due by %s";
2817
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("MMM 7, EEEE h:m a");
2818
        for (FranchiseeVisit visit : franchiseeVisits) {
2819
            if (authUserKeyMap.containsKey(visit.getAuthId())) {
2820
                continue;
2821
            }
2822
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
2823
            String message = null;
2824
            if (visit.getFranchiseActivityId() == 0) {
31886 tejbeer 2825
                message = String.format(visitTemplate, visit.getPartnerName(), timeFormatter.format(visit.getScheduleTimestamp()));
31697 amit.gupta 2826
                sendNotificationModel.setCampaignName("Franchisee visit Reminder");
2827
            } else {
31886 tejbeer 2828
                message = String.format(followupTemplate, visit.getPartnerName(), timeFormatter.format(visit.getScheduleTimestamp()));
31697 amit.gupta 2829
                sendNotificationModel.setCampaignName("Franchisee followup Reminder");
2830
            }
2831
            sendNotificationModel.setMessage(message);
2832
            sendNotificationModel.setType("url");
2833
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
2834
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
2835
            sendNotificationModel.setMessageType(MessageType.reminder);
2836
            sendNotificationModel.setUserIds(Arrays.asList(authUserKeyMap.get(visit.getAuthId())));
2837
            // notificationService.sendNotification(sendNotificationModel);
2838
        }
2839
    }
26792 tejbeer 2840
 
31697 amit.gupta 2841
    public void ticketClosed() throws Exception {
26790 tejbeer 2842
 
31697 amit.gupta 2843
        List<Ticket> tickets = ticketRepository.selectAllNotClosedTicketsWithStatus(ActivityType.RESOLVED);
2844
        for (Ticket ticket : tickets) {
2845
            if (ticket.getUpdateTimestamp().toLocalDate().isBefore(LocalDate.now().minusDays(7))) {
2846
                ticket.setCloseTimestamp(LocalDateTime.now());
2847
                ticket.setLastActivity(ActivityType.RESOLVED_ACCEPTED);
2848
                ticket.setUpdateTimestamp(LocalDateTime.now());
2849
                ticketRepository.persist(ticket);
2850
            }
2851
        }
26790 tejbeer 2852
 
31697 amit.gupta 2853
    }
26790 tejbeer 2854
 
31697 amit.gupta 2855
    public void checkValidateReferral() throws Exception {
26790 tejbeer 2856
 
31697 amit.gupta 2857
        List<Refferal> referrals = refferalRepository.selectByStatus(RefferalStatus.pending);
2858
        LOGGER.info("referrals" + referrals);
2859
        if (!referrals.isEmpty()) {
2860
            String subject = "Referral Request";
2861
            String messageText = this.getMessageForReferral(referrals);
26790 tejbeer 2862
 
31697 amit.gupta 2863
            MimeMessage message = mailSender.createMimeMessage();
2864
            MimeMessageHelper helper = new MimeMessageHelper(message, true);
2865
            String[] email = {"kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com"};
2866
            helper.setSubject(subject);
2867
            helper.setText(messageText, true);
2868
            helper.setTo(email);
2869
            InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
2870
            helper.setFrom(senderAddress);
2871
            mailSender.send(message);
26790 tejbeer 2872
 
31697 amit.gupta 2873
        }
2874
    }
26790 tejbeer 2875
 
31697 amit.gupta 2876
    private String getMessageForReferral(List<Refferal> referrals) {
2877
        StringBuilder sb = new StringBuilder();
31886 tejbeer 2878
        sb.append("<html><body><p>Alert</p><p>Pending Referrals:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
2879
        sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>RefereeName</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Referee Email</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Referral Name</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Refferal Mobile</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>city</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>state</th>\n" + "	    				</tr>");
31697 amit.gupta 2880
        for (Refferal entry : referrals) {
26790 tejbeer 2881
 
31697 amit.gupta 2882
            sb.append("<tr>");
2883
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getRefereeName() + "</td>");
30421 tejbeer 2884
 
31697 amit.gupta 2885
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getRefereeEmail() + "</td>");
2886
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getFirstName() + "</td>");
2887
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getMobile() + "</td>");
2888
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCity() + "</td>");
2889
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getState() + "</td>");
30421 tejbeer 2890
 
31697 amit.gupta 2891
            sb.append("</tr>");
30421 tejbeer 2892
 
31697 amit.gupta 2893
        }
30421 tejbeer 2894
 
31697 amit.gupta 2895
        sb.append("</tbody></table></body></html>");
30421 tejbeer 2896
 
31697 amit.gupta 2897
        return sb.toString();
2898
    }
30421 tejbeer 2899
 
32482 amit.gupta 2900
    private String getMessageForUncontacblePartner(List<PartnerCollectionRemark> pcrs) throws
2901
            ProfitMandiBusinessException {
31697 amit.gupta 2902
        StringBuilder sb = new StringBuilder();
31886 tejbeer 2903
        sb.append("<html><body><p>Alert</p><p>Not Responding Partner:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
2904
        sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>PartnerName</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>from</th>\n"
30421 tejbeer 2905
 
31697 amit.gupta 2906
                + "	    				</tr>");
2907
        for (PartnerCollectionRemark entry : pcrs) {
30421 tejbeer 2908
 
31697 amit.gupta 2909
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
30421 tejbeer 2910
 
31697 amit.gupta 2911
            sb.append("<tr>");
31886 tejbeer 2912
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
28205 tejbeer 2913
 
31886 tejbeer 2914
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCreateTimestamp().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
28205 tejbeer 2915
 
31697 amit.gupta 2916
            sb.append("</tr>");
28205 tejbeer 2917
 
31697 amit.gupta 2918
        }
28205 tejbeer 2919
 
31697 amit.gupta 2920
        sb.append("</tbody></table></body></html>");
28205 tejbeer 2921
 
31697 amit.gupta 2922
        return sb.toString();
2923
    }
28208 tejbeer 2924
 
31697 amit.gupta 2925
    public void reverseWallet() throws Exception {
2926
        LocalDate localDate = LocalDate.of(2020, 10, 28);
31886 tejbeer 2927
        List<UserWalletHistory> uwhList = userWalletHistoryRepository.selectAllByDateType(localDate.atStartOfDay(), localDate.plusDays(1).atStartOfDay(), Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT));
31697 amit.gupta 2928
        for (UserWalletHistory uwh : uwhList) {
2929
            if (uwh.getBusinessTimestamp().getMonth().equals(Month.SEPTEMBER)) {
2930
                UserWallet uw = userWalletRepository.selectById(uwh.getWalletId());
2931
                // LOGGER.info("UWH - {}", uwh);
2932
                // amount += uwh.getAmount();
2933
                // System.out.println("Amount is - " + amount);
2934
                // walletService.rollbackAmountFromWallet(uw.getUserId(), uwh.getAmount(),
2935
                // uwh.getReference(), uwh.getReferenceType(), "Margin reversal for error prone
2936
                // run", uwh.getBusinessTimestamp());
2937
                int orderId = uwh.getReference();
2938
                FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(orderId);
2939
                int inventoryItemId = 0;
2940
                // fofoOrderRepository.delete(fofoOrder);
2941
                List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
2942
                /*
2943
                 * List<PaymentOptionTransaction> paymentOptionTransactions =
2944
                 * paymentOptionTransactionRepository.selectByReferenceIdAndType(fofoOrder.getId
2945
                 * (), PaymentOptionReferenceType.ORDER); for(PaymentOptionTransaction
2946
                 * paymentOptionTransaction : paymentOptionTransactions) {
2947
                 * //paymentOptionTransactionRepository.delete(paymentOptionTransaction); }
2948
                 */
2949
                for (FofoOrderItem foi : fofoOrderItems) {
2950
                    // fofoOrderItemRepository.delete(foi);
2951
                    List<FofoLineItem> flis = fofoLineItemRepository.selectByFofoOrderItemId(foi.getId());
2952
                    for (FofoLineItem fli : flis) {
2953
                        // fofoLineItemRepository.delete(fli);
2954
                        inventoryItemId = fli.getInventoryItemId();
2955
                    }
2956
                }
2957
                List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectByInventoryItemIds(
2958
                        java.util.stream.Stream.of(inventoryItemId).collect(Collectors.toSet()));
2959
                for (SchemeInOut sio : schemeInOuts) {
2960
                    if (sio.getCreateTimestamp().toLocalDate().equals(localDate)) {
2961
                        LOGGER.info("SIO - {}", sio);
2962
                        sio.setRolledBackTimestamp(LocalDateTime.now());
2963
                    }
2964
                }
28208 tejbeer 2965
 
31697 amit.gupta 2966
            }
2967
        }
28208 tejbeer 2968
 
31697 amit.gupta 2969
    }
28208 tejbeer 2970
 
31697 amit.gupta 2971
    public void partnerProblemAlert() throws Exception {
2972
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
2973
        Map<Integer, Double> lmtdSale = fofoOrderItemRepository.selectSumMopGroupByRetailer(
2974
                curDate.withDayOfMonth(1).minusMonths(1), curDate.with(LocalTime.MAX).minusMonths(1), 0, false);
31886 tejbeer 2975
        Map<Integer, Double> mtdSales = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX), 0, false);
2976
        Map<Integer, PartnerDailyInvestment> pdi = partnerDailyInvestmentRepository.selectAll(LocalDate.now()).stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
28205 tejbeer 2977
 
31697 amit.gupta 2978
        for (Entry<Integer, Double> ls : lmtdSale.entrySet()) {
28208 tejbeer 2979
 
31697 amit.gupta 2980
            double lmtdTwentyPercentSale = ls.getValue() * 0.2;
28208 tejbeer 2981
 
31697 amit.gupta 2982
            LOGGER.info("lmtdTwentyPercentSale" + lmtdTwentyPercentSale);
28208 tejbeer 2983
 
31697 amit.gupta 2984
            double mtdSale = mtdSales.get(ls.getKey()) == null ? 0 : mtdSales.get(ls.getKey());
28205 tejbeer 2985
 
31697 amit.gupta 2986
            LOGGER.info("mtdSale" + mtdSale);
28205 tejbeer 2987
 
31886 tejbeer 2988
            double totalSixtyPercentInvestment = pdi.get(ls.getKey()) == null ? 0 : pdi.get(ls.getKey()).getTotalInvestment() * 0.6;
28205 tejbeer 2989
 
31697 amit.gupta 2990
            LOGGER.info("totalSixtyPercentInvestment" + totalSixtyPercentInvestment);
28205 tejbeer 2991
 
31697 amit.gupta 2992
            double stockInvestment = pdi.get(ls.getKey()) == null ? 0 : pdi.get(ls.getKey()).getInStockAmount();
28205 tejbeer 2993
 
31697 amit.gupta 2994
            LOGGER.info("stockInvestment" + stockInvestment);
28205 tejbeer 2995
 
31697 amit.gupta 2996
            boolean Investmentvalue = partnerInvestmentService.isInvestmentBelow(ls.getKey(), 25);
28205 tejbeer 2997
 
31697 amit.gupta 2998
            PartnerProblem partnerProblem = partnerProblemRepository.selectByFofoId(ls.getKey());
28205 tejbeer 2999
 
31697 amit.gupta 3000
            if (partnerProblem == null) {
3001
                partnerProblem = new PartnerProblem();
3002
                partnerProblem.setFofoId(ls.getKey());
3003
                if (mtdSale < lmtdTwentyPercentSale) {
3004
                    partnerProblem.setMtd(1);
3005
                }
3006
                if (Investmentvalue) {
3007
                    partnerProblem.setInvestment(1);
3008
                }
28205 tejbeer 3009
 
31697 amit.gupta 3010
                if (stockInvestment < totalSixtyPercentInvestment) {
3011
                    partnerProblem.setInvestment(1);
3012
                }
28205 tejbeer 3013
 
31697 amit.gupta 3014
                partnerProblemRepository.persist(partnerProblem);
3015
            } else {
3016
                if (mtdSale < lmtdTwentyPercentSale) {
3017
                    partnerProblem.setMtd(partnerProblem.getMtd() + 1);
28213 tejbeer 3018
 
31697 amit.gupta 3019
                } else {
3020
                    partnerProblem.setMtd(0);
28227 tejbeer 3021
 
31697 amit.gupta 3022
                }
3023
                if (Investmentvalue) {
3024
                    partnerProblem.setInvestment(partnerProblem.getInvestment() + 1);
3025
                } else {
3026
                    partnerProblem.setInvestment(0);
28227 tejbeer 3027
 
31697 amit.gupta 3028
                }
3029
                if (stockInvestment < totalSixtyPercentInvestment) {
3030
                    partnerProblem.setStockInvestment(partnerProblem.getStockInvestment() + 1);
3031
                } else {
3032
                    partnerProblem.setStockInvestment(0);
3033
                }
28213 tejbeer 3034
 
31697 amit.gupta 3035
            }
28213 tejbeer 3036
 
31697 amit.gupta 3037
        }
28213 tejbeer 3038
 
31886 tejbeer 3039
        List<PartnerProblem> partnerProblems = partnerProblemRepository.selectAll().stream().filter(x -> x.getMtd() + x.getInvestment() + x.getStockInvestment() > 0).collect(Collectors.toList());
28205 tejbeer 3040
 
31697 amit.gupta 3041
        partnerProblems = partnerProblems.stream().sorted((x1, x2) -> {
31886 tejbeer 3042
            return x1.getMtd() + x1.getInvestment() + x1.getStockInvestment() < x2.getMtd() + x2.getInvestment() + x2.getStockInvestment() ? 1 : -1;
31697 amit.gupta 3043
        }).collect(Collectors.toList());
28205 tejbeer 3044
 
31697 amit.gupta 3045
        Map<Integer, PartnerProblem> partnerProblemMap = partnerProblems.stream().sorted((x1, x2) -> {
31886 tejbeer 3046
            return x1.getMtd() + x1.getInvestment() + x1.getStockInvestment() < x2.getMtd() + x2.getInvestment() + x2.getStockInvestment() ? 1 : -1;
31697 amit.gupta 3047
        }).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
28205 tejbeer 3048
 
31697 amit.gupta 3049
        Map<Integer, CustomRetailer> customRetailers = retailerService.getAllFofoRetailers();
28205 tejbeer 3050
 
31697 amit.gupta 3051
        List<Integer> assignTo = Arrays.asList(15, 9, 54, 53);
28205 tejbeer 3052
 
31886 tejbeer 3053
        Map<Integer, AuthUser> assignAuthUserMap = authRepository.selectAllAuthUserByIds(assignTo).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
28222 tejbeer 3054
 
31886 tejbeer 3055
        List<String> sendTo = Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "sm@smartdukaan.com");
31697 amit.gupta 3056
        LOGGER.info("partnerProblem" + partnerProblems);
3057
        StringBuilder sb = new StringBuilder();
3058
        sb.append("<htl><body>");
3059
        sb.append(
3060
                "<p>Number against MTD or Investment are the count of days the MTD is low VS LMTD OR Investment is below 75%.</p><br/><p>These partners needs immediate attention.</p><br/><table style='border:1px solid black';cellspacing=0>");
31886 tejbeer 3061
        sb.append("<tbody>\n" + "	    <tr>" + "	    					<th style='border:1px solid black;padding: 5px'>Partner Name</th>" + "                         <th style='border:1px solid black;padding: 5px'>Assign TO</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Mtd</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Investment</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Stock</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Manager</th>"
28218 tejbeer 3062
 
31697 amit.gupta 3063
                + "	    				</tr>");
28218 tejbeer 3064
 
31697 amit.gupta 3065
        for (PartnerProblem pp : partnerProblems) {
3066
            int value = pp.getFofoId() % 4;
28218 tejbeer 3067
 
31697 amit.gupta 3068
            Map<EscalationType, AuthUser> authUserMap = csService.getAuthUserAndEsclationByPartnerId(pp.getFofoId());
3069
            LOGGER.info("authUserMap" + authUserMap);
3070
            sb.append("<tr>");
31886 tejbeer 3071
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailers.get(pp.getFofoId()).getBusinessName() + "</td>");
3072
            sb.append("<td style='border:1px solid black;padding: 5px'>" + assignAuthUserMap.get(assignTo.get(value)).getName() + "</td>");
31697 amit.gupta 3073
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getMtd() + "</td>");
3074
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getInvestment() + "</td>");
3075
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getStockInvestment() + "</td>");
31886 tejbeer 3076
            sb.append("<td style='border:1px solid black;padding: 5px'>" + (authUserMap.get(EscalationType.L1) == null ? "N/A" : authUserMap.get(EscalationType.L1).getFirstName()) + " ," + (authUserMap.get(EscalationType.L2) == null ? "N/A" : authUserMap.get(EscalationType.L2).getFirstName()) + "</td>");
28218 tejbeer 3077
 
31697 amit.gupta 3078
            sb.append("</tr>");
3079
        }
3080
        sb.append("</tbody></table><br><br>");
3081
        String subject = "Partner Problem Alert!";
3082
        String[] email = sendTo.toArray(new String[sendTo.size()]);
28227 tejbeer 3083
 
32350 amit.gupta 3084
        this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
28227 tejbeer 3085
 
31697 amit.gupta 3086
        Map<Integer, List<Integer>> authUserPartnerMapping = csService.getAuthUserIdPartnerIdMapping();
28224 tejbeer 3087
 
31697 amit.gupta 3088
        for (Entry<Integer, List<Integer>> authUserPartner : authUserPartnerMapping.entrySet()) {
3089
            AuthUser authUser = authRepository.selectById(authUserPartner.getKey());
3090
            for (Integer patnerId : authUserPartner.getValue()) {
3091
                if (partnerProblemMap.get(patnerId) != null) {
28230 tejbeer 3092
 
31697 amit.gupta 3093
                    StringBuilder sbbuilder = new StringBuilder();
3094
                    sbbuilder.append("<hml><body>");
3095
                    sb.append(
3096
                            "<p>Number against MTD or Investment are the count of days the MTD is low VS LMTD OR Investment is below 75%.</p><br/><p>These partners needs immediate attention.</p><br/><table style='border:1px solid black';cellspacing=0>");
31886 tejbeer 3097
                    sbbuilder.append("<tbody>\n" + "	    <tr>" + "	    					<th style='border:1px solid black;padding: 5px'>Partner Name</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Mtd</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Investment</th>" + "	    					<th style='border:1px solid black;padding: 5px'>Stock</th>"
28218 tejbeer 3098
 
31697 amit.gupta 3099
                            + "	    				</tr>");
28205 tejbeer 3100
 
31697 amit.gupta 3101
                    for (Integer partnerId : authUserPartner.getValue()) {
3102
                        if (partnerProblemMap.get(partnerId) != null) {
3103
                            PartnerProblem pp = partnerProblemMap.get(partnerId);
3104
                            sbbuilder.append("<tr>");
31886 tejbeer 3105
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + customRetailers.get(pp.getFofoId()).getBusinessName() + "</td>");
3106
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + pp.getMtd() + "</td>");
31697 amit.gupta 3107
                            sbbuilder.append(
3108
                                    "<td style='border:1px solid black;padding: 5px'>" + pp.getInvestment() + "</td>");
31886 tejbeer 3109
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + pp.getStockInvestment() + "</td>");
28790 amit.gupta 3110
 
31697 amit.gupta 3111
                            sbbuilder.append("</tr>");
3112
                        }
28790 amit.gupta 3113
 
31697 amit.gupta 3114
                    }
3115
                    sbbuilder.append("</tbody></table><br><br>");
29488 manish 3116
 
32350 amit.gupta 3117
                    this.sendMailOfHtmlFormat(googleMailSender, new String[]{authUser.getEmailId()}, sbbuilder.toString(), null, subject);
31697 amit.gupta 3118
                }
29488 manish 3119
 
31697 amit.gupta 3120
            }
3121
        }
3122
    }
28775 amit.gupta 3123
 
31697 amit.gupta 3124
    @Autowired
3125
    WarehouseRepository warehouseRepository;
29488 manish 3126
 
31697 amit.gupta 3127
    public void getVendorWarehouses(int warehouseId) {
3128
        LOGGER.info("Warehouses - {}", warehouseRepository.getVendorWarehouses().get(warehouseId));
29488 manish 3129
 
31697 amit.gupta 3130
    }
29488 manish 3131
 
31697 amit.gupta 3132
    public void checkImeiActivation() {
29801 manish 3133
 
31697 amit.gupta 3134
        try {
3135
            vivoImeiActivationService.checkImeiActivation();
3136
        } catch (ProfitMandiBusinessException e) {
3137
            // TODO Auto-generated catch block
3138
            e.printStackTrace();
3139
        } catch (IOException e) {
3140
            // TODO Auto-generated catch block
3141
            e.printStackTrace();
3142
        } catch (Exception e) {
3143
            // TODO Auto-generated catch block
3144
            e.printStackTrace();
3145
        }
29807 manish 3146
 
31697 amit.gupta 3147
    }
29801 manish 3148
 
31697 amit.gupta 3149
    public void checkItelImeiActivation(LocalDate date, Integer day) {
3150
        LOGGER.info("Hello - {}", "hhh");
29488 manish 3151
 
31697 amit.gupta 3152
        try {
3153
            itelImeiActivationService.checkItelImeiActivation(date, day);
3154
        } catch (ProfitMandiBusinessException e) {
3155
            // TODO Auto-generated catch block
3156
            e.printStackTrace();
3157
        } catch (IOException e) {
3158
            // TODO Auto-generated catch block
3159
            e.printStackTrace();
3160
        } catch (Exception e) {
3161
            // TODO Auto-generated catch block
3162
            e.printStackTrace();
3163
        }
29488 manish 3164
 
31697 amit.gupta 3165
    }
29488 manish 3166
 
32482 amit.gupta 3167
    public void selectFinServiceFollowUpDateByCurrDate(LocalDate currentDate) throws
3168
            MessagingException, ProfitMandiBusinessException, IOException {
31697 amit.gupta 3169
        LOGGER.info("selectfinServiceFollow - {}", "selectfinServiceFollowUpDateByCurrDate");
29308 tejbeer 3170
 
31697 amit.gupta 3171
        serviceConfigService.selectFinServicePartnerfollowUpDateByCurrentDate(currentDate);
29252 amit.gupta 3172
 
31697 amit.gupta 3173
    }
29451 manish 3174
 
31697 amit.gupta 3175
    public void checkTecnoImeiActivation(LocalDate date, Integer day) {
3176
        LOGGER.info("Hello - {}", "hhh");
29308 tejbeer 3177
 
31697 amit.gupta 3178
        try {
3179
            tecnoImeiActivation.checkTecnoImeiActivation(date, day);
3180
        } catch (ProfitMandiBusinessException e) {
3181
            // TODO Auto-generated catch block
3182
            e.printStackTrace();
3183
        } catch (IOException e) {
3184
            // TODO Auto-generated catch block
3185
            e.printStackTrace();
3186
        } catch (Exception e) {
3187
            // TODO Auto-generated catch block
3188
            e.printStackTrace();
3189
        }
29308 tejbeer 3190
 
31697 amit.gupta 3191
    }
29441 tejbeer 3192
 
31697 amit.gupta 3193
    public void checkCancellationMargin() throws Exception {
3194
        LocalDateTime startDate = LocalDate.of(2021, 4, 1).atStartOfDay();
3195
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectCancelledBetweenSaleDate(startDate, LocalDateTime.now());
3196
        LOGGER.info("Total Orders =  {}", fofoOrders.size());
3197
        for (FofoOrder fofoOrder : fofoOrders) {
31886 tejbeer 3198
            List<UserWalletHistory> history = userWalletHistoryRepository.selectAllByreferenceIdandreferenceType(fofoOrder.getId(), WalletReferenceType.SCHEME_OUT);
3199
            history.addAll(userWalletHistoryRepository.selectAllByreferenceIdandreferenceType(fofoOrder.getId(), WalletReferenceType.ACTIVATION_SCHEME));
31697 amit.gupta 3200
            int walletSum = history.stream().mapToInt(x -> x.getAmount()).sum();
3201
            if (Math.abs(walletSum) > 1) {
3202
                // LOGGER.info("Cancelled invoice {}, Order Id = {}, = havent rolledback, Value
3203
                // = {}", fofoOrder.getInvoiceNumber(), fofoOrder.getId(), walletSum);
3204
                List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
3205
                List<FofoLineItem> flis = fofoLineItemRepository.selectByFofoOrderItemId(fofoOrderItems.get(0).getId());
3206
                FofoLineItem fli = flis.get(0);
3207
                if (StringUtils.isEmpty(fli.getSerialNumber()))
3208
                    continue;
31886 tejbeer 3209
                List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(fli.getInventoryItemId())));
31697 amit.gupta 3210
                InventoryItem inventoryItem = inventoryItemRepository.selectById(fli.getInventoryItemId());
31886 tejbeer 3211
                double schemeSum = schemeInOuts.stream().filter(x -> x.getRolledBackTimestamp() == null).mapToDouble(x -> x.getAmount()).sum();
31697 amit.gupta 3212
                /*
3213
                 * if(inventoryItem.getGoodQuantity()==1) {
3214
                 * LOGGER.info("GoodQty, Serial Number {}, InventoryItem = {}, Billed on {}",
3215
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3216
                 * inventoryItem.getUpdateTimestamp()); } else
3217
                 * if(inventoryItem.getBadQuantity()==1){
3218
                 * LOGGER.info("Bad Qty, Serial Number {}, InventoryItem = {}, Billed on {}",
3219
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3220
                 * inventoryItem.getUpdateTimestamp()); } else if
3221
                 * (inventoryItem.getLastScanType().equals(ScanType.SALE)) { LOGGER.
3222
                 * info("Problem Sold, Serial Number {}, InventoryItem = {}, Billed on {}",
3223
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3224
                 * inventoryItem.getUpdateTimestamp()); }
3225
                 */
31886 tejbeer 3226
                if (inventoryItem.getLastScanType().equals(ScanType.SALE) || inventoryItem.getLastScanType().equals(ScanType.SALE_RET)) {
3227
                    Map<String, Double> map = schemeInOuts.stream().collect(
3228
                            groupingBy(
3229
                                    x -> DateTimeFormatter.ofPattern("yyyyMMddHH").format(x.getCreateTimestamp()) + "- " + x.getSchemeId(), Collectors.summingDouble(x -> x.getAmount())));
31697 amit.gupta 3230
                    for (Map.Entry<String, Double> entry : map.entrySet()) {
3231
                        LOGGER.info("{} = {}", entry.getKey(), entry.getValue());
3232
                    }
31886 tejbeer 3233
                    LOGGER.info("id- {}, imei- {}, lastScan = {}, Scheme sum - {}", inventoryItem.getId(), inventoryItem.getSerialNumber(), inventoryItem.getLastScanType(), schemeSum);
31697 amit.gupta 3234
                }
3235
            }
3236
        }
29441 tejbeer 3237
 
31697 amit.gupta 3238
    }
29308 tejbeer 3239
 
31697 amit.gupta 3240
    public static String readFileAsString(String file) throws Exception {
3241
        String data = "";
3242
        data = new String(Files.readAllBytes(Paths.get(file)));
3243
        return data;
3244
    }
29308 tejbeer 3245
 
32307 amit.gupta 3246
    public void markDelhiveryOrderDelivered() throws Exception {
31886 tejbeer 3247
        List<Order> orders = orderRepository.selectOrderByProviderIdAndStatus(ProfitMandiConstants.DELHIVERY_PROVIDERID, OrderStatus.SHIPPED_FROM_WH);
29308 tejbeer 3248
 
31697 amit.gupta 3249
        if (!orders.isEmpty()) {
3250
            Set<String> airwayBill = orders.stream().map(x -> x.getAirwayBillNumber()).collect(Collectors.toSet());
29308 tejbeer 3251
 
31697 amit.gupta 3252
            int arraylength = airwayBill.size();
29308 tejbeer 3253
 
31697 amit.gupta 3254
            if (arraylength >= 75) {
29308 tejbeer 3255
 
31697 amit.gupta 3256
                airwayBill = airwayBill.stream().limit(74).collect(Collectors.toSet());
3257
            }
3258
            LOGGER.info("airwayBill" + airwayBill);
3259
            String url = "https://track.delhivery.com/api/v1/packages/json/";
29308 tejbeer 3260
 
31697 amit.gupta 3261
            OkHttpClient client = new OkHttpClient();
29308 tejbeer 3262
 
31886 tejbeer 3263
            Request request1 = new Request.Builder().url(url + "?waybill=" + String.join(",", airwayBill) + "&token=" + token).get().build();
29308 tejbeer 3264
 
31697 amit.gupta 3265
            LOGGER.info("request1" + request1);
29308 tejbeer 3266
 
31697 amit.gupta 3267
            Response response = client.newCall(request1).execute();
29308 tejbeer 3268
 
31697 amit.gupta 3269
            LOGGER.info("jsonbj" + response.body());
29308 tejbeer 3270
 
31697 amit.gupta 3271
            JSONObject jsonObj = new JSONObject(response.body().string());
29308 tejbeer 3272
 
31697 amit.gupta 3273
            LOGGER.info("jsonObj" + jsonObj);
29308 tejbeer 3274
 
31697 amit.gupta 3275
            JSONArray shipmentData = jsonObj.getJSONArray("ShipmentData");
3276
            Set<String> airwaybillStatus = new HashSet<>();
3277
            for (int i = 0; i < shipmentData.length(); i++) {
3278
                JSONObject jsonObject = shipmentData.getJSONObject(i);
3279
                JSONObject shipment = jsonObject.getJSONObject("Shipment");
30982 tejbeer 3280
 
31697 amit.gupta 3281
                LOGGER.info("shipment" + shipment);
3282
                JSONObject statusDescription = shipment.getJSONObject("Status");
3283
                String awb = shipment.getString("AWB");
30982 tejbeer 3284
 
31697 amit.gupta 3285
                String status = statusDescription.getString("Status");
3286
                LOGGER.info("status" + status);
30982 tejbeer 3287
 
31697 amit.gupta 3288
                LOGGER.info("awb" + awb);
3289
                if (status.equals("Delivered")) {
3290
                    airwaybillStatus.add(awb);
3291
                }
30982 tejbeer 3292
 
31697 amit.gupta 3293
            }
3294
            markOrderDelivered(airwaybillStatus);
3295
        }
3296
    }
29308 tejbeer 3297
 
32307 amit.gupta 3298
    public void markBlueDartOrderDelivered() throws Exception {
30982 tejbeer 3299
 
31697 amit.gupta 3300
        String loginId = "DEL81122";
31117 tejbeer 3301
 
31697 amit.gupta 3302
        String licencekey = "uhfhlg2jpmnqfhfrlsgzfr1nhu1qfvel";
31117 tejbeer 3303
 
31886 tejbeer 3304
        List<Order> orders = orderRepository.selectOrderByProviderIdAndStatus(ProfitMandiConstants.BLUEDART_PROVIDERID, OrderStatus.SHIPPED_FROM_WH);
31117 tejbeer 3305
 
31697 amit.gupta 3306
        if (!orders.isEmpty()) {
31117 tejbeer 3307
 
31697 amit.gupta 3308
            Set<String> airwayBillNo = orders.stream().map(x -> x.getAirwayBillNumber()).collect(Collectors.toSet());
31117 tejbeer 3309
 
31697 amit.gupta 3310
            LOGGER.info("airwayBill" + airwayBillNo);
3311
            String url = "https://api.bluedart.com/servlet/RoutingServlet?handler=tnt&action=custawbquery";
31117 tejbeer 3312
 
31886 tejbeer 3313
            String response = restClient.get(url + "&loginid=" + loginId + "&awb=awb&numbers=" + String.join(",", airwayBillNo) + "&format=xml&lickey=" + licencekey + "&verno=1.3&scan=1", null, null);
31117 tejbeer 3314
 
31697 amit.gupta 3315
            JSONObject updateJson = XML.toJSONObject(response);
31117 tejbeer 3316
 
31697 amit.gupta 3317
            JSONObject shipmentData = updateJson.getJSONObject("ShipmentData");
3318
            Object shipmentObject = shipmentData.get("Shipment");
31117 tejbeer 3319
 
31697 amit.gupta 3320
            Set<String> airwaybillStatus = new HashSet<>();
29308 tejbeer 3321
 
31697 amit.gupta 3322
            if (shipmentObject instanceof JSONArray) {
3323
                JSONArray shipments = (JSONArray) shipmentObject;
3324
                for (int i = 0; i < shipments.length(); i++) {
3325
                    JSONObject jsonObject = shipments.getJSONObject(i);
31117 tejbeer 3326
 
31697 amit.gupta 3327
                    Number awb = jsonObject.getNumber("WaybillNo");
3328
                    String status = jsonObject.getString("Status");
31117 tejbeer 3329
 
31697 amit.gupta 3330
                    if (status.equals("SHIPMENT DELIVERED")) {
3331
                        airwaybillStatus.add(awb.toString());
3332
                    }
29308 tejbeer 3333
 
31697 amit.gupta 3334
                }
3335
            } else {
3336
                JSONObject jsonObject = (JSONObject) shipmentObject;
3337
                Number awb = jsonObject.getNumber("WaybillNo");
3338
                String status = jsonObject.getString("Status");
31117 tejbeer 3339
 
31697 amit.gupta 3340
                if (status.equals("SHIPMENT DELIVERED")) {
3341
                    airwaybillStatus.add(awb.toString());
3342
                }
31117 tejbeer 3343
 
31697 amit.gupta 3344
            }
31117 tejbeer 3345
 
31697 amit.gupta 3346
            LOGGER.info("airwaybillStatus" + airwaybillStatus);
31117 tejbeer 3347
 
31697 amit.gupta 3348
            markOrderDelivered(airwaybillStatus);
3349
        }
31117 tejbeer 3350
 
31697 amit.gupta 3351
    }
31117 tejbeer 3352
 
32307 amit.gupta 3353
    private void markOrderDelivered(Set<String> airwaybillStatus) throws Exception {
31697 amit.gupta 3354
        if (!airwaybillStatus.isEmpty()) {
3355
            for (String aws : airwaybillStatus) {
31117 tejbeer 3356
 
31697 amit.gupta 3357
                List<Order> deliverdOrders = orderRepository.selectByAirwayBillNumber(aws);
31117 tejbeer 3358
 
31697 amit.gupta 3359
                int fofoId = deliverdOrders.get(0).getRetailerId();
3360
                for (Order dlo : deliverdOrders) {
3361
                    dlo.setStatus(OrderStatus.DELIVERY_SUCCESS);
3362
                    dlo.setStatusDescription("Order Delivered");
3363
                    dlo.setDeliveryTimestamp(LocalDateTime.now());
3364
                }
31117 tejbeer 3365
 
31697 amit.gupta 3366
                com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(fofoId);
31117 tejbeer 3367
 
31697 amit.gupta 3368
                Address address = addressRepository.selectById(user.getAddressId());
29814 tejbeer 3369
 
31697 amit.gupta 3370
                String title = "Order Delivered";
29814 tejbeer 3371
 
31886 tejbeer 3372
                String message = String.format("Dear partner, Your SmartDukaan Order " + aws + " has been delivered to you in a safe sealed bag.");
29814 tejbeer 3373
 
31697 amit.gupta 3374
                SendNotificationModel sendNotificationModel = new SendNotificationModel();
3375
                sendNotificationModel.setCampaignName("Order Delivered");
3376
                sendNotificationModel.setTitle(title);
3377
                sendNotificationModel.setMessage(message);
3378
                sendNotificationModel.setType("url");
3379
                sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
3380
                sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(1));
3381
                sendNotificationModel.setMessageType(MessageType.notification);
3382
                int userId = userAccountRepository.selectUserIdByRetailerId(fofoId);
3383
                sendNotificationModel.setUserIds(Arrays.asList(userId));
3384
                notificationService.sendNotification(sendNotificationModel);
29815 tejbeer 3385
 
31697 amit.gupta 3386
                notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
29814 tejbeer 3387
 
31697 amit.gupta 3388
            }
3389
        }
3390
    }
29814 tejbeer 3391
 
31697 amit.gupta 3392
    public void partnerWiseCreditAccount() throws Exception {
29814 tejbeer 3393
 
31697 amit.gupta 3394
        List<FofoStore> fofoStores = fofoStoreRepository.selectActiveStores();
29814 tejbeer 3395
 
31697 amit.gupta 3396
        for (FofoStore fs : fofoStores) {
29835 tejbeer 3397
 
31697 amit.gupta 3398
            if (fs.getPan() != null) {
3399
                AccountStatusResponseOut accountStatusResponseOut = mandiiService.getStatus(fs.getPan());
29835 tejbeer 3400
 
31697 amit.gupta 3401
                LOGGER.info("accountStatusResponseOut" + accountStatusResponseOut);
31886 tejbeer 3402
                CreditAccount creditAccount = creditAccountRepository.selectByFofoIdAndGateway(fs.getId(), Gateway.MANDII);
29817 tejbeer 3403
 
31697 amit.gupta 3404
                if (creditAccount == null) {
29835 tejbeer 3405
 
31697 amit.gupta 3406
                    creditAccount = new CreditAccount();
29835 tejbeer 3407
 
31697 amit.gupta 3408
                    creditAccount.setFofoId(fs.getId());
3409
                    creditAccount.setGateway(Gateway.MANDII);
29817 tejbeer 3410
 
31697 amit.gupta 3411
                }
29814 tejbeer 3412
 
31697 amit.gupta 3413
                if (accountStatusResponseOut == null) {
3414
                    creditAccount.setCreditStatus(CreditStatus.UNKNOWN);
3415
                    creditAccount.setDescription("User company not found");
30421 tejbeer 3416
 
31697 amit.gupta 3417
                } else {
3418
                    if (accountStatusResponseOut.getSanctionLimit() != null) {
3419
                        creditAccount.setSanctionedAmount(accountStatusResponseOut.getSanctionLimit().floatValue());
3420
                    } else {
3421
                        creditAccount.setSanctionedAmount(0);
3422
                    }
30421 tejbeer 3423
 
31697 amit.gupta 3424
                    creditAccount.setInterestRate(accountStatusResponseOut.getRateOfInterest());
3425
                    if (accountStatusResponseOut.getBalanceAmount() != null) {
3426
                        creditAccount.setAvailableAmount(accountStatusResponseOut.getBalanceAmount().floatValue());
3427
                    } else {
3428
                        creditAccount.setAvailableAmount(0);
3429
                    }
30421 tejbeer 3430
 
31697 amit.gupta 3431
                    if (accountStatusResponseOut.getCurrentStage() != null) {
3432
                        creditAccount.setDescription(accountStatusResponseOut.getCurrentStage().toString());
3433
                    }
3434
                    if (accountStatusResponseOut.getStatus().equals(EligibilityStatusEnum.SANCTION_AVAILABLE)) {
3435
                        creditAccount.setCreditStatus(CreditStatus.SANCTIONED);
3436
                    } else if (accountStatusResponseOut.getStatus().equals(EligibilityStatusEnum.IN_ELIGIBLE)) {
3437
                        creditAccount.setCreditStatus(CreditStatus.INELIGIBLE);
3438
                    } else {
30421 tejbeer 3439
 
31697 amit.gupta 3440
                        creditAccount.setCreditStatus(CreditStatus.TO_BE_EVALUATED);
3441
                    }
3442
                }
30421 tejbeer 3443
 
31697 amit.gupta 3444
                creditAccount.setUpdatedOn(LocalDateTime.now());
3445
                creditAccountRepository.persist(creditAccount);
3446
            }
3447
        }
3448
    }
30421 tejbeer 3449
 
31697 amit.gupta 3450
    @Autowired
3451
    private PartnerCollectionRemarkRepository partnerCollectionRemarkRepository;
30421 tejbeer 3452
 
32482 amit.gupta 3453
    public void reviewUncontactablePartner() throws
3454
            ProfitMandiBusinessException, MessagingException, UnsupportedEncodingException {
30421 tejbeer 3455
 
31697 amit.gupta 3456
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
30421 tejbeer 3457
 
31886 tejbeer 3458
        List<Integer> pcrms = partnerCollectionRemarkRepository.selectMaxRemarkId(new ArrayList<>(customRetailerMap.keySet()));
30859 tejbeer 3459
 
31697 amit.gupta 3460
        if (!pcrms.isEmpty()) {
31886 tejbeer 3461
            Map<Integer, PartnerCollectionRemark> partnerCollectionRemarksMap = partnerCollectionRemarkRepository.selectByIds(pcrms).stream().filter(x -> x.getRemark().equals(CollectionRemark.NOT_RESPONDING)).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
30421 tejbeer 3462
 
31697 amit.gupta 3463
            if (!partnerCollectionRemarksMap.isEmpty()) {
31886 tejbeer 3464
                for (Map.Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMapping().entrySet()) {
3465
                    List<PartnerCollectionRemark> filteredRows = storeGuyEntry.getValue().stream().map(x -> partnerCollectionRemarksMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
31697 amit.gupta 3466
                    String subject = "UNCONTACTABLE PARTNERS";
3467
                    String messageText = this.getMessageForUncontacblePartner(filteredRows);
30859 tejbeer 3468
 
31697 amit.gupta 3469
                    MimeMessage message = mailSender.createMimeMessage();
3470
                    MimeMessageHelper helper = new MimeMessageHelper(message, true);
3471
                    String[] email = new String[]{storeGuyEntry.getKey()};
30859 tejbeer 3472
 
31697 amit.gupta 3473
                    helper.setSubject(subject);
3474
                    helper.setText(messageText, true);
3475
                    helper.setTo(email);
31886 tejbeer 3476
                    InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
31697 amit.gupta 3477
                    helper.setFrom(senderAddress);
3478
                    mailSender.send(message);
30859 tejbeer 3479
 
31697 amit.gupta 3480
                    LOGGER.info("filteredRows {}", filteredRows);
30859 tejbeer 3481
 
31697 amit.gupta 3482
                }
3483
            }
30936 tejbeer 3484
 
31697 amit.gupta 3485
        }
3486
    }
30936 tejbeer 3487
 
31697 amit.gupta 3488
    @Autowired
3489
    private LoanRepository loanRepository;
31020 tejbeer 3490
 
31697 amit.gupta 3491
    @Autowired
3492
    private LoanStatementRepository loanStatementRepository;
30859 tejbeer 3493
 
31697 amit.gupta 3494
    @Autowired
3495
    private SDCreditService sdCreditService;
30859 tejbeer 3496
 
31697 amit.gupta 3497
    @Autowired
3498
    private SDCreditRequirementRepository sdCreditRequirementRepository;
30859 tejbeer 3499
 
31697 amit.gupta 3500
    @Autowired
3501
    private CurrentPartnerDailyInvestmentRepository currentPartnerDailyInvestmentRepository;
30859 tejbeer 3502
 
31697 amit.gupta 3503
    @Autowired
3504
    private TransactionRepository transactionRepository;
30859 tejbeer 3505
 
31697 amit.gupta 3506
    @Autowired
3507
    private SanctionRequestRepository sanctionRequestRepository;
30859 tejbeer 3508
 
31697 amit.gupta 3509
    public void calculateInterestAccured() throws ProfitMandiBusinessException {
30936 tejbeer 3510
 
31697 amit.gupta 3511
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30859 tejbeer 3512
 
31697 amit.gupta 3513
        if (!loans.isEmpty()) {
30936 tejbeer 3514
 
31697 amit.gupta 3515
            for (Loan loan : loans) {
30936 tejbeer 3516
 
31697 amit.gupta 3517
                List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
30936 tejbeer 3518
 
31724 amit.gupta 3519
                Map<LoanReferenceType, Double> loanStatusAmount = loanStatements.stream().collect(groupingBy(
31697 amit.gupta 3520
                        x -> x.getLoanReferenceType(), Collectors.summingDouble(x -> x.getAmount().doubleValue())));
30859 tejbeer 3521
 
31697 amit.gupta 3522
                if (loan.getFreeDays() > 0) {
3523
                    LocalDateTime freeDaysLimitDate = loan.getCreatedOn().plusDays(loan.getFreeDays() - 1);
30859 tejbeer 3524
 
31697 amit.gupta 3525
                    LOGGER.info("freeDaysLimitDate {}", freeDaysLimitDate);
3526
                    if (LocalDateTime.now().isAfter(freeDaysLimitDate)) {
31886 tejbeer 3527
                        int loanStatementId = loanStatementRepository.selectLatestLoanSatement(loan.getFofoId(), loan.getId());
31697 amit.gupta 3528
                        LOGGER.info("loanStatementId {}", loanStatementId);
30859 tejbeer 3529
 
31697 amit.gupta 3530
                        if (loanStatementId != 0) {
30859 tejbeer 3531
 
31697 amit.gupta 3532
                            this.calculateInterest(loan, loanStatusAmount, loanStatementId);
30859 tejbeer 3533
 
31697 amit.gupta 3534
                        } else {
31886 tejbeer 3535
                            sdCreditService.addInterest(freeDaysLimitDate.toLocalDate(), LocalDate.now(), loan, loanStatusAmount);
31697 amit.gupta 3536
                        }
30859 tejbeer 3537
 
31697 amit.gupta 3538
                    }
3539
                } else {
31332 amit.gupta 3540
 
31886 tejbeer 3541
                    int loanStatementId = loanStatementRepository.selectLatestLoanSatement(loan.getFofoId(), loan.getId());
31697 amit.gupta 3542
                    LOGGER.info("loanStatementId2 {}", loanStatementId);
31604 tejbeer 3543
 
31697 amit.gupta 3544
                    this.calculateInterest(loan, loanStatusAmount, loanStatementId);
31332 amit.gupta 3545
 
31697 amit.gupta 3546
                }
31518 amit.gupta 3547
 
31697 amit.gupta 3548
            }
3549
        }
30936 tejbeer 3550
 
31697 amit.gupta 3551
    }
30936 tejbeer 3552
 
31697 amit.gupta 3553
    @Autowired
3554
    FofoPaymentRepository fofoPaymentRepository;
30936 tejbeer 3555
 
31697 amit.gupta 3556
    @Autowired
3557
    CCAvenuePaymentService ccAvenuePaymentService;
30936 tejbeer 3558
 
31697 amit.gupta 3559
    public void settleCCAvePayments() throws Exception {
31886 tejbeer 3560
        List<FofoPayment> fofoPayments = fofoPaymentRepository.selectAllByGatewayStatus(Gateway.CCAVENUE, PaymentStatus.INIT).stream().filter(x -> x.getCreateTimestamp().isBefore(LocalDateTime.now().minusMinutes(30l))).collect(Collectors.toList());
31697 amit.gupta 3561
        for (FofoPayment fofoPayment : fofoPayments) {
3562
            ccAvenuePaymentService.updatePayment(fofoPayment);
3563
        }
3564
    }
30859 tejbeer 3565
 
31697 amit.gupta 3566
    /*
3567
     * public void getCCAvenuePendingOrderStatus(int pendingOrderId) { PendingOrder
3568
     * pendingOrder = pendingOrderRepository.selectById(pendingOrderId);
3569
     * ccAvenuePaymentService.getPaymentStatusMap(pendingOrder); }
3570
     */
30859 tejbeer 3571
 
32482 amit.gupta 3572
    private void calculateInterest(Loan loan, Map<LoanReferenceType, Double> loanStatusAmount,
3573
                                   int loanStatementId) throws ProfitMandiBusinessException {
31697 amit.gupta 3574
        LoanStatement loanStatement = loanStatementRepository.selectById(loanStatementId);
30859 tejbeer 3575
 
31697 amit.gupta 3576
        if (loanStatement.getLoanId() == loan.getId()) {
30859 tejbeer 3577
 
31886 tejbeer 3578
            sdCreditService.addInterest(loanStatement.getCreatedAt().toLocalDate(), LocalDate.now(), loan, loanStatusAmount);
30859 tejbeer 3579
 
31697 amit.gupta 3580
        } else {
3581
            throw new ProfitMandiBusinessException("loanstament", loanStatement.getLoanId(), "Invalid LoanId");
3582
        }
3583
    }
31175 tejbeer 3584
 
31697 amit.gupta 3585
    public void loanSettlement() throws Exception {
3586
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30859 tejbeer 3587
 
31697 amit.gupta 3588
        if (!loans.isEmpty()) {
30859 tejbeer 3589
 
31697 amit.gupta 3590
            for (Loan loan : loans) {
31020 tejbeer 3591
 
31697 amit.gupta 3592
                UserWallet userWallet = userWalletRepository.selectByRetailerId(loan.getFofoId());
31886 tejbeer 3593
                SDCreditRequirement sdCreditRequirement = sdCreditRequirementRepository.selectByFofoId(loan.getFofoId());
30859 tejbeer 3594
 
31697 amit.gupta 3595
                if (userWallet.getAmount() >= 100) {
3596
                    List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
31175 tejbeer 3597
 
31697 amit.gupta 3598
                    LOGGER.info("loanStatements {}", loanStatements);
30859 tejbeer 3599
 
31886 tejbeer 3600
                    Map<LoanReferenceType, Double> loanStatusAmount = loanStatements.stream().collect(groupingBy(x -> x.getLoanReferenceType(), Collectors.summingDouble(x -> FormattingUtils.serialize(x.getAmount()))));
30859 tejbeer 3601
 
31697 amit.gupta 3602
                    LOGGER.info("loanStatusAmount {}", loanStatusAmount);
3603
                    Double interestAmount = loanStatusAmount.get(LoanReferenceType.INTEREST);
30859 tejbeer 3604
 
31697 amit.gupta 3605
                    if (interestAmount == null) {
3606
                        interestAmount = (double) 0;
3607
                    }
30859 tejbeer 3608
 
31697 amit.gupta 3609
                    double principalAmount = loanStatusAmount.get(LoanReferenceType.PRINCIPAL);
3610
                    double paidAmount = 0;
3611
                    if (userWallet.getAmount() > Math.abs(interestAmount)) {
30859 tejbeer 3612
 
31697 amit.gupta 3613
                        LOGGER.info("interestAmount b {}", interestAmount);
30859 tejbeer 3614
 
31697 amit.gupta 3615
                        if (interestAmount < 0) {
3616
                            LOGGER.info("interestAmount a {}", interestAmount);
30859 tejbeer 3617
 
31886 tejbeer 3618
                            settledLoanStatement(LoanReferenceType.INTEREST, BigDecimal.valueOf(interestAmount), loan.getFofoId(), loan.getId(), "Amount adjusted against loan", LocalDateTime.now());
31697 amit.gupta 3619
                            loan.setInterestPaid(loan.getInterestPaid().add(BigDecimal.valueOf(interestAmount).abs()));
30859 tejbeer 3620
 
31697 amit.gupta 3621
                            paidAmount += Math.abs(interestAmount);
3622
                        }
31020 tejbeer 3623
 
31697 amit.gupta 3624
                        double userWalletAmount = userWallet.getAmount() - Math.abs(interestAmount);
31110 tejbeer 3625
 
31697 amit.gupta 3626
                        if (userWalletAmount > Math.abs(principalAmount) && principalAmount < 0) {
31110 tejbeer 3627
 
31886 tejbeer 3628
                            settledLoanStatement(LoanReferenceType.PRINCIPAL, BigDecimal.valueOf(principalAmount), loan.getFofoId(), loan.getId(), "Amount adjusted against loan", LocalDateTime.now());
31697 amit.gupta 3629
                            double amount = userWalletAmount - Math.abs(principalAmount);
31110 tejbeer 3630
 
31697 amit.gupta 3631
                            paidAmount += Math.abs(principalAmount);
30859 tejbeer 3632
 
32145 tejbeer 3633
                            // userWallet.setAmount((int) amount);
30859 tejbeer 3634
 
31886 tejbeer 3635
                            BigDecimal utilizationAmount = sdCreditRequirement.getUtilizedAmount().subtract(BigDecimal.valueOf(principalAmount).abs());
30859 tejbeer 3636
 
31697 amit.gupta 3637
                            sdCreditRequirement.setUtilizedAmount(utilizationAmount);
30859 tejbeer 3638
 
31886 tejbeer 3639
                            CreditAccount creditAccount = creditAccountRepository.selectByFofoIdAndGateway(loan.getFofoId(), Gateway.SDDIRECT);
31020 tejbeer 3640
 
31697 amit.gupta 3641
                            creditAccount.setAvailableAmount(sdCreditRequirement.getAvailableLimit().floatValue());
3642
                            creditAccount.setUpdatedOn(LocalDateTime.now());
31020 tejbeer 3643
 
31697 amit.gupta 3644
                            loan.setPendingAmount(BigDecimal.ZERO);
32682 amit.gupta 3645
                            loan.setSettledOn(LocalDateTime.now());
31020 tejbeer 3646
 
31697 amit.gupta 3647
                        } else if (principalAmount < 0) {
31110 tejbeer 3648
 
31886 tejbeer 3649
                            settledLoanStatement(LoanReferenceType.PRINCIPAL, BigDecimal.valueOf(userWalletAmount), loan.getFofoId(), loan.getId(), "Amount adjusted against loan", LocalDateTime.now());
30859 tejbeer 3650
 
31697 amit.gupta 3651
                            paidAmount += Math.abs(userWalletAmount);
30859 tejbeer 3652
 
31886 tejbeer 3653
                            BigDecimal availableLimit = sdCreditRequirement.getAvailableLimit().add(BigDecimal.valueOf(userWalletAmount)).abs();
30859 tejbeer 3654
 
31886 tejbeer 3655
                            BigDecimal utilizationAmount = sdCreditRequirement.getUtilizedAmount().subtract(BigDecimal.valueOf(userWalletAmount)).abs();
30859 tejbeer 3656
 
31697 amit.gupta 3657
                            sdCreditRequirement.setUtilizedAmount(utilizationAmount);
30859 tejbeer 3658
 
31886 tejbeer 3659
                            CreditAccount creditAccount = creditAccountRepository.selectByFofoIdAndGateway(loan.getFofoId(), Gateway.SDDIRECT);
30859 tejbeer 3660
 
31697 amit.gupta 3661
                            creditAccount.setAvailableAmount(sdCreditRequirement.getAvailableLimit().floatValue());
3662
                            creditAccount.setUpdatedOn(LocalDateTime.now());
32117 tejbeer 3663
                            //userWallet.setAmount(0);
30859 tejbeer 3664
 
31697 amit.gupta 3665
                            loan.setPendingAmount(
3666
                                    loan.getPendingAmount().subtract(BigDecimal.valueOf(userWalletAmount)));
30859 tejbeer 3667
 
31697 amit.gupta 3668
                        }
30859 tejbeer 3669
 
32117 tejbeer 3670
                        walletService.consumeAmountFromWallet(userWallet.getUserId(), loan.getId(), WalletReferenceType.LOAN_REPAYMENT, "Amount adjusted against loan", (float) Math.abs(paidAmount), LocalDateTime.now());
30859 tejbeer 3671
 
32145 tejbeer 3672
                        // createUserWalletHistory(userWallet.getId(), userWallet.getUserId(), WalletReferenceType.LOAN_REPAYMENT, loan.getId(), Math.abs(paidAmount));
32117 tejbeer 3673
 
31697 amit.gupta 3674
                    } else {
30999 tejbeer 3675
 
31886 tejbeer 3676
                        settledLoanStatement(LoanReferenceType.INTEREST, BigDecimal.valueOf(userWallet.getAmount()), loan.getFofoId(), loan.getId(), "Amount adjusted against loan", LocalDateTime.now());
31020 tejbeer 3677
 
31697 amit.gupta 3678
                        paidAmount += Math.abs(userWallet.getAmount());
31020 tejbeer 3679
 
31697 amit.gupta 3680
                        loan.setInterestPaid(
3681
                                loan.getInterestPaid().add(BigDecimal.valueOf(userWallet.getAmount()).abs()));
31020 tejbeer 3682
 
32117 tejbeer 3683
                        //  createUserWalletHistory(userWallet.getId(), userWallet.getUserId(), WalletReferenceType.LOAN_REPAYMENT, loan.getId(), Math.abs(paidAmount));
3684
 
3685
                        walletService.consumeAmountFromWallet(userWallet.getUserId(), loan.getId(), WalletReferenceType.LOAN_REPAYMENT, "Amount adjusted against loan", (float) Math.abs(paidAmount), LocalDateTime.now());
3686
 
3687
 
3688
                        // userWallet.setAmount(0);
31697 amit.gupta 3689
                    }
31020 tejbeer 3690
 
3691
 
32439 tejbeer 3692
                    List<SanctionRequest> sanctionRequests = sanctionRequestRepository.selectHoldSanctionByFofoId(loan.getFofoId());
31020 tejbeer 3693
 
32439 tejbeer 3694
                    double settledAmount = paidAmount;
3695
                    for (SanctionRequest sanctionRequest : sanctionRequests) {
31020 tejbeer 3696
 
32439 tejbeer 3697
                        List<Order> orders = orderRepository.selectAllByTransactionId(sanctionRequest.getTransactionId());
31020 tejbeer 3698
 
3699
 
32439 tejbeer 3700
                        if (settledAmount >= sanctionRequest.getPendingAmount().doubleValue()) {
3701
                            settledAmount = settledAmount - sanctionRequest.getPendingAmount().doubleValue();
31020 tejbeer 3702
 
32439 tejbeer 3703
                            sanctionRequest.setPendingAmount(BigDecimal.valueOf(0));
3704
                            this.sendUnholdEmail(orders);
3705
                        } else {
31020 tejbeer 3706
 
32439 tejbeer 3707
                            settledAmount = sanctionRequest.getPendingAmount().doubleValue() - settledAmount;
31020 tejbeer 3708
 
32439 tejbeer 3709
                            sanctionRequest.setPendingAmount(BigDecimal.valueOf(settledAmount));
31020 tejbeer 3710
 
32439 tejbeer 3711
                            break;
31020 tejbeer 3712
 
32439 tejbeer 3713
                        }
31020 tejbeer 3714
 
32439 tejbeer 3715
                    }
3716
                }
31020 tejbeer 3717
 
32439 tejbeer 3718
            }
31020 tejbeer 3719
 
3720
 
32439 tejbeer 3721
        }
31020 tejbeer 3722
 
32439 tejbeer 3723
    }
31020 tejbeer 3724
 
3725
 
32439 tejbeer 3726
    private void sendUnholdEmail(List<Order> orders) throws Exception {
30859 tejbeer 3727
 
3728
 
32439 tejbeer 3729
        orders.forEach(x -> x.setShipmentHold(false));
3730
        double totalAmount = orders.stream().collect(Collectors.summingDouble(x -> x.getTotalAmount()));
30859 tejbeer 3731
 
32439 tejbeer 3732
        List<String> authUserEmail = csService.getAuthUserIdByPartnerId(orders.get(0).getRetailerId()).stream().map(x -> x.getEmailId()).collect(Collectors.toList());
3733
        authUserEmail.add("vinay.p@smartdukaan.com");
3734
        authUserEmail.add("shivam.gupta@smartdukaan.com");
30859 tejbeer 3735
 
32439 tejbeer 3736
        String[] emailTo = authUserEmail.toArray(new String[authUserEmail.size()]);
30859 tejbeer 3737
 
32439 tejbeer 3738
        String[] ccTo = {"tarun.verma@smartdukaan.com", "kamini.sharma@smartdukaan.com"};
30859 tejbeer 3739
 
32439 tejbeer 3740
        String subject = "Dispatched " + (orders.get(0).getRetailerName());
3741
        String message = String.format("Dear Team, \n" + "kindly note the material for the " + orders.get(0).getRetailerName() + "of Rs." + totalAmount + "is dispatched.");
3742
        Utils.sendMailWithAttachments(mailSender, emailTo, ccTo, subject, message);
30859 tejbeer 3743
 
32439 tejbeer 3744
 
31697 amit.gupta 3745
    }
30859 tejbeer 3746
 
32482 amit.gupta 3747
    private void settledLoanStatement(LoanReferenceType loanReferneceType, BigDecimal amount, int fofoId,
3748
                                      int loanId, String description, LocalDateTime now) {
30859 tejbeer 3749
 
31886 tejbeer 3750
        sdCreditService.createLoanStatement(loanReferneceType, amount.abs(), fofoId, loanId, description, LocalDateTime.now());
30859 tejbeer 3751
 
31697 amit.gupta 3752
    }
30859 tejbeer 3753
 
32482 amit.gupta 3754
    private void createUserWalletHistory(int walletId, int userId, WalletReferenceType referenceType, int loanId,
3755
                                         double interestAmount) {
31697 amit.gupta 3756
        UserWalletHistory uwh = new UserWalletHistory();
3757
        uwh.setWalletId(walletId);
3758
        uwh.setFofoId(userId);
3759
        uwh.setBusinessTimestamp(LocalDateTime.now());
3760
        uwh.setReferenceType(referenceType);
3761
        uwh.setReference(loanId);
3762
        uwh.setTimestamp(LocalDateTime.now());
3763
        uwh.setAmount((int) -(interestAmount));
3764
        uwh.setDescription("Amount adjusted against loan");
3765
        userWalletHistoryRepository.persist(uwh);
30859 tejbeer 3766
 
31697 amit.gupta 3767
    }
30859 tejbeer 3768
 
32307 amit.gupta 3769
    public void dailyLoanAlert() throws Exception {
31697 amit.gupta 3770
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30859 tejbeer 3771
 
31697 amit.gupta 3772
        Map<Integer, Double> partnerLoanAmount = new HashMap<>();
30859 tejbeer 3773
 
31697 amit.gupta 3774
        if (!loans.isEmpty()) {
30859 tejbeer 3775
 
31697 amit.gupta 3776
            for (Loan loan : loans) {
30859 tejbeer 3777
 
31697 amit.gupta 3778
                List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
30859 tejbeer 3779
 
31886 tejbeer 3780
                double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
31697 amit.gupta 3781
                if (partnerLoanAmount.get(loan.getFofoId()) != null) {
3782
                    amount += partnerLoanAmount.get(loan.getFofoId());
3783
                    partnerLoanAmount.put(loan.getFofoId(), amount);
3784
                } else {
3785
                    partnerLoanAmount.put(loan.getFofoId(), amount);
3786
                }
30965 tejbeer 3787
 
31697 amit.gupta 3788
            }
30965 tejbeer 3789
 
31697 amit.gupta 3790
        }
30859 tejbeer 3791
 
31697 amit.gupta 3792
        if (!partnerLoanAmount.isEmpty()) {
30965 tejbeer 3793
 
31697 amit.gupta 3794
            for (Entry<Integer, Double> partnerLoanAmountEnrty : partnerLoanAmount.entrySet()) {
30859 tejbeer 3795
 
31697 amit.gupta 3796
                int fofoId = partnerLoanAmountEnrty.getKey();
30859 tejbeer 3797
 
31697 amit.gupta 3798
                com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(fofoId);
30859 tejbeer 3799
 
31697 amit.gupta 3800
                Address address = addressRepository.selectById(user.getAddressId());
30896 amit.gupta 3801
 
31697 amit.gupta 3802
                String title = "Alert Credit Outstanding!";
3803
                String url = "http://app.smartdukaan.com/pages/home/credit";
31886 tejbeer 3804
                String message = "Your total pending Loan amount is Rs." + FormattingUtils.formatDecimal(Math.abs(partnerLoanAmountEnrty.getValue())) + ".";
31697 amit.gupta 3805
                notificationService.sendNotification(fofoId, title, MessageType.notification, title, message, url);
30913 tejbeer 3806
 
31697 amit.gupta 3807
                notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
30913 tejbeer 3808
 
31697 amit.gupta 3809
            }
30917 tejbeer 3810
 
31697 amit.gupta 3811
        }
30917 tejbeer 3812
 
31697 amit.gupta 3813
    }
30920 tejbeer 3814
 
31697 amit.gupta 3815
    public void processActivatedImeisForSchemes() throws ProfitMandiBusinessException {
3816
        schemeService.processActivatedImeisForSchemes();
3817
    }
30920 tejbeer 3818
 
31697 amit.gupta 3819
    public void updatePartnerLimit() throws ProfitMandiBusinessException {
3820
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
30913 tejbeer 3821
 
31886 tejbeer 3822
        Map<Integer, SDCreditRequirement> sdCreditRequirementMap = sdCreditRequirementRepository.selectAll().stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
3823
        Map<Integer, CurrentPartnerDailyInvestment> currentPartnerDailyInvestmentMap = currentPartnerDailyInvestmentRepository.selectAll().stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31697 amit.gupta 3824
        double limitValue = 100000;
3825
        for (Entry<Integer, CustomRetailer> customRetailerEntry : customRetailerMap.entrySet()) {
3826
            int fofoId = customRetailerEntry.getKey();
3827
            SDCreditRequirement sdCreditRequirement = sdCreditRequirementMap.get(customRetailerEntry.getKey());
3828
            LocalDateTime firstBillingDate = transactionRepository.getFirstBillingDate(fofoId);
3829
            CurrentPartnerDailyInvestment currentPartnerDailyInvestment = currentPartnerDailyInvestmentMap.get(fofoId);
3830
            BigDecimal suggestedAmount = BigDecimal.ZERO;
3831
            if (currentPartnerDailyInvestment != null) {
3832
                suggestedAmount = BigDecimal.valueOf(currentPartnerDailyInvestment.getTotalInvestment() * 0.1);
3833
            }
30929 tejbeer 3834
 
31697 amit.gupta 3835
            if (suggestedAmount.doubleValue() > limitValue) {
30929 tejbeer 3836
 
31697 amit.gupta 3837
                suggestedAmount = BigDecimal.valueOf(limitValue);
30929 tejbeer 3838
 
31697 amit.gupta 3839
            }
30913 tejbeer 3840
 
31697 amit.gupta 3841
            if (suggestedAmount.doubleValue() < 0) {
3842
                suggestedAmount = BigDecimal.ZERO;
3843
            }
30913 tejbeer 3844
 
31697 amit.gupta 3845
            LOGGER.info("suggestedAmount {} ", suggestedAmount);
30913 tejbeer 3846
 
31697 amit.gupta 3847
            if (sdCreditRequirement == null) {
3848
                sdCreditRequirement = new SDCreditRequirement();
3849
                sdCreditRequirement.setFofoId(fofoId);
3850
                sdCreditRequirement.setCreditDays(15);
3851
                sdCreditRequirement.setInterestRate(BigDecimal.valueOf(0.05));
3852
                sdCreditRequirement.setSuggestedLimit(suggestedAmount);
3853
                sdCreditRequirement.setRisk(CreditRisk.HIGH_RISK);
3854
                sdCreditRequirement.setLimit(suggestedAmount);
3855
                sdCreditRequirement.setUtilizedAmount(BigDecimal.ZERO);
3856
                sdCreditRequirement.setCreateTimestamp(LocalDateTime.now());
3857
                sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
3858
                sdCreditRequirementRepository.persist(sdCreditRequirement);
3859
            }
30913 tejbeer 3860
 
31697 amit.gupta 3861
            CreditRisk creditRisk = sdCreditService.getCurrentRisk(sdCreditRequirement, firstBillingDate);
30913 tejbeer 3862
 
31697 amit.gupta 3863
            sdCreditRequirement.setRisk(creditRisk);
30913 tejbeer 3864
 
31697 amit.gupta 3865
            sdCreditRequirement.setSuggestedLimit(suggestedAmount);
3866
            sdCreditRequirement.setLimit(suggestedAmount);
3867
            BigDecimal utilizedLimit = new BigDecimal(sdCreditService.getUtilizationAmount(fofoId));
30934 tejbeer 3868
 
31697 amit.gupta 3869
            BigDecimal availableLimit = sdCreditRequirement.getLimit().subtract(utilizedLimit);
30934 tejbeer 3870
 
31697 amit.gupta 3871
            LOGGER.info("utilizedLimit {} ", utilizedLimit);
30913 tejbeer 3872
 
31697 amit.gupta 3873
            LOGGER.info("availableLimit {} ", availableLimit);
30913 tejbeer 3874
 
31697 amit.gupta 3875
            sdCreditRequirement.setUtilizedAmount(utilizedLimit);
30929 tejbeer 3876
 
31697 amit.gupta 3877
            sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
30929 tejbeer 3878
 
31886 tejbeer 3879
            CreditAccount creditAccount = creditAccountRepository.selectByFofoIdAndGateway(sdCreditRequirement.getFofoId(), Gateway.SDDIRECT);
31697 amit.gupta 3880
            if (creditAccount != null) {
30929 tejbeer 3881
 
31697 amit.gupta 3882
                creditAccount.setInterestRate(sdCreditRequirement.getInterestRate().floatValue());
3883
                creditAccount.setSanctionedAmount(sdCreditRequirement.getLimit().floatValue());
3884
                creditAccount.setAvailableAmount(availableLimit.floatValue());
3885
                creditAccount.setFreeDays(sdCreditRequirement.getFreeDays());
3886
                creditAccount.setUpdatedOn(LocalDateTime.now());
3887
            }
30929 tejbeer 3888
 
31697 amit.gupta 3889
        }
31177 tejbeer 3890
 
31697 amit.gupta 3891
    }
30929 tejbeer 3892
 
31697 amit.gupta 3893
    public void notifyDefaultLoans() throws ProfitMandiBusinessException, MessagingException, IOException {
30929 tejbeer 3894
 
31697 amit.gupta 3895
        sdCreditService.updateRisk();
3896
        List<Loan> defaultLoans = sdCreditService.getDefaultLoan();
3897
        if (!defaultLoans.isEmpty()) {
3898
            this.sendDefaultLoanAlert(defaultLoans);
3899
        }
30929 tejbeer 3900
 
31697 amit.gupta 3901
    }
30929 tejbeer 3902
 
32482 amit.gupta 3903
    public void sendDefaultLoanAlert(List<Loan> defaultLoans) throws
3904
            ProfitMandiBusinessException, MessagingException, IOException {
31697 amit.gupta 3905
        String subject = "Default Partners";
30931 tejbeer 3906
 
31886 tejbeer 3907
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
30929 tejbeer 3908
 
31886 tejbeer 3909
        for (Map.Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false).entrySet()) {
31697 amit.gupta 3910
            List<Loan> filteredRows = new ArrayList<>();
3911
            for (Loan loan : defaultLoans) {
30929 tejbeer 3912
 
31697 amit.gupta 3913
                if (storeGuyEntry.getValue().contains(loan.getFofoId())) {
30929 tejbeer 3914
 
31697 amit.gupta 3915
                    filteredRows.add(loan);
3916
                }
3917
            }
3918
            if (!filteredRows.isEmpty()) {
3919
                String messageText = this.getMessageForDueDateExtend(filteredRows);
3920
                String[] email = new String[]{storeGuyEntry.getKey()};
30982 tejbeer 3921
 
32350 amit.gupta 3922
                this.sendMailOfHtmlFormat(googleMailSender, email, messageText, null, subject);
30982 tejbeer 3923
 
31697 amit.gupta 3924
            }
30936 tejbeer 3925
 
31697 amit.gupta 3926
        }
30982 tejbeer 3927
 
31697 amit.gupta 3928
        for (Loan defaultLoan : defaultLoans) {
3929
            List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(defaultLoan.getId());
30929 tejbeer 3930
 
31886 tejbeer 3931
            double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
30929 tejbeer 3932
 
31697 amit.gupta 3933
            com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(defaultLoan.getFofoId());
30936 tejbeer 3934
 
31697 amit.gupta 3935
            Address address = addressRepository.selectById(user.getAddressId());
30936 tejbeer 3936
 
31697 amit.gupta 3937
            String title = "Loan Amount Overdue!";
3938
            String url = "http://app.smartdukaan.com/pages/home/credit";
31886 tejbeer 3939
            String message = "Your loan due date " + defaultLoan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + " has been exceeded. Additional penal interest of " + defaultLoan.getInterestRate().setScale(2, RoundingMode.HALF_UP) + "%  and Rs.100 shall be levied on daily basis." + " Your total pending Loan amount is Rs." + FormattingUtils.formatDecimal(Math.abs(amount)) + ". !!Pay Now!!";
3940
            notificationService.sendNotification(defaultLoan.getFofoId(), title, MessageType.notification, title, message, url);
30936 tejbeer 3941
 
31697 amit.gupta 3942
            // notificationService.sendWhatsappMessage(message, title,
3943
            // address.getPhoneNumber());
30929 tejbeer 3944
 
31697 amit.gupta 3945
        }
3946
    }
30929 tejbeer 3947
 
31697 amit.gupta 3948
    private String getMessageForDueDateExtend(List<Loan> loans) throws ProfitMandiBusinessException {
3949
        StringBuilder sb = new StringBuilder();
3950
        sb.append(
31886 tejbeer 3951
                "<html><body><p>Alert</p><p>Default Partners :-</p>" + "<br/><p>EveryDay Rs.100 charged as Penalty</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
3952
        sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>PartnerName</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>due date</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Days</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Pending Amount</th>\n"
30929 tejbeer 3953
 
31697 amit.gupta 3954
                + "	    				</tr>");
3955
        for (Loan entry : loans) {
30929 tejbeer 3956
 
31697 amit.gupta 3957
            List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(entry.getId());
30929 tejbeer 3958
 
31886 tejbeer 3959
            double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
30929 tejbeer 3960
 
31697 amit.gupta 3961
            long noOfdaysBetween = ChronoUnit.DAYS.between(entry.getDueDate().toLocalDate(), LocalDateTime.now());
30929 tejbeer 3962
 
31697 amit.gupta 3963
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
30929 tejbeer 3964
 
31697 amit.gupta 3965
            sb.append("<tr>");
31886 tejbeer 3966
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
31397 tejbeer 3967
 
31886 tejbeer 3968
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getDueDate().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
31697 amit.gupta 3969
            sb.append("<td style='border:1px solid black;padding: 5px'>" + noOfdaysBetween + "</td>");
31886 tejbeer 3970
            sb.append("<td style='border:1px solid black;padding: 5px'>" + new DecimalFormat("#.##").format(Math.abs(amount)) + "</td>");
31397 tejbeer 3971
 
31697 amit.gupta 3972
            sb.append("</tr>");
31397 tejbeer 3973
 
31697 amit.gupta 3974
        }
31397 tejbeer 3975
 
31697 amit.gupta 3976
        sb.append("</tbody></table></body></html>");
31397 tejbeer 3977
 
31697 amit.gupta 3978
        return sb.toString();
3979
    }
31397 tejbeer 3980
 
31697 amit.gupta 3981
    private String getMessageForDueDateCross(List<Loan> loans) throws ProfitMandiBusinessException {
3982
        StringBuilder sb = new StringBuilder();
31886 tejbeer 3983
        sb.append("<html><body><p>Alert</p><p>Due Date Cross Partners :-</p>" + "<br/><p>Additional penal interest of  shall be levied on daily basis.</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
3984
        sb.append("<tbody>\n" + "	    				<tr>\n" + "	    					<th style='border:1px solid black;padding: 5px'>PartnerName</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>due date</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Days</th>\n" + "	    					<th style='border:1px solid black;padding: 5px'>Pending Amount</th>\n"
31397 tejbeer 3985
 
31697 amit.gupta 3986
                + "	    				</tr>");
3987
        for (Loan entry : loans) {
31397 tejbeer 3988
 
31697 amit.gupta 3989
            List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(entry.getId());
31397 tejbeer 3990
 
31886 tejbeer 3991
            double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
31397 tejbeer 3992
 
31697 amit.gupta 3993
            long noOfdaysBetween = ChronoUnit.DAYS.between(entry.getDueDate().toLocalDate(), LocalDateTime.now());
31397 tejbeer 3994
 
31697 amit.gupta 3995
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
31397 tejbeer 3996
 
31697 amit.gupta 3997
            sb.append("<tr>");
31886 tejbeer 3998
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
30936 tejbeer 3999
 
31886 tejbeer 4000
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getDueDate().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
31697 amit.gupta 4001
            sb.append("<td style='border:1px solid black;padding: 5px'>" + noOfdaysBetween + "</td>");
31886 tejbeer 4002
            sb.append("<td style='border:1px solid black;padding: 5px'>" + new DecimalFormat("#.##").format(Math.abs(amount)) + "</td>");
30936 tejbeer 4003
 
31697 amit.gupta 4004
            sb.append("</tr>");
31397 tejbeer 4005
 
31697 amit.gupta 4006
        }
31397 tejbeer 4007
 
31697 amit.gupta 4008
        sb.append("</tbody></table></body></html>");
31397 tejbeer 4009
 
31697 amit.gupta 4010
        return sb.toString();
4011
    }
31397 tejbeer 4012
 
32307 amit.gupta 4013
    public void notifyLoanDueDateCross() throws Exception {
31397 tejbeer 4014
 
31697 amit.gupta 4015
        List<Loan> dueDateCrossLoans = sdCreditService.getDueDateCrossLoan();
4016
        if (!dueDateCrossLoans.isEmpty()) {
4017
            this.sendDueDateCrossLoanAlert(dueDateCrossLoans);
4018
        }
31397 tejbeer 4019
 
31697 amit.gupta 4020
    }
31397 tejbeer 4021
 
32307 amit.gupta 4022
    private void sendDueDateCrossLoanAlert(List<Loan> dueDateCrossLoans) throws Exception {
31886 tejbeer 4023
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
31397 tejbeer 4024
 
31886 tejbeer 4025
        for (Map.Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false).entrySet()) {
31697 amit.gupta 4026
            List<Loan> filteredRows = new ArrayList<>();
4027
            for (Loan loan : dueDateCrossLoans) {
30936 tejbeer 4028
 
31697 amit.gupta 4029
                if (storeGuyEntry.getValue().contains(loan.getFofoId())) {
30982 tejbeer 4030
 
31697 amit.gupta 4031
                    filteredRows.add(loan);
4032
                }
4033
            }
4034
            if (!filteredRows.isEmpty()) {
4035
                String messageText = this.getMessageForDueDateCross(filteredRows);
4036
                String[] email = new String[]{storeGuyEntry.getKey()};
30982 tejbeer 4037
 
32350 amit.gupta 4038
                this.sendMailOfHtmlFormat(googleMailSender, email, messageText, null, "Due Date Cross");
30936 tejbeer 4039
 
31697 amit.gupta 4040
            }
30936 tejbeer 4041
 
31697 amit.gupta 4042
        }
4043
        if (!dueDateCrossLoans.isEmpty()) {
4044
            for (Loan loan : dueDateCrossLoans) {
30936 tejbeer 4045
 
31697 amit.gupta 4046
                long noOfdaysBetween = ChronoUnit.DAYS.between(loan.getDueDate().toLocalDate(), LocalDate.now());
30989 tejbeer 4047
 
31697 amit.gupta 4048
                com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(loan.getFofoId());
30989 tejbeer 4049
 
31697 amit.gupta 4050
                Address address = addressRepository.selectById(user.getAddressId());
30982 tejbeer 4051
 
31697 amit.gupta 4052
                LOGGER.info("noOfdaysBetween {} ", noOfdaysBetween);
30982 tejbeer 4053
 
31697 amit.gupta 4054
                List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
30936 tejbeer 4055
 
31886 tejbeer 4056
                double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
30936 tejbeer 4057
 
31697 amit.gupta 4058
                String url = "http://app.smartdukaan.com/pages/home/credit";
30936 tejbeer 4059
 
31697 amit.gupta 4060
                String title = "Alert!";
31886 tejbeer 4061
                String message = "Your loan due date " + loan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + " has been exceeded. Additional penal interest of " + loan.getInterestRate().setScale(2, RoundingMode.HALF_UP) + "% shall be levied on daily basis. Your total pending loan amount is Rs." + FormattingUtils.formatDecimal(Math.abs(amount)) + ". !!Pay Now!!";
30936 tejbeer 4062
 
31886 tejbeer 4063
                notificationService.sendNotification(loan.getFofoId(), title, MessageType.notification, title, message, url);
30936 tejbeer 4064
 
31697 amit.gupta 4065
                notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
30982 tejbeer 4066
 
31697 amit.gupta 4067
            }
4068
        }
30982 tejbeer 4069
 
31697 amit.gupta 4070
    }
30936 tejbeer 4071
 
32307 amit.gupta 4072
    public void alertForDueDate() throws Exception {
30936 tejbeer 4073
 
31697 amit.gupta 4074
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30936 tejbeer 4075
 
31697 amit.gupta 4076
        if (!loans.isEmpty()) {
4077
            for (Loan loan : loans) {
30936 tejbeer 4078
 
31697 amit.gupta 4079
                com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(loan.getFofoId());
30936 tejbeer 4080
 
31697 amit.gupta 4081
                Address address = addressRepository.selectById(user.getAddressId());
30936 tejbeer 4082
 
31697 amit.gupta 4083
                long noOfdaysBetween = ChronoUnit.DAYS.between(LocalDate.now(), loan.getDueDate().toLocalDate());
30936 tejbeer 4084
 
31697 amit.gupta 4085
                LOGGER.info("noOfdaysBetween {} ", noOfdaysBetween);
30982 tejbeer 4086
 
31697 amit.gupta 4087
                if (noOfdaysBetween <= 4 && noOfdaysBetween >= 0) {
4088
                    List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
31886 tejbeer 4089
                    double amount = loanStatements.stream().map(x -> x.getAmount()).collect(Collectors.summingDouble(x -> x.doubleValue()));
30936 tejbeer 4090
 
31697 amit.gupta 4091
                    String title = "Alert!";
4092
                    String url = "http://app.smartdukaan.com/pages/home/credit";
4093
                    String message = null;
4094
                    if (noOfdaysBetween == 0) {
30936 tejbeer 4095
 
31886 tejbeer 4096
                        message = "Your total pending Loan amount is Rs." + FormattingUtils.formatDecimal(Math.abs(amount)) + " is due for Today, Pay Now!!";
30982 tejbeer 4097
 
31697 amit.gupta 4098
                    } else {
30982 tejbeer 4099
 
31886 tejbeer 4100
                        message = "Your total pending Loan amount is Rs." + FormattingUtils.formatDecimal(Math.abs(amount)) + " is due by " + loan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + " , Pay Now!!";
30982 tejbeer 4101
 
31697 amit.gupta 4102
                    }
31886 tejbeer 4103
                    notificationService.sendNotification(loan.getFofoId(), title, MessageType.notification, title, message, url);
31697 amit.gupta 4104
                    notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
30982 tejbeer 4105
 
31697 amit.gupta 4106
                }
4107
            }
4108
        }
30984 tejbeer 4109
 
31697 amit.gupta 4110
    }
30982 tejbeer 4111
 
32307 amit.gupta 4112
    public void userMobileNumberOptIn() throws Exception {
30982 tejbeer 4113
 
31697 amit.gupta 4114
        List<FofoStore> fofoStores = fofoStoreRepository.selectActiveStores();
30982 tejbeer 4115
 
31886 tejbeer 4116
        List<com.spice.profitmandi.dao.entity.user.User> users = userUserRepository.selectByIds(fofoStores.stream().map(x -> x.getId()).collect(Collectors.toList()));
30982 tejbeer 4117
 
31886 tejbeer 4118
        List<Address> addresses = addressRepository.selectByIds(users.stream().map(x -> x.getAddressId()).collect(Collectors.toList()));
30982 tejbeer 4119
 
31697 amit.gupta 4120
        LOGGER.info("addresses" + addresses);
30984 tejbeer 4121
 
31697 amit.gupta 4122
        for (Address address : addresses) {
32307 amit.gupta 4123
            notificationService.optIn(address.getPhoneNumber());
30982 tejbeer 4124
 
31697 amit.gupta 4125
        }
30982 tejbeer 4126
 
31697 amit.gupta 4127
    }
30982 tejbeer 4128
 
31697 amit.gupta 4129
    public void authUserMobileNumberOptIn() throws HttpHostConnectException, ProfitMandiBusinessException {
31206 tejbeer 4130
 
31697 amit.gupta 4131
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
4132
        LOGGER.info("authUsers" + authUsers);
31206 tejbeer 4133
 
31697 amit.gupta 4134
        for (AuthUser authUser : authUsers) {
4135
            Map<String, String> requestheaders = new HashMap<>();
4136
            requestheaders.put("Content-Type", "application/x-www-form-urlencoded");
4137
            Map<String, String> requestParams = new HashMap<>();
4138
            requestParams.put("userid", String.valueOf(2000215976));
4139
            requestParams.put("password", "MFRd!BBL");
4140
            requestParams.put("phone_number", authUser.getMobileNumber());
4141
            requestParams.put("auth_scheme", "plain");
4142
            requestParams.put("v", "1.1");
4143
            requestParams.put("format", "json");
31206 tejbeer 4144
 
31697 amit.gupta 4145
            requestParams.put("method", "OPT_IN");
31206 tejbeer 4146
 
31697 amit.gupta 4147
            requestParams.put("channel", "WHATSAPP");
31886 tejbeer 4148
            String response = restClient.get("https://media.smsgupshup.com/GatewayAPI/rest", requestParams, requestheaders);
31697 amit.gupta 4149
            LOGGER.info("response" + response);
4150
        }
31206 tejbeer 4151
 
31697 amit.gupta 4152
    }
31206 tejbeer 4153
 
31697 amit.gupta 4154
    @Autowired
4155
    private HygieneDataRepository hygieneDataRepository;
31209 tejbeer 4156
 
31697 amit.gupta 4157
    public void hygineAlertForPartner() throws ProfitMandiBusinessException, MessagingException, IOException {
31206 tejbeer 4158
 
31697 amit.gupta 4159
        List<String> remarks = new ArrayList<>();
4160
        remarks.add("Out of Service");
4161
        remarks.add("Duplicate number");
4162
        remarks.add("Partner number");
31886 tejbeer 4163
        List<HygieneData> hygieneData = hygieneDataRepository.selectAllByDisposedDateAndRemark(LocalDate.now(), remarks);
31206 tejbeer 4164
 
31697 amit.gupta 4165
        if (!hygieneData.isEmpty()) {
31206 tejbeer 4166
 
31886 tejbeer 4167
            Map<Integer, List<HygieneData>> partnerHygieneDataMap = hygieneData.stream().collect(groupingBy(x -> x.getFofoId()));
31206 tejbeer 4168
 
31697 amit.gupta 4169
            for (Entry<Integer, List<HygieneData>> partnerHygieneDataMapEntry : partnerHygieneDataMap.entrySet()) {
31206 tejbeer 4170
 
31697 amit.gupta 4171
                CustomRetailer customRetailer = retailerService.getFofoRetailer(partnerHygieneDataMapEntry.getKey());
31206 tejbeer 4172
 
31697 amit.gupta 4173
                StringBuilder sb = new StringBuilder();
31886 tejbeer 4174
                sb.append("<html><body><p>Dear Partner," + "</p><br/><p>It has been observed in our calls to the respective customers that the contact no is either not correct or does not have incoming calls.\n"
31206 tejbeer 4175
 
31886 tejbeer 4176
                        + " </p>" + "<p>We would like to inform you that this will hinder all our marketing initiatives to bring this customer back to our smartdukaan or cross sell any product from your inventory." + "</p><p>Kindly ensure going forward that the details are correct so to avoid 1% margin loss.\n" + "</p><p>In case the data is found to be incorrect there is a loss of 1% margin on this sales under SmartDukaan hygiene guidelines.\n" + "				" + "</p>"
31206 tejbeer 4177
 
31697 amit.gupta 4178
                        + "<br/><table style='border:1px solid black ;padding: 5px';>");
4179
                sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
4180
                sb.append("<th style='border:1px solid black;padding: 5px'>Invoice Number</th>\n");
4181
                sb.append("<th style='border:1px solid black;padding: 5px'>Customer Name</th>\n");
4182
                sb.append("<th style='border:1px solid black;padding: 5px'>Customer Number</th>\n");
4183
                sb.append("</tr>\n");
31206 tejbeer 4184
 
31697 amit.gupta 4185
                List<HygieneData> hygienes = partnerHygieneDataMapEntry.getValue();
31206 tejbeer 4186
 
31697 amit.gupta 4187
                List<Integer> orderIds = hygienes.stream().map(x -> x.getOrderId()).collect(Collectors.toList());
31206 tejbeer 4188
 
31697 amit.gupta 4189
                List<FofoOrder> fofoOrders = fofoOrderRepository.selectAllByOrderIds(orderIds);
31206 tejbeer 4190
 
31697 amit.gupta 4191
                for (FofoOrder fofoOrder : fofoOrders) {
4192
                    Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
4193
                    sb.append("<tr>");
31886 tejbeer 4194
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoOrder.getInvoiceNumber() + "</td>\n");
4195
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customer.getFirstName() + "" + customer.getLastName() + "</td>\n");
4196
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customer.getMobileNumber() + "</td>\n");
31206 tejbeer 4197
 
31697 amit.gupta 4198
                    sb.append("</tr>\n");
4199
                }
31206 tejbeer 4200
 
31697 amit.gupta 4201
                sb.append("</tbody></table></body></html>");
4202
                String subject = "Customer Info - Hygiene Alert";
31206 tejbeer 4203
 
32350 amit.gupta 4204
                this.sendMailOfHtmlFormat(mailSender, new String[]{customRetailer.getEmail()}, sb.toString(), null, subject);
31206 tejbeer 4205
 
31697 amit.gupta 4206
            }
31206 tejbeer 4207
 
31697 amit.gupta 4208
        }
31206 tejbeer 4209
 
31697 amit.gupta 4210
    }
31206 tejbeer 4211
 
31697 amit.gupta 4212
    public void hygineAlertForInternalTeam() throws ProfitMandiBusinessException, MessagingException, IOException {
31206 tejbeer 4213
 
31697 amit.gupta 4214
        List<String> remarks = new ArrayList<>();
4215
        remarks.add("Out of Service");
4216
        remarks.add("Duplicate number");
4217
        remarks.add("Partner number");
31886 tejbeer 4218
        List<HygieneData> hygieneDataLastThreeMonth = hygieneDataRepository.selectDisposedDateAndRemarks(
4219
                LocalDate.now().withDayOfMonth(1).minusMonths(3).atStartOfDay(), LocalDate.now().minusMonths(1).withDayOfMonth(LocalDate.now().minusMonths(1).lengthOfMonth()).atTime(LocalTime.MAX), remarks);
31206 tejbeer 4220
 
31886 tejbeer 4221
        List<HygieneData> hygieneDataRecentMonth = hygieneDataRepository.selectDisposedDateAndRemarks(LocalDate.now().withDayOfMonth(1), remarks);
31697 amit.gupta 4222
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
4223
        Map<Integer, List<HygieneData>> partnerHygieneLastThreeMonthMap = null;
31206 tejbeer 4224
 
31697 amit.gupta 4225
        Map<Integer, List<HygieneData>> partnerHygieneDataRecentMonth = null;
31206 tejbeer 4226
 
31697 amit.gupta 4227
        if (!hygieneDataLastThreeMonth.isEmpty()) {
31886 tejbeer 4228
            partnerHygieneLastThreeMonthMap = hygieneDataLastThreeMonth.stream().collect(groupingBy(x -> x.getFofoId()));
31206 tejbeer 4229
 
31697 amit.gupta 4230
        }
31206 tejbeer 4231
 
31697 amit.gupta 4232
        if (!hygieneDataRecentMonth.isEmpty()) {
31886 tejbeer 4233
            partnerHygieneDataRecentMonth = hygieneDataRecentMonth.stream().collect(groupingBy(x -> x.getFofoId()));
31697 amit.gupta 4234
        }
31206 tejbeer 4235
 
31697 amit.gupta 4236
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
31206 tejbeer 4237
 
31697 amit.gupta 4238
            String email = storeGuyEntry.getKey();
31206 tejbeer 4239
 
31697 amit.gupta 4240
            List<Integer> fofoIds = new ArrayList<>(storeGuyEntry.getValue());
31206 tejbeer 4241
 
31697 amit.gupta 4242
            Map<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthData = new HashMap<>();
4243
            Map<Integer, Map<LocalDate, List<HygieneData>>> partnerDateWiseData = new HashMap<>();
4244
            for (Integer fofoId : fofoIds) {
31206 tejbeer 4245
 
31697 amit.gupta 4246
                partnerYearMonthData.put(fofoId, null);
4247
                partnerDateWiseData.put(fofoId, null);
4248
                if (!partnerHygieneLastThreeMonthMap.isEmpty()) {
4249
                    List<HygieneData> hygienes = partnerHygieneLastThreeMonthMap.get(fofoId);
31206 tejbeer 4250
 
31697 amit.gupta 4251
                    if (hygienes != null) {
31886 tejbeer 4252
                        Map<YearMonth, List<HygieneData>> yearMonthData = hygienes.stream().collect(groupingBy(x -> YearMonth.from(x.getDisposedTimestamp())));
31206 tejbeer 4253
 
31697 amit.gupta 4254
                        partnerYearMonthData.put(fofoId, yearMonthData);
31206 tejbeer 4255
 
31697 amit.gupta 4256
                    }
4257
                    List<HygieneData> dateWiseHygienes = partnerHygieneDataRecentMonth.get(fofoId);
31206 tejbeer 4258
 
31697 amit.gupta 4259
                    if (dateWiseHygienes != null) {
31206 tejbeer 4260
 
31886 tejbeer 4261
                        Map<LocalDate, List<HygieneData>> dateWiseData = hygienes.stream().collect(groupingBy(x -> (x.getDisposedTimestamp()).toLocalDate()));
31206 tejbeer 4262
 
31697 amit.gupta 4263
                        partnerDateWiseData.put(fofoId, dateWiseData);
31206 tejbeer 4264
 
31697 amit.gupta 4265
                    }
31206 tejbeer 4266
 
31697 amit.gupta 4267
                }
31206 tejbeer 4268
 
31697 amit.gupta 4269
            }
31206 tejbeer 4270
 
31697 amit.gupta 4271
            String subject = "Customer Info - Hygiene Alert";
31206 tejbeer 4272
 
31697 amit.gupta 4273
            LOGGER.info("hygieneData {}", partnerDateWiseData.values());
31206 tejbeer 4274
 
31697 amit.gupta 4275
            boolean partnerDateWise = partnerDateWiseData.values().stream().allMatch(Objects::isNull);
31206 tejbeer 4276
 
31697 amit.gupta 4277
            boolean partnerYearMonth = partnerYearMonthData.values().stream().allMatch(Objects::isNull);
31206 tejbeer 4278
 
31697 amit.gupta 4279
            if (!partnerDateWise && !partnerYearMonth) {
4280
                String sb = this.getMessageHygieneAlertForPartner(partnerYearMonthData, partnerDateWiseData);
32350 amit.gupta 4281
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{email}, sb, null, subject);
31697 amit.gupta 4282
            }
31206 tejbeer 4283
 
31697 amit.gupta 4284
        }
31206 tejbeer 4285
 
31697 amit.gupta 4286
    }
31206 tejbeer 4287
 
31697 amit.gupta 4288
    private String getMessageHygieneAlertForPartner(
32482 amit.gupta 4289
            Map<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthData, Map<Integer, Map<LocalDate, List<HygieneData>>> partnerDateWiseData) {
31206 tejbeer 4290
 
31697 amit.gupta 4291
        Map<Integer, CustomRetailer> customeRetailerMap = retailerService.getAllFofoRetailers();
31206 tejbeer 4292
 
31697 amit.gupta 4293
        LocalDateTime startDate = LocalDate.now().withDayOfMonth(1).atStartOfDay();
4294
        LocalDateTime endDate = LocalDateTime.now();
31206 tejbeer 4295
 
31697 amit.gupta 4296
        LocalDateTime startYearMonth = LocalDate.now().withDayOfMonth(1).minusMonths(3).atStartOfDay();
31886 tejbeer 4297
        LocalDateTime endYearMonth = LocalDate.now().minusMonths(1).withDayOfMonth(LocalDate.now().minusMonths(1).lengthOfMonth()).atTime(LocalTime.MAX);
31206 tejbeer 4298
 
31697 amit.gupta 4299
        DateTimeFormatter dateYearMonthFormatter = DateTimeFormatter.ofPattern("MMM''uu");
31206 tejbeer 4300
 
31697 amit.gupta 4301
        List<YearMonth> yearMonthRange = new ArrayList<>();
4302
        yearMonthRange.add(YearMonth.from(startYearMonth));
31206 tejbeer 4303
 
31697 amit.gupta 4304
        yearMonthRange.add(YearMonth.from(startYearMonth.plusMonths(1)));
31206 tejbeer 4305
 
31697 amit.gupta 4306
        yearMonthRange.add(YearMonth.from(endYearMonth));
31206 tejbeer 4307
 
31697 amit.gupta 4308
        long noOfDaysBetween = ChronoUnit.DAYS.between(startDate, endDate.plusDays(1));
31206 tejbeer 4309
 
31886 tejbeer 4310
        List<LocalDate> dateRange = Stream.iterate(startDate.toLocalDate(), date -> date.plusDays(1)).limit(noOfDaysBetween).collect(Collectors.toList());
31206 tejbeer 4311
 
31697 amit.gupta 4312
        StringBuilder sb = new StringBuilder();
31886 tejbeer 4313
        sb.append("<html><body><p>Hi," + "</p><br/><p>Kindly advise below mentioned partner to input correct details in the system else this will hinder all our marketing initiatives to bring this customer back to our smartdukaan or cross sell any product from partner's inventory.\n" + " </p>" + "<p>Kindly ensure going forward that the details are correct so to avoid 1% margin loss.\n" + "</p><p>In case the data is found to be incorrect there is a loss of 1% margin on this sales under SmartDukaan hygiene guidelines.\n</p>"
31206 tejbeer 4314
 
31697 amit.gupta 4315
                + "<table style='border:1px solid black ;padding: 5px';>");
4316
        sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
4317
        sb.append("<th style='border:1px solid black;padding: 5px'>Partner Name</th>\n");
31206 tejbeer 4318
 
31697 amit.gupta 4319
        for (YearMonth yearMonth : yearMonthRange) {
31886 tejbeer 4320
            sb.append("<th style='border:1px solid black;padding: 5px'>" + yearMonth.format(dateYearMonthFormatter) + "</th>\n");
31697 amit.gupta 4321
        }
31206 tejbeer 4322
 
31697 amit.gupta 4323
        for (LocalDate localDate : dateRange) {
4324
            sb.append("<th style='border:1px solid black;padding: 5px'>" + localDate + "</th>\n");
4325
        }
31206 tejbeer 4326
 
31697 amit.gupta 4327
        sb.append("</tr>\n");
31206 tejbeer 4328
 
31886 tejbeer 4329
        for (Entry<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthEntry : partnerYearMonthData.entrySet()) {
31206 tejbeer 4330
 
31697 amit.gupta 4331
            int fofoId = partnerYearMonthEntry.getKey();
31206 tejbeer 4332
 
31697 amit.gupta 4333
            Map<YearMonth, List<HygieneData>> yearMonthData = partnerYearMonthEntry.getValue();
31206 tejbeer 4334
 
31697 amit.gupta 4335
            Map<LocalDate, List<HygieneData>> dateWiseData = partnerDateWiseData.get(fofoId);
31206 tejbeer 4336
 
31697 amit.gupta 4337
            if (yearMonthData == null && dateWiseData == null) {
4338
                continue;
4339
            }
31206 tejbeer 4340
 
31697 amit.gupta 4341
            sb.append("<tr>");
31886 tejbeer 4342
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customeRetailerMap.get(fofoId).getBusinessName() + "</td>\n");
31697 amit.gupta 4343
            for (YearMonth yearMonth : yearMonthRange) {
31206 tejbeer 4344
 
31697 amit.gupta 4345
                if (yearMonthData == null) {
4346
                    sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4347
 
31697 amit.gupta 4348
                } else {
4349
                    List<HygieneData> hygieneList = yearMonthData.get(yearMonth);
31206 tejbeer 4350
 
31697 amit.gupta 4351
                    if (hygieneList != null) {
4352
                        sb.append("<td style='border:1px solid black;padding: 5px'>" + hygieneList.size() + "</td>\n");
31206 tejbeer 4353
 
31697 amit.gupta 4354
                    } else {
4355
                        sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4356
 
31697 amit.gupta 4357
                    }
4358
                }
4359
            }
31206 tejbeer 4360
 
31697 amit.gupta 4361
            for (LocalDate localDate : dateRange) {
31206 tejbeer 4362
 
31697 amit.gupta 4363
                if (dateWiseData == null) {
4364
                    sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4365
 
31697 amit.gupta 4366
                } else {
4367
                    List<HygieneData> hygieneList = dateWiseData.get(localDate);
31206 tejbeer 4368
 
31697 amit.gupta 4369
                    if (hygieneList != null) {
4370
                        sb.append("<td style='border:1px solid black;padding: 5px'>" + hygieneList.size() + "</td>\n");
31218 tejbeer 4371
 
31697 amit.gupta 4372
                    } else {
4373
                        sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31218 tejbeer 4374
 
31697 amit.gupta 4375
                    }
4376
                }
4377
            }
4378
            sb.append("</tr>");
31218 tejbeer 4379
 
31697 amit.gupta 4380
        }
31218 tejbeer 4381
 
31697 amit.gupta 4382
        sb.append("</tbody></table></body></html>");
31218 tejbeer 4383
 
31697 amit.gupta 4384
        return sb.toString();
4385
    }
31218 tejbeer 4386
 
31697 amit.gupta 4387
    @Autowired
4388
    private MonthlyTargetRepository monthlyTargetRepository;
31218 tejbeer 4389
 
31697 amit.gupta 4390
    public void monthlyTargetForPartner() throws MessagingException, ProfitMandiBusinessException, IOException {
31218 tejbeer 4391
 
31697 amit.gupta 4392
        LocalDateTime curDate = LocalDateTime.now();
4393
        List<MonthlyTarget> monthlyTargets = monthlyTargetRepository.selectByDate(YearMonth.now());
31218 tejbeer 4394
 
31886 tejbeer 4395
        Map<Integer, MonthlyTarget> partnersMonthlyTarget = monthlyTargets.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31218 tejbeer 4396
 
31886 tejbeer 4397
        Map<Integer, Double> secondaryMtd = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX));
4398
        Map<Integer, Double> todaytertiary = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate, curDate.with(LocalTime.MAX), 0, false);
31218 tejbeer 4399
 
31697 amit.gupta 4400
        String subject = "Monthly Target Vs Achievement";
31218 tejbeer 4401
 
31697 amit.gupta 4402
        for (Entry<Integer, MonthlyTarget> partnerMonthlyTargetEntry : partnersMonthlyTarget.entrySet()) {
31249 tejbeer 4403
 
31697 amit.gupta 4404
            int fofoId = partnerMonthlyTargetEntry.getKey();
31249 tejbeer 4405
 
31697 amit.gupta 4406
            CustomRetailer customRetailer = retailerService.getFofoRetailer(fofoId);
31249 tejbeer 4407
 
31697 amit.gupta 4408
            Double purchaseTarget = partnerMonthlyTargetEntry.getValue().getPurchaseTarget();
31218 tejbeer 4409
 
31697 amit.gupta 4410
            Double saleTarget = partnerMonthlyTargetEntry.getValue().getSaleTarget();
31218 tejbeer 4411
 
31697 amit.gupta 4412
            if (purchaseTarget > 0) {
4413
                Double purchase = secondaryMtd.get(fofoId);
31249 tejbeer 4414
 
31697 amit.gupta 4415
                if (purchase == null) {
4416
                    purchase = 0.0;
4417
                }
31218 tejbeer 4418
 
31697 amit.gupta 4419
                Double balanceTarget = purchaseTarget - purchase;
31218 tejbeer 4420
 
31697 amit.gupta 4421
                if (balanceTarget <= 0) {
4422
                    balanceTarget = 0.0;
4423
                }
31651 tejbeer 4424
 
31697 amit.gupta 4425
                StringBuilder sb = new StringBuilder();
4426
                sb.append("<html><body><p>Dear Partner,\n");
31886 tejbeer 4427
                sb.append("<p>Pls note your agreed monthly target is Rs." + purchaseTarget + " and your achievement till date is Rs." + purchase + "</p>");
31697 amit.gupta 4428
                sb.append("<p>Pls note that your balance target is Rs." + balanceTarget + "</p>\n");
4429
                sb.append(
32350 amit.gupta 4430
                        "<p>We wish you all the best and we are confident that this focused approach towards our outlet sales will help us take our outlet to the best SmartDukaan in your city.\n" + "</p>\n");
31651 tejbeer 4431
 
32350 amit.gupta 4432
                this.sendMailOfHtmlFormat(mailSender, new String[]{customRetailer.getEmail()}, sb.toString(), null, subject);
31697 amit.gupta 4433
            }
31218 tejbeer 4434
 
31697 amit.gupta 4435
        }
31218 tejbeer 4436
 
31697 amit.gupta 4437
    }
31218 tejbeer 4438
 
31697 amit.gupta 4439
    public void monthlyTargetForInternalTeam() throws MessagingException, ProfitMandiBusinessException, IOException {
31218 tejbeer 4440
 
31697 amit.gupta 4441
        LocalDateTime curDate = LocalDateTime.now();
31218 tejbeer 4442
 
31886 tejbeer 4443
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_MARKETING, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
31218 tejbeer 4444
 
31697 amit.gupta 4445
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false);
31218 tejbeer 4446
 
31697 amit.gupta 4447
        List<MonthlyTarget> monthlyTargets = monthlyTargetRepository.selectByDate(YearMonth.now());
31218 tejbeer 4448
 
31697 amit.gupta 4449
        Map<Integer, CustomRetailer> customeRetailerMap = retailerService.getAllFofoRetailers();
31218 tejbeer 4450
 
31886 tejbeer 4451
        Map<Integer, MonthlyTarget> partnersMonthlyTarget = monthlyTargets.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31218 tejbeer 4452
 
31886 tejbeer 4453
        Map<Integer, Double> secondaryMtd = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX));
4454
        Map<Integer, Double> todaytertiary = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate, curDate.with(LocalTime.MAX), 0, false);
31218 tejbeer 4455
 
31697 amit.gupta 4456
        String subject = "Monthly Target Vs Achievement";
31218 tejbeer 4457
 
31697 amit.gupta 4458
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
31218 tejbeer 4459
 
31697 amit.gupta 4460
            String email = storeGuyEntry.getKey();
31218 tejbeer 4461
 
31697 amit.gupta 4462
            List<Integer> fofoIds = new ArrayList<>(storeGuyEntry.getValue());
4463
            Map<Integer, MonthlyTarget> monthlyTargetAchievement = new HashMap<>();
4464
            for (Integer fofoId : fofoIds) {
31218 tejbeer 4465
 
31697 amit.gupta 4466
                MonthlyTarget monthlyTarget = partnersMonthlyTarget.get(fofoId);
4467
                if (monthlyTarget != null) {
4468
                    Double purchaseTarget = monthlyTarget.getPurchaseTarget();
31218 tejbeer 4469
 
31697 amit.gupta 4470
                    Double saleTarget = monthlyTarget.getSaleTarget();
31218 tejbeer 4471
 
31697 amit.gupta 4472
                    if (purchaseTarget != null && purchaseTarget > 0) {
4473
                        Double purchase = secondaryMtd.get(fofoId);
4474
                        if (purchase == null) {
4475
                            purchase = 0.0;
4476
                        }
4477
                        monthlyTarget.setPurchaseAchievement(purchase);
4478
                        monthlyTargetAchievement.put(fofoId, monthlyTarget);
31218 tejbeer 4479
 
31697 amit.gupta 4480
                    }
4481
                }
4482
            }
31218 tejbeer 4483
 
31697 amit.gupta 4484
            if (!monthlyTargetAchievement.isEmpty()) {
31218 tejbeer 4485
 
31697 amit.gupta 4486
                StringBuilder sb = new StringBuilder();
31218 tejbeer 4487
 
31697 amit.gupta 4488
                sb.append("<html><body><p>Hi,\n");
31886 tejbeer 4489
                sb.append("<p>Pls note your Partners agreed monthly target foolowing are :</p>\n" + " <table style='border:1px solid black ;padding: 5px';>");
31697 amit.gupta 4490
                sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
4491
                sb.append("<th style='border:1px solid black;padding: 5px'>Partner Name</th>\n");
31218 tejbeer 4492
 
31697 amit.gupta 4493
                sb.append("<th style='border:1px solid black;padding: 5px'>Purchase Target</th>\n");
31218 tejbeer 4494
 
31697 amit.gupta 4495
                sb.append("<th style='border:1px solid black;padding: 5px'>Purchase Achievement</th>\n");
4496
                sb.append("</tr>\n");
31218 tejbeer 4497
 
31886 tejbeer 4498
                for (Entry<Integer, MonthlyTarget> monthlyTargetAchievementEntry : monthlyTargetAchievement.entrySet()) {
31697 amit.gupta 4499
                    sb.append("<tr>");
4500
                    int fofoId = monthlyTargetAchievementEntry.getKey();
31218 tejbeer 4501
 
31697 amit.gupta 4502
                    MonthlyTarget monthlyTarget = monthlyTargetAchievementEntry.getValue();
31886 tejbeer 4503
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customeRetailerMap.get(fofoId).getBusinessName() + "</td>\n");
31218 tejbeer 4504
 
31886 tejbeer 4505
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + monthlyTarget.getPurchaseTarget() + "</td>\n");
31218 tejbeer 4506
 
31886 tejbeer 4507
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + monthlyTarget.getPurchaseAchievement() + "</td>\n");
31218 tejbeer 4508
 
31697 amit.gupta 4509
                    sb.append("</tr>\n");
31218 tejbeer 4510
 
31697 amit.gupta 4511
                }
31218 tejbeer 4512
 
32350 amit.gupta 4513
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{email}, sb.toString(), null, subject);
31697 amit.gupta 4514
                // this.sendMailOfHtmlFormat("tejbeer.kaur@smartdukaan.com", sb.toString(),
4515
                // null, subject);
31218 tejbeer 4516
 
31697 amit.gupta 4517
            }
31604 tejbeer 4518
 
31697 amit.gupta 4519
        }
31604 tejbeer 4520
 
31697 amit.gupta 4521
    }
31604 tejbeer 4522
 
32061 amit.gupta 4523
    @Autowired
4524
    private PerformanceService performanceService;
4525
 
4526
 
4527
    public void sendFilteredRetailerPerformance() throws Exception {
4528
        RetailerFilterModel retailerFilterModel = performanceService.getRetailerFilterModel();
4529
 
4530
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
4531
 
4532
 
4533
        List<RetailerPeformanceFilterModel> partnersPerformance = performanceService.getPerformance(retailerFilterModel, customRetailers);
4534
 
4535
        Map<Integer, RetailerPeformanceFilterModel> partnersPerformanceMap = new HashMap<>();
4536
 
4537
        if (!partnersPerformance.isEmpty()) {
4538
            partnersPerformanceMap = partnersPerformance.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
4539
            performanceService.sendPartnerPerformanceEmail(partnersPerformanceMap, retailerFilterModel, customRetailers);
4540
 
4541
        }
4542
 
4543
 
4544
    }
4545
 
32081 tejbeer 4546
    @Autowired
4547
    private VendorItemPricingRepository vendorItemPricingRepository;
32061 amit.gupta 4548
 
32081 tejbeer 4549
 
4550
    @Autowired
4551
    private VendorCatalogPricingService vendorCatalogPricingService;
4552
 
4553
 
4554
    public void migrateVendorItemPricing() {
4555
 
4556
        List<VendorItemPricing> vendorItemPricings = vendorItemPricingRepository.selectAll();
32350 amit.gupta 4557
        LOGGER.info("At migrate VendorItemPricing");
32092 tejbeer 4558
        Map<Integer, Item> items = itemRepository.selectByIds(vendorItemPricings.stream().map(x -> x.getItemId()).collect(Collectors.toSet())).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
32081 tejbeer 4559
        for (VendorItemPricing vendorItemPricing : vendorItemPricings) {
4560
            Item item = null;
32092 tejbeer 4561
            if (items.get(vendorItemPricing.getItemId()) != null) {
4562
                item = items.get(vendorItemPricing.getItemId());
4563
            } else {
32084 tejbeer 4564
                continue;
32081 tejbeer 4565
            }
32092 tejbeer 4566
 
32081 tejbeer 4567
            VendorCatalogPricingModel vendorCatalogPricingModel = new VendorCatalogPricingModel();
4568
            vendorCatalogPricingModel.setCatalogId(item.getCatalogItemId());
4569
            vendorCatalogPricingModel.setAuthId(13);
32088 tejbeer 4570
            vendorCatalogPricingModel.setDp(vendorItemPricing.getDp());
32081 tejbeer 4571
 
4572
            vendorCatalogPricingModel.setTp(vendorItemPricing.getTp());
4573
            vendorCatalogPricingModel.setMop(vendorItemPricing.getMop());
32384 amit.gupta 4574
            vendorCatalogPricingModel.setEffectedOn(LocalDate.of(2023, 8, 22));
32081 tejbeer 4575
            vendorCatalogPricingModel.setVendorId(vendorItemPricing.getVendorId());
4576
 
4577
 
4578
            try {
4579
                vendorCatalogPricingService.createVendorCatalogPricingLog(vendorCatalogPricingModel);
4580
            } catch (ProfitMandiBusinessException e) {
4581
                continue;
4582
            }
4583
 
4584
        }
4585
 
4586
    }
4587
 
4588
    public void approveVendorCatalogPricing() {
4589
        List<VendorCatalogPricingLog> vendorCatalogPricingLogs = vendorCatalogPricingLogRepository.selectByStatus(VendorCatalogPricingStatus.PENDING);
4590
 
32084 tejbeer 4591
 
32081 tejbeer 4592
        for (VendorCatalogPricingLog vendorCatalogPricingLog : vendorCatalogPricingLogs) {
32107 tejbeer 4593
            vendorCatalogPricingLog.setStatus(VendorCatalogPricingStatus.APPROVED);
4594
            vendorCatalogPricingLog.setUpdatedTimestamp(LocalDateTime.now());
4595
            vendorCatalogPricingLog.setApprovedBy(13);
4596
            vendorCatalogPricingLog.setApprovedTimestamp(LocalDateTime.now());
32114 tejbeer 4597
            vendorCatalogPricingService.createVendorCatalogPricing(vendorCatalogPricingLog);
4598
        }
32081 tejbeer 4599
 
32114 tejbeer 4600
    }
32108 tejbeer 4601
 
4602
 
32210 jai.hind 4603
}
4604
// 2284'