Subversion Repositories SmartDukaan

Rev

Rev 36473 | 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
 
34039 vikas.jang 3
import com.google.auth.oauth2.GoogleCredentials;
24542 amit.gupta 4
import com.google.common.collect.Lists;
25300 tejbeer 5
import com.google.gson.Gson;
29488 manish 6
import com.razorpay.Payment;
32421 amit.gupta 7
import com.smartdukaan.cron.itelImeiActivation.ItelImeiActivationNewService;
29488 manish 8
import com.smartdukaan.cron.itelImeiActivation.ItelImeiActivationService;
9
import com.smartdukaan.cron.itelImeiActivation.TecnoImeiActivation;
33994 amit.gupta 10
import com.smartdukaan.cron.migrations.RunOnceTasks;
35021 amit 11
import com.smartdukaan.cron.scheduled.ambreports.AbmReportSender;
32482 amit.gupta 12
import com.smartdukaan.cron.scheduled.runnables.PurchaseMigration;
32511 amit.gupta 13
import com.spice.profitmandi.common.enumuration.*;
24121 govind 14
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
32421 amit.gupta 15
import com.spice.profitmandi.common.model.*;
24681 amit.gupta 16
import com.spice.profitmandi.common.services.ReporticoService;
29814 tejbeer 17
import com.spice.profitmandi.common.services.mandii.MandiiService;
35295 amit 18
import com.spice.profitmandi.common.util.FileUtil;
19
import com.spice.profitmandi.common.util.FormattingUtils;
20
import com.spice.profitmandi.common.util.PdfUtils;
21
import com.spice.profitmandi.common.util.Utils;
24592 amit.gupta 22
import com.spice.profitmandi.common.util.Utils.Attachment;
29308 tejbeer 23
import com.spice.profitmandi.common.web.client.RestClient;
25300 tejbeer 24
import com.spice.profitmandi.dao.Interface.Campaign;
32511 amit.gupta 25
import com.spice.profitmandi.dao.cart.CartService;
34450 ranu 26
import com.spice.profitmandi.dao.cart.SmartCartService;
25590 amit.gupta 27
import com.spice.profitmandi.dao.entity.auth.AuthUser;
30421 tejbeer 28
import com.spice.profitmandi.dao.entity.auth.PartnerCollectionRemark;
33078 ranu 29
import com.spice.profitmandi.dao.entity.catalog.*;
35393 amit 30
import com.spice.profitmandi.dao.entity.catalog.Offer;
33078 ranu 31
import com.spice.profitmandi.dao.entity.cs.NonSdBuying;
25590 amit.gupta 32
import com.spice.profitmandi.dao.entity.cs.Position;
26283 tejbeer 33
import com.spice.profitmandi.dao.entity.cs.Ticket;
35295 amit 34
import com.spice.profitmandi.dao.entity.dtr.*;
28769 amit.gupta 35
import com.spice.profitmandi.dao.entity.dtr.User;
32421 amit.gupta 36
import com.spice.profitmandi.dao.entity.fofo.*;
37
import com.spice.profitmandi.dao.entity.inventory.*;
33553 ranu 38
import com.spice.profitmandi.dao.entity.logistics.AST;
39
import com.spice.profitmandi.dao.entity.logistics.ASTRepository;
32421 amit.gupta 40
import com.spice.profitmandi.dao.entity.transaction.*;
41
import com.spice.profitmandi.dao.entity.user.*;
32511 amit.gupta 42
import com.spice.profitmandi.dao.entity.warehouse.WarehouseInventoryItem;
43
import com.spice.profitmandi.dao.entity.warehouse.WarehouseScan;
30421 tejbeer 44
import com.spice.profitmandi.dao.enumuration.auth.CollectionRemark;
34324 amit.gupta 45
import com.spice.profitmandi.dao.enumuration.catalog.StockTransactionType;
25598 amit.gupta 46
import com.spice.profitmandi.dao.enumuration.cs.EscalationType;
26790 tejbeer 47
import com.spice.profitmandi.dao.enumuration.dtr.RefferalStatus;
29814 tejbeer 48
import com.spice.profitmandi.dao.enumuration.fofo.Gateway;
31332 amit.gupta 49
import com.spice.profitmandi.dao.enumuration.fofo.PaymentStatus;
32511 amit.gupta 50
import com.spice.profitmandi.dao.enumuration.fofo.ReturnType;
24242 amit.gupta 51
import com.spice.profitmandi.dao.enumuration.fofo.ScanType;
34162 ranu 52
import com.spice.profitmandi.dao.enumuration.inventory.CatalogMovingEnum;
32081 tejbeer 53
import com.spice.profitmandi.dao.enumuration.inventory.VendorCatalogPricingStatus;
34324 amit.gupta 54
import com.spice.profitmandi.dao.enumuration.transaction.CreditRisk;
55
import com.spice.profitmandi.dao.enumuration.transaction.LoanReferenceType;
56
import com.spice.profitmandi.dao.enumuration.transaction.PriceDropImeiStatus;
57
import com.spice.profitmandi.dao.enumuration.transaction.SchemePayoutStatus;
32421 amit.gupta 58
import com.spice.profitmandi.dao.model.*;
33452 amit.gupta 59
import com.spice.profitmandi.dao.repository.GenericRepository;
25590 amit.gupta 60
import com.spice.profitmandi.dao.repository.auth.AuthRepository;
33078 ranu 61
import com.spice.profitmandi.dao.repository.auth.NonSdBuyingRepository;
30421 tejbeer 62
import com.spice.profitmandi.dao.repository.auth.PartnerCollectionRemarkRepository;
32421 amit.gupta 63
import com.spice.profitmandi.dao.repository.catalog.*;
33874 ranu 64
import com.spice.profitmandi.dao.repository.cs.CsService;
65
import com.spice.profitmandi.dao.repository.cs.PartnerRegionRepository;
66
import com.spice.profitmandi.dao.repository.cs.PositionRepository;
67
import com.spice.profitmandi.dao.repository.cs.TicketRepository;
32421 amit.gupta 68
import com.spice.profitmandi.dao.repository.dtr.*;
69
import com.spice.profitmandi.dao.repository.fofo.*;
70
import com.spice.profitmandi.dao.repository.inventory.*;
33817 amit.gupta 71
import com.spice.profitmandi.dao.repository.logistics.WarehouseProviderRepository;
32421 amit.gupta 72
import com.spice.profitmandi.dao.repository.transaction.*;
35295 amit 73
import com.spice.profitmandi.dao.repository.trialOnboarding.TrialFormRepository;
24542 amit.gupta 74
import com.spice.profitmandi.dao.repository.user.AddressRepository;
34160 tejus.loha 75
import com.spice.profitmandi.dao.repository.user.LoiFormRepository;
25721 tejbeer 76
import com.spice.profitmandi.dao.repository.user.UserRepository;
32421 amit.gupta 77
import com.spice.profitmandi.dao.repository.warehouse.*;
34547 vikas.jang 78
import com.spice.profitmandi.dao.service.LiquidationService;
34252 tejus.loha 79
import com.spice.profitmandi.dao.service.PurSaleService;
33355 amit.gupta 80
import com.spice.profitmandi.dao.service.SidbiService;
32817 amit.gupta 81
import com.spice.profitmandi.dao.service.biuedart.BluedartAuthService;
82
import com.spice.profitmandi.dao.service.biuedart.BluedartService;
35788 vikas 83
import com.spice.profitmandi.dao.service.shopify.ShopifyProductSyncService;
31604 tejbeer 84
import com.spice.profitmandi.dao.service.solr.FofoSolr;
32421 amit.gupta 85
import com.spice.profitmandi.service.*;
31332 amit.gupta 86
import com.spice.profitmandi.service.integrations.CCAvenuePaymentService;
28368 tejbeer 87
import com.spice.profitmandi.service.integrations.RazorpayPaymentService;
30858 amit.gupta 88
import com.spice.profitmandi.service.integrations.bharti.model.BAGInsuranceModel;
33638 amit.gupta 89
import com.spice.profitmandi.service.integrations.gstpro.GstProAuthService;
33817 amit.gupta 90
import com.spice.profitmandi.service.integrations.gstpro.GstProService;
35666 vikas 91
import com.spice.profitmandi.service.integrations.pinelabs.PinelabsAffordabilityService;
92
import com.spice.profitmandi.service.integrations.pinelabs.PinelabsAuthService;
93
import com.spice.profitmandi.service.integrations.pinelabs.PinelabsOfferCacheService;
35393 amit 94
import com.spice.profitmandi.service.integrations.pinelabs.dto.*;
32872 amit.gupta 95
import com.spice.profitmandi.service.integrations.psismart.PsiSmartService;
32948 amit.gupta 96
import com.spice.profitmandi.service.integrations.smartping.SmartPingService;
25694 amit.gupta 97
import com.spice.profitmandi.service.integrations.toffee.ToffeeService;
32421 amit.gupta 98
import com.spice.profitmandi.service.inventory.*;
35959 amit 99
import com.spice.profitmandi.service.mail.MailOutboxService;
31746 amit.gupta 100
import com.spice.profitmandi.service.offers.OfferService;
25335 amit.gupta 101
import com.spice.profitmandi.service.order.OrderService;
33452 amit.gupta 102
import com.spice.profitmandi.service.pricecircular.PriceCircularService;
24431 amit.gupta 103
import com.spice.profitmandi.service.pricing.PriceDropService;
23724 amit.gupta 104
import com.spice.profitmandi.service.recharge.provider.OxigenRechargeProviderService;
105
import com.spice.profitmandi.service.recharge.provider.ThinkWalnutDigitalRechargeProviderService;
106
import com.spice.profitmandi.service.scheme.SchemeService;
29668 tejbeer 107
import com.spice.profitmandi.service.serviceConfig.ServiceConfigService;
35295 amit 108
import com.spice.profitmandi.service.transaction.CreditBlockedExceptionPartnersRepository;
31008 amit.gupta 109
import com.spice.profitmandi.service.transaction.CreditNoteService;
30859 tejbeer 110
import com.spice.profitmandi.service.transaction.SDCreditService;
23929 amit.gupta 111
import com.spice.profitmandi.service.transaction.TransactionService;
32990 amit.gupta 112
import com.spice.profitmandi.service.transaction.invoicing.InvoiceService;
23929 amit.gupta 113
import com.spice.profitmandi.service.user.RetailerService;
34160 tejus.loha 114
import com.spice.profitmandi.service.user.StoreTimelineTatService;
32511 amit.gupta 115
import com.spice.profitmandi.service.wallet.CommonPaymentService;
23739 amit.gupta 116
import com.spice.profitmandi.service.wallet.WalletService;
32421 amit.gupta 117
import com.spice.profitmandi.service.warehouse.PurchaseOrderService;
32511 amit.gupta 118
import com.spice.profitmandi.service.warehouse.WarehouseInventoryService;
33384 amit.gupta 119
import com.spice.profitmandi.service.warehouse.WarehouseService;
25721 tejbeer 120
import in.shop2020.model.v1.order.OrderStatus;
29308 tejbeer 121
import in.shop2020.model.v1.order.WalletReferenceType;
32421 amit.gupta 122
import org.apache.commons.io.output.ByteArrayOutputStream;
123
import org.apache.commons.lang.StringUtils;
124
import org.apache.http.client.methods.CloseableHttpResponse;
125
import org.apache.http.client.methods.HttpPost;
126
import org.apache.http.conn.HttpHostConnectException;
127
import org.apache.http.entity.StringEntity;
128
import org.apache.http.impl.client.CloseableHttpClient;
36420 amit 129
import com.spice.profitmandi.common.web.client.HttpClientFactory;
32421 amit.gupta 130
import org.apache.logging.log4j.LogManager;
131
import org.apache.logging.log4j.Logger;
132
import org.hibernate.SessionFactory;
133
import org.json.JSONObject;
134
import org.springframework.beans.factory.annotation.Autowired;
135
import org.springframework.beans.factory.annotation.Qualifier;
136
import org.springframework.beans.factory.annotation.Value;
137
import org.springframework.core.io.ByteArrayResource;
138
import org.springframework.core.io.InputStreamSource;
139
import org.springframework.mail.javamail.JavaMailSender;
140
import org.springframework.mail.javamail.MimeMessageHelper;
141
import org.springframework.stereotype.Component;
142
import org.springframework.transaction.annotation.Transactional;
31640 tejbeer 143
 
32421 amit.gupta 144
import javax.mail.MessagingException;
145
import javax.mail.internet.InternetAddress;
146
import javax.mail.internet.MimeMessage;
147
import java.io.*;
148
import java.math.BigDecimal;
149
import java.math.RoundingMode;
150
import java.nio.file.Files;
151
import java.nio.file.Paths;
152
import java.sql.Timestamp;
153
import java.text.DecimalFormat;
154
import java.time.*;
155
import java.time.format.DateTimeFormatter;
156
import java.time.temporal.ChronoField;
157
import java.time.temporal.ChronoUnit;
158
import java.util.*;
159
import java.util.Map.Entry;
160
import java.util.stream.Collectors;
161
import java.util.stream.Stream;
32060 amit.gupta 162
 
33664 amit.gupta 163
import static java.util.stream.Collectors.*;
32421 amit.gupta 164
 
165
 
23723 amit.gupta 166
@Component
33384 amit.gupta 167
@Transactional(rollbackFor = {Throwable.class, ProfitMandiBusinessException.class})
23723 amit.gupta 168
public class ScheduledTasks {
169
 
36289 amit 170
    // Lock to serialize all methods that write to sd_credit_requirement table.
171
    // Prevents deadlocks and stale-data overwrites from concurrent cron threads.
172
    public static final Object SD_CREDIT_LOCK = new Object();
173
 
31697 amit.gupta 174
    @Value("${oxigen.recharge.enquiry.url}")
175
    private String oxigenRechargeEnquiryUrl;
24533 govind 176
 
31697 amit.gupta 177
    @Autowired
32482 amit.gupta 178
    PurchaseMigration purchaseMigration;
179
 
180
    @Autowired
32795 amit.gupta 181
    SmartPingService smartPingService;
182
 
33553 ranu 183
    @Autowired
184
    private ASTRepository astRepository;
29668 tejbeer 185
 
31697 amit.gupta 186
    @Autowired
187
    private ServiceConfigService serviceConfigService;
29801 manish 188
 
31697 amit.gupta 189
    @Autowired
190
    private TecnoImeiActivation tecnoImeiActivation;
28205 tejbeer 191
 
31697 amit.gupta 192
    private static final DateTimeFormatter leadTimeFormatter = DateTimeFormatter.ofPattern("d LLL, hh:mm a");
27088 tejbeer 193
 
31697 amit.gupta 194
    @Autowired
195
    private PartnerRegionRepository partnerRegionRepository;
28790 amit.gupta 196
 
31697 amit.gupta 197
    @Autowired
198
    private EmployeeAttendanceRepository employeeAttendanceRepository;
27088 tejbeer 199
 
31697 amit.gupta 200
    @Autowired
201
    VivoImeiActivationService vivoImeiActivationService;
29488 manish 202
 
31697 amit.gupta 203
    @Autowired
204
    ItelImeiActivationService itelImeiActivationService;
29488 manish 205
 
31697 amit.gupta 206
    @Autowired
207
    private PartnerTypeChangeService partnerTypeChangeService;
25598 amit.gupta 208
 
26408 amit.gupta 209
 
31697 amit.gupta 210
    @Autowired
211
    private LeadRepository leadRepository;
25927 amit.gupta 212
 
31697 amit.gupta 213
    @Autowired
214
    private AuthRepository authRepository;
25503 amit.gupta 215
 
31697 amit.gupta 216
    @Autowired
217
    private PriceDropService priceDropService;
26283 tejbeer 218
 
31697 amit.gupta 219
    @Autowired
220
    private FranchiseeVisitRepository franchiseeVisitRepository;
26790 tejbeer 221
 
31697 amit.gupta 222
    @Autowired
223
    private FranchiseeActivityRepository franchiseeActivityRepository;
26790 tejbeer 224
 
31697 amit.gupta 225
    @Autowired
226
    private HdfcPaymentRepository hdfcPaymentRepository;
26790 tejbeer 227
 
31697 amit.gupta 228
    @Autowired
229
    private CsService csService;
25846 amit.gupta 230
 
31697 amit.gupta 231
    @Autowired
232
    private SaholicInventoryService saholicInventoryService;
27208 tejbeer 233
 
31697 amit.gupta 234
    @Autowired
235
    private InsurancePolicyRepository insurancePolicyRepository;
23723 amit.gupta 236
 
31697 amit.gupta 237
    @Autowired
238
    private ToffeeService toffeeService;
25694 amit.gupta 239
 
31697 amit.gupta 240
    @Value("${oxigen.recharge.auth.key}")
241
    private String oxigenRechargeAuthKey;
23724 amit.gupta 242
 
31697 amit.gupta 243
    @Value("${oxigen.recharge.validation.url}")
244
    private String oxigenRechargeValidationUrl;
23724 amit.gupta 245
 
31697 amit.gupta 246
    @Value("${oxigen.recharge.validation.auth.key}")
247
    private String oxigenRechargeValidationAuthKey;
23724 amit.gupta 248
 
31697 amit.gupta 249
    @Value("${think.walnut.digital.recharge.transaction.mobile.url}")
250
    private String thinkWalnutDigitalRechargeTransactionMobileUrl;
23724 amit.gupta 251
 
31697 amit.gupta 252
    @Value("${think.walnut.digital.recharge.transaction.dth.url}")
253
    private String thinkWalnutDigitalRechargeTransactionDthUrl;
23724 amit.gupta 254
 
31697 amit.gupta 255
    @Value("${think.walnut.digital.recharge.enquiry.url}")
256
    private String thinkWalnutDigitalRechargeEnquiryUrl;
23724 amit.gupta 257
 
31697 amit.gupta 258
    @Value("${think.walnut.digital.recharge.balance.url}")
259
    private String thinkWalnutDigitalRechargeBalanceUrl;
23724 amit.gupta 260
 
31697 amit.gupta 261
    @Value("${think.walnut.digital.recharge.username}")
262
    private String thinkWalnutDigitalRechargeUserName;
23724 amit.gupta 263
 
31697 amit.gupta 264
    @Value("${think.walnut.digital.recharge.password}")
265
    private String thinkWalnutDigitalRechargePassword;
23724 amit.gupta 266
 
31697 amit.gupta 267
    @Value("${think.walnut.digital.recharge.auth.key}")
268
    private String thinkWalnutDigitalRechargeAuthKey;
23724 amit.gupta 269
 
31697 amit.gupta 270
    @Autowired
271
    private PurchaseRepository purchaseRepository;
23724 amit.gupta 272
 
31697 amit.gupta 273
    @Autowired
274
    private PriceDropIMEIRepository priceDropIMEIRepository;
25609 amit.gupta 275
 
31697 amit.gupta 276
    @Autowired
277
    PriceDropRepository priceDropRepository;
25609 amit.gupta 278
 
31697 amit.gupta 279
    @Autowired
280
    private PartnerTypeChangeRepository partnerTypeChangeRepository;
28368 tejbeer 281
 
31697 amit.gupta 282
    @Autowired
283
    private SchemeService schemeService;
24683 amit.gupta 284
 
31697 amit.gupta 285
    @Autowired
286
    private ServiceConfigRepository serviceConfigRepository;
29668 tejbeer 287
 
32061 amit.gupta 288
    @Autowired
289
    private RetailerBlockBrandsRepository retailerBlockBrandsRepository;
290
 
34547 vikas.jang 291
    @Autowired
292
    private LiquidationService liquidationService;
293
 
34578 vikas.jang 294
    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.gupta1@smartdukaan.com"};
25609 amit.gupta 295
 
31886 tejbeer 296
    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 297
 
33664 amit.gupta 298
    private static final String[] INDENT_TERTIARY_MAIL_LIST = new String[]{"uday.singh@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "nishant.ohri@smartdukaan.com", "vinay.p@smartdukaan.com", "deena.nath@smartdukaan.com", "shobhit.tandon@smartdukaan.com", "ritesh.chauhan1@smartdukaan.com"};
28709 amit.gupta 299
 
31886 tejbeer 300
    private static final String[] EMPLOYEE_ATTENDANCE_MAIL_LIST = new String[]{"sm@smartdukaan.com", "sm@smartdukaan.com"};
28790 amit.gupta 301
 
31697 amit.gupta 302
    private List<OrderStatus> orderStatusList = Arrays.asList(OrderStatus.SUBMITTED_FOR_PROCESSING);
25721 tejbeer 303
 
31697 amit.gupta 304
    @Autowired
305
    private ReporticoService reporticoService;
23724 amit.gupta 306
 
31697 amit.gupta 307
    @Autowired
308
    private PartnerInvestmentService partnerInvestmentService;
25598 amit.gupta 309
 
31697 amit.gupta 310
    @Autowired
311
    private PositionRepository positionRepository;
24337 amit.gupta 312
 
31697 amit.gupta 313
    @Autowired
314
    private FofoOrderItemRepository fofoOrderItemRepository;
25865 amit.gupta 315
 
31697 amit.gupta 316
    @Autowired
317
    private NotificationService notificationService;
24542 amit.gupta 318
 
31697 amit.gupta 319
    @Autowired
320
    private PartnerDailyInvestmentRepository partnerDailyInvestmentRepository;
24277 amit.gupta 321
 
31697 amit.gupta 322
    @Autowired
323
    private SchemeInOutRepository schemeInOutRepository;
24241 amit.gupta 324
 
31697 amit.gupta 325
    @Autowired
326
    private RechargeTransactionRepository rechargeTransactionRepository;
23724 amit.gupta 327
 
31697 amit.gupta 328
    @Autowired
329
    private CustomerAddressRepository customerAddressRepository;
24542 amit.gupta 330
 
31697 amit.gupta 331
    @Autowired
332
    private RechargeProviderCreditWalletHistoryRepository rechargeProviderCreditWalletHistoryRepository;
23724 amit.gupta 333
 
31697 amit.gupta 334
    @Autowired
335
    private FofoLineItemRepository fofoLineItemRepository;
24590 amit.gupta 336
 
31697 amit.gupta 337
    @Autowired
338
    private FofoOrderRepository fofoOrderRepository;
24587 amit.gupta 339
 
31697 amit.gupta 340
    @Autowired
341
    private UserWalletHistoryRepository userWalletHistoryRepository;
24250 amit.gupta 342
 
31697 amit.gupta 343
    @Autowired
344
    private UserWalletRepository userWalletRepository;
24587 amit.gupta 345
 
31697 amit.gupta 346
    @Autowired
347
    private InventoryItemRepository inventoryItemRepository;
23929 amit.gupta 348
 
31697 amit.gupta 349
    @Autowired
350
    private WalletService walletService;
23724 amit.gupta 351
 
31697 amit.gupta 352
    @Autowired
353
    private ThinkWalnutDigitalRechargeProviderService thinkWalnutDigitalRechargeProviderService;
23724 amit.gupta 354
 
31697 amit.gupta 355
    @Autowired
356
    private OxigenRechargeProviderService oxigenRechargeProviderService;
23724 amit.gupta 357
 
31697 amit.gupta 358
    @Autowired
359
    private RechargeProviderRepository rechargeProviderRepository;
23724 amit.gupta 360
 
31697 amit.gupta 361
    @Autowired
362
    private ScanRecordRepository scanRecordRepository;
24242 amit.gupta 363
 
31697 amit.gupta 364
    @Autowired
365
    private DailyRechargeRepository dailyRechargeRepository;
23724 amit.gupta 366
 
31697 amit.gupta 367
    @Autowired
368
    private FofoStoreRepository fofoStoreRepository;
24177 govind 369
 
31697 amit.gupta 370
    @Value("${prod}")
371
    private boolean prod;
26945 amit.gupta 372
 
31697 amit.gupta 373
    @Autowired
374
    private StateGstRateRepository stateGstRateRepository;
23724 amit.gupta 375
 
31697 amit.gupta 376
    @Autowired
377
    private RetailerService retailerService;
23929 amit.gupta 378
 
31697 amit.gupta 379
    @Autowired
33078 ranu 380
    private BrandsRepository brandsRepository;
381
 
382
    @Autowired
31697 amit.gupta 383
    private TransactionService transactionService;
24250 amit.gupta 384
 
31697 amit.gupta 385
    @Autowired
386
    private ItemRepository itemRepository;
23929 amit.gupta 387
 
31697 amit.gupta 388
    @Autowired
389
    private OrderRepository orderRepository;
25351 tejbeer 390
 
31697 amit.gupta 391
    @Autowired
392
    private OrderService orderService;
23929 amit.gupta 393
 
31697 amit.gupta 394
    @Autowired
395
    private SchemeRepository schemeRepository;
24241 amit.gupta 396
 
31697 amit.gupta 397
    @Autowired
398
    private SchemeItemRepository schemeItemRepository;
31612 tejbeer 399
 
31697 amit.gupta 400
    @Autowired
36402 amit 401
    private JavaMailSender gmailRelaySender;
24177 govind 402
 
31697 amit.gupta 403
    @Autowired
404
    private PartnerTargetRepository partnerTargetRepository;
24002 amit.gupta 405
 
31697 amit.gupta 406
    @Autowired
407
    @Qualifier(value = "googleMailSender")
408
    private JavaMailSender googleMailSender;
23929 amit.gupta 409
 
31697 amit.gupta 410
    @Autowired
35959 amit 411
    private MailOutboxService mailOutboxService;
412
 
413
    @Autowired
31697 amit.gupta 414
    private InventoryService inventoryService;
23929 amit.gupta 415
 
31697 amit.gupta 416
    @Autowired
417
    private AddressRepository addressRepository;
24542 amit.gupta 418
 
31697 amit.gupta 419
    @Autowired
420
    private RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
24542 amit.gupta 421
 
31697 amit.gupta 422
    @Autowired
423
    private Mongo mongoClient;
24683 amit.gupta 424
 
31697 amit.gupta 425
    @Autowired
426
    private DeviceRepository deviceRepository;
25300 tejbeer 427
 
31697 amit.gupta 428
    @Autowired
429
    private PushNotificationRepository pushNotificationRepository;
25300 tejbeer 430
 
31697 amit.gupta 431
    @Autowired
432
    private NotificationCampaignRepository notificationCampaignRepository;
25300 tejbeer 433
 
31697 amit.gupta 434
    @Autowired
435
    private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
25721 tejbeer 436
 
31697 amit.gupta 437
    @Autowired
438
    private FocusedModelRepository focusedModelRepository;
25721 tejbeer 439
 
31697 amit.gupta 440
    @Autowired
441
    private UserAccountRepository userAccountRepository;
24653 govind 442
 
31697 amit.gupta 443
    @Autowired
444
    private UserRepository userUserRepository;
25721 tejbeer 445
 
31697 amit.gupta 446
    @Autowired
447
    private com.spice.profitmandi.dao.repository.dtr.UserRepository dtrUserRepository;
25927 amit.gupta 448
 
31697 amit.gupta 449
    @Autowired
450
    private UserCampaignRepository userCampaignRepository;
25721 tejbeer 451
 
31697 amit.gupta 452
    @Autowired
453
    private Gson gson;
25721 tejbeer 454
 
31697 amit.gupta 455
    @Autowired
456
    private TicketRepository ticketRepository;
26283 tejbeer 457
 
31697 amit.gupta 458
    @Autowired
459
    private RefferalRepository refferalRepository;
26790 tejbeer 460
 
31697 amit.gupta 461
    @Autowired
462
    private PartnerProblemRepository partnerProblemRepository;
28205 tejbeer 463
 
31697 amit.gupta 464
    @Autowired
465
    private PendingOrderRepository pendingOrderRepository;
28368 tejbeer 466
 
31697 amit.gupta 467
    @Autowired
468
    private PendingOrderItemRepository pendingOrderItemRepository;
28368 tejbeer 469
 
31697 amit.gupta 470
    @Value("${razorpay.account.keyId}")
471
    private String keyId;
28368 tejbeer 472
 
31697 amit.gupta 473
    @Value("${razorpay.account.keySecret}")
474
    private String keySecret;
28368 tejbeer 475
 
31697 amit.gupta 476
    @Autowired
477
    private RazorpayPaymentService razorPaymentService;
28369 tejbeer 478
 
31697 amit.gupta 479
    @Autowired
480
    private RazorPayRepository razorPayRepository;
28369 tejbeer 481
 
31697 amit.gupta 482
    @Autowired
483
    private PendingOrderService pendingOrderService;
28377 tejbeer 484
 
31697 amit.gupta 485
    @Autowired
486
    private CustomerRepository customerRepository;
28377 tejbeer 487
 
31697 amit.gupta 488
    @Autowired
489
    private RestClient restClient;
29308 tejbeer 490
 
31697 amit.gupta 491
    @Autowired
492
    private MandiiService mandiiService;
29814 tejbeer 493
 
31697 amit.gupta 494
    @Autowired
495
    CreditAccountRepository creditAccountRepository;
31604 tejbeer 496
 
31697 amit.gupta 497
    @Autowired
498
    CustomerOfferRepository customerOfferRepository;
31612 tejbeer 499
 
31697 amit.gupta 500
    @Autowired
501
    CustomerOfferItemRepository customerOfferItemRepository;
502
    @Autowired
503
    private FofoSolr fofoSolr;
23724 amit.gupta 504
 
25300 tejbeer 505
 
31697 amit.gupta 506
    private static final Logger LOGGER = LogManager.getLogger(ScheduledTasks.class);
31388 amit.gupta 507
 
34039 vikas.jang 508
    private String FCM_URL = "https://fcm.googleapis.com/v1/projects/api-project-309385327230/messages:send";
509
    private String FCM_SCOPED = "https://www.googleapis.com/auth/cloud-platform";
23724 amit.gupta 510
 
31697 amit.gupta 511
    @Autowired
512
    private TagListingRepository tagListingRepository;
33994 amit.gupta 513
    @Autowired
514
    private RunOnceTasks runOnceTasks;
23724 amit.gupta 515
 
31697 amit.gupta 516
    public void generateDailyRecharge() {
31886 tejbeer 517
        List<RechargeProviderCreditWalletHistory> allCreditHistory = rechargeProviderCreditWalletHistoryRepository.selectAll(0, 2000);
31697 amit.gupta 518
        List<RechargeProvider> rechargeProviders = rechargeProviderRepository.selectAll();
519
        rechargeProviders.stream().forEach(x -> x.setAmount(0));
23724 amit.gupta 520
 
31697 amit.gupta 521
        rechargeProviders.stream().forEach(x -> {
31886 tejbeer 522
            Map<LocalDate, List<RechargeProviderCreditWalletHistory>> dateWiseProviderCreditsMap = allCreditHistory.stream().filter(z -> z.getProviderId() == x.getId()).collect(groupingBy(x1 -> x1.getReceiveTimestamp().toLocalDate()));
23724 amit.gupta 523
 
31697 amit.gupta 524
            LOGGER.info("dateWiseProviderCreditsMap -{}", dateWiseProviderCreditsMap);
525
            LocalDate endDate = LocalDate.now().plusDays(1);
526
            float previousDayClosing = 0;
527
            LocalDate date = LocalDate.of(2018, 4, 6);
528
            while (date.isBefore(endDate)) {
31886 tejbeer 529
                List<RechargeTransaction> dateWiseRechargeTransactions = rechargeTransactionRepository.selectAllBetweenTimestamp(Arrays.asList(RechargeStatus.values()), date.atStartOfDay(), date.plusDays(1).atStartOfDay());
23724 amit.gupta 530
 
31886 tejbeer 531
                List<RechargeTransaction> successfulTransactions = dateWiseRechargeTransactions.stream().filter(y -> y.getStatus().equals(RechargeStatus.SUCCESS)).collect(Collectors.toList());
23724 amit.gupta 532
 
31697 amit.gupta 533
                float dailyAmount = 0;
534
                float totalCommission = 0;
535
                for (RechargeTransaction rechargeTransaction : successfulTransactions) {
536
                    if (rechargeTransaction.getProviderId() == x.getId()) {
537
                        dailyAmount += rechargeTransaction.getAmount();
538
                        totalCommission += rechargeTransaction.getCommission();
539
                    }
540
                }
28205 tejbeer 541
 
31697 amit.gupta 542
                List<RechargeProviderCreditWalletHistory> rechargeHistoryList = dateWiseProviderCreditsMap.get(date);
543
                float dailyWalletRecharge = 0;
544
                if (rechargeHistoryList != null) {
545
                    for (RechargeProviderCreditWalletHistory rechargeProviderCreditWalletHistory : rechargeHistoryList) {
546
                        if (rechargeProviderCreditWalletHistory.getProviderId() == x.getId()) {
547
                            dailyWalletRecharge += rechargeProviderCreditWalletHistory.getAmount();
548
                        }
549
                    }
550
                }
551
                if (dailyAmount > 0 || dailyWalletRecharge > 0) {
552
                    DailyRecharge dailyRecharge = null;
553
                    try {
554
                        dailyRecharge = dailyRechargeRepository.selectByProviderIdAndCreateDate(x.getId(), date);
555
                    } catch (Exception e) {
556
                        LOGGER.info("Could not find Recharge entry");
557
                    }
558
                    if (dailyRecharge == null) {
559
                        dailyRecharge = new DailyRecharge();
560
                        dailyRecharge.setCreateDate(date);
561
                    }
562
                    dailyRecharge.setOpeningBalance(previousDayClosing);
563
                    dailyRecharge.setProviderId(x.getId());
564
                    dailyRecharge.setWalletRechargeAmount(dailyWalletRecharge);
565
                    dailyRecharge.setTotalAmount(dailyAmount);
566
                    dailyRecharge.setTotalCommission(totalCommission);
567
                    float closingBalance = dailyRecharge.getOpeningBalance() + dailyWalletRecharge - dailyAmount;
568
                    dailyRecharge.setClosingBalance(closingBalance);
569
                    dailyRechargeRepository.persist(dailyRecharge);
570
                    x.setAmount(x.getAmount() + dailyRecharge.getClosingBalance() - dailyRecharge.getOpeningBalance());
571
                    previousDayClosing = dailyRecharge.getClosingBalance();
572
                }
573
                date = date.plusDays(1);
574
            }
575
            rechargeProviderRepository.persist(x);
576
        });
577
        LOGGER.info("finished generating daily recharge");
578
    }
24240 amit.gupta 579
 
31697 amit.gupta 580
    public void reconcileRecharge() throws Exception {
581
        LocalDateTime fromDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS).minusDays(30);
582
        LocalDateTime toDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS);
583
        List<RechargeStatus> nonSuccessRechargeStatuses = new ArrayList<>(Arrays.asList(RechargeStatus.values()));
584
        LOGGER.info("nonSuccessRechargeStatuses {} ", nonSuccessRechargeStatuses);
585
        nonSuccessRechargeStatuses.remove(RechargeStatus.SUCCESS);
586
        nonSuccessRechargeStatuses.remove(RechargeStatus.FAILED);
587
        RechargeCredential thinkWalnutDigitalRechargeEnquiryCredential = new RechargeCredential();
588
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeUrl(thinkWalnutDigitalRechargeEnquiryUrl);
589
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeUserName(thinkWalnutDigitalRechargeUserName);
590
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargePassword(thinkWalnutDigitalRechargePassword);
591
        thinkWalnutDigitalRechargeEnquiryCredential.setRechargeAuthKey(thinkWalnutDigitalRechargeAuthKey);
592
        Map<String, RechargeStatus> requestRechargeStatusChanged = new HashMap<>();
31886 tejbeer 593
        List<RechargeTransaction> rechargeTransactions = rechargeTransactionRepository.selectAllBetweenTimestamp(nonSuccessRechargeStatuses, fromDate, toDate);
31697 amit.gupta 594
        for (RechargeTransaction rechargeTransaction : rechargeTransactions) {
595
            try {
596
                int providerId = rechargeTransaction.getProviderId();
597
                if (providerId == 1) {
31886 tejbeer 598
                    oxigenRechargeProviderService.doCheckStatusRequest(oxigenRechargeEnquiryUrl, oxigenRechargeAuthKey, rechargeTransaction);
31697 amit.gupta 599
                } else if (providerId == 2) {
31886 tejbeer 600
                    thinkWalnutDigitalRechargeProviderService.doCheckStatusRequest(thinkWalnutDigitalRechargeEnquiryCredential, rechargeTransaction);
31697 amit.gupta 601
                }
31886 tejbeer 602
                if (rechargeTransaction.getStatus().equals(RechargeStatus.SUCCESS) || rechargeTransaction.getStatus().equals(RechargeStatus.FAILED)) {
603
                    requestRechargeStatusChanged.put(rechargeTransaction.getRequestId(), rechargeTransaction.getStatus());
31697 amit.gupta 604
                }
605
            } catch (Exception e) {
606
                LOGGER.info("Could not check status for Request {}", rechargeTransaction.getRequestId());
607
            }
608
        }
609
        LOGGER.info("Reconcile recharge ran successfully");
610
    }
24241 amit.gupta 611
 
31697 amit.gupta 612
    public void processActivation() throws Exception {
613
        schemeService.processActivation();
614
    }
24241 amit.gupta 615
 
31697 amit.gupta 616
    // TemporaryMethod
617
    public void migrateInvoice() {
618
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectFromSaleDate(LocalDateTime.now().minusDays(3));
619
        Map<Integer, List<FofoOrder>> partnerOrdersMap = new HashMap<>();
31886 tejbeer 620
        partnerOrdersMap = fofoOrders.stream().collect(groupingBy(FofoOrder::getFofoId, Collectors.toList()));
31697 amit.gupta 621
        for (List<FofoOrder> orderList : partnerOrdersMap.values()) {
622
            int sequence = 0;
623
            String prefix = "";
31886 tejbeer 624
            List<FofoOrder> sortedList = orderList.stream().sorted((x1, x2) -> x1.getId() - x2.getId()).collect(Collectors.toList());
31697 amit.gupta 625
            for (FofoOrder order : sortedList) {
23724 amit.gupta 626
 
31697 amit.gupta 627
                LOGGER.info("Order Id is {}, partner Id is {}", order.getId(), order.getFofoId());
628
                if (!order.getInvoiceNumber().contains("SEC")) {
629
                    sequence = Integer.parseInt(order.getInvoiceNumber().split("/")[1]);
630
                    prefix = order.getInvoiceNumber().split("/")[0];
631
                } else {
632
                    sequence += 1;
633
                    String invoiceNumber = prefix + "/" + sequence;
634
                    order.setInvoiceNumber(invoiceNumber);
635
                    fofoOrderRepository.persist(order);
636
                }
637
            }
24252 amit.gupta 638
 
31697 amit.gupta 639
        }
640
    }
28205 tejbeer 641
 
31697 amit.gupta 642
    @Autowired
643
    private ReporticoCacheTableRepository reporticoCacheTableRepository;
28205 tejbeer 644
 
31697 amit.gupta 645
    public void processSchemeOut(List<String> invoiceNumbers) throws Exception {
646
        for (String invoiceNumber : invoiceNumbers) {
647
            System.out.println("Invoice Number - " + invoiceNumber);
648
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
32147 amit.gupta 649
            //orderService.reverseScheme(fofoOrder);
31697 amit.gupta 650
            schemeService.processSchemeOut(fofoOrder.getId(), fofoOrder.getFofoId());
651
        }
652
    }
24271 amit.gupta 653
 
31697 amit.gupta 654
    public void processSchemeIn(List<String> invoiceNumbers) throws Exception {
655
        for (String invoiceNumber : invoiceNumbers) {
656
            System.out.println("Invoice Number - " + invoiceNumber);
657
            Purchase purchase = purchaseRepository.selectByPurchaseReference(invoiceNumber);
658
            schemeService.processSchemeIn(purchase.getId(), purchase.getFofoId());
659
        }
660
    }
24271 amit.gupta 661
 
31697 amit.gupta 662
    public void processScheme(LocalDateTime startDate, LocalDateTime endDate, boolean dryRun) throws Exception {
663
        LOGGER.info("Started execution at {}", LocalDateTime.now());
664
        System.out.println(
665
                "InventoryId\tSerialNumber\tItem Id\tScheme Id\tScheme Name\tScheme Type\tAmount Type\tDP\tTaxable\tScheme Amount\tAmount Paid");
666
        try {
667
            List<Purchase> purchases = purchaseRepository.selectAllBetweenPurchaseDate(startDate, endDate);
668
            for (Purchase purchase : purchases) {
669
                schemeService.processSchemeIn(purchase.getId(), purchase.getFofoId());
670
            }
29160 amit.gupta 671
 
31697 amit.gupta 672
            List<FofoOrder> fofoOrders = fofoOrderRepository.selectBetweenSaleDate(startDate, endDate);
673
            for (FofoOrder fofoOrder : fofoOrders) {
674
                schemeService.processSchemeOut(fofoOrder.getId(), fofoOrder.getFofoId());
675
            }
676
        } catch (Exception e) {
677
            e.printStackTrace();
678
            throw e;
679
        }
31886 tejbeer 680
        List<UserWalletHistory> uwhs = userWalletHistoryRepository.selectAllByDateType(LocalDate.now().atStartOfDay(), endDate, Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT));
31697 amit.gupta 681
        System.out.println("Amount\tReference\tReferenceType\tTimestamp\tDescription");
682
        for (UserWalletHistory uwh : uwhs) {
31886 tejbeer 683
            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 684
        }
685
        LOGGER.info("Schemes processed successfully.");
686
        if (dryRun) {
687
            throw new Exception();
688
        }
689
    }
29160 amit.gupta 690
 
31697 amit.gupta 691
    public void processRechargeCashback() throws Throwable {
692
        LocalDateTime cashbackTime = LocalDateTime.now();
693
        int referenceId = (int) Timestamp.valueOf(cashbackTime).getTime() / 1000;
31886 tejbeer 694
        List<RechargeTransaction> pendingTransactions = rechargeTransactionRepository.getPendingCashBackRehargeTransactions();
31697 amit.gupta 695
        Map<Object, Double> totalRetailerCashbacks = pendingTransactions.stream().collect(
31724 amit.gupta 696
                groupingBy(x -> x.getRetailerId(), Collectors.summingDouble(x -> x.getCommission())));
33452 amit.gupta 697
        for (Entry<Object, Double> totalRetailerCashback : totalRetailerCashbacks.entrySet()) {
31697 amit.gupta 698
            int retailerId = (Integer) totalRetailerCashback.getKey();
699
            float amount = totalRetailerCashback.getValue().floatValue();
700
            if (Math.round(amount) > 0) {
31886 tejbeer 701
                walletService.addAmountToWallet(retailerId, referenceId, WalletReferenceType.CASHBACK, "Recharge Cashback", Math.round(amount), LocalDateTime.now());
31697 amit.gupta 702
            }
703
        }
704
        for (RechargeTransaction rt : pendingTransactions) {
705
            rt.setCashbackTimestamp(cashbackTime);
706
            rt.setCashbackReference(referenceId);
707
            rechargeTransactionRepository.persist(rt);
708
        }
709
        LOGGER.info("Cashbacks for Recharge processed Successfully");
710
    }
29160 amit.gupta 711
 
35521 amit 712
    public void rollOutUpgardedMarginsNextMonth(List<Integer> fofoIds) throws Exception {
31697 amit.gupta 713
        LocalDate startOfPreviousMonth = LocalDate.now().with(ChronoField.DAY_OF_MONTH, 1).minusMonths(1);
35521 amit 714
        List<FofoStore> stores;
35530 amit 715
        if (fofoIds == null || fofoIds.isEmpty()) {
35521 amit 716
            stores = fofoStoreRepository.selectActiveStores();
717
        } else {
718
            stores = fofoStoreRepository.selectByRetailerIds(fofoIds);
719
        }
31697 amit.gupta 720
        for (FofoStore store : stores) {
32003 amit.gupta 721
            this.rolloutMarginForStoreOnMonth(store, startOfPreviousMonth);
722
        }
723
    }
29252 amit.gupta 724
 
32003 amit.gupta 725
    public void rolloutMarginForStoreOnMonth(FofoStore store, LocalDate startOfMonth) throws ProfitMandiBusinessException {
726
        int fofoId = store.getId();
29252 amit.gupta 727
 
35531 amit 728
        // Check if there's a manual partner type change on day 1 of the month
729
        PartnerTypeChange day1Change = partnerTypeChangeRepository.selectPartnerType(fofoId, startOfMonth);
730
        if (day1Change != null && day1Change.getSource() == PartnerTypeSource.MANUAL) {
731
            LOGGER.info("Manual partner type upgrade detected for code {} to {}", store.getCode(), day1Change.getPartnerType());
732
            List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startOfMonth.atStartOfDay(), startOfMonth.plusMonths(1).atStartOfDay(), 0, 0);
733
            for (FofoOrder fofoOrder : fofoOrders) {
734
                schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
735
            }
736
            return;
737
        }
738
 
739
        // Existing logic for calculated upgrades
32003 amit.gupta 740
        PartnerType startOfPreviousMonthPartnerType = partnerTypeChangeService.getTypeOnDate(fofoId, startOfMonth);
34777 amit.gupta 741
        PartnerType todayPartnerType = partnerTypeChangeService.getTypeOnMonth(fofoId, YearMonth.from(startOfMonth));
32003 amit.gupta 742
        if (!startOfPreviousMonthPartnerType.nextPartnerTypes().contains(todayPartnerType)) {
743
            return;
744
        }
745
        if (!startOfPreviousMonthPartnerType.equals(todayPartnerType)) {
746
            LOGGER.info("Partner Type has been changed for code {} from {} to {}", store.getCode(), startOfPreviousMonthPartnerType, todayPartnerType);
747
            List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startOfMonth.atStartOfDay(), startOfMonth.plusMonths(1).atStartOfDay(), 0, 0);
748
            for (FofoOrder fofoOrder : fofoOrders) {
749
                schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
31697 amit.gupta 750
            }
751
        }
752
    }
29252 amit.gupta 753
 
32003 amit.gupta 754
 
35521 amit 755
    public void rollOutUpgardedMargins(List<Integer> fofoIds) throws Exception {
31697 amit.gupta 756
        LocalDate today = LocalDate.now();
757
        LocalDate yesterday = today.minusDays(1);
758
        int upgradedCount = 0;
35521 amit 759
        List<FofoStore> stores;
760
        if (fofoIds == null || fofoIds.isEmpty()) {
761
            stores = fofoStoreRepository.selectActiveStores();
762
        } else {
763
            stores = fofoStoreRepository.selectByRetailerIds(fofoIds);
764
        }
35461 amit 765
 
766
        // Bulk fetch partner types to avoid N+1 queries
767
        Map<Integer, PartnerType> yesterdayTypeMap = partnerTypeChangeService.getTypesForFofoIds(fofoIds, yesterday);
768
        Map<Integer, PartnerType> todayTypeMap = partnerTypeChangeService.getTypesForFofoIds(fofoIds, today);
769
 
31697 amit.gupta 770
        StringBuilder sb = new StringBuilder();
771
        for (FofoStore store : stores) {
772
            int fofoId = store.getId();
23724 amit.gupta 773
 
35461 amit 774
            PartnerType yesterdayPartnerType = yesterdayTypeMap.get(fofoId);
775
            PartnerType todayPartnerType = todayTypeMap.get(fofoId);
776
            if (yesterdayPartnerType == null || todayPartnerType == null) {
777
                continue;
778
            }
31697 amit.gupta 779
            if (!yesterdayPartnerType.nextPartnerTypes().contains(todayPartnerType)) {
780
                continue;
781
            }
782
            if (!yesterdayPartnerType.equals(todayPartnerType)) {
783
                upgradedCount++;
31886 tejbeer 784
                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 785
                sb.append("<br>");
31886 tejbeer 786
                LOGGER.info("Partner Type has been changed for code {} from {} to {}", store.getCode(), yesterdayPartnerType, todayPartnerType);
787
                List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, yesterday.withDayOfMonth(1).atStartOfDay(), yesterday.atStartOfDay(), 0, 0);
31697 amit.gupta 788
                for (FofoOrder fofoOrder : fofoOrders) {
789
                    schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
790
                }
30390 amit.gupta 791
 
31697 amit.gupta 792
            }
793
        }
794
        if (upgradedCount > 0) {
36460 ranu 795
            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 796
        } else {
36460 ranu 797
            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 798
        }
799
    }
30393 amit.gupta 800
 
31697 amit.gupta 801
    @Autowired
802
    private PartnerStatsService partnerStatsService;
30393 amit.gupta 803
 
35521 amit 804
// Temporary Method
30393 amit.gupta 805
 
31697 amit.gupta 806
    public void fetchParnterStats() throws Exception {
807
        Map<Integer, PartnerDetailModel> partnerStats = partnerStatsService.getAllPartnerStats();
808
        ObjectOutputStream oos = null;
809
        FileOutputStream fout = null;
810
        try {
34666 ranu 811
//            fout = new FileOutputStream("/tmp/partnerStat.tmp", false);
812
            fout = new FileOutputStream("/var/www/partner_stats/partnerStat.tmp", false);
31697 amit.gupta 813
            oos = new ObjectOutputStream(fout);
814
            oos.writeObject(partnerStats);
30637 amit.gupta 815
 
31697 amit.gupta 816
        } catch (Exception ex) {
817
            ex.printStackTrace();
818
        } finally {
819
            if (oos != null) {
820
                oos.close();
821
            }
822
        }
32421 amit.gupta 823
        ReporticoCacheTable reporticoCacheTable = reporticoCacheTableRepository.selectByTableName("partnerStat");
824
        if (reporticoCacheTable == null) {
825
            reporticoCacheTable = new ReporticoCacheTable();
826
            reporticoCacheTable.setTableName("partnerStat");
827
            reporticoCacheTable.setLastCreatedTimestamp(LocalDateTime.now());
828
            reporticoCacheTableRepository.persist(reporticoCacheTable);
31697 amit.gupta 829
        } else {
32421 amit.gupta 830
            reporticoCacheTable.setLastCreatedTimestamp(LocalDateTime.now());
31697 amit.gupta 831
        }
832
    }
31008 amit.gupta 833
 
31697 amit.gupta 834
    public void processPriceDrop() throws Exception {
31886 tejbeer 835
        List<PriceDrop> priceDrops = priceDropRepository.selectAllByDatesBetween(LocalDateTime.now(), LocalDateTime.now().minusYears(1));
31697 amit.gupta 836
        for (PriceDrop priceDrop : priceDrops) {
837
            if (priceDrop.getDropAmount() > 0) {
838
                priceDropService.processPriceDrop(priceDrop.getId(), true);
839
            }
840
        }
841
    }
31008 amit.gupta 842
 
31697 amit.gupta 843
    @Autowired
844
    CreditNoteService creditNoteService;
25598 amit.gupta 845
 
31697 amit.gupta 846
    public void sendCreditNote(YearMonth yearMonth) throws Exception {
35803 amit 847
        LOGGER.info("Running SendCreditNote for {}", yearMonth.toString());
31697 amit.gupta 848
        creditNoteService.issueMonthlyMarginsCN(yearMonth);
849
    }
25598 amit.gupta 850
 
36220 amit 851
    public void genDNs(YearMonth yearMonth) throws Exception {
852
        LOGGER.info("Running genDNs for {}", yearMonth.toString());
853
        creditNoteService.generateDebitNotesForCancelled(yearMonth);
854
    }
855
 
31918 amit.gupta 856
    @Autowired
857
    BrandAgeingLimitRepository brandAgeingLimitRepository;
858
 
859
    @Autowired
860
    AgeingService ageingService;
861
 
33928 ranu 862
    @Autowired
863
    RbmTargetService rbmTargetService;
864
 
31918 amit.gupta 865
    public void sendMailForAgeingAlert() throws Exception {
866
        //brandAgeingLimitRepository.selectAll();
867
        Map<String, AgeingModel> ageingModelMap = ageingService.getAllAgeingForSecondary();
868
 
869
        System.out.println(ageingModelMap.size());
870
        List<PartnerAgeingModel> partnerAgeingModels = ageingService.getAllAgeingForTertiary();
871
 
872
 
33452 amit.gupta 873
        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 874
 
33452 amit.gupta 875
        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()));
876
        Attachment attachment1 = new Attachment("secondary-alert.csv", new ByteArrayResource(byteArrayOutputStream.toByteArray()));
877
        Attachment attachment2 = new Attachment("tertiary-alert.csv", new ByteArrayResource(byteArrayOutputStream2.toByteArray()));
31918 amit.gupta 878
 
879
        String mailSubject = "Stock ageing Alert";
35959 amit 880
        mailOutboxService.queueMailWithAttachmentsViaGoogle(new String[]{"deena.nath@smartdukaan.com"}, null, mailSubject, "PFA", "ScheduledTasks.sendMailForAgeingAlert", attachment1, attachment2);
31918 amit.gupta 881
    }
882
 
32724 amit.gupta 883
    public void rejectPriceDropsOfApprovedImeis() throws ProfitMandiBusinessException {
32690 amit.gupta 884
        priceDropService.rejectPriceDropsOfApprovedImeis();
885
    }
886
 
33357 amit.gupta 887
    public void processDeductions() {
888
        sidbiService.processDeductions();
889
    }
890
 
35521 amit 891
    public void resetHardLimit() throws ProfitMandiBusinessException {
33904 amit.gupta 892
        sdCreditService.resetHardLimit();
893
    }
894
 
35021 amit 895
    public void testInvoiceFormat() throws ProfitMandiBusinessException {
896
        InvoicePdfModel invoicePdfModel = orderService.getInvoicePdfModel(560280);
897
        //System.out.println(InvoiceFormatter.buildInvoiceLines(invoicePdfModel, InvoiceFormatter.WIDTH_80MM));
898
    }
899
 
35326 amit 900
    public void sendTrialExpiry() {
901
        List<FofoStore> stores = fofoStoreRepository.selectAllTrial();
35521 amit 902
        List<FofoStore> twoDaysToExpiry = stores.stream().filter(x -> x.getTrialEnd().minusDays(2).equals(LocalDate.now())).collect(Collectors.toList());
35326 amit 903
 
35521 amit 904
        List<FofoStore> fiveDaysToExpiry = stores.stream().filter(x -> x.getTrialEnd().minusDays(5).equals(LocalDate.now())).collect(Collectors.toList());
905
        List<FofoStore> expiredToday = stores.stream().filter(x -> x.getTrialEnd().equals(LocalDate.now())).collect(Collectors.toList());
906
        List<FofoStore> expired = stores.stream().filter(x -> x.getTrialEnd().isAfter(LocalDate.now())).collect(Collectors.toList());
35326 amit 907
    }
908
 
34710 amit.gupta 909
    /*public void processCashDiscount() throws ProfitMandiBusinessException {
910
        System.out.println("processing cash discount");
911
        List<Loan> loansSettledYesterday = loanRepository.selectLoansSettledOn(LocalDate.now().minusDays(1));
912
        loansSettledYesterday.addAll(loanRepository.selectLoansSettledOn(LocalDate.now()));
913
        Map<Integer, List<Loan>> partnerSettledLoans = loansSettledYesterday.stream().collect(Collectors.groupingBy(x -> x.getFofoId()));
914
        for (Entry<Integer, List<Loan>> partnerLoans : partnerSettledLoans.entrySet()) {
915
            List<Loan> fullCdLoans = partnerLoans.getValue().stream().filter(x -> x.getInvoiceNumber() != null && x.getDays() <= ProfitMandiConstants.LOAN_PARTIAL_CREDIT_DAYS).collect(toList());
916
            List<Loan> partialCdLoans = partnerLoans.getValue().stream().filter(x -> x.getInvoiceNumber() != null && x.getDays() > ProfitMandiConstants.LOAN_PARTIAL_CREDIT_DAYS &&
917
                    x.getDays() <= ProfitMandiConstants.LOAN_FULL_CREDIT_DAYS).collect(toList());
918
            //List<Loan> noCdLoans = loanRepository.selectLoansDueByDays()
919
            //
920
            for (Loan fullCdLoan : fullCdLoans) {
921
                LOGGER.info("FullCdLoan - {}", fullCdLoan);
922
                schemeService.processFullCD(fullCdLoan.getInvoiceNumber());
923
            }
924
 
925
            for (Loan partialCdLoan : partialCdLoans) {
926
                schemeService.processPartialCD(partialCdLoan.getInvoiceNumber());
927
            }
928
 
929
            *//*for (Loan noCdLoan : noCdLoans) {
930
                schemeService.processNoCD(noCdLoan.getInvoiceNumber());
931
            }*//*
932
        }
933
 
934
    }*/
935
 
31697 amit.gupta 936
    private class SaleRoles {
25598 amit.gupta 937
 
31697 amit.gupta 938
        private List<String> l1;
939
        private List<String> l2;
25598 amit.gupta 940
 
31697 amit.gupta 941
        public SaleRoles() {
942
            l1 = new ArrayList<>();
943
            l2 = new ArrayList<>();
944
        }
25598 amit.gupta 945
 
31697 amit.gupta 946
        public List<String> getL1() {
947
            return l1;
948
        }
25598 amit.gupta 949
 
31697 amit.gupta 950
        public List<String> getL2() {
951
            return l2;
952
        }
26945 amit.gupta 953
 
31697 amit.gupta 954
    }
26945 amit.gupta 955
 
31697 amit.gupta 956
    private class FofoReportingModel {
957
        private String code;
958
        private int fofoId;
959
        private String businessName;
960
        private String territoryManager;
961
        private String regionalManager;
962
        private String businessManager;
26945 amit.gupta 963
 
31697 amit.gupta 964
        public String getCode() {
965
            return code;
966
        }
26945 amit.gupta 967
 
31697 amit.gupta 968
        public void setCode(String code) {
969
            this.code = code;
970
        }
26945 amit.gupta 971
 
31697 amit.gupta 972
        public String getBusinessName() {
973
            return businessName;
974
        }
26945 amit.gupta 975
 
31697 amit.gupta 976
        public void setBusinessName(String businessName) {
977
            this.businessName = businessName;
978
        }
26945 amit.gupta 979
 
31697 amit.gupta 980
        public String getTerritoryManager() {
981
            return territoryManager;
982
        }
26945 amit.gupta 983
 
31697 amit.gupta 984
        public void setTerritoryManager(String territoryManager) {
985
            this.territoryManager = territoryManager;
986
        }
26945 amit.gupta 987
 
31697 amit.gupta 988
        public String getRegionalManager() {
989
            return regionalManager;
990
        }
26945 amit.gupta 991
 
31697 amit.gupta 992
        public void setRegionalManager(String regionalManager) {
993
            this.regionalManager = regionalManager;
994
        }
26945 amit.gupta 995
 
31697 amit.gupta 996
        private ScheduledTasks getOuterType() {
997
            return ScheduledTasks.this;
998
        }
26945 amit.gupta 999
 
31697 amit.gupta 1000
        @Override
1001
        public String toString() {
31886 tejbeer 1002
            return "FofoReportingModel{" + "code='" + code + '\'' + ", fofoId=" + fofoId + ", businessName='" + businessName + '\'' + ", territoryManager='" + territoryManager + '\'' + ", regionalManager='" + regionalManager + '\'' + ", businessManager='" + businessManager + '\'' + '}';
31697 amit.gupta 1003
        }
26945 amit.gupta 1004
 
31697 amit.gupta 1005
        @Override
1006
        public boolean equals(Object o) {
1007
            if (this == o) return true;
1008
            if (o == null || getClass() != o.getClass()) return false;
1009
            FofoReportingModel that = (FofoReportingModel) o;
1010
            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);
1011
        }
26945 amit.gupta 1012
 
31697 amit.gupta 1013
        @Override
1014
        public int hashCode() {
1015
            return Objects.hash(code, fofoId, businessName, territoryManager, regionalManager, businessManager);
1016
        }
26945 amit.gupta 1017
 
31697 amit.gupta 1018
        public String getBusinessManager() {
1019
            return businessManager;
1020
        }
26945 amit.gupta 1021
 
31697 amit.gupta 1022
        public void setBusinessManager(String businessManager) {
1023
            this.businessManager = businessManager;
1024
        }
25351 tejbeer 1025
 
31697 amit.gupta 1026
        public int getFofoId() {
1027
            return fofoId;
1028
        }
25598 amit.gupta 1029
 
31697 amit.gupta 1030
        public void setFofoId(int fofoId) {
1031
            this.fofoId = fofoId;
1032
        }
25598 amit.gupta 1033
 
31697 amit.gupta 1034
    }
26945 amit.gupta 1035
 
31697 amit.gupta 1036
    @Autowired
1037
    WarehouseInventoryItemRepository warehouseInventoryItemRepository;
26945 amit.gupta 1038
 
31746 amit.gupta 1039
    @Autowired
1040
    OfferService offerService;
1041
 
1042
    @Autowired
1043
    PurchaseReturnItemRepository purchaseReturnItemRepository;
1044
 
31918 amit.gupta 1045
    @Autowired
1046
    BrandRegionMappingRepository brandRegionMappingRepository;
1047
 
32161 tejbeer 1048
    @Autowired
1049
    StandAlone standAlone;
32214 jai.hind 1050
    @Autowired
1051
    ItelImeiActivationNewService itelImeiActivationNewService;
32350 amit.gupta 1052
 
1053
    public void checkItelImeiActivationNew(LocalDate date, Integer day) throws Exception {
32063 amit.gupta 1054
        try {
32223 amit.gupta 1055
            itelImeiActivationNewService.checkItelImeiActivationNew(date, day);
32063 amit.gupta 1056
        } catch (Throwable e) {
1057
            throw new Exception(e);
1058
        }
32223 amit.gupta 1059
    }
32062 amit.gupta 1060
 
32511 amit.gupta 1061
    @Autowired
1062
    PurchaseReturnService purchaseReturnService;
1063
 
32682 amit.gupta 1064
    @Autowired
1065
    JavaMailSender javaMailSender;
1066
 
32795 amit.gupta 1067
    @Autowired
1068
    OfferPayoutRepository offerPayoutRepository;
1069
 
1070
    @Autowired
1071
    OfferRepository offerRepository;
1072
 
32817 amit.gupta 1073
    @Autowired
1074
    BluedartAuthService bluedartAuthService;
1075
    @Autowired
1076
    BluedartService bluedartService;
1077
 
1078
    @Autowired
1079
    TransactionRelatedTasks transactionRelatedTasks;
1080
 
32872 amit.gupta 1081
    @Autowired
1082
    PsiSmartService psiSmartService;
32948 amit.gupta 1083
 
32961 amit.gupta 1084
    private void migrateValentine() throws ProfitMandiBusinessException {
1085
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectBetweenSaleDate(LocalDate.now().atStartOfDay(), LocalDateTime.now());
1086
        for (FofoOrder fofoOrder : fofoOrders) {
1087
            orderService.processScratchOffer(fofoOrder);
1088
        }
1089
    }
33051 amit.gupta 1090
 
32990 amit.gupta 1091
    @Autowired
1092
    InvoiceService invoiceService;
1093
 
33384 amit.gupta 1094
    @Autowired
1095
    WarehouseService warehouseService;
1096
 
33452 amit.gupta 1097
    @Autowired
1098
    GenericRepository genericRepository;
1099
 
1100
    @Autowired
1101
    PriceCircularService priceCircularService;
1102
 
34611 ranu 1103
    /*@Autowired
1104
    RedisCacheManager redisFortnightlyCacheManage;*/
33638 amit.gupta 1105
 
1106
    @Autowired
1107
    GstProAuthService gstProAuthService;
33664 amit.gupta 1108
 
33817 amit.gupta 1109
    @Autowired
1110
    GstProService gstProService;
1111
 
1112
    @Autowired
1113
    WarehouseProviderRepository warehouseProviderRepository;
33928 ranu 1114
 
34160 tejus.loha 1115
    @Autowired
1116
    LoiFormRepository loiFormRepository;
1117
    @Autowired
1118
    PartnerOnBoardingPanelRepository partnerOnBoardingPanelRepository;
1119
    @Autowired
1120
    StoreTimelineTatService storeTimelineTatService;
1121
    @Autowired
1122
    PartnerDealerRepository partnerDealerRepository;
33664 amit.gupta 1123
 
34275 tejus.loha 1124
    @Autowired
1125
    PurSaleService purSaleService;
1126
 
34502 amit.gupta 1127
    @Autowired
1128
    CatalogRepository catalogRepository;
1129
 
35021 amit 1130
    @Autowired
1131
    AbmReportSender abmReportSender;
34510 amit.gupta 1132
 
35021 amit 1133
    public void sendOverDueReport() {
1134
        List<Loan> loans = loanRepository.selectAllActiveLoan();
35521 amit 1135
        Map<Integer, List<Loan>> partnerLoansMap = loans.stream().filter(x -> x.isOverdue()).collect(Collectors.groupingBy(x -> x.getFofoId()));
35021 amit 1136
        //sdCreditService.getDueDateCrossLoan()
35521 amit 1137
        partnerLoansMap.entrySet().stream().forEach(x -> {
34858 amit 1138
 
35021 amit 1139
            x.getKey();
1140
            x.getValue().size();
1141
        });
34858 amit 1142
 
35021 amit 1143
    }
1144
 
35295 amit 1145
    @Autowired
1146
    OnBoardingRelatedSchelduleTask onBoardingRelatedSchelduleTask;
1147
 
1148
    @Autowired
1149
    Migrations migrations;
1150
 
1151
    /*@Autowired
1152
    BenowService benowService;*/
1153
 
1154
    @Autowired
1155
    TrialFormRepository trialFormRepository;
1156
 
1157
    @Autowired
1158
    CreditBlockedExceptionPartnersRepository creditBlockedExceptionPartnersRepository;
1159
 
1160
    @Autowired
1161
    SDCreditService sdCreditService;
1162
 
35393 amit 1163
    @Autowired
35666 vikas 1164
    PinelabsAffordabilityService pinelabsAffordabilityService;
35393 amit 1165
 
1166
    @Autowired
35666 vikas 1167
    PinelabsAuthService pinelabsAuthService;
35521 amit 1168
 
35666 vikas 1169
    @Autowired
1170
    PinelabsOfferCacheService pinelabsOfferCacheService;
1171
 
35788 vikas 1172
    @Autowired
1173
    ShopifyProductSyncService shopifyProductSyncService;
1174
 
35666 vikas 1175
    /**
1176
     * Caches pinelabs offers for all active items in Redis.
1177
     * Call this method from your cron job to pre-populate the cache.
1178
     */
1179
    public void cachePinelabsOffers() {
1180
        pinelabsOfferCacheService.cacheAllItemOffers();
1181
    }
1182
 
35788 vikas 1183
    public void syncProductsToShopifyByWarehouseId(int warehouseId) throws Exception {
1184
        shopifyProductSyncService.syncByWarehouse(warehouseId);
1185
    }
1186
 
1187
    public void syncInventoryToShopifyByWarehouseId(int warehouseId) throws Exception {
1188
        shopifyProductSyncService.syncInventory(warehouseId);
1189
    }
1190
 
35393 amit 1191
    public void testAffordability() {
1192
        Money orderAmount = new Money("1000000", "INR");
1193
        Money discountAmount = new Money("0", "INR");
1194
        List<ProductDetails> productDetails = Arrays.asList(new ProductDetails(orderAmount, discountAmount, "Alpha_2"));
1195
        OfferDiscoveryRequest offerDiscoveryRequest = new com.spice.profitmandi.service.integrations.pinelabs.dto.OfferDiscoveryRequest(orderAmount, productDetails, new AffordabilityIssuer("12345678"));
1196
        OfferDiscoveryResponse offerDiscoveryResponse = pinelabsAffordabilityService.discoverOffers(offerDiscoveryRequest);
1197
        System.out.println(offerDiscoveryResponse);
1198
    }
35521 amit 1199
 
35021 amit 1200
    public void test() throws Exception {
35393 amit 1201
 
36034 amit 1202
        //System.out.println(pinelabsAuthService.getAccessToken());
1203
        //testAffordability();
35393 amit 1204
 
35295 amit 1205
        //System.out.println(trialFormRepository.selectByEmailOrMobile("9990381568"));
1206
        /*CreditBlockedExceptionPartner creditBlockedExceptionPartner = creditBlockedExceptionPartnersRepository.select(175139430);
1207
        System.out.println(creditBlockedExceptionPartner);*/
35330 amit 1208
        //this.updatePartnerLimit(175139595);
36430 amit 1209
        this.fixStuckLimitBlocks(9999);
1210
        //this.regenerateDCInvoices();
36042 amit 1211
        //this.releaseBlockedLimit();
35326 amit 1212
        //sdCreditService.resetHardLimit();
35295 amit 1213
        //migrations.migrateSerialInvoiceMap();
35151 amit 1214
        //runOnceTasks.checkRewardsEligibility();
35295 amit 1215
        //hybridEncryptor.getJwt();
1216
        /*System.out.printf("Date|Transaction Id|Serial Number|Sale Amount|Swipe Payout|Discount Payout%n");
1217
        for(int i=0;i<10;i++){
1218
            benowService.parseBenowTransaction(LocalDate.now().minusDays(i));
1219
        }*/
1220
        //onBoardingRelatedSchelduleTask.onboardingEventDelays();
35177 amit 1221
        //runOnceTasks.migrateLimit();866009067657118
1222
        //TODO -- Sales Return Pending
1223
        //runOnceTasks.moveSaleReturnScanToDoa("866009067657118");
35295 amit 1224
        //runOnceTasks.sendCreditExposureReport();
35177 amit 1225
        //runOnceTasks.moveDoaScanToSaleReturn("868770072438608");
35150 vikas 1226
        //runOnceTasks.purchasePolicy();
35105 vikas 1227
        //purSaleService.moreThen10DaysEgedStockReport();
35102 amit 1228
        //System.out.println(schemeService.testRedis(1, 2L));
1229
        //System.out.println(schemeService.testRedis(1, null));
35177 amit 1230
        // abmReportSender.sendAbmSmartCartReport();
1231
        //this.sendOverDueReport();
35053 amit 1232
        /*List<Integer> orderIds = Arrays.asList(1929879,1932372,1932377,1932386,1932396,1935221,1935563,1935564,1945144,1955256,1955271,1955294,1961255,1961256,1972821,1972823,1972824,1972825,1972826,1974250,1974252,1974253,1974254,1974255,1974256,1974242,1974244,1974245,1974246,1974247,1974248,1976610,1978095,1978136,1978130,1978174,1978156,1978158,1978167,1978169,1978160,1978179,1978175,1978180,1978201,1978200,1978202,1978192,1978198,1978207,1978204,1978457,1979781,1979783,1979784,1979787,1982412,1982413,1986531,1986532,1986533,1991006,1991628,1991629,2016001,2018921,2042948,2047031,2058500,2058522,2058519,2058520,2058546,2058559,2058568,2058575,2058574,2058598,2058594,2058618,2058633,2066491,2067110,2067113,2067118,2067120,2067123,2067132,2067125,2067127,2069974,2069970,2069976,2069985,2069987);
35021 amit 1233
        for (Integer orderId : orderIds) {
1234
            System.out.println("Refund Started - " + orderId);
1235
            orderRepository.refundOrder(orderId, "vinay.p", "Long awaited cancellation", OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY);
1236
            System.out.println("Refund Ended");
35053 amit 1237
        }*/
1238
        //System.out.println(warehouseSupplierInvoiceRepository.selectWarehouseItemAgeing(LocalDateTime.now().minusDays(10), LocalDateTime.now(), null, 0, null));
35102 amit 1239
        /*Offer offer = offerRepository.selectById(6820);
1240
        offerService.sendWhatsapp(offer, Arrays.asList(175140233),"https://images.smartdukaan.com/uploads/campaigns/image2025-09-24/offer-6820.png");*/
1241
        /*List<String> invoices = Arrays.asList("NSDLNOI16527","NSDLNOI16366", "NSDLNOI16394", "NSDLNOI16460");
35056 amit 1242
        List<Loan> loans = new ArrayList<>();
1243
        for (String invoice : invoices) {
1244
            loans.add(loanRepository.selectLoanByInvoice(invoice));
1245
        }
1246
        loans.stream().sorted(Comparator.comparing(x->x.getCreatedOn())).forEach(x-> {
1247
            try {
1248
                sdCreditService.settleLoan(x);
1249
            } catch (ProfitMandiBusinessException e) {
1250
                throw new RuntimeException(e);
1251
            }
35102 amit 1252
        });*/
36460 ranu 1253
        //Utils.sendMailWithAttachments(googleMailSender, new String[]{"amit.gupta@smartdukaan.com"}, null, "DTDC AWb", "PFA");*/
33452 amit.gupta 1254
    }
1255
 
36039 amit 1256
    private void regenerateDCInvoices() {
1257
        List<String> dcInvoiceNumbers = Arrays.asList(
1258
                "DCNSUPDL5", "DCNSUPDL4", "DCNSLCK2", "DCNSUPDL3",
1259
                "DCNSUPDL2", "DCNSUPDL1", "DCNSLCK1");
1260
        for (String invoiceNumber : dcInvoiceNumbers) {
1261
            try {
1262
                List<Order> orders = orderRepository.selectByInvoiceNumber(invoiceNumber);
1263
                if (!orders.isEmpty()) {
36046 amit 1264
                    invoiceService.saveInvoice(orders);
1265
                    System.out.println("Regenerated DC: " + invoiceNumber);
36039 amit 1266
                }
1267
            } catch (Exception e) {
1268
                System.out.println("Failed to regenerate DC: " + invoiceNumber + " - " + e.getMessage());
1269
            }
1270
        }
1271
    }
1272
 
35330 amit 1273
    private void releaseBlockedLimit() throws ProfitMandiBusinessException {
1274
        List<Loan> blockedLoans = loanRepository.selectAllBlockedLoans();
1275
        for (Loan blockedLoan : blockedLoans) {
1276
            LoanTransaction loanTransaction = loanTransactionRepository.selectByLoanId(blockedLoan.getId());
1277
            int transactionId = loanTransaction.getTransactionId();
1278
            List<UserWalletHistory> userWalletHistory = walletService.getAllByReference(blockedLoan.getFofoId(), transactionId, WalletReferenceType.PURCHASE);
35521 amit 1279
            int amount = userWalletHistory.get(userWalletHistory.size() - 1).getAmount();
35330 amit 1280
            int loanAmount = blockedLoan.getIntialAmount().intValue();
35521 amit 1281
            if (loanAmount > -amount) {
1282
                sdCreditService.settleBlockedLoan(transactionId, loanAmount + amount);
35330 amit 1283
            }
1284
 
1285
 
1286
        }
1287
    }
1288
 
34731 amit.gupta 1289
    @Autowired
1290
    LoanTransactionRepository loanTransactionRepository;
1291
 
1292
    private void fixBlockedCredit() throws ProfitMandiBusinessException {
35877 amit 1293
        List<Loan> unsettledBlockedLoans = loanRepository.selectAllBlockedLoans();
34731 amit.gupta 1294
        //unsettledBlockedLoans = unsettledBlockedLoans.stream().filter(x -> x.getId() == 52310).collect(toList());
1295
        for (Loan unsettledBlockedLoan : unsettledBlockedLoans) {
1296
            LoanTransaction loanTransaction = loanTransactionRepository.selectByLoanId(unsettledBlockedLoan.getId());
1297
            if (loanTransaction == null) {
1298
                System.out.println("Cant find Transaction Id for Loan - " + unsettledBlockedLoan.getId() + "-- Created On ->" + unsettledBlockedLoan.getCreatedOn());
1299
                continue;
1300
            }
1301
            List<Order> processedOrders = orderRepository.selectAllByTransactionId(loanTransaction.getTransactionId()).stream()
1302
                    .filter(x -> !x.getStatus().equals(OrderStatus.SUBMITTED_FOR_PROCESSING)).collect(toList());
1303
            List<OrderStatus> processedOrderIds = processedOrders.stream().map(x -> x.getStatus()).collect(Collectors.toList());
1304
            System.out.println("processedOrderIds " + processedOrderIds);
1305
            //if(unsettledBlockedLoan !=null) continue;
1306
            double limitToRelease = processedOrders.stream().collect(Collectors.summingDouble(x -> x.getWalletAmount()));
1307
            sdCreditService.releaseBlockedLimit(unsettledBlockedLoan, limitToRelease);
1308
 
1309
 
1310
        }
1311
    }
1312
 
36430 amit 1313
    private void fixStuckLimitBlocks(int maxFixes) {
1314
        LocalDate fromDate = LocalDate.of(2026, 4, 27);
1315
        LocalDate toDate = LocalDate.of(2026, 4, 29);
1316
 
1317
        List<Loan> allBlockedLoans = loanRepository.selectAllBlockedLoans();
1318
        List<Loan> stuckLoans = allBlockedLoans.stream()
1319
                .filter(l -> {
1320
                    LocalDate created = l.getCreatedOn().toLocalDate();
1321
                    return !created.isBefore(fromDate) && !created.isAfter(toDate);
1322
                })
1323
                .collect(toList());
1324
 
1325
        System.out.println("Found " + stuckLoans.size() + " stuck limit blocks between " + fromDate + " and " + toDate);
1326
        System.out.println("Max fixes this run: " + maxFixes);
1327
 
1328
        int fixed = 0, skipped = 0, failed = 0;
1329
        for (Loan blockedLoan : stuckLoans) {
1330
            if (fixed >= maxFixes) {
1331
                System.out.println("Reached max fixes limit (" + maxFixes + "), stopping.");
1332
                break;
1333
            }
1334
 
1335
            try {
1336
                LoanTransaction loanTransaction = loanTransactionRepository.selectByLoanId(blockedLoan.getId());
1337
                if (loanTransaction == null) {
1338
                    System.out.println("SKIP loan " + blockedLoan.getId() + " - no LoanTransaction found");
1339
                    skipped++;
1340
                    continue;
1341
                }
1342
                int transactionId = loanTransaction.getTransactionId();
1343
                List<Order> billedOrders = orderRepository.selectAllByTransactionId(transactionId).stream()
1344
                        .filter(o -> o.getBillingTimestamp() != null && o.getRefundTimestamp() == null)
1345
                        .collect(toList());
1346
 
1347
                if (billedOrders.isEmpty()) {
1348
                    System.out.println("SKIP loan " + blockedLoan.getId() + " txn " + transactionId + " - no billed orders");
1349
                    skipped++;
1350
                    continue;
1351
                }
1352
 
1353
                Map<String, List<Order>> byInvoice = billedOrders.stream()
1354
                        .filter(o -> o.getInvoiceNumber() != null)
1355
                        .collect(Collectors.groupingBy(Order::getInvoiceNumber));
1356
 
1357
                for (Map.Entry<String, List<Order>> entry : byInvoice.entrySet()) {
1358
                    String invoiceNumber = entry.getKey();
1359
                    double invoiceAmount = entry.getValue().stream().mapToDouble(Order::getWalletAmount).sum();
1360
 
1361
                    Loan existingLoan = loanRepository.selectLoanByInvoice(invoiceNumber);
1362
                    if (existingLoan != null) {
1363
                        System.out.println("SKIP loan " + blockedLoan.getId() + " invoice " + invoiceNumber + " - loan already exists (id=" + existingLoan.getId() + ")");
1364
                        continue;
1365
                    }
1366
 
1367
                    System.out.println("FIX loan " + blockedLoan.getId() + " fofo " + blockedLoan.getFofoId() + " txn " + transactionId + " invoice " + invoiceNumber + " invoiceAmt " + invoiceAmount + " pending " + blockedLoan.getPendingAmount());
1368
                    sdCreditService.createLoanForBilling(transactionId, invoiceAmount, invoiceNumber);
1369
                    fixed++;
1370
                }
1371
            } catch (Exception e) {
1372
                System.out.println("FAIL loan " + blockedLoan.getId() + " fofo " + blockedLoan.getFofoId() + " - " + e.getMessage());
1373
                e.printStackTrace();
1374
                failed++;
1375
            }
1376
        }
1377
        System.out.println("Done. fixed=" + fixed + " skipped=" + skipped + " failed=" + failed);
1378
    }
1379
 
1380
    private void compensateAlreadyFixedLoans() {
1381
        int[] alreadyFixedLoanIds = {106138, 106139, 106140, 106141, 106142, 106143, 106144, 106145, 106146, 106147};
1382
        System.out.println("Compensating " + alreadyFixedLoanIds.length + " already-fixed loans");
1383
 
1384
        int done = 0, failed = 0;
36472 amit 1385
 
36430 amit 1386
        for (int loanId : alreadyFixedLoanIds) {
1387
            try {
1388
                Loan loan = loanRepository.selectByLoanId(loanId);
1389
                if (loan == null) {
1390
                    System.out.println("SKIP compensate loan " + loanId + " - not found");
1391
                    continue;
1392
                }
1393
                double compensateAmount = loan.getIntialAmount().doubleValue();
1394
                String compensateDesc = "Compensating double credit - forced loan " + loan.getId() + " against invoice " + loan.getInvoiceNumber();
1395
                walletService.consumeAmountFromWallet(loan.getFofoId(), loan.getId(),
1396
                        WalletReferenceType.CREDIT_UTILIZED, compensateDesc, (float) compensateAmount, LocalDateTime.now());
1397
                System.out.println("COMPENSATE fofo " + loan.getFofoId() + " loan " + loan.getId() + " amount -" + compensateAmount);
1398
 
1399
                String forcedLoanReason = "Forced loan against invoice " + loan.getInvoiceNumber() + " (limit fix)";
1400
                Loan forcedLoan = sdCreditService.createLoan(loan.getFofoId(), compensateAmount, loan.getFreeDays(), forcedLoanReason);
1401
                System.out.println("FORCED LOAN fofo " + loan.getFofoId() + " loan " + forcedLoan.getId() + " amount " + compensateAmount + " freeDays " + loan.getFreeDays());
1402
                done++;
1403
            } catch (Exception e) {
1404
                System.out.println("FAIL compensate loan " + loanId + " - " + e.getMessage());
1405
                e.printStackTrace();
1406
                failed++;
1407
            }
1408
        }
1409
        System.out.println("Compensate done. done=" + done + " failed=" + failed);
1410
    }
1411
 
34710 amit.gupta 1412
    public static byte[] toByteArray(InputStream input) throws IOException {
1413
        ByteArrayOutputStream buffer = new ByteArrayOutputStream();
1414
        int nRead;
1415
        byte[] data = new byte[16384];
1416
        while ((nRead = input.read(data, 0, data.length)) != -1) {
1417
            buffer.write(data, 0, nRead);
1418
        }
1419
        return buffer.toByteArray();
1420
    }
1421
 
34547 vikas.jang 1422
    private void whatsappTest() throws Exception {
34603 ranu 1423
        //liquidationService.processBids(ProfitMandiConstants.BID_CRON_ENUM.TODAY);
35959 amit 1424
        mailOutboxService.queueMailViaGoogle(new String[]{"ranu.rajput@smartdukaan.com"}, null, "Test Mail", "Mail is working", "ScheduledTasks.whatsappTest");
34532 amit.gupta 1425
    }
1426
 
34510 amit.gupta 1427
    private void debitLoanAmountFromWallet() {
1428
        List l1 = Arrays.asList(1234, 1420, 2694, 8129, 12182, 12880, 16289, 16462, 16551, 16625, 16819, 17606, 18902, 19152, 19663, 22409, 22410, 23924, 24058, 24206, 24215, 24220, 24459, 25977, 30585, 31590);
1429
        l1.addAll(Arrays.asList(11849, 12702, 14554, 14643, 19166, 19638, 32824, 33467, 33954, 34017, 34514, 35128, 35229, 35355, 36007, 36351, 36435, 36586, 36608, 36612, 36665, 37076, 37495, 37678, 38519, 38563, 38638, 38690, 38815, 38840, 39015, 39084, 39142, 39379, 39384, 39586, 39636, 39657, 39755, 39788, 39908, 40054, 40220, 40534, 41731, 41962, 42692));
1430
        l1.addAll(Arrays.asList());
1431
    }
1432
 
33452 amit.gupta 1433
    public void test4() throws Exception {
1434
        List<Integer> offerIds = Arrays.asList(2882, 2881, 2880, 2879, 2878, 2877, 2876, 2875, 2874, 2873, 2872, 2871, 2870, 2869, 2868, 2867, 2866, 2865, 2864, 2863, 2862, 2861, 2860, 2859, 2858, 2857, 2856, 2855, 2854, 2853, 2852, 2851, 2850, 2849, 2847, 2846, 2845, 2844, 2843, 2842, 2841, 2840, 2839, 2838, 2837, 2836, 2835, 2834, 2833, 2832, 2831, 2830, 2829, 2828, 2827, 2826, 2825, 2824, 2823, 2822, 2821, 2820, 2819, 2818, 2817, 2816, 2815, 2814, 2813, 2812, 2811, 2810, 2809, 2808, 2807, 2806, 2805, 2804, 2803, 2802, 2801, 2800, 2799, 2798, 2797, 2796, 2795, 2794, 2793, 2792, 2791, 2790, 2789, 2788, 2787, 2786, 2785, 2784, 2783, 2782, 2781, 2780, 2777, 2776, 2775, 2774, 2773, 2772, 2771, 2770, 2769, 2768, 2767, 2766, 2765, 2764, 2763, 2762, 2761, 2760, 2759, 2758, 2757, 2756, 2755, 2754, 2753, 2752, 2751, 2750, 2749, 2748, 2747, 2746, 2745, 2744, 2723, 2722, 2721, 2720, 2719, 2718, 2717, 2716, 2715, 2714, 2713, 2712, 2711, 2710, 2709, 2708, 2707, 2706, 2705, 2704, 2703, 2702, 2701, 2700, 2699, 2698, 2697, 2696, 2695, 2694, 2693, 2692, 2691, 2690, 2494, 2493, 2492, 2491, 2490, 2489, 2488, 2487, 2486, 2485, 2484, 2483, 2482, 2481, 2480, 2479, 2478, 2477, 2476, 2475, 2474, 2473, 2472, 2471, 2470, 2469, 2466, 2465, 2464, 2463, 2462, 2461, 2460, 2459, 2458, 2457, 2456, 2455, 2454, 2453, 2452, 2451, 2450, 2449, 2448, 2447, 2446, 2445, 2444, 2443, 2442, 2441, 2440, 2439, 2407, 2406, 2405, 2404, 2403, 2402, 2401, 2400, 2399, 2398, 2397, 2396, 2395, 2394, 2393, 2392, 2391, 2390, 2389, 2388, 2387, 2386, 2385, 2384, 2383, 2382, 2381, 2117, 2116, 2115, 2114, 2113, 2112, 2111, 2110, 2109, 2108, 2107, 2106, 2105, 2104, 2103, 2102, 2101, 2100, 2099, 2098, 2077);
1435
        for (Integer offerId : offerIds) {
1436
            Offer fromOffer = offerRepository.selectById(offerId);
1437
            CreateOfferRequest createOfferRequest = offerService.getCreateOfferRequest(fromOffer);
1438
            System.out.println("Processing offer Id " + fromOffer);
1439
            offerService.processActivationtOffer(createOfferRequest);
1440
        }
34160 tejus.loha 1441
 
33433 amit.gupta 1442
        this.processSidbiDeductions();
32817 amit.gupta 1443
    }
1444
 
1445
    public void test3() throws Exception {
1446
        List<Long> payoutIds = Arrays.asList();
32795 amit.gupta 1447
        List<OfferPayout> offerPayouts = offerPayoutRepository.selectAllByIds(payoutIds);
33452 amit.gupta 1448
        Map<Integer, List<OfferPayout>> offerPayoutMap = offerPayouts.stream().collect(groupingBy(x -> (int) x.getOfferId()));
1449
        for (Entry<Integer, List<OfferPayout>> offerPayoutEntry : offerPayoutMap.entrySet()) {
32795 amit.gupta 1450
            int offerId = offerPayoutEntry.getKey();
1451
            List<OfferPayout> offerPayoutList = offerPayoutEntry.getValue();
33452 amit.gupta 1452
            Map<Integer, List<OfferPayout>> partnerOfferPayoutMap = offerPayoutList.stream().collect(groupingBy(x -> (int) x.getFofoId()));
32795 amit.gupta 1453
            for (Entry<Integer, List<OfferPayout>> partnerOfferPayoutEntry : partnerOfferPayoutMap.entrySet()) {
1454
                int fofoId = partnerOfferPayoutEntry.getKey();
1455
                List<OfferPayout> partnerPayouts = partnerOfferPayoutEntry.getValue();
1456
                float amount = 0;
1457
                for (OfferPayout offerPayout : partnerPayouts) {
1458
                    amount += offerPayout.getAmount();
1459
                    offerPayout.setStatus(SchemePayoutStatus.REJECTED);
1460
                    offerPayout.setRejectTimestamp(LocalDateTime.now());
1461
                }
1462
                walletService.rollbackAmountFromWallet(fofoId, amount, offerId,
1463
                        WalletReferenceType.ADDITIONAL_SCHEME, "Imeis returned - " + partnerPayouts.size() + "pc(s)", LocalDateTime.now());
1464
            }
1465
        }
1466
    }
1467
 
33316 amit.gupta 1468
    public void test1() throws Exception {
32690 amit.gupta 1469
        System.out.println("Hello from test");
32724 amit.gupta 1470
        //this.calculateInterestAccured();
32690 amit.gupta 1471
        //sendMailOfHtmlFormat(javaMailSender, new String[]{"amit.gupta@smartdukaan.com"}, "hello", null, "Hello");
32698 amit.gupta 1472
        //priceDropService.rejectPriceDropsOfApprovedImeis();
32511 amit.gupta 1473
        //Create return
32600 amit.gupta 1474
        //this.updatePartnerLimit();
32607 ranu 1475
        //creditNoteService.sendCnMails(YearMonth.now().minusMonths(2));
32690 amit.gupta 1476
        //orderService.createMissingScratchOffers();
33315 amit.gupta 1477
        LocalDateTime debitNoteDate = LocalDate.of(2024, Month.APRIL, 30).atStartOfDay();
32698 amit.gupta 1478
        Map<Integer, Set<String>> fofoIdImeiReturnMap = new LinkedHashMap<>();
33355 amit.gupta 1479
        /*fofoIdImeiReturnMap.put(175139690,	new HashSet<>(Arrays.asList("862054078463472","863862077158219","866202075810858","866202077654494","866335072023651","866518078002718")));
33315 amit.gupta 1480
        fofoIdImeiReturnMap.put(175139414,	new HashSet<>(Arrays.asList("356494471684303","356494471857164","356494472062590","861753065078075","863511068904178","863511069732933","864179068109203","864179068112504","864259078789978","866202076254130","866202076254775","866657078259165","866657078272846","867492065809718","867907071107955","868565073021423","868565073022223","868565073386347")));
1481
        fofoIdImeiReturnMap.put(175139603,	new HashSet<>(Arrays.asList("350886063151961","356412387787135","357594162824701","357594162874771","860600078193972","863862077025350","863862077875796","863967075815072","866335073794995","866335074287874","869116067546048")));
1482
        fofoIdImeiReturnMap.put(175139657,	new HashSet<>(Arrays.asList("350933415734746","354324787135850","354324788766356","354990352512960","354990352580181","358142881241184","866611064207332","869116067600464")));
1483
        fofoIdImeiReturnMap.put(175139223,	new HashSet<>(Arrays.asList("350210770983048","350210771169027","350210771179844","350210771180784","863975067090596","866611060326797","868565075758196","869452074016992","869452074609515","869452074609556","869452074976674","869452074978654")));
1484
        fofoIdImeiReturnMap.put(175139557,	new HashSet<>(Arrays.asList("861977073551795","861977073552678","861977074486819","862046062571245","862046067278226","862046067734921","862046067756866","864468070394741","864468071225506","864468071668341","864468073604740","864468074854625","866993074734475")));
1485
        fofoIdImeiReturnMap.put(175139079,	new HashSet<>(Arrays.asList("862046068861921","862282079169299","865388071283496","866335072007753","866335073946256","866518073601712","866518077425993","866518078760471","868938062675394","868938062690799","868938064895552")));
1486
        fofoIdImeiReturnMap.put(175139711,	new HashSet<>(Arrays.asList("861753065266498","861888066009099","864468073703369","866993071640154","869116062800465")));
1487
        fofoIdImeiReturnMap.put(175139488,	new HashSet<>(Arrays.asList("862054076866114","862054076866650","866335071879079","866335077875998","866335077876095","866518078758939","868938062692878")));
1488
        fofoIdImeiReturnMap.put(175138934,	new HashSet<>(Arrays.asList("862054072810231","862054072823150","862054076867674","862054078659590","863862075768456","863862077158193","863975064472490","863975064473233","865388071160033","865610079408035","866335072117370","866335073899471","866335074306153","866335075664477","868938062669876","868938062677895","868938062685997")));
1489
        fofoIdImeiReturnMap.put(4149607	 ,   new HashSet<>(Arrays.asList("864468073415741","864468075548523","864468075549927","864468079499426","866657074106022","868938062686656","868938062696978","868938062699352","868938064895198","868938066363799")));
1490
        fofoIdImeiReturnMap.put(175139138,	new HashSet<>(Arrays.asList("862286066217631","864259076533691","864468073358842","864487061610014","864487061675918","866083066080028","866518078760950","866518078768979","866657075343848","868544061108518","868544061138432","869116065510848","869116065519781","869452074116891","869452074972939")));
1491
        fofoIdImeiReturnMap.put(175139608,	new HashSet<>(Arrays.asList("350201087552063","350201087559944","350201087635660","350201087649760","350201087843140","350201088470224","350201088696687","350201088697180","354324783756923","354324786101366","355472822024008","355472822025625","860388068055779","860388068262219","866518078762337","866518078767534","868544061141493","868544061141774","868544061141816","868938064895719","868938066360910")));
1492
        fofoIdImeiReturnMap.put(175139731,	new HashSet<>(Arrays.asList("860600079214413","861753063502217","861753065084172","861753065084636","863975064472094","863975064473076","863975064477218","864468074456462","865883068726994","866657074641481","866657078016946","868938062699832","868938062700754")));
1493
        fofoIdImeiReturnMap.put(175138958,	new HashSet<>(Arrays.asList("863862075766393","864179064784108","866202075811732","866202076252654","866202078005571","868544060277439")));
1494
        fofoIdImeiReturnMap.put(175139612,	new HashSet<>(Arrays.asList("864468073474946","864468073477808","864468075031082","864468075280689","864468075745723","864468079481747","864468079483123","866657074538125","866657074538141","866657074573106","867467071856465","867467071875465","867467071891223","867467071913845","867467072729125","867467072760088")));
1495
        fofoIdImeiReturnMap.put(175139479,	new HashSet<>(Arrays.asList("863975062106595","863975064472672","863975064472870","863975064472953","863975064482333","863975064483570","863975064484719","863975064662694","863975064666455","863975064668931","863975067090257","863975067090810","863975067230218","863975067232230","866186062852892","866186062853973","866186062855051","866186062855077","866186063250773","866186063251094","866186063251219","866186063251318")));
1496
        fofoIdImeiReturnMap.put(175139245,	new HashSet<>(Arrays.asList("354324787133962","354324787569397","354324787602750","863816078139719","863816078448318","866335070534139")));
1497
        fofoIdImeiReturnMap.put(175139324,	new HashSet<>(Arrays.asList("863718060410316","863862075060755","865610074109257","866518078844457","866518079735159")));
1498
        fofoIdImeiReturnMap.put(175139576,	new HashSet<>(Arrays.asList("354324789013261","861128071288044","862736064686138","863718062236859","863816074642674","863816074646691","864259078939631","867467071870367","867467072760625","868565073047048")));
1499
        fofoIdImeiReturnMap.put(175139150,	new HashSet<>(Arrays.asList("860492060436217","861977073052257","862054073026738","862054073052056","863862077158938","866993074147710","867907071407074","868938060257450","868956064835055")));
1500
        fofoIdImeiReturnMap.put(175139463,	new HashSet<>(Arrays.asList("862181066909552","863816077757719","863816078448516","864214068977273","866335070447936","866335071699212","866335071699592","866335071700291")));
1501
        fofoIdImeiReturnMap.put(175139722,	new HashSet<>(Arrays.asList("358250293364682","358250294683627","358250295102007","861858064421273","861888066009537","864214068983198","864259078491112","864259078787733","865883068445694","866335072878930","866518078371014","868492068014968","868565072254660","868565073401468","868565073465661")));
1502
        fofoIdImeiReturnMap.put(168311083,	new HashSet<>(Arrays.asList("863718064506176","864468070873488","865883068175572","866335071204435","866335072093738","866518077064313","866657077386209","866657077862282","868938061427359")));
1503
        fofoIdImeiReturnMap.put(175139691,	new HashSet<>(Arrays.asList("863718061338714","863718061339258")));
1504
        fofoIdImeiReturnMap.put(175139395,	new HashSet<>(Arrays.asList("860492060436910","861220079009850","862054077288730","863511068660374","863718060300574","863718060617936","866335072874111","869452070894897")));
1505
        fofoIdImeiReturnMap.put(175139621,	new HashSet<>(Arrays.asList("351240553452191","351240553483527","351240553502920","354990353485570","860492062979750","860492062980998","864214068585274","864214068784398","864214068795378","864214068946534","864214068946757","864214068982075","868938061418754","868938061427391","868938062623139")));
1506
        fofoIdImeiReturnMap.put(175139638,	new HashSet<>(Arrays.asList("863862077159191","866518078780438","866518079750471","868428060238049","868938061532836","868938062619517")));
1507
        fofoIdImeiReturnMap.put(175139313,	new HashSet<>(Arrays.asList("350837023070346","350837023075022","350837023075568","350837023075782","352256988699643","862054076944275","863862075060359","863862075520055","864468075575948","865388072943635","868938060248574","868938061422830","868938062630894","869116061122184","869452070893717","869452073157912","869452074054373","869452075220890")));
1508
        fofoIdImeiReturnMap.put(175139513,	new HashSet<>(Arrays.asList("861977073670355","863718060618439","864468075204986","868024064295935","868024065473754","868024065567811","868024065763972","868956063947893")));
1509
        fofoIdImeiReturnMap.put(175139524,	new HashSet<>(Arrays.asList("350933416006946","350933416007944","351115165469199","351115165471237","351115167775437","351115167778431","351115167784413","351688420101625","355300592141142","358250295005267","358250295284607","359197386833520","359197386864947","862054073974671","862054073979597","862054074261730","862054074425954","862054074426036","864468073609384","866518078777392","868544060023239","868938060253772","868938060258516","868938061419018")));
1510
        fofoIdImeiReturnMap.put(175139359,	new HashSet<>(Arrays.asList("358250293060942","358250293061387","863718063044252","863862077160991","866335072536793","866335072536975","866335072537130","866335072726691","866335072726733","866335073628532","866335073925250","866335073925292","866335073926233","866335075267156")));
1511
        fofoIdImeiReturnMap.put(175139397,	new HashSet<>(Arrays.asList("861977073659010","863511069721050","864468071611101","864468074432844","864468074435284")));
1512
        fofoIdImeiReturnMap.put(175139677,	new HashSet<>(Arrays.asList("351115165472839","351115165476095","351115165476251","351115165477739","351115165483430","351115165485377","351115165486516","351115165487191","351115166897992","351115166898438","351115166900416","351115166900879","351115166902438","351115166903816","351115166903857","351115166903915","351115166904475","351115166905753","351115166906454","351115166906595","351115166907015","351115166907759","351115166907957","351115166908872","351115166909813","864259078771372","864468075692644","864468079730101","864468079736744","866657076858687","868565073398649","869116061118042","869116061261081")));
1513
        fofoIdImeiReturnMap.put(175139460,	new HashSet<>(Arrays.asList("860492061918494","862054079983072","862054079983171","866335070533032","866518078995119","866518079014993","868938060095017")));
1514
        fofoIdImeiReturnMap.put(175139585,	new HashSet<>(Arrays.asList("358250293614706","358250293614904","358250294602908","358250294603120","358250295002181","861977074487718","863718061173699","863816078050254","865883068445777","866335070453439","866335070526812","866335071204351","866518078640293","869116067596803")));
1515
        fofoIdImeiReturnMap.put(175139726,	new HashSet<>(Arrays.asList("861858064489411","863718063927654","864468073702221","864468073928784","864468074193149","865883068445819","866657078378742","866657078498904","867949078179850","867949078180494","868544060023197")));
1516
        fofoIdImeiReturnMap.put(175139532,	new HashSet<>(Arrays.asList("863718060615096","863718060615617","863718060727537","863816077797897","866335073405139","868565072217287","868565072264560","868956065132510")));
1517
        fofoIdImeiReturnMap.put(175139462,	new HashSet<>(Arrays.asList("865610074119819","865610074120536","866335072878658","866335072882098","866335073617030")));
1518
        fofoIdImeiReturnMap.put(175139259,	new HashSet<>(Arrays.asList("350210771180644","355300593052348","860492061918213","861858064422651","864259078402572","864259078924310","866335070769719","866335071700556","866335071742558","866657073553208","867949078178530","867949078692472","868024065518616","868024065619091","869116067492540")));
1519
        fofoIdImeiReturnMap.put(175139344,	new HashSet<>(Arrays.asList("350115571135781","354990352587723","358250293362843","358250293363148","862736064732510","865610070849617","865610070851290","866518078899998","868938062623378","868956065234613")));
1520
        fofoIdImeiReturnMap.put(175139602,	new HashSet<>(Arrays.asList("861128070090482","868565072242160","868565072243044","868565072261004","868565073051644")));
1521
        fofoIdImeiReturnMap.put(175139605,	new HashSet<>(Arrays.asList("861515075217922","861515076369466","863816074206397","863816075080072","864259078661755","864468075627368","867467071860541","868565072177903","868565073075726","868565073401625","868938060248012","868938066709652","869452074088611","869452074609234")));
1522
        fofoIdImeiReturnMap.put(175139640,	new HashSet<>(Arrays.asList("358250293363429","358250293363684","861753065277792","863511069733998","864214068943713","864259078496574","864259078518773","864487060042870","864487060050352","865883069366170","866518079782391","867949078692639","867949078692852","868273068551617","868938066464571","869452073150115")));
1523
        fofoIdImeiReturnMap.put(175139346,	new HashSet<>(Arrays.asList("356494471614953","860600076022215","861765072074616","861977070097412","864468074885181","864468076046105","865610073263139","865883065558994","866335075002538","866657079093605","867907070983216")));
1524
        fofoIdImeiReturnMap.put(175139489,	new HashSet<>(Arrays.asList("354324789015209","354324789081797","861515075189824","861515075575501","861977070268997","864468072790144","864468072983921","864468075233225","866657077951960","869452071082492","869452071982378","869452074617070")));
1525
        fofoIdImeiReturnMap.put(175139508,	new HashSet<>(Arrays.asList("861515075367024","864468072781283","864468074453386","864468075200448","864468076050669","866083062293849")));
1526
        fofoIdImeiReturnMap.put(175139716,	new HashSet<>(Arrays.asList("350832440575209","358250295571425","860600076019492","861753063494373","861753063501151","864468073696100","864468074855689","865883065542311","865883067956030","866202075825450","866202077663297","866335073632591","866657078023769")));
1527
        fofoIdImeiReturnMap.put(175139727,	new HashSet<>(Arrays.asList("355300592353325","355300593005387","861765072344258","862046060196128","864468073908604","864468073910121","864468073911269","867437074118411","868024064300099","868024065464977","868024065468218","869116065414389")));
1528
        fofoIdImeiReturnMap.put(175139521,	new HashSet<>(Arrays.asList("860600071402594","860600071416719","861888064397496","861977073658616","864468070509587","864468073866406","866335074999056","866657077949642","866657078406964","866993072229072","867437070891698")));
1529
        fofoIdImeiReturnMap.put(175139523,	new HashSet<>(Arrays.asList("354324785409950","354324788632830","354990352587939","358250295736085","358250295805187","358311601935629","863967076359575","866657074163502","867907070986318","869452071963378","869452074611750")));
1530
        fofoIdImeiReturnMap.put(175139697,	new HashSet<>(Arrays.asList("862282078030112","862282078867117","863975067709930","863975068443810","864468072828860","864468073705786","864468075276489","864468075277685","865610073830739","866335073264577","866518079802116","866657074518903","866657077949980","868565073058664","868938060985639","869116065613949")));
1531
        fofoIdImeiReturnMap.put(175139622,	new HashSet<>(Arrays.asList("358250293381926","358250293382304","358250293382601","358250294076046","358250294078109","358250294078463","358250294602064","358250294602429","358250294603062","358250294603203")));
1532
        fofoIdImeiReturnMap.put(175139699,	new HashSet<>(Arrays.asList("863718064441317","865610074942897","866202077653173","866202077653553","866335072262671","866335073632211","866335074805519")));
1533
        fofoIdImeiReturnMap.put(175139741,	new HashSet<>(Arrays.asList("861515071386101","861515074123402","861515074124186","861977073047752","861977073658574","864468075082804","864468076049869","865883065542139","865883067957111","866518070599679","866518079800672","866657078018587","866657078270162","866657079236220")));
1534
        fofoIdImeiReturnMap.put(175139114,	new HashSet<>(Arrays.asList("861888066708856","861977074487692","866335070051217","866335070517274","866993074145631")));
1535
        fofoIdImeiReturnMap.put(175139531,	new HashSet<>(Arrays.asList("863816077976194","863816079685710","866335070997336","866335074729354","866335075514698")));
1536
        fofoIdImeiReturnMap.put(175139386,	new HashSet<>(Arrays.asList("350210771192805","358250295053846","860388068563434","863862077333374","864468075193221","864562077193757","864718076084310","866202077464092","866202077742190","866518077001513","868565079682020","868956065252516")));
1537
        fofoIdImeiReturnMap.put(175139452,	new HashSet<>(Arrays.asList("350835033581484","350835034344999","350835035973283","350886063052599","351115165490559","351115165492290","351115165492811","354324788947428","354996630411503","354996631256261","355480685142494","355480686969416","359197386860549","861977073020494","862046067791525","862054077982977","866335072889499","867467072712048","868938062127511")));
1538
        fofoIdImeiReturnMap.put(175139306,	new HashSet<>(Arrays.asList("863718064547394","864718076075516","864718076083478","866202077463631","866202077470057")));
1539
        fofoIdImeiReturnMap.put(175139733,	new HashSet<>(Arrays.asList("350210771180008","861515071845668","861888067164877","866335070489094","866518076378276","868565072242269")));
1540
        fofoIdImeiReturnMap.put(175138824,	new HashSet<>(Arrays.asList("862054078573478","863862074697490","863862075442375","864468074485545","866335070216315","866657078016169","866657078449402","869116065542247")));
1541
        fofoIdImeiReturnMap.put(175139511,	new HashSet<>(Arrays.asList("862054075642557","862054075643530","862054076379357","862054077978934","863816078158016","868938062108974")));
1542
        fofoIdImeiReturnMap.put(175139701,	new HashSet<>(Arrays.asList("863862078258331","866611061131790")));
1543
        fofoIdImeiReturnMap.put(175139552,	new HashSet<>(Arrays.asList("861753065084958","866202075814439","866202075825633","866202075864194","866202076138754","866202076252811","866202077646870","866202077651094","866202077653876","866202077659956","866202077660293","866202077663339","866202078006397","866202078006611","866202078008914","866657078023280")));
1544
        fofoIdImeiReturnMap.put(175139499,	new HashSet<>(Arrays.asList("351115165467359","351115166905951","355358277809813","355358277814052","356049795822532","358250290682060","863862075504950","864468073944906","864468076048721","866657079234365")));
1545
        fofoIdImeiReturnMap.put(175139630,	new HashSet<>(Arrays.asList("357349229650288","358250290499184","358250294552947","358250294590301","860946078570556","860946078571059","861977073552215","861977073657790","861977073657832","861977073658731","861977074660850","862054075627517","862054075632756","862054075642979","862054076374879","863967071220830")));
1546
        fofoIdImeiReturnMap.put(175139720,	new HashSet<>(Arrays.asList("865388072300075","866335073071691","866335073073697","866335073390398")));
1547
        fofoIdImeiReturnMap.put(175138854,	new HashSet<>(Arrays.asList("50115570082950","351688420279827","351688420575703","354324788647382","357594162666201","359333606194530","863862075760198")));
1548
        fofoIdImeiReturnMap.put(175139569,	new HashSet<>(Arrays.asList("350201087565545","350201087948386","350201087949087","350210771180081","351088890316094","351088890318454","351088896121530","351088896127776","351088896127958","351088896133410","351088896133832","352476512881224","352476512979242","354448512964985","357888147926932","357888147928292","357888147928557","357888147929050","357888147929795","357888147933094","861128070182420","861753065277115","863511069713933","866657077333680","868273068567092","868565072301768","869116062743905","869452071985157","869452073161393")));
1549
        fofoIdImeiReturnMap.put(175139610,	new HashSet<>(Arrays.asList("862736063981738","863718063044617","866335072870176","866335072870598")));
1550
        fofoIdImeiReturnMap.put(175139366,	new HashSet<>(Arrays.asList("354324783144864","354324788632608","354889661849990","354990353239423","863967070558271","864718076129396","866657077789543","866657078285368","866657078508066","869116060977828","869116061054429","869116061208546")));
1551
        fofoIdImeiReturnMap.put(175139412,	new HashSet<>(Arrays.asList("351115165488595","351115165491318","351115165491359","351115165491458","351115165492332","355358278026573","355358278081610","861888063460717","861977073052018","863816078633919","865883069477035","866335074538870","866993071639594")));
1552
        fofoIdImeiReturnMap.put(175139504,	new HashSet<>(Arrays.asList("862054072660792","862054075971873","862054076312374","862054077948630","863816075363171","863862075442334","864718075894230","868938062122017","868938065268932","869452071940632","869452073034897","869452073158233","869452073158498","869452074159735")));
1553
        fofoIdImeiReturnMap.put(175139201,	new HashSet<>(Arrays.asList("863718061956671","863862075497734","863862075596915","864718076078510","864718076134834","866335070211639","866611060437032","866611061133812")));
1554
        fofoIdImeiReturnMap.put(175139362,	new HashSet<>(Arrays.asList("350201087545646","350201087547048","350201087547709","350201087548764","350201087597043","350201087597167","350201087597464","350201087597787","350201087598165","350201087600789","863718062929271","865883069477191","865883069477530","866335071174133","866518078023870","866518078243072","868938061053494")));
33355 amit.gupta 1555
        fofoIdImeiReturnMap.put(175139661,	new HashSet<>(Arrays.asList("860946077691031","861977074661155","862054073218855","866335070523694","867940069973476","868938062656477")));*/
33452 amit.gupta 1556
        fofoIdImeiReturnMap.put(175139556, new HashSet<>(Arrays.asList("863718063534013", "866335072895173", "866335073390810")));
1557
        fofoIdImeiReturnMap.put(175139721, new HashSet<>(Arrays.asList("358250294549067", "865883067508138", "866993072210619")));
33355 amit.gupta 1558
        /*fofoIdImeiReturnMap.put(175139455,	new HashSet<>(Arrays.asList("358293804087913","866518078020694","866518078021650","866518078243676","866518078571936")));
33315 amit.gupta 1559
        fofoIdImeiReturnMap.put(175138674,	new HashSet<>(Arrays.asList("351115165482275","359197386868583","862054074428875","862054077945693","862054078556879","863967070559535","863975068705671","863975068705770","864468076196124","866186064235971","866186066185117","866186066186917","866518073607370","866518079641514","868938060476456","868938060501535","868938060717990","868938062656931")));
1560
        fofoIdImeiReturnMap.put(175139559,	new HashSet<>(Arrays.asList("863718069016890","863816078879256","864468075283881","866335073245436","866335073403571","866657074268327","868024065473853","868956065899993","869452070362895","869452074030274")));
1561
        fofoIdImeiReturnMap.put(175139575,	new HashSet<>(Arrays.asList("354324786659199","860388067452035","861220078009919","863816078878134","863862075841154","865388070857498","867907071407116")));
33355 amit.gupta 1562
        fofoIdImeiReturnMap.put(175139686,	new HashSet<>(Arrays.asList("866657078019106","866657078032869")));*/
33315 amit.gupta 1563
 
33355 amit.gupta 1564
        //this.processOrdersToRebill(fofoIdImeiReturnMap, debitNoteDate);
1565
        purchaseReturnService.fixReturns(fofoIdImeiReturnMap, debitNoteDate);
32513 amit.gupta 1566
 
32698 amit.gupta 1567
    }
1568
 
1569
 
33315 amit.gupta 1570
    private void processOrdersToRebill(Map<Integer, Set<String>> fofoIdImeiReturnMap, LocalDateTime debitNoteDate) throws Exception {
32698 amit.gupta 1571
 
1572
 
1573
        for (Entry<Integer, Set<String>> fofoIdImeiReturnEntry : fofoIdImeiReturnMap.entrySet()) {
32511 amit.gupta 1574
            int fofoId = fofoIdImeiReturnEntry.getKey();
1575
            Set<String> imeis = fofoIdImeiReturnEntry.getValue();
1576
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(fofoId, imeis, true);
1577
            for (InventoryItem inventoryItem : inventoryItems) {
1578
                //inventoryItem.getId();
1579
                purchaseReturnService.returnInventoryItem(fofoId, true, inventoryItem.getId(), ReturnType.GOOD);
1580
                //Approve return
1581
                PurchaseReturnItem purchaseReturnItem = purchaseReturnItemRepository.selectByInventoryItemId(inventoryItem.getId());
1582
                purchaseReturnItem.setStatus(PurchaseReturnStatus.APPROVED);
1583
                purchaseReturnItem.setApproveTimestamp(LocalDateTime.now());
1584
            }
1585
            Map<Purchase, List<InventoryItem>> purchaseInventoryItemsMap = purchaseReturnService.getPurchaseMapForApprovedReturns(fofoId);
1586
            int walletAmount = walletService.getWalletAmount(fofoId);
1587
            List<DebitNote> debitNotes = purchaseReturnService.generateDebitNotes(purchaseInventoryItemsMap);
1588
            int walletDiff = walletAmount - walletService.getWalletAmount(fofoId);
1589
            if (walletDiff > 0) {
1590
                int reference = walletService.getManualReference(WalletReferenceType.OTHERS);
32514 amit.gupta 1591
                walletService.addAmountToWallet(fofoId, reference, WalletReferenceType.ADVANCE_AMOUNT, "Sytematically added for internal PO", (float) walletDiff + 5000, LocalDateTime.now());
32511 amit.gupta 1592
            }
32698 amit.gupta 1593
            List<CartItem> cartItems = new ArrayList<>();
32511 amit.gupta 1594
            for (DebitNote debitNote : debitNotes) {
33315 amit.gupta 1595
                debitNote.setCreateTimestamp(debitNoteDate);
32511 amit.gupta 1596
                //Try to refund amount per debit note
32698 amit.gupta 1597
                cartItems.addAll(this.refundDnAmount(debitNote));
32511 amit.gupta 1598
            }
32698 amit.gupta 1599
            //If order created
33452 amit.gupta 1600
            Map<Integer, List<CartItem>> warehouseCartItemsMap = cartItems.stream().collect(groupingBy(x -> x.getWarehouseId()));
1601
            for (Entry<Integer, List<CartItem>> warehouseCartItemsEntry : warehouseCartItemsMap.entrySet()) {
32223 amit.gupta 1602
 
32698 amit.gupta 1603
                List<CartItem> warehouseCartItems = warehouseCartItemsEntry.getValue();
1604
 
1605
                List<CartItem> mergedCartItems = warehouseCartItems.stream()
1606
                        .collect(Collectors.collectingAndThen(
33452 amit.gupta 1607
                                groupingBy(x -> x.getItemId(), Collectors.collectingAndThen(
32724 amit.gupta 1608
                                        Collectors.reducing((a, b) -> {
32698 amit.gupta 1609
                                            a.setQuantity(a.getQuantity() + b.getQuantity());
1610
                                            return a;
1611
                                        }), Optional::get)),
1612
                                m -> new ArrayList<>(m.values())));
1613
 
32724 amit.gupta 1614
                double walletTotalAmount = mergedCartItems.stream().mapToDouble(x -> x.getQuantity() * x.getSellingPrice()).sum();
32698 amit.gupta 1615
 
1616
                com.spice.profitmandi.dao.entity.user.User user = userRepository.selectById(fofoId);
1617
                cartService.clearCart(user.getActiveCartId());
1618
                cartService.addItemsToCart(user.getActiveCartId(), mergedCartItems);
1619
 
1620
                UserCart userCart = new UserCart();
1621
                userCart.setCartId(user.getActiveCartId());
1622
                userCart.setUserId(user.getId());
1623
 
1624
                int transactionId = transactionService.createTransactionInternally(userCart, walletTotalAmount, warehouseCartItemsEntry.getKey());
1625
                commonPaymentService.payThroughWallet(transactionId);
34352 amit.gupta 1626
                transactionService.processTransaction(transactionId, 0);
32698 amit.gupta 1627
            }
1628
        }
31697 amit.gupta 1629
    }
32048 tejbeer 1630
 
32384 amit.gupta 1631
    @Autowired
32511 amit.gupta 1632
    CartService cartService;
1633
    @Autowired
1634
    UserRepository userRepository;
1635
 
1636
    @Autowired
1637
    WarehouseScanRepository warehouseScanRepository;
1638
 
1639
    @Autowired
1640
    WarehouseInventoryService warehouseInventoryService;
1641
 
1642
    @Autowired
1643
    CommonPaymentService commonPaymentService;
1644
 
32533 amit.gupta 1645
    @Autowired
1646
    LineItemImeisRepository lineItemImeisRepository;
1647
 
32698 amit.gupta 1648
 
32511 amit.gupta 1649
    //Also create order
32698 amit.gupta 1650
    private List<CartItem> refundDnAmount(DebitNote debitNote) throws ProfitMandiBusinessException {
32511 amit.gupta 1651
        List<Integer> inventoryItemIds = purchaseReturnItemRepository.selectAllByDebitNoteId(debitNote.getId()).stream().map(x -> x.getInventoryItemId()).collect(Collectors.toList());
33452 amit.gupta 1652
        Map<Integer, Long> inventoryItemCountMap = inventoryItemIds.stream().collect(groupingBy(x -> x, Collectors.counting()));
32511 amit.gupta 1653
        List<InventoryItem> inventoryItems = inventoryItemRepository.selectAllByIds(new ArrayList<>(inventoryItemCountMap.keySet()));
1654
        Purchase purchase = purchaseRepository.selectById(inventoryItems.get(0).getPurchaseId());
1655
        String invoice = purchase.getPurchaseReference();
1656
        List<Order> orders = orderRepository.selectByInvoiceNumber(invoice);
1657
        Set<Integer> orderIds = orders.stream().map(x -> x.getId()).collect(Collectors.toSet());
1658
        Order order = orders.get(0);
1659
        float totalAmount = 0;
1660
        int totalQty = 0;
1661
        Map<Integer, CartItem> itemIdCartItemMap = new HashMap<>();
1662
 
35447 amit 1663
        // Batch fetch all TagListings by itemIds to avoid N+1 queries
1664
        Set<Integer> allItemIds = inventoryItems.stream()
1665
                .map(InventoryItem::getItemId)
1666
                .collect(Collectors.toSet());
1667
        List<TagListing> allTagListings = tagListingRepository.selectByItemIdsAndTagIds(allItemIds, null);
1668
        Map<Integer, TagListing> itemIdTagListingMap = allTagListings.stream()
1669
                .collect(Collectors.toMap(TagListing::getItemId, t -> t, (u, v) -> u));
1670
 
32511 amit.gupta 1671
        List<CartItem> cartItems = new ArrayList<>();
1672
        for (InventoryItem inventoryItem : inventoryItems) {
35447 amit 1673
            TagListing tagListing = itemIdTagListingMap.get(inventoryItem.getItemId());
32511 amit.gupta 1674
            long quantity = inventoryItemCountMap.get(inventoryItem.getId());
1675
            totalAmount += inventoryItem.getUnitPrice() * quantity;
1676
            totalQty += quantity;
1677
            if (!itemIdCartItemMap.containsKey(inventoryItem.getItemId())) {
1678
                CartItem cartItem = new CartItem();
1679
                cartItem.setItemId(inventoryItem.getItemId());
1680
                cartItem.setSellingPrice(tagListing.getSellingPrice());
32698 amit.gupta 1681
                cartItem.setWarehouseId(order.getWarehouseId());
32511 amit.gupta 1682
                cartItems.add(cartItem);
1683
                itemIdCartItemMap.put(inventoryItem.getItemId(), cartItem);
1684
            }
1685
            CartItem cartItem = itemIdCartItemMap.get(inventoryItem.getItemId());
1686
            cartItem.setQuantity((int) quantity + cartItem.getQuantity());
1687
        }
1688
        String rollbackDescription = String.format("Refunded against DN %s, %d pc(s)", debitNote.getDebitNoteNumber(), totalQty);
1689
        walletService.addAmountToWallet(debitNote.getFofoId(), order.getTransactionId(), WalletReferenceType.PURCHASE, rollbackDescription, totalAmount, LocalDateTime.now());
1690
        //Before creating order lets try to in the stock
1691
 
1692
        //All scans pertaining to specific Invoices
1693
        List<WarehouseScan> warehouseScans = warehouseScanRepository.selectAllByOrderIds(new ArrayList<>(orderIds));
32698 amit.gupta 1694
        Map<Integer, Integer> inventoryItemIdOrderIdMap = new HashMap<>();
1695
        try {
1696
            inventoryItemIdOrderIdMap = warehouseScans.stream().collect(Collectors.toMap(x -> x.getInventoryItemId(), x -> x.getQuantity()));
32724 amit.gupta 1697
        } catch (Exception e) {
32698 amit.gupta 1698
            LOGGER.info("Could not process for fofoId - {}, {}", debitNote.getFofoId(), warehouseScans);
1699
        }
32511 amit.gupta 1700
        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)))
1701
                .map(x -> x.getInventoryItemId()).collect(Collectors.toList());
1702
        List<WarehouseInventoryItem> warehouseInventoryItems = warehouseInventoryItemRepository.selectAllByIds(warehouseInventoryItemIds);
1703
 
1704
        Map<String, WarehouseInventoryItem> serialNumberWarehouseInventoryItemMap = warehouseInventoryItems.stream().filter(x -> StringUtils.isNotBlank(x.getSerialNumber())).collect(Collectors.toMap(x -> x.getSerialNumber(), x -> x));
1705
 
1706
        for (InventoryItem inventoryItem : inventoryItems) {
1707
            if (StringUtils.isBlank(inventoryItem.getSerialNumber())) {
1708
                //As of now this should be happening as  dn are specifically for serialized devices
1709
                /*int returnQty = inventoryItemCountMap.get(inventoryItem.getId()).intValue();
1710
                List<WarehouseInventoryItem> warehouseInventoryItemList = itemIdWarehouseInventoryItemsMap.get(inventoryItem.getItemId());
1711
                warehouseInventoryService.returnNonSerializedQty(warehouseInventoryItem)*/
1712
            } else if (StringUtils.isNotBlank(inventoryItem.getSerialNumber())) {
1713
                String serialNumber = inventoryItem.getSerialNumber();
1714
                WarehouseInventoryItem warehouseInventoryItem = serialNumberWarehouseInventoryItemMap.get(serialNumber);
1715
                warehouseInventoryItem.setLastScanType(in.shop2020.warehouse.ScanType.SALE_RET);
1716
                warehouseInventoryService.addQuantity(warehouseInventoryItem.getId(), 1);
1717
                WarehouseScan warehouseScan = new WarehouseScan();
1718
                warehouseScan.setInventoryItemId(warehouseInventoryItem.getId());
1719
                warehouseScan.setQuantity(1);
1720
                warehouseScan.setOrderId(inventoryItemIdOrderIdMap.get(warehouseInventoryItem.getItemId()));
1721
                warehouseScan.setScannedAt(LocalDateTime.now());
1722
                warehouseScan.setType(in.shop2020.warehouse.ScanType.SALE_RET);
1723
                warehouseScanRepository.persist(warehouseScan);
1724
 
1725
            }
1726
        }
1727
 
1728
        //Create Order as well
32724 amit.gupta 1729
        return cartItems;
32698 amit.gupta 1730
    }
32511 amit.gupta 1731
 
32698 amit.gupta 1732
    void addToCartAndCreateOrder() {
32511 amit.gupta 1733
 
1734
    }
1735
 
1736
    @Autowired
32384 amit.gupta 1737
    WarehouseDebitNoteRepository warehouseDebitNoteRepository;
1738
    @Autowired
1739
    WarehouseDebitNoteLineRepository warehouseDebitNoteLineRepository;
1740
 
1741
    @Autowired
1742
    WarehouseInvoiceItemRepository warehouseInvoiceItemRepository;
1743
    @Autowired
1744
    WarehouseSupplierInvoiceRepository warehouseSupplierInvoiceRepository;
1745
 
1746
    @Autowired
1747
    PurchaseOrderService purchaseOrderService;
1748
 
32482 amit.gupta 1749
    @Autowired
1750
    VendorCatalogPricingLogRepository vendorCatalogPricingLogRepository;
32384 amit.gupta 1751
 
32214 jai.hind 1752
//    private void checkItelImeiActivationNew(LocalDate now, int i) {
1753
//    }
1754
 
32169 amit.gupta 1755
    @Autowired
1756
    SessionFactory sessionFactory;
1757
 
1758
 
31697 amit.gupta 1759
    public void sendMailForSamsungRebilling() throws Exception {
1760
        List<BilledImeiModel> samsungModels = warehouseInventoryItemRepository.findByBillingDateBrand(LocalDate.now(), "Samsung");
1761
        LOGGER.info("SamsungModels {}", samsungModels);
1762
        samsungModels = samsungModels.stream().sorted(Comparator.comparing(x -> x.getPcmDate() == null ? -1 : 1)).collect(Collectors.toList());
1763
        if (samsungModels.size() > 0) {
1764
            List<String> headers = Arrays.asList("Partner Id", "Code", "Name", "City", "Brand", "Model Name", "Model Number", "Color", "Serial Number", "Remarks");
1765
            List<List<?>> rows = new ArrayList<>();
1766
            for (BilledImeiModel billedImeiModel : samsungModels) {
31886 tejbeer 1767
                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 1768
                rows.add(row);
1769
            }
1770
            ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, rows);
1771
            String[] sendToArray = new String[]{"kamini.sharma@smartdukaan.com", "praveen.sharma@smartdukaan.com"};
1772
            String fileName = "Imeis need Rebilling -" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
36460 ranu 1773
            Utils.sendMailWithAttachment(googleMailSender, sendToArray, new String[]{"tarun.verma@smartdukaan.com"}, "Samsung Rebilling IMEI Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
31697 amit.gupta 1774
        }
1775
    }
24002 amit.gupta 1776
 
31697 amit.gupta 1777
    public void sendPartnerInvestmentDetails(List<String> sendTo) throws Exception {
1778
        LocalDate yesterDay = LocalDate.now().minusDays(1);
1779
        List<FofoStore> fofoStores = fofoStoreRepository.selectActiveStores();
31886 tejbeer 1780
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(fofoStores.stream().map(x -> x.getId()).collect(Collectors.toList()));
25312 amit.gupta 1781
 
32169 amit.gupta 1782
        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 1783
        List<List<?>> rows = new ArrayList<>();
1784
        Map<Integer, List<?>> partnerRowsMap = new HashMap<>();
25598 amit.gupta 1785
 
31697 amit.gupta 1786
        Map<Integer, FofoReportingModel> partnerIdSalesHeaderMap = this.getPartnerIdSalesHeaders();
25312 amit.gupta 1787
 
31886 tejbeer 1788
        Map<Integer, Integer> shortDaysMap = partnerDailyInvestmentRepository.selectAll(LocalDate.now().withDayOfMonth(1), LocalDate.now()).stream().collect(groupingBy(
35848 amit 1789
                x -> x.getFofoId(), Collectors.summingInt(x -> x.getShortPercentage() > ProfitMandiConstants.OK_INVESTMENT_SHORT_PERCENTAGE ? 1 : 0)));
24271 amit.gupta 1790
 
31697 amit.gupta 1791
        for (FofoStore fofoStore : fofoStores) {
1792
            LOGGER.info("Fofo Store {},  {}", fofoStore.getId(), fofoStore.getCode());
1793
            int fofoId = fofoStore.getId();
1794
            PartnerDailyInvestment partnerDailyInvestment = partnerInvestmentService.getInvestment(fofoId, 1);
1795
            partnerDailyInvestment.setDate(yesterDay);
24177 govind 1796
 
31697 amit.gupta 1797
            try {
1798
                partnerDailyInvestmentRepository.persist(partnerDailyInvestment);
35848 amit 1799
                shortDaysMap.put(fofoId, shortDaysMap.get(fofoId) + (partnerDailyInvestment.getShortPercentage() > ProfitMandiConstants.OK_INVESTMENT_SHORT_PERCENTAGE ? 1 : 0));
31697 amit.gupta 1800
            } catch (Exception e) {
1801
                // ignore the exceptions during persist
1802
            }
25598 amit.gupta 1803
 
31697 amit.gupta 1804
            CustomRetailer retailer = customRetailerMap.get(fofoStore.getId());
1805
            if (retailer == null || partnerIdSalesHeaderMap.get(fofoStore.getId()) == null) {
1806
                LOGGER.info("Could not find retailer with retailer Id {}", fofoStore.getId());
1807
                continue;
1808
            }
1809
            FofoReportingModel reportingModel = partnerIdSalesHeaderMap.get(fofoStore.getId());
1810
            List<Serializable> row = new ArrayList<>();
31886 tejbeer 1811
            row.addAll(Arrays.asList(reportingModel.getCode(), reportingModel.getBusinessName(), reportingModel.getRegionalManager(), reportingModel.getTerritoryManager()));
31697 amit.gupta 1812
            row.addAll(
31886 tejbeer 1813
                    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 1814
            partnerRowsMap.put(fofoStore.getId(), row);
1815
            rows.add(row);
25837 amit.gupta 1816
 
31697 amit.gupta 1817
        }
25837 amit.gupta 1818
 
34611 ranu 1819
        String fileName = "InvestmentSummary-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
25837 amit.gupta 1820
 
34337 amit.gupta 1821
        if (sendTo == null) {
33452 amit.gupta 1822
            for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMapping().entrySet()) {
31886 tejbeer 1823
                List<List<?>> filteredRows = storeGuyEntry.getValue().stream().map(x -> partnerRowsMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
31697 amit.gupta 1824
                ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, filteredRows);
1825
                String[] sendToArray = new String[]{storeGuyEntry.getKey()};
36460 ranu 1826
                Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Franchise Investment Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
31697 amit.gupta 1827
            }
34578 vikas.jang 1828
            sendTo = Arrays.asList("tarun.verma@smartdukaan.com", "kamini.sharma@smartdukaan.com", "neeraj.gupta@smartdukaan.com", "amit.gupta@shop2020.in", "manish.gupta1@smartdukaan.com", "niranjan.kala@smartdukaan.com");
31697 amit.gupta 1829
        }
25837 amit.gupta 1830
 
31697 amit.gupta 1831
        ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, rows);
1832
        String[] sendToArray = sendTo.toArray(new String[sendTo.size()]);
36460 ranu 1833
        Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Franchise Investment Summary", "PFA", fileName, new ByteArrayResource(baos.toByteArray()));
25837 amit.gupta 1834
 
31697 amit.gupta 1835
    }
25598 amit.gupta 1836
 
33256 amit.gupta 1837
    private Map<Integer, FofoReportingModel> getPartnerIdSalesHeaders() throws ProfitMandiBusinessException {
31697 amit.gupta 1838
        Map<String, SaleRoles> partnerEmailSalesMap = new HashMap<>();
1839
        Map<String, SaleRoles> partnerEmailRBMMap = new HashMap<>();
34903 ranu 1840
        Map<String, SaleRoles> partnerEmailABMMap = new HashMap<>();
24271 amit.gupta 1841
 
35521 amit 1842
        List<Position> positions = positionRepository.selectPositionByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_ABM));
31886 tejbeer 1843
        Map<Integer, AuthUser> authUsersMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
31697 amit.gupta 1844
        Map<Integer, List<CustomRetailer>> positionIdRetailerMap = csService.getPositionCustomRetailerMap(positions);
1845
        for (Position position : positions) {
1846
            List<CustomRetailer> crList = positionIdRetailerMap.get(position.getId());
1847
            if (crList == null)
1848
                continue;
1849
            if (position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_SALES) {
1850
                for (CustomRetailer cr : crList) {
1851
                    if (!partnerEmailSalesMap.containsKey(cr.getEmail())) {
1852
                        partnerEmailSalesMap.put(cr.getEmail(), new SaleRoles());
1853
                    }
1854
                    SaleRoles saleRoles = partnerEmailSalesMap.get(cr.getEmail());
1855
                    AuthUser authUser = authUsersMap.get(position.getAuthUserId());
1856
                    if (authUser == null) {
1857
                        continue;
1858
                    }
1859
                    String name = authUser.getFirstName() + " " + authUser.getLastName();
1860
                    if (position.getEscalationType().equals(EscalationType.L1)) {
1861
                        saleRoles.getL1().add(name);
1862
                    } else if (position.getEscalationType().equals(EscalationType.L2)) {
1863
                        saleRoles.getL2().add(name);
1864
                    }
1865
                }
1866
            }
1867
            if (position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_RBM) {
1868
                for (CustomRetailer cr : crList) {
1869
                    if (!partnerEmailRBMMap.containsKey(cr.getEmail())) {
1870
                        partnerEmailRBMMap.put(cr.getEmail(), new SaleRoles());
1871
                    }
1872
                    SaleRoles saleRoles = partnerEmailRBMMap.get(cr.getEmail());
1873
                    AuthUser authUser = authUsersMap.get(position.getAuthUserId());
1874
                    if (authUser == null) {
1875
                        continue;
1876
                    }
1877
                    String name = authUser.getFirstName() + " " + authUser.getLastName();
1878
                    if (position.getEscalationType().equals(EscalationType.L1) || position.getEscalationType().equals(EscalationType.L1)) {
1879
                        saleRoles.getL1().add(name);
1880
                    }
1881
                    /*else if (position.getEscalationType().equals(EscalationType.L2)) {
1882
                        saleRoles.getL2().add(name);
1883
                    }*/
1884
                }
1885
            }
24692 amit.gupta 1886
 
34903 ranu 1887
            if (position.getCategoryId() == ProfitMandiConstants.TICKET_CATEGORY_ABM) {
1888
                for (CustomRetailer cr : crList) {
1889
                    if (!partnerEmailABMMap.containsKey(cr.getEmail())) {
1890
                        partnerEmailABMMap.put(cr.getEmail(), new SaleRoles());
1891
                    }
1892
                    SaleRoles saleRoles = partnerEmailABMMap.get(cr.getEmail());
1893
                    AuthUser authUser = authUsersMap.get(position.getAuthUserId());
1894
                    if (authUser == null) {
1895
                        continue;
1896
                    }
1897
                    String name = authUser.getFirstName() + " " + authUser.getLastName();
1898
                    if (position.getEscalationType().equals(EscalationType.L1) || position.getEscalationType().equals(EscalationType.L1)) {
1899
                        saleRoles.getL1().add(name);
35521 amit 1900
                    } else if (position.getEscalationType().equals(EscalationType.L2)) {
34903 ranu 1901
                        saleRoles.getL2().add(name);
1902
                    }
1903
                }
1904
            }
1905
 
31697 amit.gupta 1906
        }
25418 amit.gupta 1907
 
31697 amit.gupta 1908
        Set<CustomRetailer> allCrList = new HashSet<>();
1909
        for (List<CustomRetailer> cr : positionIdRetailerMap.values()) {
1910
            allCrList.addAll(cr);
1911
        }
25609 amit.gupta 1912
 
31886 tejbeer 1913
        Map<Integer, FofoStore> fofoStoresMap = fofoStoreRepository.selectActiveStores().stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
25503 amit.gupta 1914
 
31697 amit.gupta 1915
        Map<Integer, FofoReportingModel> partnerIdSalesHeadersMap = new HashMap<>();
25503 amit.gupta 1916
 
31697 amit.gupta 1917
        for (CustomRetailer cr : allCrList) {
1918
            FofoStore fofoStore = fofoStoresMap.get(cr.getPartnerId());
1919
            if (fofoStore == null) {
1920
                LOGGER.info("Could not find Store {} in active Store", cr.getBusinessName());
1921
                continue;
1922
            }
1923
            String code = fofoStore.getCode();
1924
            // String storeName = "SmartDukaan-" +
1925
            // fofoStore.getCode().replaceAll("[a-zA-Z]", "");
1926
            String businessName = cr.getBusinessName();
1927
            try {
1928
                String stateManager = StringUtils.join(partnerEmailSalesMap.get(cr.getEmail()).getL2(), ", ");
1929
                String territoryManager = StringUtils.join(partnerEmailSalesMap.get(cr.getEmail()).getL1(), ", ");
1930
                String bdm = StringUtils.join(partnerEmailRBMMap.get(cr.getEmail()).getL1(), ", ");
1931
                FofoReportingModel reportingModel = new FofoReportingModel();
1932
                reportingModel.setBusinessName(businessName);
1933
                reportingModel.setCode(code);
1934
                reportingModel.setFofoId(fofoStore.getId());
1935
                reportingModel.setRegionalManager(stateManager);
1936
                reportingModel.setTerritoryManager(territoryManager);
1937
                reportingModel.setBusinessManager(bdm);
1938
                partnerIdSalesHeadersMap.put(fofoStore.getId(), reportingModel);
1939
            } catch (Exception e) {
1940
                LOGGER.warn("Could not find partner with email - {}", cr.getEmail());
1941
            }
1942
        }
1943
        return partnerIdSalesHeadersMap;
24533 govind 1944
 
31697 amit.gupta 1945
    }
28709 amit.gupta 1946
 
34275 tejus.loha 1947
    public void persistRbmTodayTargets() throws Exception {
33928 ranu 1948
        rbmTargetService.setMovementWiseRbmTargets();
1949
    }
1950
 
34275 tejus.loha 1951
    public void persistRbmTodayAchievements() throws Exception {
33986 ranu 1952
        rbmTargetService.setMovementWiseRbmAchievement();
1953
    }
1954
 
31697 amit.gupta 1955
    public void sendPartnerInvestmentDetails() throws Exception {
1956
        this.sendPartnerInvestmentDetails(null);
1957
    }
28709 amit.gupta 1958
 
31697 amit.gupta 1959
    public void sendAgeingReport(String... sendTo) throws Exception {
28790 amit.gupta 1960
 
31886 tejbeer 1961
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.WAREHOUSENEW, "itemstockageing.xml");
1962
        InputStreamSource isr1 = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "ItemwiseOverallPendingIndent.xml");
31697 amit.gupta 1963
        Attachment attachment = new Attachment(
1964
                "ageing-report-" + FormattingUtils.formatDate(LocalDateTime.now().minusDays(1)) + ".csv", isr);
1965
        Attachment attachment1 = new Attachment(
1966
                "pending-indent-" + FormattingUtils.formatDate(LocalDateTime.now().minusDays(1)) + ".csv", isr1);
28790 amit.gupta 1967
 
35959 amit 1968
        mailOutboxService.queueMailWithAttachmentsViaGoogle(STOCK_AGEING_MAIL_LIST, null, "Stock Ageing Report", "PFA", "ScheduledTasks.sendAgeingReport", attachment);
1969
        mailOutboxService.queueMailWithAttachmentsViaGoogle(ITEMWISE_PENDING_INDENT_MAIL_LIST, null, "Itemwise Pending indent", "PFA", "ScheduledTasks.sendAgeingReport", attachment1);
28790 amit.gupta 1970
 
31697 amit.gupta 1971
        // Reports to be sent to mapped partners
1972
        Map<String, Set<String>> storeGuysMap = csService.getAuthUserPartnerEmailMapping();
28790 amit.gupta 1973
 
33452 amit.gupta 1974
        for (Entry<String, Set<String>> storeGuyEntry : storeGuysMap.entrySet()) {
31697 amit.gupta 1975
            Map<String, String> params = new HashMap<>();
1976
            if (storeGuyEntry.getValue().size() == 0)
1977
                continue;
1978
            params.put("MANUAL_email", String.join(",", storeGuyEntry.getValue()));
31886 tejbeer 1979
            InputStreamSource isr3 = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "focostockreport.xml", params);
31697 amit.gupta 1980
            Attachment attache = new Attachment(
1981
                    "Franchise-stock-report" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr3);
1982
            System.out.println(storeGuyEntry.getValue());
35959 amit 1983
            mailOutboxService.queueMailWithAttachmentsViaGoogle(new String[]{storeGuyEntry.getKey()}, null, "Franchise Stock Report", "PFA", "ScheduledTasks.sendAgeingReport", attache);
31697 amit.gupta 1984
        }
28839 tejbeer 1985
 
31697 amit.gupta 1986
    }
28839 tejbeer 1987
 
31697 amit.gupta 1988
    public void sendIndentTertiary() throws Exception {
28790 amit.gupta 1989
 
31886 tejbeer 1990
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "indentandtertiary.xml");
31697 amit.gupta 1991
        Attachment attachment = new Attachment(
1992
                "indentandtertiary-report-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr);
35959 amit 1993
        mailOutboxService.queueMailWithAttachmentsViaGoogle(INDENT_TERTIARY_MAIL_LIST, null, "Indent Tertiary Report", "PFA", "ScheduledTasks.sendIndentTertiary", attachment);
28790 amit.gupta 1994
 
31697 amit.gupta 1995
    }
28790 amit.gupta 1996
 
31697 amit.gupta 1997
    public void sendAttendanceMorningAlert() throws Exception {
1998
        LocalDateTime moriningTime = LocalDate.now().atTime(10, 31);
1999
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
31886 tejbeer 2000
        Map<String, AuthUser> authUserEmailMap = authUsers.stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28775 amit.gupta 2001
 
31697 amit.gupta 2002
        List<User> users = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.keySet()));
2003
        Map<String, User> userMap = users.stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28790 amit.gupta 2004
 
31886 tejbeer 2005
        List<EmployeeAttendance> employeeAttendances = employeeAttendanceRepository.selectAllByDatesBetween(LocalDate.now().atStartOfDay(), LocalDateTime.now());
28784 amit.gupta 2006
 
31886 tejbeer 2007
        Map<Integer, Optional<EmployeeAttendance>> employeeMorningAttendance = employeeAttendances.stream().collect(groupingBy(EmployeeAttendance::getUserId, Collectors.minBy(Comparator.comparing(EmployeeAttendance::getCreateTimestamp))));
31697 amit.gupta 2008
        for (AuthUser authUser : authUsers) {
2009
            User user = userMap.get(authUser.getEmailId());
2010
            Optional<EmployeeAttendance> employeeAttendanceOptional = employeeMorningAttendance.get(user.getId());
2011
            LOGGER.info("AuthUser - {}, employeeAttendanceOptional {}", authUser.getName(), employeeAttendanceOptional);
2012
            if (employeeAttendanceOptional != null) {
2013
                LOGGER.info("employeeAttendanceOptional.orElse {}", employeeAttendanceOptional.orElse(null));
2014
                if (employeeAttendanceOptional.orElse(null) != null) {
31886 tejbeer 2015
                    LOGGER.info("employeeAttendanceOptional.get().getCreateTimestamp() {}", employeeAttendanceOptional.get().getCreateTimestamp());
31697 amit.gupta 2016
                }
2017
            }
31886 tejbeer 2018
            if (employeeAttendanceOptional == null || employeeAttendanceOptional.orElse(null) == null || employeeAttendanceOptional.get().getCreateTimestamp().isAfter(moriningTime)) {
31697 amit.gupta 2019
                LOGGER.info("Will Send Email to {}", authUser.getFullName());
2020
                String body = String.format(
31886 tejbeer 2021
                        "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 2022
 
35959 amit 2023
                mailOutboxService.queueMailViaGoogle(new String[]{authUser.getEmailId()}, new String[]{"kangan.monga@smartdukaan.com"}, "Attendance Alert", body, "ScheduledTasks.sendAttendanceMorningAlert");
28790 amit.gupta 2024
 
31697 amit.gupta 2025
            }
2026
        }
28790 amit.gupta 2027
 
31697 amit.gupta 2028
    }
28790 amit.gupta 2029
 
31697 amit.gupta 2030
    public void sendAttendanceEveningAlert() throws Exception {
2031
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
31886 tejbeer 2032
        Map<String, AuthUser> authUserEmailMap = authUsers.stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28709 amit.gupta 2033
 
31697 amit.gupta 2034
        List<User> users = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.keySet()));
2035
        Map<String, User> userMap = users.stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x));
28709 amit.gupta 2036
 
31886 tejbeer 2037
        Map<Integer, List<EmployeeAttendance>> employeeAttendancesMap = employeeAttendanceRepository.selectAllByDatesBetween(LocalDate.now().atStartOfDay(), LocalDateTime.now()).stream().collect(groupingBy(x -> x.getUserId()));
28709 amit.gupta 2038
 
31697 amit.gupta 2039
        for (AuthUser authUser : authUsers) {
2040
            User user = userMap.get(authUser.getEmailId());
2041
            String body = null;
2042
            List<EmployeeAttendance> employeeAttendances = employeeAttendancesMap.get(user.getId());
2043
            if (employeeAttendances == null) {
2044
                body = String.format(
31886 tejbeer 2045
                        "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 2046
            } else {
31886 tejbeer 2047
                List<LocalDateTime> punchTimes = employeeAttendances.stream().sorted(Comparator.comparing(EmployeeAttendance::getCreateTimestamp)).map(x -> x.getCreateTimestamp()).collect(Collectors.toList());
31697 amit.gupta 2048
                if (punchTimes.size() == 1) {
2049
                    // body = String.format("Dear %s,\n Pls note that you haven't punched out yet.
2050
                    // You have been marked absent for half the day. You may contact your manager
2051
                    // and get it regularise.\n\nRegards\nHR Team", authUser.getFullName());
2052
                } else {
2053
                    LocalDateTime firstPunch = punchTimes.get(0);
2054
                    LocalDateTime lastPunch = punchTimes.get(punchTimes.size() - 1);
2055
                    Duration duration = Duration.between(firstPunch, lastPunch);
2056
                    boolean hoursCompleted = lastPunch.isAfter(firstPunch.plusHours(8).plusMinutes(30));
2057
                    if (!hoursCompleted) {
2058
                        body = String.format(
31886 tejbeer 2059
                                "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 2060
                    }
2061
                }
28709 amit.gupta 2062
 
31697 amit.gupta 2063
            }
2064
            if (body != null) {
35959 amit 2065
                mailOutboxService.queueMailViaGoogle(new String[]{authUser.getEmailId()}, new String[]{"kangan.monga@smartdukaan.com"}, "Attendance Alert", body, "ScheduledTasks.sendAttendanceEveningAlert");
31697 amit.gupta 2066
            }
2067
        }
28709 amit.gupta 2068
 
31697 amit.gupta 2069
        this.sendMailToHR();
28709 amit.gupta 2070
 
31697 amit.gupta 2071
    }
28709 amit.gupta 2072
 
31697 amit.gupta 2073
    private void sendMailToHR() throws Exception {
2074
        Map<String, String> map = new HashMap<>();
2075
        String reporticoDate = FormattingUtils.formatReporitcoDate(LocalDateTime.now());
2076
        map.put("MANUAL_datesBetween_FROMDATE", reporticoDate);
2077
        map.put("MANUAL_datesBetween_FROMDATE", reporticoDate);
31886 tejbeer 2078
        InputStreamSource isr = reporticoService.getReportInputStreamSource(ReporticoProject.FOCO, "employeeattendance.xml");
2079
        Attachment attachment = new Attachment("attendance-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv", isr);
35959 amit 2080
        mailOutboxService.queueMailWithAttachmentsViaGoogle(EMPLOYEE_ATTENDANCE_MAIL_LIST, null, "Attendance - " + FormattingUtils.formatDate(LocalDateTime.now()), "PFA Attendance", "ScheduledTasks.sendMailToHR", attachment);
31697 amit.gupta 2081
    }
28709 amit.gupta 2082
 
31697 amit.gupta 2083
    public void checkPartnerActiveStore() throws Exception {
24697 amit.gupta 2084
 
31697 amit.gupta 2085
        List<FofoStore> fofoStores = fofoStoreRepository.selectByStatus(true);
23929 amit.gupta 2086
 
31697 amit.gupta 2087
        LocalDateTime currentDate = LocalDate.now().atStartOfDay();
2088
        if (!fofoStores.isEmpty()) {
2089
            for (FofoStore fofoStore : fofoStores) {
24551 amit.gupta 2090
 
31697 amit.gupta 2091
                if (currentDate.isBefore(fofoStore.getActiveTimeStamp())) {
24542 amit.gupta 2092
 
31697 amit.gupta 2093
                    fofoStore.setActive(true);
2094
                    fofoStoreRepository.persist(fofoStore);
2095
                    LOGGER.info("inserted into InActiveFofoStore successfully");
29160 amit.gupta 2096
 
31697 amit.gupta 2097
                } else {
2098
                    fofoStore.setActive(false);
2099
                    fofoStore.setActiveTimeStamp(null);
2100
                    fofoStoreRepository.persist(fofoStore);
2101
                    LOGGER.info("inserted into InActiveFofoStore successfully");
2102
                }
24542 amit.gupta 2103
 
31697 amit.gupta 2104
            }
2105
        }
24542 amit.gupta 2106
 
31697 amit.gupta 2107
    }
24548 amit.gupta 2108
 
31697 amit.gupta 2109
    public void sendAgeingReport() throws Exception {
33820 ranu 2110
        sendAgeingReport("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "niranjan.kala@smartdukaan.com", "kuldeep.kumar@smartdukaan.com");
31697 amit.gupta 2111
    }
24542 amit.gupta 2112
 
31697 amit.gupta 2113
    public void moveImeisToPriceDropImeis() throws Exception {
2114
        List<PriceDrop> priceDrops = priceDropRepository.selectAll();
2115
        for (PriceDrop priceDrop : priceDrops) {
2116
            priceDropService.priceDropStatus(priceDrop.getId());
2117
        }
2118
    }
29160 amit.gupta 2119
 
31697 amit.gupta 2120
    public void walletmismatch() throws Exception {
2121
        LocalDate curDate = LocalDate.now();
2122
        List<PartnerDailyInvestment> pdis = partnerDailyInvestmentRepository.selectAll(curDate.minusDays(2));
2123
        System.out.println(pdis.size());
2124
        for (PartnerDailyInvestment pdi : pdis) {
2125
            int fofoId = pdi.getFofoId();
31886 tejbeer 2126
            for (PartnerDailyInvestment investment : Lists.reverse(partnerDailyInvestmentRepository.selectAll(fofoId, null, null))) {
2127
                float statementAmount = walletService.getOpeningTill(fofoId, investment.getDate().plusDays(1).atTime(LocalTime.of(4, 0)));
31697 amit.gupta 2128
                CustomRetailer retailer = retailerService.getFofoRetailer(fofoId);
31886 tejbeer 2129
                LOGGER.info("{}\t{}\t{}\t{}\t{}", fofoId, retailer.getBusinessName(), retailer.getMobileNumber(), investment.getDate().toString(), investment.getWalletAmount(), statementAmount);
29160 amit.gupta 2130
 
31697 amit.gupta 2131
            }
2132
        }
29160 amit.gupta 2133
 
31697 amit.gupta 2134
    }
29160 amit.gupta 2135
 
31697 amit.gupta 2136
    @Autowired
2137
    StateRepository stateRepository;
29160 amit.gupta 2138
 
31697 amit.gupta 2139
    public void gst() throws Exception {
31886 tejbeer 2140
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectBetweenSaleDate(LocalDate.of(2021, 8, 16).atStartOfDay(), LocalDateTime.now());
31697 amit.gupta 2141
        for (FofoOrder fofoOrder : fofoOrders) {
31886 tejbeer 2142
            int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(fofoOrder.getFofoId());
24548 amit.gupta 2143
 
31697 amit.gupta 2144
            Address retailerAddress = addressRepository.selectById(retailerAddressId);
2145
            CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
2146
            Integer stateId = null;
2147
            if (customerAddress.getState().equals(retailerAddress.getState())) {
2148
                try {
2149
                    stateId = stateRepository.selectByName(customerAddress.getState()).getId();
2150
                } catch (Exception e) {
2151
                    LOGGER.error("Cannot found state named {}", customerAddress.getState());
2152
                    continue;
2153
                }
2154
            }
2155
            Map<Integer, GstRate> itemIdStateTaxRateMap = null;
24542 amit.gupta 2156
 
31697 amit.gupta 2157
            List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
2158
            List<Integer> itemIds = fofoOrderItems.stream().map(x -> x.getItemId()).collect(Collectors.toList());
2159
            if (stateId != null) {
2160
                itemIdStateTaxRateMap = stateGstRateRepository.getStateTaxRate(itemIds, stateId);
2161
            } else {
32145 tejbeer 2162
                itemIdStateTaxRateMap = stateGstRateRepository.getIgstTaxRate(itemIds);
31697 amit.gupta 2163
            }
24580 amit.gupta 2164
 
31697 amit.gupta 2165
            for (FofoOrderItem foi : fofoOrderItems) {
2166
                float sgstRate = foi.getSgstRate();
2167
                float cgstRate = foi.getCgstRate();
2168
                float igstRate = foi.getIgstRate();
32145 tejbeer 2169
                foi.setCgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getCgstRate());
2170
                foi.setSgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getSgstRate());
2171
                foi.setIgstRate(itemIdStateTaxRateMap.get(foi.getItemId()).getIgstRate());
24587 amit.gupta 2172
 
32145 tejbeer 2173
                LOGGER.info("Invoice {}, Date {}", fofoOrder.getInvoiceNumber(), fofoOrder.getCreateTimestamp());
2174
                LOGGER.info("customerAddress.getState() {}, retailerAddress.getState() {}", customerAddress.getState(), retailerAddress.getState());
2175
                LOGGER.info("Rates getIgstRate() {}", itemIdStateTaxRateMap.get(foi.getItemId()).getIgstRate());
2176
                LOGGER.info("Rates getCgstRate() {}, getSgstRate() {}", itemIdStateTaxRateMap.get(foi.getItemId()).getCgstRate(), itemIdStateTaxRateMap.get(foi.getItemId()).getSgstRate());
24587 amit.gupta 2177
 
2178
 
31697 amit.gupta 2179
            }
2180
        }
26092 amit.gupta 2181
 
31697 amit.gupta 2182
    }
24590 amit.gupta 2183
 
33256 amit.gupta 2184
    public void schemewalletmismatch() throws ProfitMandiBusinessException {
31697 amit.gupta 2185
        LocalDate dateToReconcile = LocalDate.of(2018, 4, 1);
2186
        while (dateToReconcile.isBefore(LocalDate.now())) {
2187
            reconcileSchemes(dateToReconcile);
2188
            // reconcileOrders(dateTime);
2189
            // reconcileRecharges(dateTime);
2190
            dateToReconcile = dateToReconcile.plusDays(1);
2191
        }
2192
    }
24587 amit.gupta 2193
 
33256 amit.gupta 2194
    private void reconcileSchemes(LocalDate date) throws ProfitMandiBusinessException {
31697 amit.gupta 2195
        LocalDateTime startDate = date.atStartOfDay();
2196
        LocalDateTime endDate = startDate.plusDays(1);
2197
        List<SchemeInOut> siosCreated = schemeInOutRepository.selectAllByCreateDate(startDate, endDate);
2198
        List<SchemeInOut> siosRefunded = schemeInOutRepository.selectAllByRefundDate(startDate, endDate);
2199
        double totalSchemeDisbursed = siosCreated.stream().mapToDouble(x -> x.getAmount()).sum();
2200
        double totalSchemeRolledback = siosRefunded.stream().mapToDouble(x -> x.getAmount()).sum();
2201
        double netSchemeDisbursed = totalSchemeDisbursed - totalSchemeRolledback;
31886 tejbeer 2202
        List<WalletReferenceType> walletReferenceTypes = Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT);
2203
        List<UserWalletHistory> history = userWalletHistoryRepository.selectAllByDateType(startDate, endDate, walletReferenceTypes);
31697 amit.gupta 2204
        double schemeAmountWalletTotal = history.stream().mapToDouble(x -> x.getAmount()).sum();
2205
        if (Math.abs(netSchemeDisbursed - schemeAmountWalletTotal) > 10d) {
2206
            LOGGER.info("Scheme Amount mismatched for Date {}", date);
24590 amit.gupta 2207
 
31724 amit.gupta 2208
            Map<Integer, Double> inventoryItemSchemeIO = siosCreated.stream().collect(groupingBy(x -> x.getInventoryItemId(), Collectors.summingDouble(SchemeInOut::getAmount)));
24635 amit.gupta 2209
 
31886 tejbeer 2210
            Map<Integer, Double> userSchemeMap = inventoryItemRepository.selectByIds(inventoryItemSchemeIO.keySet()).stream().collect(groupingBy(x -> x.getFofoId(), Collectors.summingDouble(x -> inventoryItemSchemeIO.get(x.getId()))));
24635 amit.gupta 2211
 
31724 amit.gupta 2212
            Map<Integer, Double> inventoryItemSchemeIORefunded = siosRefunded.stream().collect(groupingBy(x -> x.getInventoryItemId(), Collectors.summingDouble(SchemeInOut::getAmount)));
24635 amit.gupta 2213
 
31886 tejbeer 2214
            Map<Integer, Double> userSchemeRefundedMap = inventoryItemRepository.selectByIds(inventoryItemSchemeIORefunded.keySet()).stream().collect(groupingBy(x -> x.getFofoId(), Collectors.summingDouble(x -> inventoryItemSchemeIORefunded.get(x.getId()))));
24635 amit.gupta 2215
 
31697 amit.gupta 2216
            Map<Integer, Double> finalUserSchemeAmountMap = new HashMap<>();
24635 amit.gupta 2217
 
33452 amit.gupta 2218
            for (Entry<Integer, Double> schemeAmount : userSchemeRefundedMap.entrySet()) {
31697 amit.gupta 2219
                if (!finalUserSchemeAmountMap.containsKey(schemeAmount.getKey())) {
2220
                    finalUserSchemeAmountMap.put(schemeAmount.getKey(), schemeAmount.getValue());
2221
                } else {
31886 tejbeer 2222
                    finalUserSchemeAmountMap.put(schemeAmount.getKey(), finalUserSchemeAmountMap.get(schemeAmount.getKey()) + schemeAmount.getValue());
31697 amit.gupta 2223
                }
2224
            }
31886 tejbeer 2225
            Map<Integer, Integer> userWalletMap = userWalletRepository.selectByRetailerIds(finalUserSchemeAmountMap.keySet()).stream().collect(Collectors.toMap(UserWallet::getUserId, UserWallet::getId));
24635 amit.gupta 2226
 
31724 amit.gupta 2227
            Map<Integer, Double> walletAmountMap = history.stream().collect(groupingBy(
31697 amit.gupta 2228
                    UserWalletHistory::getWalletId, Collectors.summingDouble((UserWalletHistory::getAmount))));
33452 amit.gupta 2229
            for (Entry<Integer, Double> userAmount : walletAmountMap.entrySet()) {
31697 amit.gupta 2230
                double diff = Math.abs(finalUserSchemeAmountMap.get(userAmount.getKey()) - userAmount.getValue());
2231
                if (diff > 5) {
2232
                    LOGGER.info("Partner scheme mismatched for Userid {}", userWalletMap.get(userAmount.getKey()));
2233
                }
2234
            }
2235
        }
24635 amit.gupta 2236
 
31697 amit.gupta 2237
    }
24635 amit.gupta 2238
 
31697 amit.gupta 2239
    public void sendDailySalesNotificationToPartner(Integer fofoIdInt) throws Exception {
30982 tejbeer 2240
 
31697 amit.gupta 2241
        LocalDateTime now = LocalDateTime.now();
2242
        LocalDateTime from = now.with(LocalTime.MIN);
2243
        String timeString = "Today %s";
2244
        // Send yesterday's report
2245
        /*
2246
         * if (now.getHour() < 13) { timeString = "Yesterday %s"; from =
2247
         * now.minusDays(1).; now = from.with(LocalTime.MAX);
2248
         *
2249
         * }
2250
         */
30982 tejbeer 2251
 
31697 amit.gupta 2252
        List<Integer> fofoIds = null;
31886 tejbeer 2253
        Map<Integer, FofoStore> fofoStoreMap = fofoStoreRepository.selectAll().stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getId(), x -> x));
30982 tejbeer 2254
 
24653 govind 2255
 
31697 amit.gupta 2256
        if (fofoIdInt == null) {
2257
            fofoIds = new ArrayList<>(fofoStoreMap.keySet());
2258
        } else {
2259
            fofoIds = Arrays.asList(fofoIdInt);
2260
        }
2261
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("h:m a");
28368 tejbeer 2262
 
31886 tejbeer 2263
        Map<Integer, Float> partnerPolicyAmountMap = insurancePolicyRepository.selectAmountSumGroupByRetailerId(now, null);
31697 amit.gupta 2264
        Map<Integer, Long> partnerPolicyQtyMap = insurancePolicyRepository.selectQtyGroupByRetailerId(now, null);
28368 tejbeer 2265
 
31886 tejbeer 2266
        Map<Integer, Double> spPartnerOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from, now, 0, true);
28377 tejbeer 2267
 
31886 tejbeer 2268
        Map<Integer, Double> spPartner3DaysOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from.minusDays(3), now, 0, true);
31697 amit.gupta 2269
        Map<Integer, Long> spPartnerOrderQtyMap = fofoOrderItemRepository.selectQtyGroupByRetailer(from, now, 0, true);
28368 tejbeer 2270
 
31886 tejbeer 2271
        Map<Integer, Double> partnerOrderValMap = fofoOrderItemRepository.selectSumAmountGroupByRetailer(from, now, 0, false);
31697 amit.gupta 2272
        Map<Integer, Long> partnerOrderQtyMap = fofoOrderItemRepository.selectQtyGroupByRetailer(from, now, 0, false);
28377 tejbeer 2273
 
31697 amit.gupta 2274
        //4 days + current day running
2275
        Map<Integer, Double> partnerBilledValueMap = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(from.minusDays(4), now);
28377 tejbeer 2276
 
31697 amit.gupta 2277
        Map<Integer, SaleTargetReportModel> saleTargetReportModelMap = new HashMap<>();
2278
        for (int fofoId : fofoIds) {
2279
            SaleTargetReportModel model = new SaleTargetReportModel();
2280
            model.setInsuranceSale(
2281
                    partnerPolicyAmountMap.containsKey(fofoId) ? partnerPolicyAmountMap.get(fofoId).doubleValue() : 0);
2282
            model.setInsruanceQty(partnerPolicyQtyMap.containsKey(fofoId) ? partnerPolicyQtyMap.get(fofoId) : 0);
2283
            model.setSecondary(partnerBilledValueMap.containsKey(fofoId) ? partnerBilledValueMap.get(fofoId) : 0);
2284
            model.setSmartphoneSale(spPartnerOrderValMap.containsKey(fofoId) ? spPartnerOrderValMap.get(fofoId) : 0);
2285
            model.setSmartphoneQty(spPartnerOrderQtyMap.containsKey(fofoId) ? spPartnerOrderQtyMap.get(fofoId) : 0);
2286
            model.setTotalSale(partnerOrderValMap.containsKey(fofoId) ? partnerOrderValMap.get(fofoId) : 0);
2287
            model.setTotalQty(partnerOrderQtyMap.containsKey(fofoId) ? partnerOrderQtyMap.get(fofoId) : 0);
2288
            model.setPast3daysSale(
2289
                    spPartner3DaysOrderValMap.containsKey(fofoId) ? spPartner3DaysOrderValMap.get(fofoId) : 0);
2290
            model.setFofoId(fofoId);
2291
            model.setCode(fofoStoreMap.get(fofoId).getCode());
31724 amit.gupta 2292
            model.setActivationType(fofoStoreMap.get(fofoId).getActivationType());
31697 amit.gupta 2293
            saleTargetReportModelMap.put(fofoId, model);
2294
        }
28377 tejbeer 2295
 
31697 amit.gupta 2296
        Map<Integer, FofoReportingModel> partnerSalesHeadersMap = this.getPartnerIdSalesHeaders();
2297
        for (Integer fofoId : fofoIds) {
2298
            SaleTargetReportModel model = saleTargetReportModelMap.get(fofoId);
28368 tejbeer 2299
 
31697 amit.gupta 2300
            // com.spice.profitmandi.dao.entity.user.User user =
2301
            // userUserRepository.selectById(fofoId);
28377 tejbeer 2302
 
31697 amit.gupta 2303
            // Address address = addressRepository.selectById(user.getAddressId());
28377 tejbeer 2304
 
31697 amit.gupta 2305
            String title = "Sale Update";
31886 tejbeer 2306
            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 2307
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
2308
            sendNotificationModel.setCampaignName("Sales update alert");
2309
            sendNotificationModel.setTitle(title);
2310
            sendNotificationModel.setMessage(messageTemplate);
2311
            sendNotificationModel.setType("url");
2312
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
2313
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(1));
2314
            sendNotificationModel.setMessageType(MessageType.notification);
2315
            int userId = userAccountRepository.selectUserIdByRetailerId(fofoId);
2316
            sendNotificationModel.setUserIds(Arrays.asList(userId));
2317
            notificationService.sendNotification(sendNotificationModel);
2318
            String whatsappMessageTemplate = String.format(
31886 tejbeer 2319
                    "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 2320
            // notificationService.sendWhatsappMessage(whatsappMessageTemplate, title,
2321
            // address.getPhoneNumber());
28377 tejbeer 2322
 
31697 amit.gupta 2323
        }
2324
        // String saleReport = this.getDailySalesReportHtml(partnerSalesHeadersMap,
2325
        // saleTargetReportModelMap);
2326
        this.getStateWiseSales(saleTargetReportModelMap, partnerSalesHeadersMap);
2327
    }
28377 tejbeer 2328
 
31697 amit.gupta 2329
    public void checkRazorPayPaymentStatus() throws Exception {
31886 tejbeer 2330
        List<PendingOrder> pendingOrder = pendingOrderRepository.selectAllByStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PENDING);
28377 tejbeer 2331
 
31697 amit.gupta 2332
        for (PendingOrder po : pendingOrder) {
2333
            RazorPay razorPay = razorPayRepository.selectByOrdeId(po.getId());
2334
            List<PendingOrderItem> poItems = pendingOrderItemRepository.selectByOrderId(po.getId());
28369 tejbeer 2335
 
31697 amit.gupta 2336
            LOGGER.info("razorPay" + razorPay);
2337
            if (razorPay != null) {
2338
                List<Payment> payments = razorPaymentService.fetchOrderForPayment(razorPay.getRazorOrderId());
28368 tejbeer 2339
 
31697 amit.gupta 2340
                if (!payments.isEmpty()) {
2341
                    List<String> statusList = new ArrayList<>();
2342
                    for (Payment payment : payments) {
25880 amit.gupta 2343
 
31697 amit.gupta 2344
                        JSONObject jsonObj = new JSONObject(payment.toString());
25880 amit.gupta 2345
 
31697 amit.gupta 2346
                        String status = jsonObj.getString("status");
25880 amit.gupta 2347
 
31697 amit.gupta 2348
                        statusList.add(status);
25865 amit.gupta 2349
 
31697 amit.gupta 2350
                    }
2351
                    LOGGER.info("statusList" + statusList);
26941 amit.gupta 2352
 
31697 amit.gupta 2353
                    if (statusList.contains("authorized") || statusList.contains("captured")) {
2354
                        po.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PROCESSING);
2355
                        po.setPaidAmount(po.getTotalAmount());
2356
                        for (PendingOrderItem poi : poItems) {
2357
                            poi.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.PROCESSING);
2358
                        }
2359
                        Map<String, Object> emailModel = pendingOrderService.sendCreateOrderMail(po);
26941 amit.gupta 2360
 
31697 amit.gupta 2361
                        CustomRetailer customRetailer = retailerService.getFofoRetailer(po.getFofoId());
2362
                        Customer customer = customerRepository.selectById(po.getCustomerId());
2363
                        String[] customerEmail = null;
2364
                        if (customer.getEmailId() != null) {
2365
                            customerEmail = new String[]{customer.getEmailId()};
2366
                        }
31886 tejbeer 2367
                        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 2368
                        List<String> authUserEmails = csService.getAuthUserByPartnerId(customRetailer.getPartnerId());
2369
                        if (authUserEmails != null) {
2370
                            authUserEmails = new ArrayList<>();
2371
                        }
2372
                        authUserEmails.addAll(bccTo);
26945 amit.gupta 2373
 
31697 amit.gupta 2374
                        // emailService.sendMailWithAttachments("Order Created with SmartDukaan",
2375
                        // "order-confirm.vm",
2376
                        // emailModel, customerEmail, null, authUserEmails.toArray(new String[0]));
26945 amit.gupta 2377
 
31697 amit.gupta 2378
                    } else if (statusList.contains("refunded") || statusList.contains("failed")) {
2379
                        for (PendingOrderItem poi : poItems) {
2380
                            poi.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.FAILED);
2381
                        }
25865 amit.gupta 2382
 
31697 amit.gupta 2383
                        po.setStatus(com.spice.profitmandi.dao.enumuration.transaction.OrderStatus.FAILED);
2384
                    }
25865 amit.gupta 2385
 
31697 amit.gupta 2386
                }
2387
                // LOGGER.info("payment" + payments);
25865 amit.gupta 2388
 
31697 amit.gupta 2389
            }
2390
        }
2391
    }
25865 amit.gupta 2392
 
31697 amit.gupta 2393
    public static class SaleTargetReportModel {
2394
        private double totalSale;
2395
        private long totalQty;
2396
        private double past3daysSale;
2397
        private int fofoId;
2398
        private String code;
31724 amit.gupta 2399
        private ActivationType activationType;
25865 amit.gupta 2400
 
31724 amit.gupta 2401
 
2402
        @Override
2403
        public boolean equals(Object o) {
2404
            if (this == o) return true;
2405
            if (o == null || getClass() != o.getClass()) return false;
2406
            SaleTargetReportModel that = (SaleTargetReportModel) o;
2407
            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;
2408
        }
2409
 
2410
        @Override
2411
        public int hashCode() {
2412
            return Objects.hash(totalSale, totalQty, past3daysSale, fofoId, code, activationType, secondary, smartphoneSale, smartphoneQty, insuranceSale, insruanceQty);
2413
        }
2414
 
2415
        public ActivationType getActivationType() {
2416
            return activationType;
2417
        }
2418
 
2419
        public void setActivationType(ActivationType activationType) {
2420
            this.activationType = activationType;
2421
        }
2422
 
31697 amit.gupta 2423
        public double getSecondary() {
2424
            return secondary;
2425
        }
25865 amit.gupta 2426
 
31697 amit.gupta 2427
        public void setSecondary(double secondary) {
2428
            this.secondary = secondary;
2429
        }
25865 amit.gupta 2430
 
31697 amit.gupta 2431
        private double secondary;
25865 amit.gupta 2432
 
31697 amit.gupta 2433
        public int getFofoId() {
2434
            return fofoId;
2435
        }
25865 amit.gupta 2436
 
31697 amit.gupta 2437
        @Override
2438
        public String toString() {
31886 tejbeer 2439
            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 2440
        }
25865 amit.gupta 2441
 
31697 amit.gupta 2442
        public String getCode() {
2443
            return code;
2444
        }
25865 amit.gupta 2445
 
31697 amit.gupta 2446
        public void setCode(String code) {
2447
            this.code = code;
2448
        }
25865 amit.gupta 2449
 
31697 amit.gupta 2450
        public void setFofoId(int fofoId) {
2451
            this.fofoId = fofoId;
2452
        }
25872 tejbeer 2453
 
31697 amit.gupta 2454
        private double smartphoneSale;
2455
        private long smartphoneQty;
2456
        private double insuranceSale;
2457
        private long insruanceQty;
26945 amit.gupta 2458
 
31697 amit.gupta 2459
        public long getTotalQty() {
2460
            return totalQty;
2461
        }
30765 tejbeer 2462
 
31697 amit.gupta 2463
        public void setTotalQty(long totalQty) {
2464
            this.totalQty = totalQty;
2465
        }
2466
 
2467
        public double getPast3daysSale() {
2468
            return past3daysSale;
2469
        }
2470
 
2471
        public void setPast3daysSale(double past3daysSale) {
2472
            this.past3daysSale = past3daysSale;
2473
        }
2474
 
2475
        public double getTotalSale() {
2476
            return totalSale;
2477
        }
2478
 
2479
        public void setTotalSale(double totalSale) {
2480
            this.totalSale = totalSale;
2481
        }
2482
 
2483
        public double getSmartphoneSale() {
2484
            return smartphoneSale;
2485
        }
2486
 
2487
        public void setSmartphoneSale(double smartphoneSale) {
2488
            this.smartphoneSale = smartphoneSale;
2489
        }
2490
 
2491
        public long getSmartphoneQty() {
2492
            return smartphoneQty;
2493
        }
2494
 
2495
        public void setSmartphoneQty(long smartphoneQty) {
2496
            this.smartphoneQty = smartphoneQty;
2497
        }
2498
 
2499
        public double getInsuranceSale() {
2500
            return insuranceSale;
2501
        }
2502
 
2503
        public void setInsuranceSale(double insuranceSale) {
2504
            this.insuranceSale = insuranceSale;
2505
        }
2506
 
2507
        public long getInsruanceQty() {
2508
            return insruanceQty;
2509
        }
2510
 
2511
        public void setInsruanceQty(long insruanceQty) {
2512
            this.insruanceQty = insruanceQty;
2513
        }
2514
 
2515
    }
2516
 
32482 amit.gupta 2517
    private void getStateWiseSales
2518
            (Map<Integer, SaleTargetReportModel> saleTargetReportModelMap, Map<Integer, FofoReportingModel> partnerSalesHeadersMap) throws
2519
            Exception {
31697 amit.gupta 2520
        String timeString = "Today %s";
2521
        LocalDateTime now = LocalDateTime.now();
2522
 
2523
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("h:m a");
35521 amit 2524
        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_ABM, ProfitMandiConstants.TICKET_CATEGORY_MARKETING, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT, ProfitMandiConstants.TICKET_CATEGORY_TECHNOLOGY);
31697 amit.gupta 2525
 
2526
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false);
2527
 
31746 amit.gupta 2528
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
2529
            String email = storeGuyEntry.getKey();
2530
            Set<Integer> fofoIds = storeGuyEntry.getValue();
2531
            LOGGER.info("fofoIds {}", fofoIds);
24683 amit.gupta 2532
 
31746 amit.gupta 2533
            if (!fofoIds.isEmpty()) {
31886 tejbeer 2534
                List<FofoStore> stores = fofoStoreRepository.selectActivePartnersByRetailerIds(new ArrayList<>(fofoIds));
26945 amit.gupta 2535
 
31724 amit.gupta 2536
                Map<String, List<Integer>> stateMap = stores.stream().collect(groupingBy(
2537
                        x -> x.getCode().substring(0, 2), mapping(x -> x.getId(), Collectors.toList())));
31697 amit.gupta 2538
                List<List<Serializable>> stateWiseSales = new ArrayList<>();
33452 amit.gupta 2539
                for (Entry<String, List<Integer>> stateMapEntry : stateMap.entrySet()) {
31886 tejbeer 2540
                    long totalQty = stateMapEntry.getValue().stream().collect(Collectors.summingLong(x -> saleTargetReportModelMap.get(x).getTotalQty()));
2541
                    double totalSale = stateMapEntry.getValue().stream().collect(Collectors.summingDouble(x -> saleTargetReportModelMap.get(x).getTotalSale()));
2542
                    long smartPhoneQty = stateMapEntry.getValue().stream().collect(Collectors.summingLong(x -> saleTargetReportModelMap.get(x).getSmartphoneQty()));
31697 amit.gupta 2543
                    double smartPhoneSale = stateMapEntry.getValue().stream().collect(
2544
                            Collectors.summingDouble(x -> saleTargetReportModelMap.get(x).getSmartphoneSale()));
2545
                    stateWiseSales.add(
2546
                            Arrays.asList(stateMapEntry.getKey(), smartPhoneQty, smartPhoneSale, totalQty, totalSale));
2547
                }
2548
                StringBuilder sb = new StringBuilder();
2549
                sb.append("<html><body>");
2550
                sb.append("<p>Statewise Sale Report:</p><br/><table style=\"border-collapse: collapse;\">");
31886 tejbeer 2551
                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 2552
                for (List<Serializable> stateSale : stateWiseSales) {
2553
                    sb.append("<tr>");
2554
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(0) + "</td>");
2555
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(1) + "</td>");
2556
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(2) + "</td>");
2557
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(3) + "</td>");
2558
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + stateSale.get(4) + "</td>");
2559
                    sb.append("</tr>");
2560
                }
2561
                sb.append("</tbody></table><br><br>");
26945 amit.gupta 2562
 
31697 amit.gupta 2563
                sb.append("<p>Partnerwise Report:</p><br/><table style=\"border-collapse: collapse;\">");
31886 tejbeer 2564
                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 2565
 
2566
 
31886 tejbeer 2567
                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 2568
 
31697 amit.gupta 2569
                String subject = String.format("Sale till %s", String.format(timeString, now.format(timeFormatter)));
31169 tejbeer 2570
 
31886 tejbeer 2571
                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 2572
                List<List<?>> rows = new ArrayList<>();
2573
                for (Integer fofoId : sortedSaleTargetReport) {
2574
                    FofoReportingModel fofoReportingModel = partnerSalesHeadersMap.get(fofoId);
31886 tejbeer 2575
                    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 2576
                    ));
31169 tejbeer 2577
 
31724 amit.gupta 2578
                    //Now try to populate html rows
2579
                    if (!saleTargetReportModelMap.get(fofoId).getActivationType().equals(ActivationType.ACTIVE)) {
31697 amit.gupta 2580
                        continue;
2581
                    }
2582
                    if (saleTargetReportModelMap.get(fofoId).getSecondary() == 0) {
2583
                        sb.append("<tr style='background-color:#D21F3C;color:white'>");
2584
                    } else {
2585
                        sb.append("<tr>");
2586
                    }
31886 tejbeer 2587
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getCode() + "</td>");
2588
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getBusinessName() + "</td>");
2589
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getBusinessManager() + "</td>");
2590
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getRegionalManager() + "</td>");
2591
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + partnerSalesHeadersMap.get(fofoId).getTerritoryManager() + "</td>");
2592
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSecondary() + "</td>");
2593
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getTotalSale() + "</td>");
2594
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSmartphoneSale() + "</td>");
2595
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + saleTargetReportModelMap.get(fofoId).getSmartphoneQty() + "</td>");
31697 amit.gupta 2596
                    sb.append("</tr>");
24841 govind 2597
 
25300 tejbeer 2598
 
31697 amit.gupta 2599
                }
2600
                sb.append("</tr>");
2601
                sb.append("</body></html>");
2602
                String statewiseSaleReport = sb.toString();
25300 tejbeer 2603
 
2604
 
31697 amit.gupta 2605
                ByteArrayOutputStream baos = null;
2606
                try {
2607
                    baos = FileUtil.getCSVByteStream(headers, rows);
2608
                } catch (Exception e2) {
2609
                    e2.printStackTrace();
2610
                }
2611
                Attachment attachment = new Attachment("PartnerSalePerformance.csv", new ByteArrayResource(baos.toByteArray()));
36460 ranu 2612
                Utils.sendHtmlMailWithAttachments(googleMailSender, new String[]{email}, null, "Statewise " + subject, statewiseSaleReport, attachment);
31697 amit.gupta 2613
            }
2614
        }
2615
    }
29668 tejbeer 2616
 
32350 amit.gupta 2617
 
32482 amit.gupta 2618
    private void sendMailOfHtmlFormat(JavaMailSender sender, String[] email, String body, String cc[], String subject) throws
2619
            MessagingException, ProfitMandiBusinessException, IOException {
32350 amit.gupta 2620
        MimeMessage message = sender.createMimeMessage();
31697 amit.gupta 2621
        MimeMessageHelper helper = new MimeMessageHelper(message);
2622
        helper.setSubject(subject);
2623
        helper.setText(body, true);
2624
        helper.setTo(email);
2625
        if (cc != null) {
2626
            helper.setCc(cc);
2627
        }
36463 ranu 2628
        InternetAddress senderAddress = new InternetAddress("sdtech@smartdukaan.com", "Smart Dukaan");
31697 amit.gupta 2629
        helper.setFrom(senderAddress);
36472 amit 2630
        sender.send(message);
31697 amit.gupta 2631
    }
25694 amit.gupta 2632
 
31697 amit.gupta 2633
    public void sendNotification() throws Exception {
34042 vikas.jang 2634
        LOGGER.info("FCM sendNotification");
32610 amit.gupta 2635
        List<PushNotifications> pushNotifications = pushNotificationRepository.selectAllPendingNotifications();
31697 amit.gupta 2636
        if (!pushNotifications.isEmpty()) {
34042 vikas.jang 2637
            InputStream serviceAccount = getClass().getClassLoader().getResourceAsStream("service-account.json");
34039 vikas.jang 2638
            GoogleCredentials googleCredentials = GoogleCredentials.fromStream(serviceAccount).createScoped(FCM_SCOPED);
2639
            googleCredentials.refreshIfExpired();
2640
            String accessToken = googleCredentials.getAccessToken().getTokenValue();
2641
 
31697 amit.gupta 2642
            for (PushNotifications pushNotification : pushNotifications) {
2643
                Device device = deviceRepository.selectById(pushNotification.getDeviceId());
31886 tejbeer 2644
                NotificationCampaign notificationCampaign = notificationCampaignRepository.selectById(pushNotification.getNotificationCampaignid());
2645
                SimpleCampaignParams scp = gson.fromJson(notificationCampaign.getImplementationParams(), SimpleCampaignParams.class);
31697 amit.gupta 2646
                Campaign campaign = new SimpleCampaign(scp);
2647
                String result_url = campaign.getUrl() + "&user_id=" + device.getUser_id();
34039 vikas.jang 2648
 
2649
                JSONObject message = new JSONObject();
2650
                message.put("token", device.getFcmId());
2651
 
2652
                JSONObject notification = new JSONObject();
2653
                notification.put("title", campaign.getTitle());
2654
                notification.put("body", campaign.getMessage());
2655
                message.put("notification", notification);
2656
 
2657
                JSONObject data = new JSONObject();
2658
                data.put("type", campaign.getType());
2659
                data.put("url", result_url);
2660
                data.put("time_to_live", campaign.getExpireTimestamp());
2661
                data.put("image", campaign.getImageUrl());
2662
                data.put("largeIcon", "large_icon");
2663
                data.put("smallIcon", "small_icon");
34043 vikas.jang 2664
                data.put("vibrate", "1");
34044 vikas.jang 2665
                data.put("pid", String.valueOf(pushNotification.getId()));
34043 vikas.jang 2666
                data.put("sound", "1");
34039 vikas.jang 2667
                data.put("priority", "high");
2668
                message.put("data", data);
2669
 
2670
                JSONObject payload = new JSONObject();
2671
                payload.put("message", message);
2672
 
31697 amit.gupta 2673
                try {
36420 amit 2674
                    CloseableHttpClient client = HttpClientFactory.apacheHttp();
31697 amit.gupta 2675
                    HttpPost httpPost = new HttpPost(FCM_URL);
25694 amit.gupta 2676
 
34039 vikas.jang 2677
                    httpPost.setHeader("Authorization", "Bearer " + accessToken);
2678
                    httpPost.setHeader("Content-Type", "application/json");
2679
 
2680
                    StringEntity entity = new StringEntity(payload.toString());
31697 amit.gupta 2681
                    httpPost.setEntity(entity);
2682
                    CloseableHttpResponse response = client.execute(httpPost);
34275 tejus.loha 2683
                    LOGGER.info("google FCM status code: {}", response.getStatusLine().getStatusCode());
34043 vikas.jang 2684
                    String responseBody = new BufferedReader(new InputStreamReader(response.getEntity().getContent()))
2685
                            .lines().collect(Collectors.joining("\n"));
31697 amit.gupta 2686
                    if (response.getStatusLine().getStatusCode() == 200) {
2687
                        pushNotification.setSentTimestamp(LocalDateTime.now());
2688
                    } else {
2689
                        pushNotification.setSentTimestamp(LocalDateTime.of(1970, 1, 1, 00, 00));
34043 vikas.jang 2690
                        LOGGER.info("FCM Response message" + responseBody);
31697 amit.gupta 2691
                        response.toString();
2692
                    }
25694 amit.gupta 2693
 
31697 amit.gupta 2694
                } catch (Exception e) {
2695
                    e.printStackTrace();
2696
                    pushNotification.setSentTimestamp(LocalDateTime.of(1970, 1, 1, 00, 00));
2697
                    LOGGER.info("message " + "not sent " + e.getMessage());
2698
                }
2699
            }
2700
        }
2701
    }
25721 tejbeer 2702
 
31697 amit.gupta 2703
    public void grouping() throws Exception {
2704
        DateTimeFormatter dtf = DateTimeFormatter.ofPattern("MM-dd-yyyy hh:mm");
2705
        List<PriceDropIMEI> priceDropImeis = priceDropIMEIRepository.selectByStatus(PriceDropImeiStatus.APPROVED);
31886 tejbeer 2706
        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 2707
        Map<Integer, CustomRetailer> retailersMap = retailerService.getFofoRetailers(false);
2708
        for (PriceDropIMEI priceDropIMEI : priceDropImeis) {
2709
            if (priceDropIMEI.getPartnerId() == 0)
2710
                continue;
2711
            HashSet<String> imeis = new HashSet<>();
2712
            PriceDrop priceDrop = priceDropRepository.selectById(priceDropIMEI.getPriceDropId());
2713
            imeis.add(priceDropIMEI.getImei());
31886 tejbeer 2714
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(priceDropIMEI.getPartnerId(), imeis, false);
31697 amit.gupta 2715
            if (inventoryItems.size() == 0) {
2716
                LOGGER.info("Need to investigate partnerId - {} imeis - {}", priceDropIMEI.getPartnerId(), imeis);
2717
                continue;
2718
            }
2719
            InventoryItem inventoryItem = inventoryItems.get(0);
2720
            CustomRetailer customRetailer = retailersMap.get(inventoryItem.getFofoId());
31886 tejbeer 2721
            if (inventoryItem.getLastScanType().equals(ScanType.DOA_OUT) || inventoryItem.getLastScanType().equals(ScanType.PURCHASE_RET)) {
31697 amit.gupta 2722
                // check if pricedrop has been rolled out
31886 tejbeer 2723
                List<UserWalletHistory> uwh = walletService.getAllByReference(inventoryItem.getFofoId(), priceDropIMEI.getPriceDropId(), WalletReferenceType.PRICE_DROP);
31697 amit.gupta 2724
                if (uwh.size() > 0) {
2725
                    Item item = itemRepository.selectById(inventoryItem.getItemId());
31886 tejbeer 2726
                    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 2727
                }
2728
            }
2729
        }
2730
    }
25721 tejbeer 2731
 
31697 amit.gupta 2732
    public void toffeeRollback() throws Exception {
2733
        toffeeService.cancelPolicyCopy("110143521986");
2734
        toffeeService.getOrderId("110143521986");
2735
    }
27212 tejbeer 2736
 
31697 amit.gupta 2737
    public void attachToffeeInvoices() throws Exception {
31886 tejbeer 2738
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectAllByProviderId(3, Optional.of(false));
31697 amit.gupta 2739
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
2740
            String invoiceNumber = insurancePolicy.getInvoiceNumber();
2741
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
2742
            InvoicePdfModel pdfModel = orderService.getInvoicePdfModel(fofoOrder.getId());
2743
            java.io.ByteArrayOutputStream byteArrayOutputStream = new java.io.ByteArrayOutputStream();
2744
            PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
31886 tejbeer 2745
            String pdfInvoiceString = "data:application/pdf;base64," + Base64.getEncoder().encodeToString(byteArrayOutputStream.toByteArray());
2746
            boolean attached = toffeeService.attachInvoice(insurancePolicy.getPolicyNumber().split("#")[1], pdfInvoiceString);
31697 amit.gupta 2747
            if (attached) {
2748
                insurancePolicy.setPosted(true);
2749
            }
2750
        }
2751
    }
25721 tejbeer 2752
 
31697 amit.gupta 2753
    public void sendBAGPendingPolicies() throws Exception {
31886 tejbeer 2754
        List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectAllByProviderId(4, Optional.of(false));
31697 amit.gupta 2755
        for (InsurancePolicy insurancePolicy : insurancePolicies) {
2756
            String invoiceNumber = insurancePolicy.getInvoiceNumber();
2757
            FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
2758
            FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId()).get(0);
2759
            CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
2760
            Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
2761
            BAGInsuranceModel bagInsuranceModel = new BAGInsuranceModel();
2762
            // bagInsuranceModel.setModelId();
2763
            bagInsuranceModel.setAddressLine1(customerAddress.getLine1());
2764
            bagInsuranceModel.setAddressLine2(customerAddress.getLine2());
2765
            bagInsuranceModel.setCity(customerAddress.getCity());
2766
            bagInsuranceModel.setBrandWarranty("1 Year");
2767
            Item item = itemRepository.selectById(fofoOrderItem.getId());
2768
            bagInsuranceModel.setModelName(item.getItemDescription());
2769
            bagInsuranceModel.setDateOfPurchase(fofoOrder.getFormattedDate());
2770
            bagInsuranceModel.setEmail(customer.getEmailId());
2771
            bagInsuranceModel.setImei1(insurancePolicy.getSerialNumber());
2772
            bagInsuranceModel.setFirstName(customer.getFirstName());
2773
            bagInsuranceModel.setLastName(customer.getLastName());
2774
            bagInsuranceModel.setMobileNumber(customer.getMobileNumber());
2775
            bagInsuranceModel.setPlanId("");
2776
            insurancePolicy.setPosted(true);
2777
        }
2778
    }
25721 tejbeer 2779
 
31697 amit.gupta 2780
    public void schemeRollback(List<String> schemeIds) throws Exception {
2781
        List<Integer> schemeIdsInt = schemeIds.stream().map(x -> Integer.parseInt(x)).collect(Collectors.toList());
31886 tejbeer 2782
        Map<Integer, Scheme> schemesMap = schemeRepository.selectBySchemeIds(schemeIdsInt, 0, schemeIds.size()).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
31697 amit.gupta 2783
        List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectBySchemeIds(new HashSet<>(schemeIdsInt));
2784
        for (SchemeInOut sio : schemeInOuts) {
2785
            Scheme scheme = schemesMap.get(sio.getSchemeId());
34324 amit.gupta 2786
            if (scheme.getType().getTransactionType().equals(StockTransactionType.IN)) {
25721 tejbeer 2787
 
34324 amit.gupta 2788
            } else if (scheme.getType().getTransactionType().equals(StockTransactionType.OUT)) {
31697 amit.gupta 2789
                InventoryItem inventoryItem = inventoryItemRepository.selectById(sio.getInventoryItemId());
2790
                List<ScanRecord> sr = scanRecordRepository.selectByInventoryItemId(sio.getInventoryItemId());
31886 tejbeer 2791
                ScanRecord scanRecord = sr.stream().filter(x -> x.getType().equals(ScanType.SALE)).max((x1, x2) -> x1.getCreateTimestamp().compareTo(x2.getCreateTimestamp())).get();
2792
                if (scanRecord.getCreateTimestamp().isAfter(scheme.getEndDateTime()) || scanRecord.getCreateTimestamp().isBefore(scheme.getStartDateTime())) {
31697 amit.gupta 2793
                    sio.setRolledBackTimestamp(LocalDateTime.now());
2794
                    FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(scanRecord.getOrderId());
31886 tejbeer 2795
                    String rollbackReason = "Scheme reversed for " + itemRepository.selectById(inventoryItem.getItemId()).getItemDescription() + "/Inv - " + fofoOrder.getInvoiceNumber();
2796
                    walletService.rollbackAmountFromWallet(scanRecord.getFofoId(), sio.getAmount(), scanRecord.getOrderId(), WalletReferenceType.SCHEME_OUT, rollbackReason, LocalDateTime.now());
2797
                    System.out.printf("Amount %f,SchemeId %d,Reason %s\n", sio.getAmount(), sio.getSchemeId(), rollbackReason);
31697 amit.gupta 2798
                }
2799
            }
2800
        }
2801
        // throw new Exception();
2802
    }
25721 tejbeer 2803
 
31697 amit.gupta 2804
    public void checkfocusedModelInPartnerStock() throws Exception {
25721 tejbeer 2805
 
35442 amit 2806
        // ========== PHASE 1: Batch fetch all data upfront ==========
2807
        Map<Integer, FofoStore> fofoStoreMap = fofoStoreRepository.selectActiveStores().stream()
2808
                .collect(Collectors.toMap(FofoStore::getId, x -> x));
2809
        List<Integer> allPartnerIds = new ArrayList<>(fofoStoreMap.keySet());
2810
 
31886 tejbeer 2811
        Map<Integer, Map<Integer, List<SaholicCIS>>> warehouseItemAvailabilityMap = saholicInventoryService.getSaholicStock();
31697 amit.gupta 2812
        Map<Integer, String> warehouseMap = ProfitMandiConstants.WAREHOUSE_MAP;
2813
        Map<Integer, FofoReportingModel> partnerIdSalesHeadersMap = this.getPartnerIdSalesHeaders();
35442 amit 2814
        Map<Integer, List<FocusedModel>> regionFocusedModelsMap = focusedModelRepository.selectAll().stream()
2815
                .collect(Collectors.groupingBy(FocusedModel::getRegionId));
2816
        LOGGER.info("regionFocusedModelsMap - {}", regionFocusedModelsMap);
31886 tejbeer 2817
        Map<Integer, Map<Integer, List<SaholicPOItem>>> warehousePoItemAvailabilityMap = saholicInventoryService.getSaholicPOItems();
35442 amit 2818
 
2819
        // Batch fetch all customRetailers upfront
2820
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(allPartnerIds);
2821
        LOGGER.info("Fetched {} customRetailers", customRetailerMap.size());
2822
 
2823
        // Batch fetch all inventory snapshots upfront
2824
        Map<Integer, List<CurrentInventorySnapshot>> allInventorySnapshotsMap = currentInventorySnapshotRepository
2825
                .selectByFofoId(allPartnerIds).stream()
2826
                .collect(Collectors.groupingBy(CurrentInventorySnapshot::getFofoId));
2827
        LOGGER.info("Fetched inventory snapshots for {} partners", allInventorySnapshotsMap.size());
2828
 
2829
        // Batch fetch all pending GRN orders upfront
2830
        Map<Integer, List<Order>> allGrnPendingOrdersMap = orderRepository.selectPendingGrnOrders(allPartnerIds).stream()
2831
                .collect(Collectors.groupingBy(Order::getRetailerId));
2832
        LOGGER.info("Fetched GRN pending orders for {} partners", allGrnPendingOrdersMap.size());
2833
 
2834
        // Batch fetch all processing orders upfront
2835
        Map<Integer, List<Order>> allProcessingOrdersMap = orderRepository.selectOrders(allPartnerIds, orderStatusList).stream()
2836
                .collect(Collectors.groupingBy(Order::getRetailerId));
2837
        LOGGER.info("Fetched processing orders for {} partners", allProcessingOrdersMap.size());
2838
 
2839
        // Collect all focused catalog IDs
2840
        Set<Integer> allFocusedCatalogIds = regionFocusedModelsMap.values().stream()
2841
                .flatMap(List::stream)
2842
                .map(FocusedModel::getCatalogId)
2843
                .collect(Collectors.toSet());
2844
 
2845
        // Batch fetch all items by catalog IDs upfront
35446 amit 2846
        List<Item> allItemsByCatalogId = itemRepository.selectAllByCatalogIds(allFocusedCatalogIds);
2847
        Map<Integer, List<Item>> itemsByCatalogIdMap = allItemsByCatalogId.stream()
35442 amit 2848
                .collect(Collectors.groupingBy(Item::getCatalogItemId));
2849
        LOGGER.info("Fetched items for {} catalog IDs", itemsByCatalogIdMap.size());
2850
 
35446 amit 2851
        // Batch fetch all tagListings using pre-fetched items to avoid duplicate item fetch
35442 amit 2852
        Map<Integer, TagListing> tagListingByCatalogIdMap = tagListingRepository
35446 amit 2853
                .selectAllByItems(allItemsByCatalogId);
35442 amit 2854
        LOGGER.info("Fetched {} tagListings", tagListingByCatalogIdMap.size());
2855
 
2856
        // Collect all item IDs from inventory, GRN orders, and processing orders for batch item lookup
2857
        Set<Integer> allItemIds = new HashSet<>();
2858
        allInventorySnapshotsMap.values().forEach(list ->
2859
                list.forEach(cis -> allItemIds.add(cis.getItemId())));
2860
        allGrnPendingOrdersMap.values().forEach(orders ->
2861
                orders.forEach(o -> allItemIds.add(o.getLineItem().getItemId())));
2862
        allProcessingOrdersMap.values().forEach(orders ->
2863
                orders.forEach(o -> allItemIds.add(o.getLineItem().getItemId())));
2864
 
2865
        // Batch fetch all items and create itemId -> catalogId mapping
2866
        Map<Integer, Integer> itemIdToCatalogIdMap = new HashMap<>();
2867
        if (!allItemIds.isEmpty()) {
2868
            itemRepository.selectByIds(allItemIds).forEach(item ->
2869
                    itemIdToCatalogIdMap.put(item.getId(), item.getCatalogItemId()));
2870
        }
2871
        LOGGER.info("Built itemId->catalogId mapping for {} items", itemIdToCatalogIdMap.size());
2872
 
2873
        // ========== PHASE 2: Build partner region mappings ==========
34352 amit.gupta 2874
        Map<Integer, Set<Integer>> partnerToRegions = partnerRegionRepository.selectAll().stream()
2875
                .collect(Collectors.groupingBy(
2876
                        pr -> pr.getFofoId(),
2877
                        Collectors.mapping(pr -> pr.getRegionId(), Collectors.toSet())
2878
                ));
2879
        Map<Set<Integer>, List<Integer>> regionPartnerMap = partnerToRegions.entrySet().stream()
2880
                .collect(Collectors.groupingBy(
2881
                        Map.Entry::getValue,
2882
                        Collectors.mapping(Map.Entry::getKey, Collectors.toList())
2883
                ));
35442 amit 2884
        LOGGER.info("regionPartnerMap - {}", regionPartnerMap.keySet());
2885
 
2886
        // ========== PHASE 3: Process partners using pre-fetched data ==========
2887
        Map<Integer, List<FocusedModelShortageModel>> focusedModelShortageReportMap = new HashMap<>();
2888
 
34352 amit.gupta 2889
        for (Map.Entry<Set<Integer>, List<Integer>> regionPartnerEntry : regionPartnerMap.entrySet()) {
2890
            Set<Integer> regionIds = regionPartnerEntry.getKey();
35442 amit 2891
            List<Integer> partnerIds = new ArrayList<>(regionPartnerEntry.getValue());
2892
 
34502 amit.gupta 2893
            if (regionIds.stream().anyMatch(x -> !regionFocusedModelsMap.containsKey(x))) continue;
34383 amit.gupta 2894
 
35442 amit 2895
            LOGGER.info("Processing regionIds: {}", regionIds);
2896
            if (regionIds == null || regionIds.isEmpty()) {
34352 amit.gupta 2897
                LOGGER.info("No region found for partner {}", partnerIds);
34343 amit.gupta 2898
                continue;
2899
            }
34502 amit.gupta 2900
            if (regionIds.contains(5)) {
34383 amit.gupta 2901
                partnerIds.addAll(fofoStoreMap.keySet());
2902
            }
35442 amit 2903
 
2904
            Map<Integer, Optional<Integer>> focusedCatalogIdAndQtyMap = regionIds.stream()
2905
                    .map(regionFocusedModelsMap::get)
2906
                    .flatMap(x -> x != null ? x.stream() : Stream.empty())
2907
                    .collect(groupingBy(FocusedModel::getCatalogId,
2908
                            mapping(FocusedModel::getObsMinimumQty, Collectors.maxBy(Integer::compareTo))));
2909
 
2910
            if (focusedCatalogIdAndQtyMap.isEmpty()) continue;
2911
 
34352 amit.gupta 2912
            for (int partnerId : partnerIds) {
34502 amit.gupta 2913
                if (partnerId == 0) continue;
34352 amit.gupta 2914
                FofoStore fofoStore = fofoStoreMap.get(partnerId);
35442 amit 2915
                if (fofoStore == null) continue;
2916
 
2917
                CustomRetailer customRetailer = customRetailerMap.get(partnerId);
2918
                if (customRetailer == null) continue;
2919
 
34352 amit.gupta 2920
                List<FocusedModelShortageModel> focusedModelShortageList = new ArrayList<>();
2921
                focusedModelShortageReportMap.put(fofoStore.getId(), focusedModelShortageList);
34343 amit.gupta 2922
 
35442 amit 2923
                // Build catalogIdAndQtyMap from pre-fetched inventory snapshots
2924
                Map<Integer, Integer> catalogIdAndQtyMap = new HashMap<>();
2925
                List<CurrentInventorySnapshot> inventorySnapshots = allInventorySnapshotsMap.get(partnerId);
2926
                if (inventorySnapshots != null) {
2927
                    Map<Integer, Integer> itemQtyMap = inventorySnapshots.stream()
2928
                            .collect(Collectors.toMap(CurrentInventorySnapshot::getItemId, CurrentInventorySnapshot::getAvailability));
2929
                    for (Map.Entry<Integer, Integer> e : itemQtyMap.entrySet()) {
2930
                        Integer catalogId = itemIdToCatalogIdMap.get(e.getKey());
2931
                        if (catalogId != null) {
2932
                            catalogIdAndQtyMap.merge(catalogId, e.getValue(), Integer::sum);
2933
                        }
2934
                    }
34352 amit.gupta 2935
                }
25721 tejbeer 2936
 
35442 amit 2937
                // Build grnPendingOrdersMap from pre-fetched orders
2938
                Map<Integer, Integer> grnPendingOrdersMap = new HashMap<>();
2939
                List<Order> grnOrders = allGrnPendingOrdersMap.get(partnerId);
2940
                if (grnOrders != null) {
2941
                    for (Order order : grnOrders) {
2942
                        Integer catalogId = itemIdToCatalogIdMap.get(order.getLineItem().getItemId());
2943
                        if (catalogId != null) {
2944
                            grnPendingOrdersMap.merge(catalogId, order.getLineItem().getQuantity(), Integer::sum);
2945
                        }
2946
                    }
34352 amit.gupta 2947
                }
25800 tejbeer 2948
 
35442 amit 2949
                // Build processingOrderMap from pre-fetched orders
2950
                Map<Integer, Integer> processingOrderMap = new HashMap<>();
2951
                List<Order> processingOrders = allProcessingOrdersMap.get(partnerId);
2952
                if (processingOrders != null) {
2953
                    for (Order order : processingOrders) {
2954
                        Integer catalogId = itemIdToCatalogIdMap.get(order.getLineItem().getItemId());
2955
                        if (catalogId != null) {
2956
                            processingOrderMap.merge(catalogId, order.getLineItem().getQuantity(), Integer::sum);
2957
                        }
2958
                    }
34352 amit.gupta 2959
                }
25721 tejbeer 2960
 
35442 amit 2961
                Map<Integer, List<SaholicCIS>> itemAvailabilityMap = warehouseItemAvailabilityMap.get(fofoStore.getWarehouseId());
2962
                Map<Integer, List<SaholicPOItem>> poItemAvailabilityMap = warehousePoItemAvailabilityMap.get(fofoStore.getWarehouseId());
25721 tejbeer 2963
 
34352 amit.gupta 2964
                for (Entry<Integer, Optional<Integer>> entry : focusedCatalogIdAndQtyMap.entrySet()) {
35442 amit 2965
                    int catalogId = entry.getKey();
2966
                    int minQty = entry.getValue().orElse(0);
2967
                    int inStockQty = catalogIdAndQtyMap.getOrDefault(catalogId, 0);
2968
                    int processingQty = processingOrderMap.getOrDefault(catalogId, 0);
2969
                    int grnPendingQty = grnPendingOrdersMap.getOrDefault(catalogId, 0);
28526 tejbeer 2970
 
34352 amit.gupta 2971
                    int grnStockQty = grnPendingQty + inStockQty;
2972
                    int totalQty = processingQty + grnPendingQty + inStockQty;
2973
                    int shortageQty = minQty - totalQty;
27213 tejbeer 2974
 
35442 amit 2975
                    // Use pre-fetched items
2976
                    List<Item> items = itemsByCatalogIdMap.get(catalogId);
2977
                    if (items == null || items.isEmpty()) continue;
25721 tejbeer 2978
 
35442 amit 2979
                    // Use pre-fetched tagListing
2980
                    TagListing tagListing = tagListingByCatalogIdMap.get(catalogId);
2981
                    if (tagListing == null) continue;
27208 tejbeer 2982
 
35442 amit 2983
                    int allColorNetAvailability = 0;
2984
                    int allColorPoAvailability = 0;
28528 tejbeer 2985
 
34352 amit.gupta 2986
                    for (Item item : items) {
2987
                        if (itemAvailabilityMap != null) {
35442 amit 2988
                            List<SaholicCIS> currentAvailability = itemAvailabilityMap.get(item.getId());
2989
                            if (currentAvailability != null) {
2990
                                allColorNetAvailability += currentAvailability.stream()
2991
                                        .mapToInt(SaholicCIS::getNetavailability).sum();
2992
                            }
34352 amit.gupta 2993
                        }
2994
                        if (poItemAvailabilityMap != null) {
35442 amit 2995
                            List<SaholicPOItem> poItemAvailability = poItemAvailabilityMap.get(item.getId());
2996
                            if (poItemAvailability != null) {
2997
                                allColorPoAvailability += poItemAvailability.stream()
2998
                                        .mapToInt(SaholicPOItem::getUnfulfilledQty).sum();
2999
                            }
34352 amit.gupta 3000
                        }
31697 amit.gupta 3001
                    }
25721 tejbeer 3002
 
34352 amit.gupta 3003
                    FocusedModelShortageModel fm = new FocusedModelShortageModel();
3004
                    fm.setFofoId(fofoStore.getId());
3005
                    fm.setStoreCode(fofoStore.getCode());
3006
                    fm.setStoreName(customRetailer.getBusinessName());
3007
                    fm.setBrandName(items.get(0).getBrand());
3008
                    fm.setModelName(items.get(0).getModelName());
3009
                    fm.setModelNumber(items.get(0).getModelNumber());
3010
                    fm.setGrnStockQty(grnStockQty);
3011
                    fm.setPendingIndentQty(processingQty);
3012
                    fm.setShortageQty(shortageQty);
3013
                    fm.setPoAvailability(allColorPoAvailability);
3014
                    fm.setDp(tagListing.getSellingPrice());
3015
                    fm.setWarehouseName(warehouseMap.get(customRetailer.getWarehouseId()));
35442 amit 3016
 
3017
                    // FIX: Use fofoStore.getId() instead of fofoStore object as key
3018
                    FofoReportingModel reportingModel = partnerIdSalesHeadersMap.get(fofoStore.getId());
3019
                    if (reportingModel != null) {
3020
                        fm.setStateManager(reportingModel.getRegionalManager());
3021
                        fm.setTerritoryManager(reportingModel.getTerritoryManager());
34352 amit.gupta 3022
                    } else {
3023
                        fm.setStateManager("");
3024
                        fm.setTerritoryManager("");
31697 amit.gupta 3025
                    }
25800 tejbeer 3026
 
34352 amit.gupta 3027
                    fm.setItemName(items.get(0).getBrand() + items.get(0).getModelNumber() + items.get(0).getModelName());
3028
                    fm.setAvailability(allColorNetAvailability);
25800 tejbeer 3029
 
34352 amit.gupta 3030
                    focusedModelShortageList.add(fm);
31697 amit.gupta 3031
                }
3032
            }
34352 amit.gupta 3033
        }
25721 tejbeer 3034
 
35442 amit 3035
        // ========== PHASE 4: Send emails ==========
3036
        LOGGER.info("focusedModelShortageReportMap size: {}", focusedModelShortageReportMap.size());
31697 amit.gupta 3037
        if (!focusedModelShortageReportMap.isEmpty()) {
3038
            String fileName = "Stock Alert-" + FormattingUtils.formatDate(LocalDateTime.now()) + ".csv";
3039
            Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
3040
            Map<String, List<List<?>>> emailRowsMap = new HashMap<>();
28526 tejbeer 3041
 
35442 amit 3042
            for (Map.Entry<Integer, List<FocusedModelShortageModel>> x : focusedModelShortageReportMap.entrySet()) {
3043
                for (Map.Entry<String, Set<Integer>> y : storeGuyMap.entrySet()) {
3044
                    if (y.getValue().contains(x.getKey())) {
3045
                        emailRowsMap.computeIfAbsent(y.getKey(), k -> new ArrayList<>());
3046
                        List<List<? extends Serializable>> fms = x.getValue().stream()
3047
                                .map(r -> Arrays.asList(r.getStoreCode(), r.getStoreName(), r.getBrandName(),
3048
                                        r.getModelName(), r.getModelNumber(), r.getDp(), r.getWarehouseName(),
3049
                                        r.getStateManager(), r.getTerritoryManager(), r.getPendingIndentQty(),
3050
                                        r.getGrnStockQty(), r.getShortageQty(), r.getAvailability()))
3051
                                .collect(Collectors.toList());
3052
                        emailRowsMap.get(y.getKey()).addAll(fms);
3053
                    }
31697 amit.gupta 3054
                }
35442 amit 3055
            }
25721 tejbeer 3056
 
35442 amit 3057
            List<String> headers = Arrays.asList("Store Code", "Store Name", "Brand", "Model Name", "Model Number",
3058
                    "DP", "Warehouse Name", "State Manager", "Territory Manager", "Pending Indent", "InStock",
3059
                    "Shortage Qty", "Availability");
25721 tejbeer 3060
 
35442 amit 3061
            for (Map.Entry<String, List<List<?>>> entry : emailRowsMap.entrySet()) {
31697 amit.gupta 3062
                try {
35442 amit 3063
                    ByteArrayOutputStream baos = FileUtil.getCSVByteStream(headers, entry.getValue());
3064
                    String[] sendToArray = new String[]{entry.getKey()};
36460 ranu 3065
                    Utils.sendMailWithAttachment(googleMailSender, sendToArray, null, "Stock Alert", "PFA",
35442 amit 3066
                            fileName, new ByteArrayResource(baos.toByteArray()));
3067
                } catch (Exception e) {
3068
                    LOGGER.error("Failed to send email to {}", entry.getKey(), e);
31697 amit.gupta 3069
                }
35442 amit 3070
            }
31697 amit.gupta 3071
        }
3072
    }
25721 tejbeer 3073
 
31697 amit.gupta 3074
    private String getNotificationMessage(List<FocusedModelShortageModel> focusedModelShortageModel) {
3075
        StringBuilder sb = new StringBuilder();
3076
        sb.append("Focused Model Shortage in Your Stock : \n");
3077
        for (FocusedModelShortageModel entry : focusedModelShortageModel) {
25721 tejbeer 3078
 
31697 amit.gupta 3079
            sb.append(entry.getItemName() + "-" + entry.getShortageQty());
3080
            sb.append(String.format("%n", ""));
3081
        }
3082
        return sb.toString();
3083
    }
25721 tejbeer 3084
 
31697 amit.gupta 3085
    private void sendMailWithAttachments(String subject, String messageText, String email) throws Exception {
36402 amit 3086
        MimeMessage message = gmailRelaySender.createMimeMessage();
31697 amit.gupta 3087
        MimeMessageHelper helper = new MimeMessageHelper(message, true);
25721 tejbeer 3088
 
31697 amit.gupta 3089
        helper.setSubject(subject);
3090
        helper.setText(messageText, true);
3091
        helper.setTo(email);
3092
        InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
3093
        helper.setFrom(senderAddress);
36402 amit 3094
        gmailRelaySender.send(message);
25721 tejbeer 3095
 
31697 amit.gupta 3096
    }
25721 tejbeer 3097
 
31697 amit.gupta 3098
    private String getMessage(List<FocusedModelShortageModel> focusedModelShortageModel) {
3099
        StringBuilder sb = new StringBuilder();
31886 tejbeer 3100
        sb.append("<html><body><p>Alert</p><p>Focused Model Shortage in Your Stock:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
3101
        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 3102
        for (FocusedModelShortageModel entry : focusedModelShortageModel) {
25721 tejbeer 3103
 
31697 amit.gupta 3104
            sb.append("<tr>");
3105
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getItemName() + "</td>");
25936 amit.gupta 3106
 
31697 amit.gupta 3107
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getShortageQty() + "</td>");
26790 tejbeer 3108
 
31697 amit.gupta 3109
            sb.append("</tr>");
25927 amit.gupta 3110
 
31697 amit.gupta 3111
        }
26790 tejbeer 3112
 
31697 amit.gupta 3113
        sb.append("</tbody></table></body></html>");
26945 amit.gupta 3114
 
31697 amit.gupta 3115
        return sb.toString();
3116
    }
26945 amit.gupta 3117
 
31697 amit.gupta 3118
    public void notifyLead() throws Exception {
31886 tejbeer 3119
        List<Lead> leadsToNotify = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDateTime.now().minusDays(15), LocalDateTime.now().plusHours(4));
3120
        Map<Integer, String> authUserEmailMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x.getEmailId()));
31697 amit.gupta 3121
        LOGGER.info("authUserEmailMap {}", authUserEmailMap);
31886 tejbeer 3122
        Map<String, Integer> dtrEmailMap = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.values())).stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x.getId()));
25982 amit.gupta 3123
 
31697 amit.gupta 3124
        LOGGER.info("dtrEmailMap {}", dtrEmailMap);
26283 tejbeer 3125
 
31697 amit.gupta 3126
        Map<Integer, Integer> authUserKeyMap = new HashMap<>();
26283 tejbeer 3127
 
33452 amit.gupta 3128
        for (Entry<Integer, String> authUserEmail : authUserEmailMap.entrySet()) {
31697 amit.gupta 3129
            int authId = authUserEmail.getKey();
3130
            String email = authUserEmail.getValue();
3131
            authUserKeyMap.put(authId, dtrEmailMap.get(email));
3132
        }
3133
        LOGGER.info("authUserKeyMap", authUserKeyMap);
3134
        LOGGER.info("leadsToNotify {}", leadsToNotify);
26283 tejbeer 3135
 
31697 amit.gupta 3136
        String templateMessage = "Lead followup for %s %s, %s, %s is due by %s";
3137
        for (Lead lead : leadsToNotify) {
3138
            if (authUserKeyMap.get(lead.getAssignTo()) == null) {
3139
                LOGGER.info("Assignee no longer part of system {}", lead.getAssignTo());
3140
                continue;
3141
            }
3142
            String title = "Leads followup Reminder";
31886 tejbeer 3143
            String notificationMessage = String.format(templateMessage, lead.getFirstName(), lead.getLastName(), lead.getAddress(), lead.getLeadMobile(), leadTimeFormatter.format(lead.getScheduledTimestamp()));
31697 amit.gupta 3144
            String url = "https://app.smartdukaan.com/pages/home/leadUpdate?leadId=" + lead.getId();
3145
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
3146
            sendNotificationModel.setCampaignName("Lead Reminder");
3147
            sendNotificationModel.setTitle(title);
3148
            sendNotificationModel.setMessage(notificationMessage);
3149
            sendNotificationModel.setType("url");
3150
            sendNotificationModel.setUrl(url);
3151
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
3152
            sendNotificationModel.setMessageType(MessageType.reminder);
3153
            sendNotificationModel.setUserIds(Arrays.asList(authUserKeyMap.get(lead.getAssignTo())));
3154
            System.out.println(sendNotificationModel);
3155
            notificationService.sendNotification(sendNotificationModel);
3156
        }
3157
    }
26790 tejbeer 3158
 
32350 amit.gupta 3159
    @Autowired
3160
    AuthService authService;
3161
 
3162
    public void sendUnscheduledFollowUpMail() throws Exception {
3163
        List<Lead> missedScheduleLeads = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDate.now().atStartOfDay().minusDays(30), LocalDateTime.now().toLocalDate().atStartOfDay());
3164
        List<Lead> leadsScheduledForToday = leadRepository.selectLeadsScheduledBetweenDate(null, LocalDate.now().atStartOfDay(), LocalDate.now().atTime(LocalTime.MAX));
3165
        List<Integer> authIds = missedScheduleLeads.stream().map(x -> x.getAssignTo()).distinct().collect(Collectors.toList());
3166
        LOGGER.info(authIds.size());
35393 amit 3167
        Map<Integer, AuthUser> authUserMap = authRepository.selectByIds(authIds).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
32350 amit.gupta 3168
        LOGGER.info(authUserMap.size());
3169
        //if(true) return;
3170
 
3171
        missedScheduleLeads = missedScheduleLeads.stream().sorted(Comparator.comparing(Lead::getState, String.CASE_INSENSITIVE_ORDER).thenComparing(Lead::getAssignTo).thenComparing(Lead::getScheduledTimestamp)).collect(Collectors.toList());
3172
        //leadsScheduledForToday
3173
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
3174
        LOGGER.info("Auth Users Size - {}", authUsers.size());
3175
        for (AuthUser authUser : authUsers) {
3176
            LOGGER.info("Auth Name - {}", authUser.getFullName());
3177
            List<Integer> reporteeAuthIds = authService.getAllReportees(authUser.getId());
3178
            reporteeAuthIds.add(authUser.getId());
3179
            StringBuilder sb = new StringBuilder();
3180
            sb.append("<html><body>");
3181
            List<Lead> authMissedScheduledLeads = missedScheduleLeads.stream().filter(x -> reporteeAuthIds.contains(x.getAssignTo())).collect(Collectors.toList());
3182
            LOGGER.info("authMissedScheduledLeads {}", authMissedScheduledLeads.size());
3183
            if (authMissedScheduledLeads.size() > 0) {
3184
                addMissedScheduledLeadsTable(sb, authMissedScheduledLeads, authUserMap);
3185
                sb.append("</body></html>");
3186
 
3187
                String subject = "Lead Updates Summary";
32421 amit.gupta 3188
                String[] email = Arrays.asList(authUser.getEmailId()).toArray(new String[1]);
3189
                //String[] email = Arrays.asList("amit.gupta@smartdukaan.com").toArray(new String[1]);
36460 ranu 3190
                this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
32421 amit.gupta 3191
                //break;
32350 amit.gupta 3192
            }
3193
        }
3194
 
3195
    }
3196
 
32482 amit.gupta 3197
    private void addMissedScheduledLeadsTable(StringBuilder
3198
                                                      sb, List<Lead> missedScheduleLeads, Map<Integer, AuthUser> authUserMap) {
32350 amit.gupta 3199
        sb.append("<h3>Leads That Missed the schedule</h3>");
32439 tejbeer 3200
        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 3201
        for (Lead lead : missedScheduleLeads) {
32439 tejbeer 3202
            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(
3203
                    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 3204
        }
3205
        sb.append("</table>");
3206
    }
3207
 
31697 amit.gupta 3208
    public void notifyVisits() throws Exception {
31886 tejbeer 3209
        List<FranchiseeVisit> franchiseeVisits = franchiseeVisitRepository.selectVisitsScheduledBetweenDate(LocalDateTime.now().minusDays(15), LocalDateTime.now().plusHours(4));
3210
        Map<Integer, String> authUserEmailMap = authRepository.selectAllActiveUser().stream().collect(Collectors.toMap(x -> x.getId(), x -> x.getEmailId()));
3211
        Map<String, Integer> dtrEmailMap = dtrUserRepository.selectAllByEmailIds(new ArrayList<>(authUserEmailMap.values())).stream().collect(Collectors.toMap(x -> x.getEmailId(), x -> x.getId()));
31697 amit.gupta 3212
        Map<Integer, Integer> authUserKeyMap = new HashMap<>();
26790 tejbeer 3213
 
33452 amit.gupta 3214
        for (Entry<Integer, String> authUserEmail : authUserEmailMap.entrySet()) {
31697 amit.gupta 3215
            int authId = authUserEmail.getKey();
3216
            String email = authUserEmail.getValue();
3217
            authUserKeyMap.put(authId, dtrEmailMap.get(email));
3218
        }
3219
        String visitTemplate = "Planned visit to franchisee %s is due by %s";
3220
        String followupTemplate = "Lead followup for franchisee %s is due by %s";
3221
        DateTimeFormatter timeFormatter = DateTimeFormatter.ofPattern("MMM 7, EEEE h:m a");
3222
        for (FranchiseeVisit visit : franchiseeVisits) {
3223
            if (authUserKeyMap.containsKey(visit.getAuthId())) {
3224
                continue;
3225
            }
3226
            SendNotificationModel sendNotificationModel = new SendNotificationModel();
3227
            String message = null;
3228
            if (visit.getFranchiseActivityId() == 0) {
31886 tejbeer 3229
                message = String.format(visitTemplate, visit.getPartnerName(), timeFormatter.format(visit.getScheduleTimestamp()));
31697 amit.gupta 3230
                sendNotificationModel.setCampaignName("Franchisee visit Reminder");
3231
            } else {
31886 tejbeer 3232
                message = String.format(followupTemplate, visit.getPartnerName(), timeFormatter.format(visit.getScheduleTimestamp()));
31697 amit.gupta 3233
                sendNotificationModel.setCampaignName("Franchisee followup Reminder");
3234
            }
3235
            sendNotificationModel.setMessage(message);
3236
            sendNotificationModel.setType("url");
3237
            sendNotificationModel.setUrl("https://app.smartdukaan.com/pages/home/notifications");
3238
            sendNotificationModel.setExpiresat(LocalDateTime.now().plusDays(2));
3239
            sendNotificationModel.setMessageType(MessageType.reminder);
3240
            sendNotificationModel.setUserIds(Arrays.asList(authUserKeyMap.get(visit.getAuthId())));
3241
            // notificationService.sendNotification(sendNotificationModel);
3242
        }
3243
    }
26792 tejbeer 3244
 
35568 amit 3245
    // REMOVED: Duplicate ticketClosed() - now handled by TicketRelatedScheduledTask.autoCloseResolvedTickets()
3246
    // which uses 8 working days instead of 7 calendar days
26790 tejbeer 3247
 
31697 amit.gupta 3248
    public void checkValidateReferral() throws Exception {
26790 tejbeer 3249
 
31697 amit.gupta 3250
        List<Refferal> referrals = refferalRepository.selectByStatus(RefferalStatus.pending);
3251
        LOGGER.info("referrals" + referrals);
3252
        if (!referrals.isEmpty()) {
3253
            String subject = "Referral Request";
3254
            String messageText = this.getMessageForReferral(referrals);
26790 tejbeer 3255
 
36402 amit 3256
            MimeMessage message = gmailRelaySender.createMimeMessage();
31697 amit.gupta 3257
            MimeMessageHelper helper = new MimeMessageHelper(message, true);
3258
            String[] email = {"kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com"};
3259
            helper.setSubject(subject);
3260
            helper.setText(messageText, true);
3261
            helper.setTo(email);
3262
            InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
3263
            helper.setFrom(senderAddress);
36402 amit 3264
            gmailRelaySender.send(message);
26790 tejbeer 3265
 
31697 amit.gupta 3266
        }
3267
    }
26790 tejbeer 3268
 
31697 amit.gupta 3269
    private String getMessageForReferral(List<Refferal> referrals) {
3270
        StringBuilder sb = new StringBuilder();
31886 tejbeer 3271
        sb.append("<html><body><p>Alert</p><p>Pending Referrals:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
3272
        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 3273
        for (Refferal entry : referrals) {
26790 tejbeer 3274
 
31697 amit.gupta 3275
            sb.append("<tr>");
3276
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getRefereeName() + "</td>");
30421 tejbeer 3277
 
31697 amit.gupta 3278
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getRefereeEmail() + "</td>");
3279
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getFirstName() + "</td>");
3280
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getMobile() + "</td>");
3281
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCity() + "</td>");
3282
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getState() + "</td>");
30421 tejbeer 3283
 
31697 amit.gupta 3284
            sb.append("</tr>");
30421 tejbeer 3285
 
31697 amit.gupta 3286
        }
30421 tejbeer 3287
 
31697 amit.gupta 3288
        sb.append("</tbody></table></body></html>");
30421 tejbeer 3289
 
31697 amit.gupta 3290
        return sb.toString();
3291
    }
30421 tejbeer 3292
 
32832 amit.gupta 3293
    private String getMessageForRBMEscalatedPartners(List<PartnerCollectionRemark> pcrs) throws
32482 amit.gupta 3294
            ProfitMandiBusinessException {
31697 amit.gupta 3295
        StringBuilder sb = new StringBuilder();
32832 amit.gupta 3296
        sb.append("<html><body><p>Alert</p><p>Escalated by RBM-L1:-</p>" + "<br/><table style='border:1px solid black ;padding: 5px';>");
3297
        sb.append("<tbody>" +
3298
                "<tr>" +
3299
                "<th style='border:1px solid black;padding: 5px'>PartnerName</th>" +
3300
                "<th style='border:1px solid black;padding: 5px'>Escalated Since</th>" +
3301
                "<th style='border:1px solid black;padding: 5px'>Message</th>" +
3302
                "</tr>");
30421 tejbeer 3303
 
31697 amit.gupta 3304
        for (PartnerCollectionRemark entry : pcrs) {
30421 tejbeer 3305
 
31697 amit.gupta 3306
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
30421 tejbeer 3307
 
31697 amit.gupta 3308
            sb.append("<tr>");
31886 tejbeer 3309
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
3310
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCreateTimestamp().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
32832 amit.gupta 3311
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getMessage() + "</td>");
28205 tejbeer 3312
 
31697 amit.gupta 3313
            sb.append("</tr>");
28205 tejbeer 3314
 
31697 amit.gupta 3315
        }
28205 tejbeer 3316
 
31697 amit.gupta 3317
        sb.append("</tbody></table></body></html>");
28205 tejbeer 3318
 
31697 amit.gupta 3319
        return sb.toString();
3320
    }
28208 tejbeer 3321
 
32795 amit.gupta 3322
    private String getMessageForSalesEscalatedPartners(List<PartnerCollectionRemark> pcrs) throws
3323
            ProfitMandiBusinessException {
3324
        StringBuilder sb = new StringBuilder();
3325
        sb.append("<html><body><p>Alert</p><p>Escalated to Sales Team:-</p>" + "<br/>" +
3326
                "<table style='border:1px solid black ;padding: 5px';>");
3327
        sb.append("<tbody>" +
3328
                "<tr>" +
3329
                "<th style='border:1px solid black;padding: 5px'>PartnerName</th>" +
3330
                "<th style='border:1px solid black;padding: 5px'>Escalated Since</th>" +
3331
                "<th style='border:1px solid black;padding: 5px'>Message</th>" +
3332
                "</tr>");
3333
        for (PartnerCollectionRemark entry : pcrs) {
3334
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
3335
            sb.append("<tr>");
3336
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
3337
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCreateTimestamp().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
3338
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getMessage() + "</td>");
3339
            sb.append("</tr>");
3340
        }
3341
 
3342
        sb.append("</tbody></table></body></html>");
3343
 
3344
        return sb.toString();
3345
    }
3346
 
33078 ranu 3347
    private String getMessageForUnauthorizedBuying(List<NonSdBuying> nsb) throws
3348
            ProfitMandiBusinessException {
3349
        StringBuilder sb = new StringBuilder();
3350
        sb.append("<html><body><p>Alert</p><p>Unauthorized Buying-</p>" + "<br/>" +
3351
                "<table style='border:1px solid black ;padding: 5px';>");
3352
        sb.append("<tbody>" +
3353
                "<tr>" +
3354
                "<th style='border:1px solid black;padding: 5px'>PartnerName</th>" +
3355
                "<th style='border:1px solid black;padding: 5px'>Brand Name</th>" +
3356
                "<th style='border:1px solid black;padding: 5px'>Brand Value</th>" +
3357
                "<th style='border:1px solid black;padding: 5px'>Created At</th>" +
3358
                "<th style='border:1px solid black;padding: 5px'>Reason</th>" +
3359
                "</tr>");
3360
        for (NonSdBuying entry : nsb) {
3361
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
3362
            List<Integer> brandIds = Collections.singletonList(entry.getBrandId());
3363
            BrandCatalog brandsDisplay = brandsRepository.selectByIds(brandIds).get(0);
3364
            sb.append("<tr>");
3365
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
3366
            sb.append("<td style='border:1px solid black;padding: 5px'>" + brandsDisplay.getName() + "</td>");
3367
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getBrandValue() + "</td>");
3368
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getCreateTimestamp().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
3369
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getReason() + "</td>");
3370
            sb.append("</tr>");
3371
        }
3372
 
3373
        sb.append("</tbody></table></body></html>");
3374
 
3375
        return sb.toString();
3376
    }
3377
 
31697 amit.gupta 3378
    public void reverseWallet() throws Exception {
3379
        LocalDate localDate = LocalDate.of(2020, 10, 28);
31886 tejbeer 3380
        List<UserWalletHistory> uwhList = userWalletHistoryRepository.selectAllByDateType(localDate.atStartOfDay(), localDate.plusDays(1).atStartOfDay(), Arrays.asList(WalletReferenceType.SCHEME_IN, WalletReferenceType.SCHEME_OUT));
31697 amit.gupta 3381
        for (UserWalletHistory uwh : uwhList) {
3382
            if (uwh.getBusinessTimestamp().getMonth().equals(Month.SEPTEMBER)) {
3383
                UserWallet uw = userWalletRepository.selectById(uwh.getWalletId());
3384
                // LOGGER.info("UWH - {}", uwh);
3385
                // amount += uwh.getAmount();
3386
                // System.out.println("Amount is - " + amount);
3387
                // walletService.rollbackAmountFromWallet(uw.getUserId(), uwh.getAmount(),
3388
                // uwh.getReference(), uwh.getReferenceType(), "Margin reversal for error prone
3389
                // run", uwh.getBusinessTimestamp());
3390
                int orderId = uwh.getReference();
3391
                FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(orderId);
3392
                int inventoryItemId = 0;
3393
                // fofoOrderRepository.delete(fofoOrder);
3394
                List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
3395
                /*
3396
                 * List<PaymentOptionTransaction> paymentOptionTransactions =
3397
                 * paymentOptionTransactionRepository.selectByReferenceIdAndType(fofoOrder.getId
3398
                 * (), PaymentOptionReferenceType.ORDER); for(PaymentOptionTransaction
3399
                 * paymentOptionTransaction : paymentOptionTransactions) {
3400
                 * //paymentOptionTransactionRepository.delete(paymentOptionTransaction); }
3401
                 */
3402
                for (FofoOrderItem foi : fofoOrderItems) {
3403
                    // fofoOrderItemRepository.delete(foi);
3404
                    List<FofoLineItem> flis = fofoLineItemRepository.selectByFofoOrderItemId(foi.getId());
3405
                    for (FofoLineItem fli : flis) {
3406
                        // fofoLineItemRepository.delete(fli);
3407
                        inventoryItemId = fli.getInventoryItemId();
3408
                    }
3409
                }
3410
                List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectByInventoryItemIds(
33452 amit.gupta 3411
                        Stream.of(inventoryItemId).collect(Collectors.toSet()));
31697 amit.gupta 3412
                for (SchemeInOut sio : schemeInOuts) {
3413
                    if (sio.getCreateTimestamp().toLocalDate().equals(localDate)) {
3414
                        LOGGER.info("SIO - {}", sio);
3415
                        sio.setRolledBackTimestamp(LocalDateTime.now());
3416
                    }
3417
                }
28208 tejbeer 3418
 
31697 amit.gupta 3419
            }
3420
        }
28208 tejbeer 3421
 
31697 amit.gupta 3422
    }
28208 tejbeer 3423
 
31697 amit.gupta 3424
    public void partnerProblemAlert() throws Exception {
3425
        LocalDateTime curDate = LocalDate.now().atStartOfDay();
3426
        Map<Integer, Double> lmtdSale = fofoOrderItemRepository.selectSumMopGroupByRetailer(
3427
                curDate.withDayOfMonth(1).minusMonths(1), curDate.with(LocalTime.MAX).minusMonths(1), 0, false);
31886 tejbeer 3428
        Map<Integer, Double> mtdSales = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX), 0, false);
3429
        Map<Integer, PartnerDailyInvestment> pdi = partnerDailyInvestmentRepository.selectAll(LocalDate.now()).stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
28205 tejbeer 3430
 
31697 amit.gupta 3431
        for (Entry<Integer, Double> ls : lmtdSale.entrySet()) {
28208 tejbeer 3432
 
31697 amit.gupta 3433
            double lmtdTwentyPercentSale = ls.getValue() * 0.2;
28208 tejbeer 3434
 
31697 amit.gupta 3435
            LOGGER.info("lmtdTwentyPercentSale" + lmtdTwentyPercentSale);
28208 tejbeer 3436
 
31697 amit.gupta 3437
            double mtdSale = mtdSales.get(ls.getKey()) == null ? 0 : mtdSales.get(ls.getKey());
28205 tejbeer 3438
 
31697 amit.gupta 3439
            LOGGER.info("mtdSale" + mtdSale);
28205 tejbeer 3440
 
31886 tejbeer 3441
            double totalSixtyPercentInvestment = pdi.get(ls.getKey()) == null ? 0 : pdi.get(ls.getKey()).getTotalInvestment() * 0.6;
28205 tejbeer 3442
 
31697 amit.gupta 3443
            LOGGER.info("totalSixtyPercentInvestment" + totalSixtyPercentInvestment);
28205 tejbeer 3444
 
31697 amit.gupta 3445
            double stockInvestment = pdi.get(ls.getKey()) == null ? 0 : pdi.get(ls.getKey()).getInStockAmount();
28205 tejbeer 3446
 
31697 amit.gupta 3447
            LOGGER.info("stockInvestment" + stockInvestment);
28205 tejbeer 3448
 
31697 amit.gupta 3449
            boolean Investmentvalue = partnerInvestmentService.isInvestmentBelow(ls.getKey(), 25);
28205 tejbeer 3450
 
31697 amit.gupta 3451
            PartnerProblem partnerProblem = partnerProblemRepository.selectByFofoId(ls.getKey());
28205 tejbeer 3452
 
31697 amit.gupta 3453
            if (partnerProblem == null) {
3454
                partnerProblem = new PartnerProblem();
3455
                partnerProblem.setFofoId(ls.getKey());
3456
                if (mtdSale < lmtdTwentyPercentSale) {
3457
                    partnerProblem.setMtd(1);
3458
                }
3459
                if (Investmentvalue) {
3460
                    partnerProblem.setInvestment(1);
3461
                }
28205 tejbeer 3462
 
31697 amit.gupta 3463
                if (stockInvestment < totalSixtyPercentInvestment) {
3464
                    partnerProblem.setInvestment(1);
3465
                }
28205 tejbeer 3466
 
31697 amit.gupta 3467
                partnerProblemRepository.persist(partnerProblem);
3468
            } else {
3469
                if (mtdSale < lmtdTwentyPercentSale) {
3470
                    partnerProblem.setMtd(partnerProblem.getMtd() + 1);
28213 tejbeer 3471
 
31697 amit.gupta 3472
                } else {
3473
                    partnerProblem.setMtd(0);
28227 tejbeer 3474
 
31697 amit.gupta 3475
                }
3476
                if (Investmentvalue) {
3477
                    partnerProblem.setInvestment(partnerProblem.getInvestment() + 1);
3478
                } else {
3479
                    partnerProblem.setInvestment(0);
28227 tejbeer 3480
 
31697 amit.gupta 3481
                }
3482
                if (stockInvestment < totalSixtyPercentInvestment) {
3483
                    partnerProblem.setStockInvestment(partnerProblem.getStockInvestment() + 1);
3484
                } else {
3485
                    partnerProblem.setStockInvestment(0);
3486
                }
28213 tejbeer 3487
 
31697 amit.gupta 3488
            }
28213 tejbeer 3489
 
31697 amit.gupta 3490
        }
28213 tejbeer 3491
 
31886 tejbeer 3492
        List<PartnerProblem> partnerProblems = partnerProblemRepository.selectAll().stream().filter(x -> x.getMtd() + x.getInvestment() + x.getStockInvestment() > 0).collect(Collectors.toList());
28205 tejbeer 3493
 
31697 amit.gupta 3494
        partnerProblems = partnerProblems.stream().sorted((x1, x2) -> {
31886 tejbeer 3495
            return x1.getMtd() + x1.getInvestment() + x1.getStockInvestment() < x2.getMtd() + x2.getInvestment() + x2.getStockInvestment() ? 1 : -1;
31697 amit.gupta 3496
        }).collect(Collectors.toList());
28205 tejbeer 3497
 
31697 amit.gupta 3498
        Map<Integer, PartnerProblem> partnerProblemMap = partnerProblems.stream().sorted((x1, x2) -> {
31886 tejbeer 3499
            return x1.getMtd() + x1.getInvestment() + x1.getStockInvestment() < x2.getMtd() + x2.getInvestment() + x2.getStockInvestment() ? 1 : -1;
31697 amit.gupta 3500
        }).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
28205 tejbeer 3501
 
31697 amit.gupta 3502
        Map<Integer, CustomRetailer> customRetailers = retailerService.getAllFofoRetailers();
28205 tejbeer 3503
 
31697 amit.gupta 3504
        List<Integer> assignTo = Arrays.asList(15, 9, 54, 53);
28205 tejbeer 3505
 
35393 amit 3506
        Map<Integer, AuthUser> assignAuthUserMap = authRepository.selectByIds(assignTo).stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
28222 tejbeer 3507
 
31886 tejbeer 3508
        List<String> sendTo = Arrays.asList("kamini.sharma@smartdukaan.com", "tarun.verma@smartdukaan.com", "sm@smartdukaan.com");
31697 amit.gupta 3509
        LOGGER.info("partnerProblem" + partnerProblems);
3510
        StringBuilder sb = new StringBuilder();
3511
        sb.append("<htl><body>");
3512
        sb.append(
3513
                "<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 3514
        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 3515
 
31697 amit.gupta 3516
                + "	    				</tr>");
28218 tejbeer 3517
 
31697 amit.gupta 3518
        for (PartnerProblem pp : partnerProblems) {
3519
            int value = pp.getFofoId() % 4;
28218 tejbeer 3520
 
31697 amit.gupta 3521
            Map<EscalationType, AuthUser> authUserMap = csService.getAuthUserAndEsclationByPartnerId(pp.getFofoId());
3522
            LOGGER.info("authUserMap" + authUserMap);
3523
            sb.append("<tr>");
31886 tejbeer 3524
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailers.get(pp.getFofoId()).getBusinessName() + "</td>");
3525
            sb.append("<td style='border:1px solid black;padding: 5px'>" + assignAuthUserMap.get(assignTo.get(value)).getName() + "</td>");
31697 amit.gupta 3526
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getMtd() + "</td>");
3527
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getInvestment() + "</td>");
3528
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pp.getStockInvestment() + "</td>");
31886 tejbeer 3529
            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 3530
 
31697 amit.gupta 3531
            sb.append("</tr>");
3532
        }
3533
        sb.append("</tbody></table><br><br>");
3534
        String subject = "Partner Problem Alert!";
3535
        String[] email = sendTo.toArray(new String[sendTo.size()]);
28227 tejbeer 3536
 
36460 ranu 3537
        this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
28227 tejbeer 3538
 
31697 amit.gupta 3539
        Map<Integer, List<Integer>> authUserPartnerMapping = csService.getAuthUserIdPartnerIdMapping();
28224 tejbeer 3540
 
31697 amit.gupta 3541
        for (Entry<Integer, List<Integer>> authUserPartner : authUserPartnerMapping.entrySet()) {
3542
            AuthUser authUser = authRepository.selectById(authUserPartner.getKey());
3543
            for (Integer patnerId : authUserPartner.getValue()) {
3544
                if (partnerProblemMap.get(patnerId) != null) {
28230 tejbeer 3545
 
31697 amit.gupta 3546
                    StringBuilder sbbuilder = new StringBuilder();
3547
                    sbbuilder.append("<hml><body>");
3548
                    sb.append(
3549
                            "<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 3550
                    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 3551
 
31697 amit.gupta 3552
                            + "	    				</tr>");
28205 tejbeer 3553
 
31697 amit.gupta 3554
                    for (Integer partnerId : authUserPartner.getValue()) {
3555
                        if (partnerProblemMap.get(partnerId) != null) {
3556
                            PartnerProblem pp = partnerProblemMap.get(partnerId);
3557
                            sbbuilder.append("<tr>");
31886 tejbeer 3558
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + customRetailers.get(pp.getFofoId()).getBusinessName() + "</td>");
3559
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + pp.getMtd() + "</td>");
31697 amit.gupta 3560
                            sbbuilder.append(
3561
                                    "<td style='border:1px solid black;padding: 5px'>" + pp.getInvestment() + "</td>");
31886 tejbeer 3562
                            sbbuilder.append("<td style='border:1px solid black;padding: 5px'>" + pp.getStockInvestment() + "</td>");
28790 amit.gupta 3563
 
31697 amit.gupta 3564
                            sbbuilder.append("</tr>");
3565
                        }
28790 amit.gupta 3566
 
31697 amit.gupta 3567
                    }
3568
                    sbbuilder.append("</tbody></table><br><br>");
29488 manish 3569
 
36460 ranu 3570
                    this.sendMailOfHtmlFormat(googleMailSender, new String[]{authUser.getEmailId()}, sbbuilder.toString(), null, subject);
31697 amit.gupta 3571
                }
29488 manish 3572
 
31697 amit.gupta 3573
            }
3574
        }
3575
    }
28775 amit.gupta 3576
 
31697 amit.gupta 3577
    @Autowired
3578
    WarehouseRepository warehouseRepository;
29488 manish 3579
 
33256 amit.gupta 3580
    public void getVendorWarehouses(int warehouseId) throws ProfitMandiBusinessException {
31697 amit.gupta 3581
        LOGGER.info("Warehouses - {}", warehouseRepository.getVendorWarehouses().get(warehouseId));
29488 manish 3582
 
31697 amit.gupta 3583
    }
29488 manish 3584
 
31697 amit.gupta 3585
    public void checkImeiActivation() {
29801 manish 3586
 
31697 amit.gupta 3587
        try {
3588
            vivoImeiActivationService.checkImeiActivation();
3589
        } catch (ProfitMandiBusinessException e) {
3590
            e.printStackTrace();
3591
        } catch (IOException e) {
3592
            e.printStackTrace();
3593
        } catch (Exception e) {
3594
            e.printStackTrace();
3595
        }
29807 manish 3596
 
31697 amit.gupta 3597
    }
29801 manish 3598
 
36253 amit 3599
    public void checkImeiActivationTertiary() {
3600
 
3601
        try {
3602
            vivoImeiActivationService.checkImeiActivationTertiary();
3603
        } catch (ProfitMandiBusinessException e) {
3604
            e.printStackTrace();
3605
        } catch (IOException e) {
3606
            e.printStackTrace();
3607
        } catch (Exception e) {
3608
            e.printStackTrace();
3609
        }
3610
 
3611
    }
3612
 
31697 amit.gupta 3613
    public void checkItelImeiActivation(LocalDate date, Integer day) {
3614
        LOGGER.info("Hello - {}", "hhh");
29488 manish 3615
 
31697 amit.gupta 3616
        try {
3617
            itelImeiActivationService.checkItelImeiActivation(date, day);
3618
        } catch (ProfitMandiBusinessException e) {
3619
            // TODO Auto-generated catch block
3620
            e.printStackTrace();
3621
        } catch (IOException e) {
3622
            // TODO Auto-generated catch block
3623
            e.printStackTrace();
3624
        } catch (Exception e) {
3625
            // TODO Auto-generated catch block
3626
            e.printStackTrace();
3627
        }
29488 manish 3628
 
31697 amit.gupta 3629
    }
29488 manish 3630
 
32482 amit.gupta 3631
    public void selectFinServiceFollowUpDateByCurrDate(LocalDate currentDate) throws
3632
            MessagingException, ProfitMandiBusinessException, IOException {
31697 amit.gupta 3633
        LOGGER.info("selectfinServiceFollow - {}", "selectfinServiceFollowUpDateByCurrDate");
29308 tejbeer 3634
 
31697 amit.gupta 3635
        serviceConfigService.selectFinServicePartnerfollowUpDateByCurrentDate(currentDate);
29252 amit.gupta 3636
 
31697 amit.gupta 3637
    }
29451 manish 3638
 
31697 amit.gupta 3639
    public void checkTecnoImeiActivation(LocalDate date, Integer day) {
3640
        LOGGER.info("Hello - {}", "hhh");
29308 tejbeer 3641
 
31697 amit.gupta 3642
        try {
3643
            tecnoImeiActivation.checkTecnoImeiActivation(date, day);
3644
        } catch (ProfitMandiBusinessException e) {
3645
            // TODO Auto-generated catch block
3646
            e.printStackTrace();
3647
        } catch (IOException e) {
3648
            // TODO Auto-generated catch block
3649
            e.printStackTrace();
3650
        } catch (Exception e) {
3651
            // TODO Auto-generated catch block
3652
            e.printStackTrace();
3653
        }
29308 tejbeer 3654
 
31697 amit.gupta 3655
    }
29441 tejbeer 3656
 
31697 amit.gupta 3657
    public void checkCancellationMargin() throws Exception {
3658
        LocalDateTime startDate = LocalDate.of(2021, 4, 1).atStartOfDay();
3659
        List<FofoOrder> fofoOrders = fofoOrderRepository.selectCancelledBetweenSaleDate(startDate, LocalDateTime.now());
3660
        LOGGER.info("Total Orders =  {}", fofoOrders.size());
3661
        for (FofoOrder fofoOrder : fofoOrders) {
31886 tejbeer 3662
            List<UserWalletHistory> history = userWalletHistoryRepository.selectAllByreferenceIdandreferenceType(fofoOrder.getId(), WalletReferenceType.SCHEME_OUT);
3663
            history.addAll(userWalletHistoryRepository.selectAllByreferenceIdandreferenceType(fofoOrder.getId(), WalletReferenceType.ACTIVATION_SCHEME));
31697 amit.gupta 3664
            int walletSum = history.stream().mapToInt(x -> x.getAmount()).sum();
3665
            if (Math.abs(walletSum) > 1) {
3666
                // LOGGER.info("Cancelled invoice {}, Order Id = {}, = havent rolledback, Value
3667
                // = {}", fofoOrder.getInvoiceNumber(), fofoOrder.getId(), walletSum);
3668
                List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
3669
                List<FofoLineItem> flis = fofoLineItemRepository.selectByFofoOrderItemId(fofoOrderItems.get(0).getId());
3670
                FofoLineItem fli = flis.get(0);
3671
                if (StringUtils.isEmpty(fli.getSerialNumber()))
3672
                    continue;
31886 tejbeer 3673
                List<SchemeInOut> schemeInOuts = schemeInOutRepository.selectByInventoryItemIds(new HashSet<>(Arrays.asList(fli.getInventoryItemId())));
31697 amit.gupta 3674
                InventoryItem inventoryItem = inventoryItemRepository.selectById(fli.getInventoryItemId());
31886 tejbeer 3675
                double schemeSum = schemeInOuts.stream().filter(x -> x.getRolledBackTimestamp() == null).mapToDouble(x -> x.getAmount()).sum();
31697 amit.gupta 3676
                /*
3677
                 * if(inventoryItem.getGoodQuantity()==1) {
3678
                 * LOGGER.info("GoodQty, Serial Number {}, InventoryItem = {}, Billed on {}",
3679
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3680
                 * inventoryItem.getUpdateTimestamp()); } else
3681
                 * if(inventoryItem.getBadQuantity()==1){
3682
                 * LOGGER.info("Bad Qty, Serial Number {}, InventoryItem = {}, Billed on {}",
3683
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3684
                 * inventoryItem.getUpdateTimestamp()); } else if
3685
                 * (inventoryItem.getLastScanType().equals(ScanType.SALE)) { LOGGER.
3686
                 * info("Problem Sold, Serial Number {}, InventoryItem = {}, Billed on {}",
3687
                 * inventoryItem.getSerialNumber(), inventoryItem.getId(),
3688
                 * inventoryItem.getUpdateTimestamp()); }
3689
                 */
31886 tejbeer 3690
                if (inventoryItem.getLastScanType().equals(ScanType.SALE) || inventoryItem.getLastScanType().equals(ScanType.SALE_RET)) {
3691
                    Map<String, Double> map = schemeInOuts.stream().collect(
3692
                            groupingBy(
3693
                                    x -> DateTimeFormatter.ofPattern("yyyyMMddHH").format(x.getCreateTimestamp()) + "- " + x.getSchemeId(), Collectors.summingDouble(x -> x.getAmount())));
33452 amit.gupta 3694
                    for (Entry<String, Double> entry : map.entrySet()) {
31697 amit.gupta 3695
                        LOGGER.info("{} = {}", entry.getKey(), entry.getValue());
3696
                    }
31886 tejbeer 3697
                    LOGGER.info("id- {}, imei- {}, lastScan = {}, Scheme sum - {}", inventoryItem.getId(), inventoryItem.getSerialNumber(), inventoryItem.getLastScanType(), schemeSum);
31697 amit.gupta 3698
                }
3699
            }
3700
        }
29441 tejbeer 3701
 
31697 amit.gupta 3702
    }
29308 tejbeer 3703
 
31697 amit.gupta 3704
    public static String readFileAsString(String file) throws Exception {
3705
        String data = "";
3706
        data = new String(Files.readAllBytes(Paths.get(file)));
3707
        return data;
3708
    }
29308 tejbeer 3709
 
31697 amit.gupta 3710
    @Autowired
3711
    private PartnerCollectionRemarkRepository partnerCollectionRemarkRepository;
30421 tejbeer 3712
 
32832 amit.gupta 3713
    //RBM L2 Escalations
32482 amit.gupta 3714
    public void reviewUncontactablePartner() throws
3715
            ProfitMandiBusinessException, MessagingException, UnsupportedEncodingException {
30421 tejbeer 3716
 
31697 amit.gupta 3717
        Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
30421 tejbeer 3718
 
32832 amit.gupta 3719
        List<Integer> partnerLastCollectionRemarkIds = partnerCollectionRemarkRepository.selectMaxRemarkId(new ArrayList<>(customRetailerMap.keySet()));
30859 tejbeer 3720
 
32832 amit.gupta 3721
        if (!partnerLastCollectionRemarkIds.isEmpty()) {
3722
            List<PartnerCollectionRemark> partnerCollectionRemarks = partnerCollectionRemarkRepository.selectByIds(partnerLastCollectionRemarkIds);
30421 tejbeer 3723
 
33064 ranu 3724
            Map<Integer, PartnerCollectionRemark> rbmEscalatedRemarksMap = partnerCollectionRemarks.stream().filter(x -> x.getRemark().equals(CollectionRemark.RBM_L2_ESCALATION)).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
36269 ranu 3725
            Map<Integer, PartnerCollectionRemark> rbmL3EscalatedRemarksMap = partnerCollectionRemarks.stream().filter(x -> x.getRemark().equals(CollectionRemark.RBM_L3_ESCALATION)).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
32832 amit.gupta 3726
            Map<Integer, PartnerCollectionRemark> salesEscalatedRemarksMap = partnerCollectionRemarks.stream().filter(x -> x.getRemark().equals(CollectionRemark.SALES_ESCALATION)).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
30859 tejbeer 3727
 
32832 amit.gupta 3728
 
3729
            if (!rbmEscalatedRemarksMap.isEmpty()) {
3730
                //
33452 amit.gupta 3731
                for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_RBM), true).entrySet()) {
32832 amit.gupta 3732
                    List<PartnerCollectionRemark> filteredRows = storeGuyEntry.getValue().stream()
3733
                            .map(x -> rbmEscalatedRemarksMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
3734
                    String subject = "Partners escalated to RBM-L2";
3735
                    String messageText = this.getMessageForRBMEscalatedPartners(filteredRows);
3736
 
36402 amit 3737
                    MimeMessage message = gmailRelaySender.createMimeMessage();
31697 amit.gupta 3738
                    MimeMessageHelper helper = new MimeMessageHelper(message, true);
3739
                    String[] email = new String[]{storeGuyEntry.getKey()};
30859 tejbeer 3740
 
31697 amit.gupta 3741
                    helper.setSubject(subject);
3742
                    helper.setText(messageText, true);
3743
                    helper.setTo(email);
31886 tejbeer 3744
                    InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
31697 amit.gupta 3745
                    helper.setFrom(senderAddress);
36402 amit 3746
                    gmailRelaySender.send(message);
30859 tejbeer 3747
 
36269 ranu 3748
                }
3749
            }
3750
            if (!rbmL3EscalatedRemarksMap.isEmpty()) {
3751
                //
3752
                for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_RBM), true).entrySet()) {
3753
                    List<PartnerCollectionRemark> filteredRows = storeGuyEntry.getValue().stream()
3754
                            .map(x -> rbmL3EscalatedRemarksMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
3755
                    String subject = "Partners escalated to RBM-L3";
3756
                    String messageText = this.getMessageForRBMEscalatedPartners(filteredRows);
30859 tejbeer 3757
 
36402 amit 3758
                    MimeMessage message = gmailRelaySender.createMimeMessage();
36269 ranu 3759
                    MimeMessageHelper helper = new MimeMessageHelper(message, true);
3760
                    String[] email = new String[]{storeGuyEntry.getKey()};
3761
 
3762
                    helper.setSubject(subject);
3763
                    helper.setText(messageText, true);
3764
                    helper.setTo(email);
3765
                    InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
3766
                    helper.setFrom(senderAddress);
36402 amit 3767
                    gmailRelaySender.send(message);
36269 ranu 3768
 
31697 amit.gupta 3769
                }
3770
            }
32832 amit.gupta 3771
            if (!salesEscalatedRemarksMap.isEmpty()) {
3772
                //
35521 amit 3773
                for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ABM, ProfitMandiConstants.TICKET_CATEGORY_RBM), true).entrySet()) {
32832 amit.gupta 3774
                    List<PartnerCollectionRemark> filteredRows = storeGuyEntry.getValue().stream()
3775
                            .map(x -> salesEscalatedRemarksMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
3776
                    String subject = "Partners escalated to Sales";
3777
                    String messageText = this.getMessageForSalesEscalatedPartners(filteredRows);
30936 tejbeer 3778
 
36402 amit 3779
                    MimeMessage message = gmailRelaySender.createMimeMessage();
32832 amit.gupta 3780
                    MimeMessageHelper helper = new MimeMessageHelper(message, true);
3781
                    String[] email = new String[]{storeGuyEntry.getKey()};
3782
 
3783
                    helper.setSubject(subject);
3784
                    helper.setText(messageText, true);
3785
                    helper.setTo(email);
3786
                    InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
3787
                    helper.setFrom(senderAddress);
36402 amit 3788
                    gmailRelaySender.send(message);
32832 amit.gupta 3789
 
3790
                }
3791
            }
3792
 
31697 amit.gupta 3793
        }
3794
    }
30936 tejbeer 3795
 
33078 ranu 3796
 
31697 amit.gupta 3797
    @Autowired
33078 ranu 3798
    private NonSdBuyingRepository nonSdBuyingRepository;
3799
 
3800
    //Non Sd Buying
3801
    public void reviewNonSdBuyingBrand() throws
3802
            ProfitMandiBusinessException, MessagingException, UnsupportedEncodingException {
3803
        List<NonSdBuying> nonSdByuingActiveList = nonSdBuyingRepository.selectAllActiveNonSDBuyingList(true);
3804
        Map<Integer, NonSdBuying> unAuthorizedBuyingMap = nonSdByuingActiveList.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
3805
 
3806
        if (!unAuthorizedBuyingMap.isEmpty()) {
35521 amit 3807
            for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ABM), true).entrySet()) {
33078 ranu 3808
                List<NonSdBuying> unAuthorizedfilteredRows = storeGuyEntry.getValue().stream()
3809
                        .map(x -> unAuthorizedBuyingMap.get(x)).filter(x -> x != null).collect(Collectors.toList());
33112 amit.gupta 3810
                if (!unAuthorizedfilteredRows.isEmpty()) {
33078 ranu 3811
                    String subject = "Unauthorized Buying";
3812
                    String messageText = this.getMessageForUnauthorizedBuying(unAuthorizedfilteredRows);
3813
 
36402 amit 3814
                    MimeMessage message = gmailRelaySender.createMimeMessage();
33078 ranu 3815
                    MimeMessageHelper helper = new MimeMessageHelper(message, true);
3816
                    String[] email = new String[]{storeGuyEntry.getKey()};
3817
 
3818
                    helper.setSubject(subject);
3819
                    helper.setText(messageText, true);
3820
                    helper.setTo(email);
3821
                    InternetAddress senderAddress = new InternetAddress("noreply@smartdukaan.com", "Smartdukaan Alerts");
3822
                    helper.setFrom(senderAddress);
36402 amit 3823
                    gmailRelaySender.send(message);
33078 ranu 3824
                    LOGGER.info("unAuthorizedfilteredRows {}", unAuthorizedfilteredRows);
3825
                }
3826
 
3827
 
3828
            }
3829
 
3830
        }
3831
    }
3832
 
3833
    @Autowired
31697 amit.gupta 3834
    private LoanRepository loanRepository;
31020 tejbeer 3835
 
31697 amit.gupta 3836
    @Autowired
3837
    private LoanStatementRepository loanStatementRepository;
30859 tejbeer 3838
 
31697 amit.gupta 3839
    @Autowired
3840
    private SDCreditRequirementRepository sdCreditRequirementRepository;
30859 tejbeer 3841
 
31697 amit.gupta 3842
    @Autowired
3843
    private CurrentPartnerDailyInvestmentRepository currentPartnerDailyInvestmentRepository;
30859 tejbeer 3844
 
31697 amit.gupta 3845
    @Autowired
3846
    private TransactionRepository transactionRepository;
30859 tejbeer 3847
 
31697 amit.gupta 3848
    @Autowired
3849
    private SanctionRequestRepository sanctionRequestRepository;
30859 tejbeer 3850
 
31697 amit.gupta 3851
    public void calculateInterestAccured() throws ProfitMandiBusinessException {
36289 amit 3852
        synchronized (SD_CREDIT_LOCK) {
3853
            List<Loan> loans = loanRepository.selectAllActiveLoan();
30859 tejbeer 3854
 
36289 amit 3855
            for (Loan loan : loans) {
3856
                List<LoanStatement> loanStatements = loanStatementRepository.selectByLoanId(loan.getId());
3857
                Map<LoanReferenceType, Double> loanStatusAmount = loanStatements.stream().collect(groupingBy(
3858
                        x -> x.getLoanReferenceType(), Collectors.summingDouble(x -> x.getAmount().doubleValue())));
30936 tejbeer 3859
 
36289 amit 3860
                // Interest starts from this date (inclusive). Under current policy (MIN_FREE_DAYS=1),
3861
                // this is at minimum createdOn + 1 — billing day is always free.
3862
                LocalDate interestStartDate = com.spice.profitmandi.service.transaction.SDCreditServiceImpl.computeInterestStartDate(loan);
30936 tejbeer 3863
 
36289 amit 3864
                LOGGER.info("Loan id - {}, interestStartDate {}", loan.getId(), interestStartDate);
3865
                if (!LocalDate.now().isBefore(interestStartDate)) {
3866
                    int loanStatementId = loanStatementRepository.selectLatestLoanSatement(loan.getFofoId(), loan.getId());
3867
                    LOGGER.info("loanStatementId {}", loanStatementId);
3868
                    if (loanStatementId != 0) {
3869
                        this.calculateInterest(loan, loanStatusAmount, loanStatementId);
3870
                    } else {
3871
                        sdCreditService.addInterest(interestStartDate, LocalDate.now(), loan, loanStatusAmount);
3872
                    }
31697 amit.gupta 3873
                }
32724 amit.gupta 3874
            }
31697 amit.gupta 3875
        }
3876
    }
30936 tejbeer 3877
 
31697 amit.gupta 3878
    @Autowired
3879
    FofoPaymentRepository fofoPaymentRepository;
30936 tejbeer 3880
 
31697 amit.gupta 3881
    @Autowired
3882
    CCAvenuePaymentService ccAvenuePaymentService;
30936 tejbeer 3883
 
31697 amit.gupta 3884
    public void settleCCAvePayments() throws Exception {
31886 tejbeer 3885
        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 3886
        for (FofoPayment fofoPayment : fofoPayments) {
3887
            ccAvenuePaymentService.updatePayment(fofoPayment);
3888
        }
3889
    }
30859 tejbeer 3890
 
31697 amit.gupta 3891
    /*
3892
     * public void getCCAvenuePendingOrderStatus(int pendingOrderId) { PendingOrder
3893
     * pendingOrder = pendingOrderRepository.selectById(pendingOrderId);
3894
     * ccAvenuePaymentService.getPaymentStatusMap(pendingOrder); }
3895
     */
30859 tejbeer 3896
 
32482 amit.gupta 3897
    private void calculateInterest(Loan loan, Map<LoanReferenceType, Double> loanStatusAmount,
3898
                                   int loanStatementId) throws ProfitMandiBusinessException {
31697 amit.gupta 3899
        LoanStatement loanStatement = loanStatementRepository.selectById(loanStatementId);
30859 tejbeer 3900
 
31697 amit.gupta 3901
        if (loanStatement.getLoanId() == loan.getId()) {
34710 amit.gupta 3902
            sdCreditService.addInterest(loanStatement.getCreatedAt().toLocalDate().plusDays(1), LocalDate.now(), loan, loanStatusAmount);
31697 amit.gupta 3903
        } else {
3904
            throw new ProfitMandiBusinessException("loanstament", loanStatement.getLoanId(), "Invalid LoanId");
3905
        }
3906
    }
31175 tejbeer 3907
 
31697 amit.gupta 3908
    public void loanSettlement() throws Exception {
36289 amit 3909
        synchronized (SD_CREDIT_LOCK) {
3910
            List<Loan> loans = loanRepository.selectAllActiveLoanForSettlement().stream().filter(x -> x.canBeSettled()).collect(toList());
3911
            //TODO:Upto here
3912
            if (!loans.isEmpty()) {
31020 tejbeer 3913
 
36289 amit 3914
                for (Loan loan : loans) {
3915
                    LOGGER.info("Loan - {},  {}", loan.getId(), loan.canBeSettled());
3916
                    double settledAmount = sdCreditService.settleLoan(loan);
30859 tejbeer 3917
 
36289 amit 3918
                    List<SanctionRequest> sanctionRequests = sanctionRequestRepository.selectHoldSanctionByFofoId(loan.getFofoId());
3919
                    for (SanctionRequest sanctionRequest : sanctionRequests) {
31175 tejbeer 3920
 
36289 amit 3921
                        List<Order> orders = orderRepository.selectAllByTransactionId(sanctionRequest.getTransactionId());
3922
                        if (orders.size() == 0) {
3923
                            LOGGER.info("Could not find orders - for Sanction Request {}", sanctionRequest);
3924
                            continue;
3925
                        }
30999 tejbeer 3926
 
36289 amit 3927
                        if (settledAmount >= sanctionRequest.getPendingAmount().doubleValue()) {
3928
                            settledAmount -= sanctionRequest.getPendingAmount().doubleValue();
3929
                            sanctionRequest.setPendingAmount(BigDecimal.valueOf(0));
3930
                            this.sendUnholdEmail(orders);
3931
                        } else {
3932
                            double pendinAmount = sanctionRequest.getPendingAmount().doubleValue() - settledAmount;
3933
                            System.out.println("Pending Amount - " + pendinAmount);
3934
                            sanctionRequest.setPendingAmount(BigDecimal.valueOf(pendinAmount));
3935
                            break;
33828 ranu 3936
 
36289 amit 3937
                        }
3938
 
34275 tejus.loha 3939
                    }
36289 amit 3940
                }
34162 ranu 3941
 
32439 tejbeer 3942
            }
34275 tejus.loha 3943
        }
33664 amit.gupta 3944
 
32439 tejbeer 3945
    }
31020 tejbeer 3946
 
3947
 
32439 tejbeer 3948
    private void sendUnholdEmail(List<Order> orders) throws Exception {
30859 tejbeer 3949
 
3950
 
32439 tejbeer 3951
        orders.forEach(x -> x.setShipmentHold(false));
33452 amit.gupta 3952
        orders = orders.stream().filter(x -> x.getRefundTimestamp() != null).collect(Collectors.toList());
33506 amit.gupta 3953
        if (orders.size() > 0) {
33427 amit.gupta 3954
 
33664 amit.gupta 3955
            double totalAmount = orders.stream().collect(Collectors.summingDouble(x -> x.getTotalAmount()));
30859 tejbeer 3956
 
33506 amit.gupta 3957
            List<String> authUserEmail = csService.getAuthUserIdByPartnerId(orders.get(0).getRetailerId()).stream().map(x -> x.getEmailId()).collect(Collectors.toList());
3958
            authUserEmail.add("vinay.p@smartdukaan.com");
3959
            authUserEmail.add("shivam.gupta@smartdukaan.com");
30859 tejbeer 3960
 
33506 amit.gupta 3961
            String[] emailTo = authUserEmail.toArray(new String[authUserEmail.size()]);
30859 tejbeer 3962
 
33506 amit.gupta 3963
            String[] ccTo = {"tarun.verma@smartdukaan.com", "kamini.sharma@smartdukaan.com"};
30859 tejbeer 3964
 
33664 amit.gupta 3965
            String subject = "Dispatch held orders of - " + (orders.get(0).getRetailerName());
3966
            String message = String.format("Dear Team, \n" + "kindly note the material for the " + orders.get(0).getRetailerName() + "of Rs." + totalAmount + "is unhold now and needs to be dispatched.");
35959 amit 3967
            mailOutboxService.queueMailViaGoogle(emailTo, ccTo, subject, message, "ScheduledTasks.sendUnholdEmail");
33506 amit.gupta 3968
        }
30859 tejbeer 3969
 
32439 tejbeer 3970
 
31697 amit.gupta 3971
    }
30859 tejbeer 3972
 
32307 amit.gupta 3973
    public void dailyLoanAlert() throws Exception {
31697 amit.gupta 3974
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30859 tejbeer 3975
 
31697 amit.gupta 3976
        Map<Integer, Double> partnerLoanAmount = new HashMap<>();
30859 tejbeer 3977
 
35877 amit 3978
        for (Loan loan : loans) {
3979
            double amount = partnerLoanAmount.getOrDefault(loan.getFofoId(), 0.0);
3980
            amount += loan.getPendingAmount().doubleValue() + loan.getInterestAccrued().doubleValue() - loan.getInterestPaid().doubleValue();
3981
            partnerLoanAmount.put(loan.getFofoId(), amount);
31697 amit.gupta 3982
        }
30859 tejbeer 3983
 
31697 amit.gupta 3984
        if (!partnerLoanAmount.isEmpty()) {
30965 tejbeer 3985
 
31697 amit.gupta 3986
            for (Entry<Integer, Double> partnerLoanAmountEnrty : partnerLoanAmount.entrySet()) {
30859 tejbeer 3987
 
31697 amit.gupta 3988
                int fofoId = partnerLoanAmountEnrty.getKey();
30859 tejbeer 3989
 
31697 amit.gupta 3990
                com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(fofoId);
30859 tejbeer 3991
 
31697 amit.gupta 3992
                Address address = addressRepository.selectById(user.getAddressId());
30896 amit.gupta 3993
 
31697 amit.gupta 3994
                String title = "Alert Credit Outstanding!";
3995
                String url = "http://app.smartdukaan.com/pages/home/credit";
34729 amit.gupta 3996
                String message = "Your total outstanding Credit Balance is Rs." + FormattingUtils.formatDecimal(Math.abs(partnerLoanAmountEnrty.getValue())) + ".";
31697 amit.gupta 3997
                notificationService.sendNotification(fofoId, title, MessageType.notification, title, message, url);
30913 tejbeer 3998
 
32841 amit.gupta 3999
                //notificationService.sendWhatsappMessage(message, title, address.getPhoneNumber());
30913 tejbeer 4000
 
31697 amit.gupta 4001
            }
30917 tejbeer 4002
 
31697 amit.gupta 4003
        }
30917 tejbeer 4004
 
31697 amit.gupta 4005
    }
30920 tejbeer 4006
 
31697 amit.gupta 4007
    public void processActivatedImeisForSchemes() throws ProfitMandiBusinessException {
4008
        schemeService.processActivatedImeisForSchemes();
4009
    }
30920 tejbeer 4010
 
33112 amit.gupta 4011
    @Autowired
33355 amit.gupta 4012
    SidbiService sidbiService;
33112 amit.gupta 4013
 
33364 amit.gupta 4014
    public void processSidbiDeductions() throws ProfitMandiBusinessException {
33434 amit.gupta 4015
        //sidbiService.migrateSanctions();
33355 amit.gupta 4016
        sidbiService.processDeductions();
4017
    }
35521 amit 4018
 
35326 amit 4019
    public void updatePartnerLimit(int fofoId) throws ProfitMandiBusinessException {
4020
        LocalDateTime firstBillingDate = transactionRepository.getFirstBillingDate(fofoId);
33355 amit.gupta 4021
 
35326 amit 4022
        CreditAccount creditAccount = creditAccountRepository.selectByFofoIdAndGateway(fofoId, Gateway.SDDIRECT);
35393 amit 4023
        BigDecimal utilizationAmount = sdCreditService.getUtilizationAmount(fofoId);
35326 amit 4024
        PartnerDailyInvestment partnerDailyInvestment = partnerInvestmentService.getInvestment(fofoId, 0);
4025
        BigDecimal suggestedAmount = this.getSuggestedAmount(creditAccount, partnerDailyInvestment, utilizationAmount, null);
4026
        SDCreditRequirement sdCreditRequirement = sdCreditRequirementRepository.selectByFofoId(fofoId);
4027
 
4028
        LOGGER.info("suggestedAmount {} ", suggestedAmount);
4029
 
4030
        if (sdCreditRequirement == null) {
4031
            sdCreditRequirement = new SDCreditRequirement();
4032
            sdCreditRequirement.setFofoId(fofoId);
4033
            sdCreditRequirement.setCreditDays(15);
4034
            sdCreditRequirement.setInterestRate(ProfitMandiConstants.NEW_INTEREST_RATE);
4035
            sdCreditRequirement.setRisk(CreditRisk.HIGH_RISK);
4036
            sdCreditRequirement.setUtilizedAmount(BigDecimal.ZERO);
4037
            sdCreditRequirement.setCreateTimestamp(LocalDateTime.now());
4038
            sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
4039
            sdCreditRequirementRepository.persist(sdCreditRequirement);
4040
        }
4041
 
4042
        CreditRisk creditRisk = sdCreditService.getCurrentRisk(sdCreditRequirement, firstBillingDate);
4043
 
4044
        sdCreditRequirement.setRisk(creditRisk);
4045
        LOGGER.info("Suggested Amount - {}", suggestedAmount);
4046
        sdCreditRequirement.setSuggestedLimit(suggestedAmount);
4047
        if (!sdCreditRequirement.isHardLimit()) {
4048
            sdCreditRequirement.setLimit(suggestedAmount);
4049
        }
35811 amit 4050
        BigDecimal availableLimit = sdCreditRequirement.getLimit().subtract(utilizationAmount);
35326 amit 4051
 
35811 amit 4052
        LOGGER.info("utilizedLimit {} ", utilizationAmount);
35326 amit 4053
 
4054
        LOGGER.info("availableLimit {} ", availableLimit);
4055
 
35811 amit 4056
        sdCreditRequirement.setUtilizedAmount(utilizationAmount);
35326 amit 4057
 
4058
        sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
4059
 
4060
        if (creditAccount != null) {
4061
 
4062
            creditAccount.setInterestRate(sdCreditRequirement.getInterestRate().floatValue());
4063
            creditAccount.setSanctionedAmount(sdCreditRequirement.getLimit().floatValue());
4064
            creditAccount.setAvailableAmount(availableLimit.floatValue());
4065
            creditAccount.setFreeDays(sdCreditRequirement.getFreeDays());
4066
            creditAccount.setUpdatedOn(LocalDateTime.now());
4067
        }
4068
 
4069
    }
35521 amit 4070
 
31697 amit.gupta 4071
    public void updatePartnerLimit() throws ProfitMandiBusinessException {
36289 amit 4072
        synchronized (SD_CREDIT_LOCK) {
4073
            Map<Integer, CustomRetailer> customRetailerMap = retailerService.getFofoRetailers(true);
4074
            Map<Integer, BigDecimal> fofoSidbiLimitMap = sidbiService.getSuggestedLimitMap();
4075
            Map<Integer, SDCreditRequirement> sdCreditRequirementMap = sdCreditRequirementRepository.selectAll().stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
4076
            Map<Integer, CreditAccount> creditAccountMap = creditAccountRepository.selectAllByGateways(Arrays.asList(Gateway.SIDBI, Gateway.SDDIRECT))
4077
                    .stream().filter(x -> x.isActive()).collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
4078
            Map<Integer, BulkCreditSummary> bulkSummaryMap = sdCreditService.getCreditSummaryBulk();
33287 amit.gupta 4079
 
36289 amit 4080
            // Sort by fofoId to ensure deterministic row-locking order and prevent deadlocks
4081
            List<Integer> sortedFofoIds = customRetailerMap.keySet().stream().sorted().collect(Collectors.toList());
30929 tejbeer 4082
 
36289 amit 4083
            for (int fofoId : sortedFofoIds) {
4084
                CustomRetailer customRetailer = customRetailerMap.get(fofoId);
4085
                LocalDateTime firstBillingDate = transactionRepository.getFirstBillingDate(fofoId);
30913 tejbeer 4086
 
36289 amit 4087
                CreditAccount creditAccount = creditAccountMap.get(fofoId);
4088
                BulkCreditSummary bulkSummary = bulkSummaryMap.get(fofoId);
4089
                BigDecimal utilizationAmount = bulkSummary != null ? bulkSummary.getUtilization() : BigDecimal.ZERO;
4090
                PartnerDailyInvestment partnerDailyInvestment = partnerInvestmentService.getInvestment(fofoId, 0);
4091
                BigDecimal suggestedAmount = this.getSuggestedAmount(creditAccount, partnerDailyInvestment, utilizationAmount, fofoSidbiLimitMap.get(fofoId));
4092
                SDCreditRequirement sdCreditRequirement = sdCreditRequirementMap.get(fofoId);
30913 tejbeer 4093
 
36289 amit 4094
                LOGGER.info("suggestedAmount {} ", suggestedAmount);
30913 tejbeer 4095
 
36289 amit 4096
                if (sdCreditRequirement == null) {
4097
                    sdCreditRequirement = new SDCreditRequirement();
4098
                    sdCreditRequirement.setFofoId(fofoId);
4099
                    sdCreditRequirement.setCreditDays(15);
4100
                    sdCreditRequirement.setInterestRate(ProfitMandiConstants.NEW_INTEREST_RATE);
4101
                    sdCreditRequirement.setRisk(CreditRisk.HIGH_RISK);
4102
                    sdCreditRequirement.setUtilizedAmount(BigDecimal.ZERO);
4103
                    sdCreditRequirement.setCreateTimestamp(LocalDateTime.now());
4104
                    sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
4105
                    sdCreditRequirementRepository.persist(sdCreditRequirement);
4106
                }
30913 tejbeer 4107
 
36289 amit 4108
                CreditRisk creditRisk = sdCreditService.getCurrentRisk(sdCreditRequirement, firstBillingDate);
30934 tejbeer 4109
 
36289 amit 4110
                sdCreditRequirement.setRisk(creditRisk);
30934 tejbeer 4111
 
36289 amit 4112
                sdCreditRequirement.setSuggestedLimit(suggestedAmount);
4113
                if (!sdCreditRequirement.isHardLimit()) {
4114
                    sdCreditRequirement.setLimit(suggestedAmount);
4115
                }
30913 tejbeer 4116
 
36289 amit 4117
                BigDecimal availableLimit = sdCreditRequirement.getLimit().subtract(utilizationAmount);
30913 tejbeer 4118
 
36289 amit 4119
                LOGGER.info("utilizedLimit {} ", utilizationAmount);
30929 tejbeer 4120
 
36289 amit 4121
                LOGGER.info("availableLimit {} ", availableLimit);
30929 tejbeer 4122
 
36289 amit 4123
                sdCreditRequirement.setUtilizedAmount(utilizationAmount);
30929 tejbeer 4124
 
36289 amit 4125
                sdCreditRequirement.setUpdateTimestamp(LocalDateTime.now());
4126
 
4127
                if (creditAccount != null) {
4128
 
4129
                    creditAccount.setInterestRate(sdCreditRequirement.getInterestRate().floatValue());
4130
                    creditAccount.setSanctionedAmount(sdCreditRequirement.getLimit().floatValue());
4131
                    creditAccount.setAvailableAmount(availableLimit.floatValue());
4132
                    creditAccount.setFreeDays(sdCreditRequirement.getFreeDays());
4133
                    creditAccount.setUpdatedOn(LocalDateTime.now());
4134
                }
4135
 
31697 amit.gupta 4136
            }
4137
        }
31177 tejbeer 4138
 
31697 amit.gupta 4139
    }
34502 amit.gupta 4140
 
34374 amit.gupta 4141
    private static final NavigableMap<Double, Double> discountMap = new TreeMap<>();
34502 amit.gupta 4142
 
34374 amit.gupta 4143
    static {
34852 amit 4144
        discountMap.put(4 * ProfitMandiConstants.ONE_LAC - 1, 0.2);    // Up to 3,99,999 -> 20%
4145
        discountMap.put(10 * ProfitMandiConstants.ONE_LAC - 1, 0.25);  // 4,00,000 to 9,99,999 -> 25%
4146
        discountMap.put(20 * ProfitMandiConstants.ONE_LAC - 1, 0.3);   // 10,00,000 to 19,99,999 -> 30%
4147
        discountMap.put(Double.MAX_VALUE, 0.4);                        // 20,00,000 and above -> 40%
34374 amit.gupta 4148
    }
34502 amit.gupta 4149
 
4150
    public BigDecimal getSuggestedLimit(double investmentValue) {
34374 amit.gupta 4151
        double percentageValue = discountMap.ceilingEntry(investmentValue).getValue();
34510 amit.gupta 4152
        return this.getSuggestedAmount(investmentValue, percentageValue);
4153
 
4154
    }
4155
 
4156
    private BigDecimal getSuggestedAmount(double investmentValue, double percentageValue) {
34374 amit.gupta 4157
        return BigDecimal.valueOf(investmentValue * percentageValue);
4158
    }
34502 amit.gupta 4159
 
35299 amit 4160
    /*private static List<Integer> hundredPercentLimitPartnerIds = Arrays.asList(175139630,
34510 amit.gupta 4161
            175139815,
4162
            175139844,
4163
            175140101
35299 amit 4164
    );*/
34510 amit.gupta 4165
 
35299 amit 4166
    private static List<Integer> hundredPercentLimitPartnerIds = Arrays.asList();
4167
 
35177 amit 4168
    private BigDecimal getSuggestedAmount(CreditAccount creditAccount, PartnerDailyInvestment
35393 amit 4169
            partnerDailyInvestment, BigDecimal utilizationAmount, BigDecimal sidbiLimit) {
33112 amit.gupta 4170
        BigDecimal suggestedAmount = BigDecimal.ZERO;
35393 amit 4171
        double utilization = utilizationAmount != null ? utilizationAmount.doubleValue() : 0;
33112 amit.gupta 4172
        //1 LAC
33295 amit.gupta 4173
        if (creditAccount == null || creditAccount.getGateway().equals(Gateway.SDDIRECT)) {
33112 amit.gupta 4174
 
35177 amit 4175
            if (partnerDailyInvestment != null) {
4176
                if (hundredPercentLimitPartnerIds.contains(partnerDailyInvestment.getFofoId())) {
35393 amit 4177
                    suggestedAmount = getSuggestedAmount(partnerDailyInvestment.getTotalInvestment() - utilization, 1);
34512 amit.gupta 4178
                    suggestedAmount = suggestedAmount.min(BigDecimal.valueOf(1500000));
34510 amit.gupta 4179
                } else {
35393 amit 4180
                    suggestedAmount = getSuggestedLimit(partnerDailyInvestment.getTotalInvestment() - utilization);
34510 amit.gupta 4181
                }
33112 amit.gupta 4182
            }
4183
            if (suggestedAmount.doubleValue() < 0) {
4184
                suggestedAmount = BigDecimal.ZERO;
4185
            }
33355 amit.gupta 4186
        } else if (creditAccount.getGateway().equals(Gateway.SIDBI) && sidbiLimit != null) {
35393 amit 4187
            suggestedAmount = getSuggestedLimit(partnerDailyInvestment.getTotalInvestment() - utilization);
34993 ranu 4188
            suggestedAmount = suggestedAmount.max(sidbiLimit);
4189
 
4190
 
33112 amit.gupta 4191
        }
4192
        return suggestedAmount;
4193
    }
4194
 
31697 amit.gupta 4195
    public void notifyDefaultLoans() throws ProfitMandiBusinessException, MessagingException, IOException {
36462 ranu 4196
        synchronized (SD_CREDIT_LOCK) {
36289 amit 4197
            sdCreditService.updateRisk();
4198
            List<Loan> defaultLoans = sdCreditService.getDefaultLoans();
4199
            if (!defaultLoans.isEmpty()) {
4200
                this.sendDefaultLoanAlert(defaultLoans);
4201
            }
36462 ranu 4202
        }
31697 amit.gupta 4203
    }
30929 tejbeer 4204
 
32482 amit.gupta 4205
    public void sendDefaultLoanAlert(List<Loan> defaultLoans) throws
4206
            ProfitMandiBusinessException, MessagingException, IOException {
31697 amit.gupta 4207
        String subject = "Default Partners";
30931 tejbeer 4208
 
35591 aman 4209
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ABM, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
30929 tejbeer 4210
 
33452 amit.gupta 4211
        for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false).entrySet()) {
31697 amit.gupta 4212
            List<Loan> filteredRows = new ArrayList<>();
4213
            for (Loan loan : defaultLoans) {
30929 tejbeer 4214
 
31697 amit.gupta 4215
                if (storeGuyEntry.getValue().contains(loan.getFofoId())) {
30929 tejbeer 4216
 
31697 amit.gupta 4217
                    filteredRows.add(loan);
4218
                }
4219
            }
4220
            if (!filteredRows.isEmpty()) {
35591 aman 4221
                String[] email = new String[]{storeGuyEntry.getKey(),"neeraj.gupta@smartdukaan.com"};
31697 amit.gupta 4222
                String messageText = this.getMessageForDueDateExtend(filteredRows);
36473 amit 4223
                this.sendMailOfHtmlFormat(googleMailSender, email, messageText, null, subject);
30982 tejbeer 4224
 
31697 amit.gupta 4225
            }
30936 tejbeer 4226
 
31697 amit.gupta 4227
        }
33628 tejus.loha 4228
        String messageText = this.getMessageForDueDateExtend(defaultLoans);
36473 amit 4229
        this.sendMailOfHtmlFormat(googleMailSender, new String[]{"puneet.wahi@smartdukaan.com", "rahul.latwal@smartdukaan.com", "dilbag.singh@smartdukaan.com"}, messageText, null, subject);
30982 tejbeer 4230
 
31697 amit.gupta 4231
        for (Loan defaultLoan : defaultLoans) {
35877 amit 4232
            double principal = defaultLoan.getPendingAmount().doubleValue();
4233
            double interest = defaultLoan.getInterestAccrued().doubleValue() - defaultLoan.getInterestPaid().doubleValue();
4234
            double total = principal + interest;
30929 tejbeer 4235
 
35877 amit 4236
            String title = "Credit Default Alert!";
31697 amit.gupta 4237
            String url = "http://app.smartdukaan.com/pages/home/credit";
35915 amit 4238
            String message = "Your credit payment (due " + defaultLoan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + ") is now in default. A penalty interest of " + (defaultLoan.getPenaltyRate() != null ? defaultLoan.getPenaltyRate() : ProfitMandiConstants.NEW_DELAYED_INTEREST_RATE) + "% per day is being charged. Total outstanding: Rs." + FormattingUtils.formatDecimal(total) + " (Principal: Rs." + FormattingUtils.formatDecimal(principal) + " + Interest: Rs." + FormattingUtils.formatDecimal(interest) + "). Pay immediately to avoid further penalties.";
31886 tejbeer 4239
            notificationService.sendNotification(defaultLoan.getFofoId(), title, MessageType.notification, title, message, url);
30936 tejbeer 4240
 
31697 amit.gupta 4241
        }
4242
    }
30929 tejbeer 4243
 
31697 amit.gupta 4244
    private String getMessageForDueDateExtend(List<Loan> loans) throws ProfitMandiBusinessException {
33553 ranu 4245
        Map<Integer, com.spice.profitmandi.dao.model.FofoReportingModel> fofoReportingModelMap = csService.getPartnerIdSalesHeaders();
4246
        Map<Integer, FofoRBMReportingModel> fofoRbmReportingModelMap = csService.getPartnerIdRBMHeaders();
4247
        List<AST> asts = astRepository.selectAll();
4248
        Map<Integer, AST> astMap = asts.stream()
4249
                .collect(Collectors.toMap(AST::getId, ast -> ast));
31697 amit.gupta 4250
        StringBuilder sb = new StringBuilder();
4251
        sb.append(
35877 amit 4252
                "<html><body><p>Alert</p><p>Default Partners :-</p>" + "<br/><p>Penalty interest of " + ProfitMandiConstants.NEW_DELAYED_INTEREST_RATE + "% per day is being charged on outstanding amount.</p>" + "<br/>" +
33553 ranu 4253
                        "<table style='border:1px solid black ;padding: 5px';>");
4254
        sb.append("<tbody>\n" +
4255
                "<tr>\n" +
4256
                "<th style='border:1px solid black;padding: 5px'>PartnerName</th>\n" +
33555 ranu 4257
                "<th style='border:1px solid black;padding: 5px'>State Name</th>\n" +
4258
                "<th style='border:1px solid black;padding: 5px'>Area</th>\n" +
4259
                "<th style='border:1px solid black;padding: 5px'>Territory</th>\n" +
33553 ranu 4260
                "<th style='border:1px solid black;padding: 5px'>due date</th>\n" +
4261
                "<th style='border:1px solid black;padding: 5px'>Days</th>\n" +
33664 amit.gupta 4262
                "<th style='border:1px solid black;padding: 5px'>Pending Amount</th>\n" +
33810 ranu 4263
                "<th style='border:1px solid black;padding: 5px'>RBM L2</th>\n" +
33553 ranu 4264
                "<th style='border:1px solid black;padding: 5px'>RBM L1</th>\n" +
4265
                "<th style='border:1px solid black;padding: 5px'>Sales L1</th>\n" +
4266
                "<th style='border:1px solid black;padding: 5px'>Sales L2</th>\n" +
4267
                "</tr>");
35877 amit 4268
        DecimalFormat df = new DecimalFormat("#.##");
31697 amit.gupta 4269
        for (Loan entry : loans) {
30929 tejbeer 4270
 
35877 amit 4271
            double amount = entry.getPendingAmount().doubleValue() + entry.getInterestAccrued().doubleValue() - entry.getInterestPaid().doubleValue();
30929 tejbeer 4272
 
31697 amit.gupta 4273
            long noOfdaysBetween = ChronoUnit.DAYS.between(entry.getDueDate().toLocalDate(), LocalDateTime.now());
30929 tejbeer 4274
 
31697 amit.gupta 4275
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
30929 tejbeer 4276
 
31697 amit.gupta 4277
            sb.append("<tr>");
31886 tejbeer 4278
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")" + "</td>");
33555 ranu 4279
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getAddress().getState() + "</td>");
4280
            sb.append("<td style='border:1px solid black;padding: 5px'>" + astMap.get(customRetailer.getAstId()).getArea() + "</td>");
4281
            sb.append("<td style='border:1px solid black;padding: 5px'>" + astMap.get(customRetailer.getAstId()).getTerritory() + "</td>");
31886 tejbeer 4282
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getDueDate().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
31697 amit.gupta 4283
            sb.append("<td style='border:1px solid black;padding: 5px'>" + noOfdaysBetween + "</td>");
35877 amit 4284
            sb.append("<td style='border:1px solid black;padding: 5px'>" + df.format(amount) + "</td>");
33553 ranu 4285
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoRbmReportingModelMap.get(entry.getFofoId()).getL1Manager() + "</td>");
4286
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoRbmReportingModelMap.get(entry.getFofoId()).getL2Manager() + "</td>");
4287
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoReportingModelMap.get(entry.getFofoId()).getTerritoryManager() + "</td>");
4288
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoReportingModelMap.get(entry.getFofoId()).getRegionalManager() + "</td>");
31397 tejbeer 4289
 
31697 amit.gupta 4290
            sb.append("</tr>");
31397 tejbeer 4291
 
31697 amit.gupta 4292
        }
31397 tejbeer 4293
 
31697 amit.gupta 4294
        sb.append("</tbody></table></body></html>");
31397 tejbeer 4295
 
31697 amit.gupta 4296
        return sb.toString();
4297
    }
31397 tejbeer 4298
 
35111 ranu 4299
    private String getMessageForDueDateCross(List<Loan> dueDateCrossLoans) throws ProfitMandiBusinessException {
33161 ranu 4300
        Map<Integer, com.spice.profitmandi.dao.model.FofoReportingModel> fofoReportingModelMap = csService.getPartnerIdSalesHeaders();
33452 amit.gupta 4301
        Map<Integer, FofoRBMReportingModel> fofoRbmReportingModelMap = csService.getPartnerIdRBMHeaders();
33553 ranu 4302
        List<AST> asts = astRepository.selectAll();
4303
        Map<Integer, AST> astMap = asts.stream()
4304
                .collect(Collectors.toMap(AST::getId, ast -> ast));
4305
 
31697 amit.gupta 4306
        StringBuilder sb = new StringBuilder();
35877 amit 4307
        sb.append("<html><body><p>Alert</p><p>Partner Credit Report - Overdue :-</p>" + "<br/><p>Overdue interest of " + ProfitMandiConstants.TIER2_INTEREST_RATE + "% per day is being charged on outstanding amount.</p>" + "<br/>" +
33161 ranu 4308
                "<table style='border:1px solid black ;padding: 5px';>");
4309
        sb.append("<tbody>\n" + "<tr>\n" +
33256 amit.gupta 4310
                "<th style='border:1px solid black;padding: 5px'>PartnerName</th>\n" +
36303 aman 4311
                "<th style='border:1px solid black;padding: 5px'>Code</th>\n" +
33256 amit.gupta 4312
                "<th style='border:1px solid black;padding: 5px'>State Name</th>\n" +
33555 ranu 4313
                "<th style='border:1px solid black;padding: 5px'>Area</th>\n" +
33553 ranu 4314
                "<th style='border:1px solid black;padding: 5px'>Territory</th>\n" +
33256 amit.gupta 4315
                "<th style='border:1px solid black;padding: 5px'>due date</th>\n" +
4316
                "<th style='border:1px solid black;padding: 5px'>Days</th>\n" +
4317
                "<th style='border:1px solid black;padding: 5px'>Pending Amount</th>\n" +
33810 ranu 4318
                "<th style='border:1px solid black;padding: 5px'>RBM L2</th>\n" +
33256 amit.gupta 4319
                "<th style='border:1px solid black;padding: 5px'>RBM L1</th>\n" +
4320
                "<th style='border:1px solid black;padding: 5px'>Sales L1</th>\n" +
4321
                "<th style='border:1px solid black;padding: 5px'>Sales L2</th>\n" +
35107 ranu 4322
                "<th style='border:1px solid black;padding: 5px'>Limit Assigned</th>\n" +
33161 ranu 4323
                "</tr>");
31397 tejbeer 4324
 
35877 amit 4325
        DecimalFormat df = new DecimalFormat("#.##");
35111 ranu 4326
        for (Loan entry : dueDateCrossLoans) {
31397 tejbeer 4327
 
35877 amit 4328
            double amount = entry.getPendingAmount().doubleValue() + entry.getInterestAccrued().doubleValue() - entry.getInterestPaid().doubleValue();
31397 tejbeer 4329
 
31697 amit.gupta 4330
            long noOfdaysBetween = ChronoUnit.DAYS.between(entry.getDueDate().toLocalDate(), LocalDateTime.now());
31397 tejbeer 4331
 
31697 amit.gupta 4332
            CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
31397 tejbeer 4333
 
35106 ranu 4334
            SDCreditRequirement sdCreditRequirement = sdCreditRequirementRepository.selectByFofoId(customRetailer.getPartnerId());
4335
 
31697 amit.gupta 4336
            sb.append("<tr>");
36303 aman 4337
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getBusinessName() + "</td>");
4338
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getCode() + "</td>");
33162 ranu 4339
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customRetailer.getAddress().getState() + "</td>");
33553 ranu 4340
            sb.append("<td style='border:1px solid black;padding: 5px'>" + astMap.get(customRetailer.getAstId()).getArea() + "</td>");
4341
            sb.append("<td style='border:1px solid black;padding: 5px'>" + astMap.get(customRetailer.getAstId()).getTerritory() + "</td>");
31886 tejbeer 4342
            sb.append("<td style='border:1px solid black;padding: 5px'>" + entry.getDueDate().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")) + "</td>");
31697 amit.gupta 4343
            sb.append("<td style='border:1px solid black;padding: 5px'>" + noOfdaysBetween + "</td>");
35877 amit 4344
            sb.append("<td style='border:1px solid black;padding: 5px'>" + df.format(amount) + "</td>");
33161 ranu 4345
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoRbmReportingModelMap.get(entry.getFofoId()).getL1Manager() + "</td>");
4346
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoRbmReportingModelMap.get(entry.getFofoId()).getL2Manager() + "</td>");
4347
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoReportingModelMap.get(entry.getFofoId()).getTerritoryManager() + "</td>");
4348
            sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoReportingModelMap.get(entry.getFofoId()).getRegionalManager() + "</td>");
35521 amit 4349
            sb.append("<td style='border:1px solid black;padding: 5px'>" + df.format(sdCreditRequirement.getLimit()) + "</td>");
31697 amit.gupta 4350
            sb.append("</tr>");
4351
        }
31397 tejbeer 4352
 
31697 amit.gupta 4353
        sb.append("</tbody></table></body></html>");
31397 tejbeer 4354
 
31697 amit.gupta 4355
        return sb.toString();
4356
    }
31397 tejbeer 4357
 
32307 amit.gupta 4358
    public void notifyLoanDueDateCross() throws Exception {
31397 tejbeer 4359
 
35111 ranu 4360
        List<Loan> dueDateCrossLoans = sdCreditService.getDueDateCrossLoan();
4361
        List<Loan> allActiveLoans = sdCreditService.getAllActiveLoan();
31697 amit.gupta 4362
        if (!dueDateCrossLoans.isEmpty()) {
35521 amit 4363
            this.sendDueDateCrossLoanAlert(dueDateCrossLoans, allActiveLoans);
31697 amit.gupta 4364
        }
31397 tejbeer 4365
 
31697 amit.gupta 4366
    }
31397 tejbeer 4367
 
35521 amit 4368
    private void sendDueDateCrossLoanAlert(List<Loan> dueDateCrossLoans, List<Loan> allActiveLoans) throws Exception {
35591 aman 4369
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ABM, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
31397 tejbeer 4370
 
35115 ranu 4371
        for (Entry<String, Set<Integer>> storeGuyEntry : csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false).entrySet()) {
33631 tejus.loha 4372
            List<Loan> filteredRows = new ArrayList<>();
31697 amit.gupta 4373
            for (Loan loan : dueDateCrossLoans) {
30936 tejbeer 4374
 
31697 amit.gupta 4375
                if (storeGuyEntry.getValue().contains(loan.getFofoId())) {
30982 tejbeer 4376
 
31697 amit.gupta 4377
                    filteredRows.add(loan);
4378
                }
4379
            }
35111 ranu 4380
 
35112 ranu 4381
            List<Loan> filteredAllActiveLoans = new ArrayList<>();
35111 ranu 4382
            for (Loan loan : allActiveLoans) {
4383
 
4384
                if (storeGuyEntry.getValue().contains(loan.getFofoId())) {
4385
 
35112 ranu 4386
                    filteredAllActiveLoans.add(loan);
35111 ranu 4387
                }
4388
            }
4389
 
35112 ranu 4390
            ByteArrayOutputStream byteArrayOutputStream = null;
4391
            Utils.Attachment attachment1 = null;
35521 amit 4392
            if (!filteredAllActiveLoans.isEmpty()) {
4393
                byteArrayOutputStream = this.generateLoanCsv(filteredAllActiveLoans);
4394
                attachment1 = new Utils.Attachment("partnner-credit.csv", new ByteArrayResource(byteArrayOutputStream.toByteArray()));
35111 ranu 4395
 
4396
            }
4397
 
4398
 
31697 amit.gupta 4399
            if (!filteredRows.isEmpty()) {
4400
                String messageText = this.getMessageForDueDateCross(filteredRows);
35591 aman 4401
                String[] email = new String[]{storeGuyEntry.getKey(),"neeraj.gupta@smartdukaan.com"};
30982 tejbeer 4402
 
35521 amit 4403
                if (attachment1 != null) {
35959 amit 4404
                    mailOutboxService.queueMailWithAttachmentsViaGoogle(email, null, null, "Partner Credit Report", messageText, true, "ScheduledTasks.sendDueDateCrossLoanAlert", attachment1);
35521 amit 4405
                } else {
36460 ranu 4406
                    this.sendMailOfHtmlFormat(googleMailSender, email, messageText, null, "Due Date Cross");
30936 tejbeer 4407
 
35521 amit 4408
                }
4409
 
31697 amit.gupta 4410
            }
30936 tejbeer 4411
 
35115 ranu 4412
        }
35113 ranu 4413
 
4414
        String messageText = this.getMessageForDueDateCross(dueDateCrossLoans);
4415
        ByteArrayOutputStream byteArrayOutputStream = this.generateLoanCsv(allActiveLoans);
4416
        Utils.Attachment attachment = null;
35521 amit 4417
        if (byteArrayOutputStream != null) {
4418
            attachment = new Utils.Attachment("partnner-credit.csv", new ByteArrayResource(byteArrayOutputStream.toByteArray()));
35113 ranu 4419
 
31697 amit.gupta 4420
        }
33628 tejus.loha 4421
 
35521 amit 4422
        if (attachment != null) {
35959 amit 4423
            mailOutboxService.queueMailWithAttachmentsViaGoogle(new String[]{"sdtech@smartdukaan.com"}, null, null, "Partner Credit Report", messageText, true, "ScheduledTasks.sendDueDateCrossLoanAlert", attachment);
35521 amit 4424
        } else {
36460 ranu 4425
            this.sendMailOfHtmlFormat(googleMailSender, new String[]{"sdtech@smartdukaan.com"}, messageText, null, "Due Date Cross");
35113 ranu 4426
        }
33628 tejus.loha 4427
 
35111 ranu 4428
 
31697 amit.gupta 4429
        if (!dueDateCrossLoans.isEmpty()) {
4430
            for (Loan loan : dueDateCrossLoans) {
35877 amit 4431
                double principal = loan.getPendingAmount().doubleValue();
4432
                double interest = loan.getInterestAccrued().doubleValue() - loan.getInterestPaid().doubleValue();
4433
                double total = principal + interest;
30936 tejbeer 4434
 
31697 amit.gupta 4435
                String url = "http://app.smartdukaan.com/pages/home/credit";
30936 tejbeer 4436
 
35877 amit 4437
                String title = "Credit Payment Overdue!";
35915 amit 4438
                String message = "Your credit payment (due " + loan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + ") is overdue. An interest of " + (loan.getOverdueRate() != null ? loan.getOverdueRate() : ProfitMandiConstants.TIER2_INTEREST_RATE) + "% per day is now being charged. Total outstanding: Rs." + FormattingUtils.formatDecimal(total) + " (Principal: Rs." + FormattingUtils.formatDecimal(principal) + " + Interest: Rs." + FormattingUtils.formatDecimal(interest) + "). Pay now to avoid higher penalties.";
30936 tejbeer 4439
 
31886 tejbeer 4440
                notificationService.sendNotification(loan.getFofoId(), title, MessageType.notification, title, message, url);
30936 tejbeer 4441
 
31697 amit.gupta 4442
            }
4443
        }
30982 tejbeer 4444
 
31697 amit.gupta 4445
    }
30936 tejbeer 4446
 
35112 ranu 4447
    private ByteArrayOutputStream generateLoanCsv(List<Loan> loans) throws ProfitMandiBusinessException {
4448
        org.apache.commons.io.output.ByteArrayOutputStream byteArrayOutputStream = null;
4449
 
4450
 
4451
        if (!loans.isEmpty()) {
4452
            Map<Integer, com.spice.profitmandi.dao.model.FofoReportingModel> fofoReportingModelMap = csService.getPartnerIdSalesHeaders();
4453
            Map<Integer, FofoRBMReportingModel> fofoRbmReportingModelMap = csService.getPartnerIdRBMHeaders();
4454
            List<AST> asts = astRepository.selectAll();
4455
            Map<Integer, AST> astMap = asts.stream()
4456
                    .collect(Collectors.toMap(AST::getId, ast -> ast));
4457
            try {
4458
                List<String> headers = Arrays.asList(
4459
                        "PartnerName", "State Name", "Area", "Territory",
4460
                        "Due Date", "Days", "Pending Amount",
4461
                        "RBM L2", "RBM L1", "Sales L1", "Sales L2", "Limit Assigned"
4462
                );
4463
 
4464
                List<List<?>> rows = new ArrayList<>();
4465
 
35877 amit 4466
                DecimalFormat df = new DecimalFormat("#.##");
35112 ranu 4467
                for (Loan entry : loans) {
4468
 
35877 amit 4469
                    double amount = entry.getPendingAmount().doubleValue() + entry.getInterestAccrued().doubleValue() - entry.getInterestPaid().doubleValue();
35112 ranu 4470
 
35114 ranu 4471
                    long noOfdaysBetween = ChronoUnit.DAYS.between(entry.getCreatedOn().toLocalDate(), LocalDateTime.now());
35112 ranu 4472
 
4473
                    CustomRetailer customRetailer = retailerService.getFofoRetailer(entry.getFofoId());
4474
                    SDCreditRequirement sdCreditRequirement = sdCreditRequirementRepository.selectByFofoId(customRetailer.getPartnerId());
4475
                    List<String> row = Arrays.asList(
4476
                            customRetailer.getBusinessName() + "(" + customRetailer.getCode() + ")",
4477
                            customRetailer.getAddress().getState(),
4478
                            astMap.get(customRetailer.getAstId()).getArea(),
4479
                            astMap.get(customRetailer.getAstId()).getTerritory(),
4480
                            entry.getDueDate().format(DateTimeFormatter.ofPattern("dd/MM/yyyy")),
4481
                            String.valueOf(noOfdaysBetween),
35877 amit 4482
                            df.format(amount),
35112 ranu 4483
                            fofoRbmReportingModelMap.get(entry.getFofoId()).getL1Manager(),
4484
                            fofoRbmReportingModelMap.get(entry.getFofoId()).getL2Manager(),
4485
                            fofoReportingModelMap.get(entry.getFofoId()).getTerritoryManager(),
4486
                            fofoReportingModelMap.get(entry.getFofoId()).getRegionalManager(),
4487
                            df.format(sdCreditRequirement.getLimit())
4488
                    );
4489
 
4490
                    rows.add(row);
4491
                }
4492
 
4493
                byteArrayOutputStream = FileUtil.getCSVByteStream(headers, rows);
4494
 
4495
 
4496
            } catch (Exception e) {
4497
                throw new RuntimeException(e);
4498
            }
4499
 
4500
        }
4501
        return byteArrayOutputStream;
4502
    }
4503
 
4504
 
32307 amit.gupta 4505
    public void alertForDueDate() throws Exception {
30936 tejbeer 4506
 
31697 amit.gupta 4507
        List<Loan> loans = loanRepository.selectAllActiveLoan();
30936 tejbeer 4508
 
35877 amit 4509
        for (Loan loan : loans) {
4510
            long noOfdaysBetween = ChronoUnit.DAYS.between(LocalDate.now(), loan.getDueDate().toLocalDate());
30936 tejbeer 4511
 
35877 amit 4512
            LOGGER.info("noOfdaysBetween {} ", noOfdaysBetween);
30936 tejbeer 4513
 
35877 amit 4514
            if (noOfdaysBetween <= 4 && noOfdaysBetween >= 0) {
4515
                double amount = loan.getPendingAmount().doubleValue() + loan.getInterestAccrued().doubleValue() - loan.getInterestPaid().doubleValue();
30936 tejbeer 4516
 
35877 amit 4517
                String title = "Alert!";
4518
                String url = "http://app.smartdukaan.com/pages/home/credit";
4519
                String message;
4520
                if (noOfdaysBetween == 0) {
4521
                    message = "Your total outstanding Credit amount is Rs." + FormattingUtils.formatDecimal(amount) + " is due for Today, Pay Now!!";
4522
                } else {
4523
                    message = "Your total outstanding Credit amount is Rs." + FormattingUtils.formatDecimal(amount) + " is due by " + loan.getDueDate().toLocalDate().format(DateTimeFormatter.ofPattern("dd-MM-yyyy")) + " , Pay Now!!";
31697 amit.gupta 4524
                }
35877 amit 4525
                notificationService.sendNotification(loan.getFofoId(), title, MessageType.notification, title, message, url);
31697 amit.gupta 4526
            }
4527
        }
30984 tejbeer 4528
 
31697 amit.gupta 4529
    }
30982 tejbeer 4530
 
32307 amit.gupta 4531
    public void userMobileNumberOptIn() throws Exception {
30982 tejbeer 4532
 
31697 amit.gupta 4533
        List<FofoStore> fofoStores = fofoStoreRepository.selectActiveStores();
30982 tejbeer 4534
 
31886 tejbeer 4535
        List<com.spice.profitmandi.dao.entity.user.User> users = userUserRepository.selectByIds(fofoStores.stream().map(x -> x.getId()).collect(Collectors.toList()));
30982 tejbeer 4536
 
31886 tejbeer 4537
        List<Address> addresses = addressRepository.selectByIds(users.stream().map(x -> x.getAddressId()).collect(Collectors.toList()));
30982 tejbeer 4538
 
31697 amit.gupta 4539
        LOGGER.info("addresses" + addresses);
30984 tejbeer 4540
 
31697 amit.gupta 4541
        for (Address address : addresses) {
32307 amit.gupta 4542
            notificationService.optIn(address.getPhoneNumber());
30982 tejbeer 4543
 
31697 amit.gupta 4544
        }
30982 tejbeer 4545
 
31697 amit.gupta 4546
    }
30982 tejbeer 4547
 
31697 amit.gupta 4548
    public void authUserMobileNumberOptIn() throws HttpHostConnectException, ProfitMandiBusinessException {
31206 tejbeer 4549
 
31697 amit.gupta 4550
        List<AuthUser> authUsers = authRepository.selectAllActiveUser();
4551
        LOGGER.info("authUsers" + authUsers);
31206 tejbeer 4552
 
31697 amit.gupta 4553
        for (AuthUser authUser : authUsers) {
4554
            Map<String, String> requestheaders = new HashMap<>();
4555
            requestheaders.put("Content-Type", "application/x-www-form-urlencoded");
4556
            Map<String, String> requestParams = new HashMap<>();
4557
            requestParams.put("userid", String.valueOf(2000215976));
4558
            requestParams.put("password", "MFRd!BBL");
4559
            requestParams.put("phone_number", authUser.getMobileNumber());
4560
            requestParams.put("auth_scheme", "plain");
4561
            requestParams.put("v", "1.1");
4562
            requestParams.put("format", "json");
31206 tejbeer 4563
 
31697 amit.gupta 4564
            requestParams.put("method", "OPT_IN");
31206 tejbeer 4565
 
31697 amit.gupta 4566
            requestParams.put("channel", "WHATSAPP");
31886 tejbeer 4567
            String response = restClient.get("https://media.smsgupshup.com/GatewayAPI/rest", requestParams, requestheaders);
31697 amit.gupta 4568
            LOGGER.info("response" + response);
4569
        }
31206 tejbeer 4570
 
31697 amit.gupta 4571
    }
31206 tejbeer 4572
 
31697 amit.gupta 4573
    @Autowired
4574
    private HygieneDataRepository hygieneDataRepository;
31209 tejbeer 4575
 
31697 amit.gupta 4576
    public void hygineAlertForPartner() throws ProfitMandiBusinessException, MessagingException, IOException {
31206 tejbeer 4577
 
31697 amit.gupta 4578
        List<String> remarks = new ArrayList<>();
4579
        remarks.add("Out of Service");
4580
        remarks.add("Duplicate number");
4581
        remarks.add("Partner number");
31886 tejbeer 4582
        List<HygieneData> hygieneData = hygieneDataRepository.selectAllByDisposedDateAndRemark(LocalDate.now(), remarks);
31206 tejbeer 4583
 
31697 amit.gupta 4584
        if (!hygieneData.isEmpty()) {
31206 tejbeer 4585
 
31886 tejbeer 4586
            Map<Integer, List<HygieneData>> partnerHygieneDataMap = hygieneData.stream().collect(groupingBy(x -> x.getFofoId()));
31206 tejbeer 4587
 
31697 amit.gupta 4588
            for (Entry<Integer, List<HygieneData>> partnerHygieneDataMapEntry : partnerHygieneDataMap.entrySet()) {
31206 tejbeer 4589
 
31697 amit.gupta 4590
                CustomRetailer customRetailer = retailerService.getFofoRetailer(partnerHygieneDataMapEntry.getKey());
31206 tejbeer 4591
 
31697 amit.gupta 4592
                StringBuilder sb = new StringBuilder();
31886 tejbeer 4593
                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 4594
 
31886 tejbeer 4595
                        + " </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 4596
 
31697 amit.gupta 4597
                        + "<br/><table style='border:1px solid black ;padding: 5px';>");
4598
                sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
4599
                sb.append("<th style='border:1px solid black;padding: 5px'>Invoice Number</th>\n");
4600
                sb.append("<th style='border:1px solid black;padding: 5px'>Customer Name</th>\n");
4601
                sb.append("<th style='border:1px solid black;padding: 5px'>Customer Number</th>\n");
4602
                sb.append("</tr>\n");
31206 tejbeer 4603
 
31697 amit.gupta 4604
                List<HygieneData> hygienes = partnerHygieneDataMapEntry.getValue();
31206 tejbeer 4605
 
31697 amit.gupta 4606
                List<Integer> orderIds = hygienes.stream().map(x -> x.getOrderId()).collect(Collectors.toList());
31206 tejbeer 4607
 
31697 amit.gupta 4608
                List<FofoOrder> fofoOrders = fofoOrderRepository.selectAllByOrderIds(orderIds);
31206 tejbeer 4609
 
31697 amit.gupta 4610
                for (FofoOrder fofoOrder : fofoOrders) {
4611
                    Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
4612
                    sb.append("<tr>");
31886 tejbeer 4613
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + fofoOrder.getInvoiceNumber() + "</td>\n");
4614
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customer.getFirstName() + "" + customer.getLastName() + "</td>\n");
4615
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customer.getMobileNumber() + "</td>\n");
31206 tejbeer 4616
 
31697 amit.gupta 4617
                    sb.append("</tr>\n");
4618
                }
31206 tejbeer 4619
 
31697 amit.gupta 4620
                sb.append("</tbody></table></body></html>");
4621
                String subject = "Customer Info - Hygiene Alert";
31206 tejbeer 4622
 
36473 amit 4623
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{customRetailer.getEmail()}, sb.toString(), null, subject);
31206 tejbeer 4624
 
31697 amit.gupta 4625
            }
31206 tejbeer 4626
 
31697 amit.gupta 4627
        }
31206 tejbeer 4628
 
31697 amit.gupta 4629
    }
31206 tejbeer 4630
 
33046 amit.gupta 4631
    //
4632
    public void setInventoryItemIdToPriceDropImei() {
4633
        List<PriceDropIMEI> priceDropIMEIList = priceDropIMEIRepository.selectAllMissingInventoryItemIds();
4634
        LOGGER.info("Problems with - {} entries", priceDropIMEIList.size());
4635
        //priceDropIMEIList.stream().collect(C)
4636
        for (PriceDropIMEI priceDropIMEI : priceDropIMEIList) {
4637
            System.out.println(priceDropIMEI.getImei());
4638
            List<InventoryItem> inventoryItems = inventoryItemRepository.selectAllBySerialNumberFofoId(priceDropIMEI.getImei(), priceDropIMEI.getPartnerId());
33051 amit.gupta 4639
            if (inventoryItems.size() == 0) {
33046 amit.gupta 4640
                LOGGER.info("Could not find Grn - FofoID {} , Imei {} ", priceDropIMEI);
33051 amit.gupta 4641
            } else if (inventoryItems.size() > 1) {
33046 amit.gupta 4642
                LOGGER.info("Found 2 such instance for - FofoID {} , Imei {} ", priceDropIMEI.getImei(), priceDropIMEI.getPartnerId());
4643
            } else {
4644
                priceDropIMEI.setInventoryItemId(inventoryItems.get(0).getId());
4645
            }
4646
 
4647
        }
4648
    }
4649
 
33051 amit.gupta 4650
    @Autowired
4651
    SaholicReservationSnapshotRepository saholicReservationSnapshotRepository;
4652
 
33256 amit.gupta 4653
    public void removePartialBillingForTransaction(int transactionId) throws ProfitMandiBusinessException {
35424 amit 4654
        // Fetch with pessimistic lock to prevent concurrent modifications
4655
        List<Order> orderList = orderRepository.selectAllByTransactionIdForUpdate(transactionId);
33051 amit.gupta 4656
        Map<Integer, Order> orderMap = orderList.stream().collect(Collectors.toMap(x -> x.getId(), x -> x));
4657
        //Delete scanRecords
4658
        List<WarehouseScan> warehouseScans = warehouseScanRepository.selectAllByOrderIds(new ArrayList<>(orderMap.keySet()));
4659
        for (WarehouseScan warehouseScan : warehouseScans) {
4660
            warehouseScanRepository.delete(warehouseScan);
4661
            WarehouseInventoryItem warehouseInventoryItem = warehouseInventoryItemRepository.selectById(warehouseScan.getInventoryItemId());
4662
            warehouseInventoryItem.setLastScanType(in.shop2020.warehouse.ScanType.PURCHASE);
4663
            warehouseInventoryItem.setCurrentQuantity(warehouseInventoryItem.getCurrentQuantity() + warehouseScan.getQuantity());
4664
        }
4665
 
4666
        for (Order order : orderList) {
33078 ranu 4667
            if (order.getBillingTimestamp() != null) {
33056 amit.gupta 4668
                order.setStatus(OrderStatus.ACCEPTED);
4669
                order.setStatusDescription("Submitted for Processing");
4670
                order.setBillingTimestamp(null);
4671
                order.setBilledBy(null);
33057 amit.gupta 4672
                order.setSerialNumber(null);
33056 amit.gupta 4673
                order.setJacketNumber(null);
33060 amit.gupta 4674
                order.getLineItem().setSerialNumber(null);
33056 amit.gupta 4675
                List<LineItemImei> lineItemImeis = lineItemImeisRepository.selectByLineItemId(order.getLineItem().getId());
4676
                for (LineItemImei lineItemImei : lineItemImeis) {
4677
                    lineItemImeisRepository.delete(lineItemImei);
4678
                }
4679
                SaholicReservationSnapshot saholicReservationSnapshot = saholicReservationSnapshotRepository
4680
                        .selectByOrderId(order.getId());
4681
                if (saholicReservationSnapshot == null) {
4682
                    saholicInventoryService.addReservationCount(order.getLineItem().getItemId(),
4683
                            order.getFulfilmentWarehouseId(), order.getLineItem().getQuantity(), order.getId());
4684
                }
33055 amit.gupta 4685
            }
33051 amit.gupta 4686
        }
4687
    }
4688
 
31697 amit.gupta 4689
    public void hygineAlertForInternalTeam() throws ProfitMandiBusinessException, MessagingException, IOException {
31206 tejbeer 4690
 
31697 amit.gupta 4691
        List<String> remarks = new ArrayList<>();
4692
        remarks.add("Out of Service");
4693
        remarks.add("Duplicate number");
4694
        remarks.add("Partner number");
31886 tejbeer 4695
        List<HygieneData> hygieneDataLastThreeMonth = hygieneDataRepository.selectDisposedDateAndRemarks(
4696
                LocalDate.now().withDayOfMonth(1).minusMonths(3).atStartOfDay(), LocalDate.now().minusMonths(1).withDayOfMonth(LocalDate.now().minusMonths(1).lengthOfMonth()).atTime(LocalTime.MAX), remarks);
31206 tejbeer 4697
 
31886 tejbeer 4698
        List<HygieneData> hygieneDataRecentMonth = hygieneDataRepository.selectDisposedDateAndRemarks(LocalDate.now().withDayOfMonth(1), remarks);
31697 amit.gupta 4699
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMapping();
4700
        Map<Integer, List<HygieneData>> partnerHygieneLastThreeMonthMap = null;
31206 tejbeer 4701
 
31697 amit.gupta 4702
        Map<Integer, List<HygieneData>> partnerHygieneDataRecentMonth = null;
31206 tejbeer 4703
 
31697 amit.gupta 4704
        if (!hygieneDataLastThreeMonth.isEmpty()) {
31886 tejbeer 4705
            partnerHygieneLastThreeMonthMap = hygieneDataLastThreeMonth.stream().collect(groupingBy(x -> x.getFofoId()));
31206 tejbeer 4706
 
31697 amit.gupta 4707
        }
31206 tejbeer 4708
 
31697 amit.gupta 4709
        if (!hygieneDataRecentMonth.isEmpty()) {
31886 tejbeer 4710
            partnerHygieneDataRecentMonth = hygieneDataRecentMonth.stream().collect(groupingBy(x -> x.getFofoId()));
31697 amit.gupta 4711
        }
31206 tejbeer 4712
 
31697 amit.gupta 4713
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
31206 tejbeer 4714
 
31697 amit.gupta 4715
            String email = storeGuyEntry.getKey();
31206 tejbeer 4716
 
31697 amit.gupta 4717
            List<Integer> fofoIds = new ArrayList<>(storeGuyEntry.getValue());
31206 tejbeer 4718
 
31697 amit.gupta 4719
            Map<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthData = new HashMap<>();
4720
            Map<Integer, Map<LocalDate, List<HygieneData>>> partnerDateWiseData = new HashMap<>();
4721
            for (Integer fofoId : fofoIds) {
31206 tejbeer 4722
 
31697 amit.gupta 4723
                partnerYearMonthData.put(fofoId, null);
4724
                partnerDateWiseData.put(fofoId, null);
4725
                if (!partnerHygieneLastThreeMonthMap.isEmpty()) {
4726
                    List<HygieneData> hygienes = partnerHygieneLastThreeMonthMap.get(fofoId);
31206 tejbeer 4727
 
31697 amit.gupta 4728
                    if (hygienes != null) {
31886 tejbeer 4729
                        Map<YearMonth, List<HygieneData>> yearMonthData = hygienes.stream().collect(groupingBy(x -> YearMonth.from(x.getDisposedTimestamp())));
31206 tejbeer 4730
 
31697 amit.gupta 4731
                        partnerYearMonthData.put(fofoId, yearMonthData);
31206 tejbeer 4732
 
31697 amit.gupta 4733
                    }
4734
                    List<HygieneData> dateWiseHygienes = partnerHygieneDataRecentMonth.get(fofoId);
31206 tejbeer 4735
 
31697 amit.gupta 4736
                    if (dateWiseHygienes != null) {
31206 tejbeer 4737
 
31886 tejbeer 4738
                        Map<LocalDate, List<HygieneData>> dateWiseData = hygienes.stream().collect(groupingBy(x -> (x.getDisposedTimestamp()).toLocalDate()));
31206 tejbeer 4739
 
31697 amit.gupta 4740
                        partnerDateWiseData.put(fofoId, dateWiseData);
31206 tejbeer 4741
 
31697 amit.gupta 4742
                    }
31206 tejbeer 4743
 
31697 amit.gupta 4744
                }
31206 tejbeer 4745
 
31697 amit.gupta 4746
            }
31206 tejbeer 4747
 
31697 amit.gupta 4748
            String subject = "Customer Info - Hygiene Alert";
31206 tejbeer 4749
 
31697 amit.gupta 4750
            LOGGER.info("hygieneData {}", partnerDateWiseData.values());
31206 tejbeer 4751
 
31697 amit.gupta 4752
            boolean partnerDateWise = partnerDateWiseData.values().stream().allMatch(Objects::isNull);
31206 tejbeer 4753
 
31697 amit.gupta 4754
            boolean partnerYearMonth = partnerYearMonthData.values().stream().allMatch(Objects::isNull);
31206 tejbeer 4755
 
31697 amit.gupta 4756
            if (!partnerDateWise && !partnerYearMonth) {
4757
                String sb = this.getMessageHygieneAlertForPartner(partnerYearMonthData, partnerDateWiseData);
36460 ranu 4758
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{email}, sb, null, subject);
31697 amit.gupta 4759
            }
31206 tejbeer 4760
 
31697 amit.gupta 4761
        }
31206 tejbeer 4762
 
31697 amit.gupta 4763
    }
31206 tejbeer 4764
 
31697 amit.gupta 4765
    private String getMessageHygieneAlertForPartner(
33256 amit.gupta 4766
            Map<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthData, Map<Integer, Map<LocalDate, List<HygieneData>>> partnerDateWiseData)
4767
            throws ProfitMandiBusinessException {
31206 tejbeer 4768
 
31697 amit.gupta 4769
        Map<Integer, CustomRetailer> customeRetailerMap = retailerService.getAllFofoRetailers();
31206 tejbeer 4770
 
31697 amit.gupta 4771
        LocalDateTime startDate = LocalDate.now().withDayOfMonth(1).atStartOfDay();
4772
        LocalDateTime endDate = LocalDateTime.now();
31206 tejbeer 4773
 
31697 amit.gupta 4774
        LocalDateTime startYearMonth = LocalDate.now().withDayOfMonth(1).minusMonths(3).atStartOfDay();
31886 tejbeer 4775
        LocalDateTime endYearMonth = LocalDate.now().minusMonths(1).withDayOfMonth(LocalDate.now().minusMonths(1).lengthOfMonth()).atTime(LocalTime.MAX);
31206 tejbeer 4776
 
31697 amit.gupta 4777
        DateTimeFormatter dateYearMonthFormatter = DateTimeFormatter.ofPattern("MMM''uu");
31206 tejbeer 4778
 
31697 amit.gupta 4779
        List<YearMonth> yearMonthRange = new ArrayList<>();
4780
        yearMonthRange.add(YearMonth.from(startYearMonth));
31206 tejbeer 4781
 
31697 amit.gupta 4782
        yearMonthRange.add(YearMonth.from(startYearMonth.plusMonths(1)));
31206 tejbeer 4783
 
31697 amit.gupta 4784
        yearMonthRange.add(YearMonth.from(endYearMonth));
31206 tejbeer 4785
 
31697 amit.gupta 4786
        long noOfDaysBetween = ChronoUnit.DAYS.between(startDate, endDate.plusDays(1));
31206 tejbeer 4787
 
31886 tejbeer 4788
        List<LocalDate> dateRange = Stream.iterate(startDate.toLocalDate(), date -> date.plusDays(1)).limit(noOfDaysBetween).collect(Collectors.toList());
31206 tejbeer 4789
 
31697 amit.gupta 4790
        StringBuilder sb = new StringBuilder();
31886 tejbeer 4791
        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 4792
 
31697 amit.gupta 4793
                + "<table style='border:1px solid black ;padding: 5px';>");
4794
        sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
4795
        sb.append("<th style='border:1px solid black;padding: 5px'>Partner Name</th>\n");
31206 tejbeer 4796
 
31697 amit.gupta 4797
        for (YearMonth yearMonth : yearMonthRange) {
31886 tejbeer 4798
            sb.append("<th style='border:1px solid black;padding: 5px'>" + yearMonth.format(dateYearMonthFormatter) + "</th>\n");
31697 amit.gupta 4799
        }
31206 tejbeer 4800
 
31697 amit.gupta 4801
        for (LocalDate localDate : dateRange) {
4802
            sb.append("<th style='border:1px solid black;padding: 5px'>" + localDate + "</th>\n");
4803
        }
31206 tejbeer 4804
 
31697 amit.gupta 4805
        sb.append("</tr>\n");
31206 tejbeer 4806
 
31886 tejbeer 4807
        for (Entry<Integer, Map<YearMonth, List<HygieneData>>> partnerYearMonthEntry : partnerYearMonthData.entrySet()) {
31206 tejbeer 4808
 
31697 amit.gupta 4809
            int fofoId = partnerYearMonthEntry.getKey();
31206 tejbeer 4810
 
31697 amit.gupta 4811
            Map<YearMonth, List<HygieneData>> yearMonthData = partnerYearMonthEntry.getValue();
31206 tejbeer 4812
 
31697 amit.gupta 4813
            Map<LocalDate, List<HygieneData>> dateWiseData = partnerDateWiseData.get(fofoId);
31206 tejbeer 4814
 
31697 amit.gupta 4815
            if (yearMonthData == null && dateWiseData == null) {
4816
                continue;
4817
            }
31206 tejbeer 4818
 
31697 amit.gupta 4819
            sb.append("<tr>");
31886 tejbeer 4820
            sb.append("<td style='border:1px solid black;padding: 5px'>" + customeRetailerMap.get(fofoId).getBusinessName() + "</td>\n");
31697 amit.gupta 4821
            for (YearMonth yearMonth : yearMonthRange) {
31206 tejbeer 4822
 
31697 amit.gupta 4823
                if (yearMonthData == null) {
4824
                    sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4825
 
31697 amit.gupta 4826
                } else {
4827
                    List<HygieneData> hygieneList = yearMonthData.get(yearMonth);
31206 tejbeer 4828
 
31697 amit.gupta 4829
                    if (hygieneList != null) {
4830
                        sb.append("<td style='border:1px solid black;padding: 5px'>" + hygieneList.size() + "</td>\n");
31206 tejbeer 4831
 
31697 amit.gupta 4832
                    } else {
4833
                        sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4834
 
31697 amit.gupta 4835
                    }
4836
                }
4837
            }
31206 tejbeer 4838
 
31697 amit.gupta 4839
            for (LocalDate localDate : dateRange) {
31206 tejbeer 4840
 
31697 amit.gupta 4841
                if (dateWiseData == null) {
4842
                    sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31206 tejbeer 4843
 
31697 amit.gupta 4844
                } else {
4845
                    List<HygieneData> hygieneList = dateWiseData.get(localDate);
31206 tejbeer 4846
 
31697 amit.gupta 4847
                    if (hygieneList != null) {
4848
                        sb.append("<td style='border:1px solid black;padding: 5px'>" + hygieneList.size() + "</td>\n");
31218 tejbeer 4849
 
31697 amit.gupta 4850
                    } else {
4851
                        sb.append("<td style='border:1px solid black;padding: 5px'>-</td>\n");
31218 tejbeer 4852
 
31697 amit.gupta 4853
                    }
4854
                }
4855
            }
4856
            sb.append("</tr>");
31218 tejbeer 4857
 
31697 amit.gupta 4858
        }
31218 tejbeer 4859
 
31697 amit.gupta 4860
        sb.append("</tbody></table></body></html>");
31218 tejbeer 4861
 
31697 amit.gupta 4862
        return sb.toString();
4863
    }
31218 tejbeer 4864
 
33874 ranu 4865
    @Autowired
4866
    private MonthlyTargetRepository monthlyTargetRepository;
31218 tejbeer 4867
 
31697 amit.gupta 4868
    public void monthlyTargetForPartner() throws MessagingException, ProfitMandiBusinessException, IOException {
31218 tejbeer 4869
 
31697 amit.gupta 4870
        LocalDateTime curDate = LocalDateTime.now();
4871
        List<MonthlyTarget> monthlyTargets = monthlyTargetRepository.selectByDate(YearMonth.now());
31218 tejbeer 4872
 
31886 tejbeer 4873
        Map<Integer, MonthlyTarget> partnersMonthlyTarget = monthlyTargets.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31218 tejbeer 4874
 
31886 tejbeer 4875
        Map<Integer, Double> secondaryMtd = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX));
4876
        Map<Integer, Double> todaytertiary = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate, curDate.with(LocalTime.MAX), 0, false);
31218 tejbeer 4877
 
31697 amit.gupta 4878
        String subject = "Monthly Target Vs Achievement";
31218 tejbeer 4879
 
31697 amit.gupta 4880
        for (Entry<Integer, MonthlyTarget> partnerMonthlyTargetEntry : partnersMonthlyTarget.entrySet()) {
31249 tejbeer 4881
 
31697 amit.gupta 4882
            int fofoId = partnerMonthlyTargetEntry.getKey();
31249 tejbeer 4883
 
31697 amit.gupta 4884
            CustomRetailer customRetailer = retailerService.getFofoRetailer(fofoId);
31249 tejbeer 4885
 
31697 amit.gupta 4886
            Double purchaseTarget = partnerMonthlyTargetEntry.getValue().getPurchaseTarget();
31218 tejbeer 4887
 
31697 amit.gupta 4888
            Double saleTarget = partnerMonthlyTargetEntry.getValue().getSaleTarget();
31218 tejbeer 4889
 
31697 amit.gupta 4890
            if (purchaseTarget > 0) {
4891
                Double purchase = secondaryMtd.get(fofoId);
31249 tejbeer 4892
 
31697 amit.gupta 4893
                if (purchase == null) {
4894
                    purchase = 0.0;
4895
                }
31218 tejbeer 4896
 
31697 amit.gupta 4897
                Double balanceTarget = purchaseTarget - purchase;
31218 tejbeer 4898
 
31697 amit.gupta 4899
                if (balanceTarget <= 0) {
4900
                    balanceTarget = 0.0;
4901
                }
31651 tejbeer 4902
 
31697 amit.gupta 4903
                StringBuilder sb = new StringBuilder();
4904
                sb.append("<html><body><p>Dear Partner,\n");
31886 tejbeer 4905
                sb.append("<p>Pls note your agreed monthly target is Rs." + purchaseTarget + " and your achievement till date is Rs." + purchase + "</p>");
31697 amit.gupta 4906
                sb.append("<p>Pls note that your balance target is Rs." + balanceTarget + "</p>\n");
4907
                sb.append(
32350 amit.gupta 4908
                        "<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 4909
 
36473 amit 4910
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{customRetailer.getEmail()}, sb.toString(), null, subject);
31697 amit.gupta 4911
            }
31218 tejbeer 4912
 
31697 amit.gupta 4913
        }
31218 tejbeer 4914
 
31697 amit.gupta 4915
    }
31218 tejbeer 4916
 
33444 ranu 4917
 
34502 amit.gupta 4918
    public void findAllLiveDemoBrandItemsByBillingDate() throws
4919
            MessagingException, ProfitMandiBusinessException, IOException {
33444 ranu 4920
        LocalDateTime endDate = LocalDate.now().atStartOfDay().minusDays(8);
4921
 
4922
        List<LiveDemoOrderLineItemModel> liveDemoOrderLineItemModels = orderRepository.findAllLiveDemoBrandItemsByBillingDate(endDate.minusDays(60), endDate);
4923
        LOGGER.info("liveDemoOrderLineItemModels {}", liveDemoOrderLineItemModels);
4924
        String subject = "Billed Live Demo Model";
4925
        StringBuilder sb = new StringBuilder();
4926
 
4927
        sb.append("<html><body><p>Hi,\n");
4928
        sb.append("<p>Please check live demo billed order :</p>\n" + " <table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
4929
 
4930
        sb.append("<th style='border:1px solid black;padding: 5px'>Item Id</th>\n");
4931
        sb.append("<th style='border:1px solid black;padding: 5px'>Invoice Number</th>\n");
4932
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
4933
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
4934
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
4935
        sb.append("<th style='border:1px solid black;padding: 5px'>Serial Number</th>\n");
4936
        sb.append("<th style='border:1px solid black;padding: 5px'>Retailer Name</th>\n");
4937
        sb.append("<th style='border:1px solid black;padding: 5px'>Retailer City</th>\n");
4938
        sb.append("<th style='border:1px solid black;padding: 5px'>Retailer Pincode</th>\n");
4939
        sb.append("<th style='border:1px solid black;padding: 5px'>Retailer State</th>\n");
4940
        sb.append("<th style='border:1px solid black;padding: 5px'>Billing Date</th>\n");
4941
        sb.append("</tr>\n");
4942
        for (LiveDemoOrderLineItemModel liveDemoModel : liveDemoOrderLineItemModels) {
4943
            sb.append("<tr>");
4944
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getItemId() + "</td>\n");
4945
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getInvoiceNumber() + "</td>\n");
4946
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getBrand() + "</td>\n");
4947
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getModelNumber() + "</td>\n");
4948
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getModelName() + "</td>\n");
4949
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getSerialNumber() + "</td>\n");
4950
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getRetailerName() + "</td>\n");
4951
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getRetailerCity() + "</td>\n");
4952
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getRetailerPincode() + "</td>\n");
4953
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getState() + "</td>\n");
4954
            sb.append("<td style='border:1px solid black;padding: 5px'>" + liveDemoModel.getFormattedBillingDate() + "</td>\n");
4955
 
4956
            sb.append("</tr>\n");
4957
 
33506 amit.gupta 4958
        }
33444 ranu 4959
        List<String> sendTo = Arrays.asList("kamini.sharma@smartdukaan.com", "niranjan.kala@smartdukaan.com",
33506 amit.gupta 4960
                "mohit.gulati@smartdukaan.com", "vinay.p@smartdukaan.com", "shivam.gupta@smartdukaan.com");
33444 ranu 4961
 
4962
 
4963
        String[] email = sendTo.toArray(new String[sendTo.size()]);
36476 amit 4964
    this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
33444 ranu 4965
 
4966
    }
4967
 
33464 ranu 4968
    public void findTodayPocoBillingItems() throws MessagingException, ProfitMandiBusinessException, IOException {
4969
        LocalDateTime endDate = LocalDate.now().atStartOfDay().plusDays(1);
4970
        LocalDateTime startDate = LocalDate.now().atStartOfDay().minusDays(1);
33444 ranu 4971
 
33464 ranu 4972
        List<LiveDemoOrderLineItemModel> pocoBillingOrderLineItemModels = orderRepository.findTodayPocoBillingItems(startDate, endDate);
4973
        LOGGER.info("pocoBillingOrderLineItemModels {}", pocoBillingOrderLineItemModels);
4974
        String subject = "Poco Billing";
4975
        StringBuilder sb = new StringBuilder();
4976
 
4977
        sb.append("<html><body><p>Hi,\n");
4978
        sb.append("<p>Please check poco billed order :</p>\n" + " <table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
4979
 
4980
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
4981
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
4982
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
4983
        sb.append("<th style='border:1px solid black;padding: 5px'>Serial Number</th>\n");
4984
        sb.append("<th style='border:1px solid black;padding: 5px'>Retailer State</th>\n");
4985
        sb.append("<th style='border:1px solid black;padding: 5px'>Billing Date</th>\n");
4986
        sb.append("</tr>\n");
4987
        for (LiveDemoOrderLineItemModel pocoModel : pocoBillingOrderLineItemModels) {
4988
            sb.append("<tr>");
4989
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getBrand() + "</td>\n");
4990
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getModelNumber() + "</td>\n");
4991
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getModelName() + "</td>\n");
4992
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getSerialNumber() + "</td>\n");
4993
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getState() + "</td>\n");
4994
            sb.append("<td style='border:1px solid black;padding: 5px'>" + pocoModel.getFormattedBillingDate() + "</td>\n");
4995
 
4996
            sb.append("</tr>\n");
4997
 
33506 amit.gupta 4998
        }
33664 amit.gupta 4999
        List<String> sendTo = Arrays.asList("uday.singh@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "nishant.ohri@smartdukaan.com", "ritesh.chauhan1@smartdukaan.com");
33464 ranu 5000
 
5001
        String[] email = sendTo.toArray(new String[sendTo.size()]);
36473 amit 5002
        this.sendMailOfHtmlFormat(googleMailSender, email, sb.toString(), null, subject);
33464 ranu 5003
 
5004
    }
5005
 
5006
 
31697 amit.gupta 5007
    public void monthlyTargetForInternalTeam() throws MessagingException, ProfitMandiBusinessException, IOException {
31218 tejbeer 5008
 
31697 amit.gupta 5009
        LocalDateTime curDate = LocalDateTime.now();
31218 tejbeer 5010
 
34903 ranu 5011
        List<Integer> categoryIds = Arrays.asList(ProfitMandiConstants.TICKET_CATEGORY_CATEGORY, ProfitMandiConstants.TICKET_CATEGORY_RBM, ProfitMandiConstants.TICKET_CATEGORY_SALES, ProfitMandiConstants.TICKET_CATEGORY_ABM, ProfitMandiConstants.TICKET_CATEGORY_MARKETING, ProfitMandiConstants.TICKET_CATEGORY_ACCOUNTS, ProfitMandiConstants.TICKET_CATEGORY_BUSINESSINTELLIGENT);
31218 tejbeer 5012
 
31697 amit.gupta 5013
        Map<String, Set<Integer>> storeGuyMap = csService.getAuthUserPartnerIdMappingByCategoryIds(categoryIds, false);
31218 tejbeer 5014
 
31697 amit.gupta 5015
        List<MonthlyTarget> monthlyTargets = monthlyTargetRepository.selectByDate(YearMonth.now());
31218 tejbeer 5016
 
31697 amit.gupta 5017
        Map<Integer, CustomRetailer> customeRetailerMap = retailerService.getAllFofoRetailers();
31218 tejbeer 5018
 
31886 tejbeer 5019
        Map<Integer, MonthlyTarget> partnersMonthlyTarget = monthlyTargets.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
31218 tejbeer 5020
 
31886 tejbeer 5021
        Map<Integer, Double> secondaryMtd = orderRepository.selectBillingDatesBetweenSumGroupByRetailerId(curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX));
5022
        Map<Integer, Double> todaytertiary = fofoOrderItemRepository.selectSumMopGroupByRetailer(curDate, curDate.with(LocalTime.MAX), 0, false);
31218 tejbeer 5023
 
31697 amit.gupta 5024
        String subject = "Monthly Target Vs Achievement";
31218 tejbeer 5025
 
31697 amit.gupta 5026
        for (Entry<String, Set<Integer>> storeGuyEntry : storeGuyMap.entrySet()) {
31218 tejbeer 5027
 
31697 amit.gupta 5028
            String email = storeGuyEntry.getKey();
31218 tejbeer 5029
 
31697 amit.gupta 5030
            List<Integer> fofoIds = new ArrayList<>(storeGuyEntry.getValue());
5031
            Map<Integer, MonthlyTarget> monthlyTargetAchievement = new HashMap<>();
5032
            for (Integer fofoId : fofoIds) {
31218 tejbeer 5033
 
31697 amit.gupta 5034
                MonthlyTarget monthlyTarget = partnersMonthlyTarget.get(fofoId);
5035
                if (monthlyTarget != null) {
5036
                    Double purchaseTarget = monthlyTarget.getPurchaseTarget();
31218 tejbeer 5037
 
31697 amit.gupta 5038
                    Double saleTarget = monthlyTarget.getSaleTarget();
31218 tejbeer 5039
 
31697 amit.gupta 5040
                    if (purchaseTarget != null && purchaseTarget > 0) {
5041
                        Double purchase = secondaryMtd.get(fofoId);
5042
                        if (purchase == null) {
5043
                            purchase = 0.0;
5044
                        }
5045
                        monthlyTarget.setPurchaseAchievement(purchase);
5046
                        monthlyTargetAchievement.put(fofoId, monthlyTarget);
31218 tejbeer 5047
 
31697 amit.gupta 5048
                    }
5049
                }
5050
            }
31218 tejbeer 5051
 
31697 amit.gupta 5052
            if (!monthlyTargetAchievement.isEmpty()) {
31218 tejbeer 5053
 
31697 amit.gupta 5054
                StringBuilder sb = new StringBuilder();
31218 tejbeer 5055
 
31697 amit.gupta 5056
                sb.append("<html><body><p>Hi,\n");
31886 tejbeer 5057
                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 5058
                sb.append("<tbody>\n" + "	" + "    				" + "<tr>\n");
5059
                sb.append("<th style='border:1px solid black;padding: 5px'>Partner Name</th>\n");
31218 tejbeer 5060
 
31697 amit.gupta 5061
                sb.append("<th style='border:1px solid black;padding: 5px'>Purchase Target</th>\n");
31218 tejbeer 5062
 
31697 amit.gupta 5063
                sb.append("<th style='border:1px solid black;padding: 5px'>Purchase Achievement</th>\n");
5064
                sb.append("</tr>\n");
31218 tejbeer 5065
 
31886 tejbeer 5066
                for (Entry<Integer, MonthlyTarget> monthlyTargetAchievementEntry : monthlyTargetAchievement.entrySet()) {
31697 amit.gupta 5067
                    sb.append("<tr>");
5068
                    int fofoId = monthlyTargetAchievementEntry.getKey();
31218 tejbeer 5069
 
31697 amit.gupta 5070
                    MonthlyTarget monthlyTarget = monthlyTargetAchievementEntry.getValue();
31886 tejbeer 5071
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + customeRetailerMap.get(fofoId).getBusinessName() + "</td>\n");
31218 tejbeer 5072
 
31886 tejbeer 5073
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + monthlyTarget.getPurchaseTarget() + "</td>\n");
31218 tejbeer 5074
 
31886 tejbeer 5075
                    sb.append("<td style='border:1px solid black;padding: 5px'>" + monthlyTarget.getPurchaseAchievement() + "</td>\n");
31218 tejbeer 5076
 
31697 amit.gupta 5077
                    sb.append("</tr>\n");
31218 tejbeer 5078
 
31697 amit.gupta 5079
                }
31218 tejbeer 5080
 
36460 ranu 5081
                this.sendMailOfHtmlFormat(googleMailSender, new String[]{email}, sb.toString(), null, subject);
31697 amit.gupta 5082
                // this.sendMailOfHtmlFormat("tejbeer.kaur@smartdukaan.com", sb.toString(),
5083
                // null, subject);
31218 tejbeer 5084
 
31697 amit.gupta 5085
            }
31604 tejbeer 5086
 
31697 amit.gupta 5087
        }
31604 tejbeer 5088
 
31697 amit.gupta 5089
    }
31604 tejbeer 5090
 
32061 amit.gupta 5091
    @Autowired
5092
    private PerformanceService performanceService;
5093
 
5094
 
5095
    public void sendFilteredRetailerPerformance() throws Exception {
5096
        RetailerFilterModel retailerFilterModel = performanceService.getRetailerFilterModel();
5097
 
5098
        Map<Integer, CustomRetailer> customRetailers = retailerService.getFofoRetailers(true);
5099
 
5100
 
5101
        List<RetailerPeformanceFilterModel> partnersPerformance = performanceService.getPerformance(retailerFilterModel, customRetailers);
5102
 
5103
        Map<Integer, RetailerPeformanceFilterModel> partnersPerformanceMap = new HashMap<>();
5104
 
5105
        if (!partnersPerformance.isEmpty()) {
5106
            partnersPerformanceMap = partnersPerformance.stream().collect(Collectors.toMap(x -> x.getFofoId(), x -> x));
5107
            performanceService.sendPartnerPerformanceEmail(partnersPerformanceMap, retailerFilterModel, customRetailers);
5108
 
5109
        }
5110
 
5111
 
5112
    }
5113
 
32081 tejbeer 5114
    @Autowired
5115
    private VendorItemPricingRepository vendorItemPricingRepository;
32061 amit.gupta 5116
 
32081 tejbeer 5117
 
5118
    @Autowired
5119
    private VendorCatalogPricingService vendorCatalogPricingService;
5120
 
5121
 
33256 amit.gupta 5122
    public void migrateVendorItemPricing() throws ProfitMandiBusinessException {
32081 tejbeer 5123
 
5124
        List<VendorItemPricing> vendorItemPricings = vendorItemPricingRepository.selectAll();
32350 amit.gupta 5125
        LOGGER.info("At migrate VendorItemPricing");
32092 tejbeer 5126
        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 5127
        for (VendorItemPricing vendorItemPricing : vendorItemPricings) {
5128
            Item item = null;
32092 tejbeer 5129
            if (items.get(vendorItemPricing.getItemId()) != null) {
5130
                item = items.get(vendorItemPricing.getItemId());
5131
            } else {
32084 tejbeer 5132
                continue;
32081 tejbeer 5133
            }
32092 tejbeer 5134
 
32081 tejbeer 5135
            VendorCatalogPricingModel vendorCatalogPricingModel = new VendorCatalogPricingModel();
5136
            vendorCatalogPricingModel.setCatalogId(item.getCatalogItemId());
5137
            vendorCatalogPricingModel.setAuthId(13);
32088 tejbeer 5138
            vendorCatalogPricingModel.setDp(vendorItemPricing.getDp());
32081 tejbeer 5139
 
5140
            vendorCatalogPricingModel.setTp(vendorItemPricing.getTp());
5141
            vendorCatalogPricingModel.setMop(vendorItemPricing.getMop());
32384 amit.gupta 5142
            vendorCatalogPricingModel.setEffectedOn(LocalDate.of(2023, 8, 22));
32081 tejbeer 5143
            vendorCatalogPricingModel.setVendorId(vendorItemPricing.getVendorId());
5144
 
5145
 
5146
            try {
5147
                vendorCatalogPricingService.createVendorCatalogPricingLog(vendorCatalogPricingModel);
5148
            } catch (ProfitMandiBusinessException e) {
5149
                continue;
5150
            }
5151
 
5152
        }
5153
 
5154
    }
5155
 
5156
    public void approveVendorCatalogPricing() {
5157
        List<VendorCatalogPricingLog> vendorCatalogPricingLogs = vendorCatalogPricingLogRepository.selectByStatus(VendorCatalogPricingStatus.PENDING);
5158
 
32084 tejbeer 5159
 
32081 tejbeer 5160
        for (VendorCatalogPricingLog vendorCatalogPricingLog : vendorCatalogPricingLogs) {
32107 tejbeer 5161
            vendorCatalogPricingLog.setStatus(VendorCatalogPricingStatus.APPROVED);
5162
            vendorCatalogPricingLog.setUpdatedTimestamp(LocalDateTime.now());
5163
            vendorCatalogPricingLog.setApprovedBy(13);
5164
            vendorCatalogPricingLog.setApprovedTimestamp(LocalDateTime.now());
32114 tejbeer 5165
            vendorCatalogPricingService.createVendorCatalogPricing(vendorCatalogPricingLog);
5166
        }
32081 tejbeer 5167
 
32114 tejbeer 5168
    }
32108 tejbeer 5169
 
32822 ranu 5170
    public void sendMailWhatsAppAfterLoanDueDate() throws Exception {
36289 amit 5171
        synchronized (SD_CREDIT_LOCK) {
5172
            sdCreditService.updateRisk();
5173
            List<Loan> defaultLoans = sdCreditService.getDefaultLoans();
5174
            if (!defaultLoans.isEmpty()) {
5175
                this.sendLoanAlert(defaultLoans);
5176
            }
32822 ranu 5177
        }
5178
    }
5179
 
5180
    public void sendLoanAlert(List<Loan> defaultLoans) throws
5181
            Exception {
5182
 
35877 amit 5183
        // Sort by lowest dueDate first (most overdue)
5184
        defaultLoans.sort(Comparator.comparing(Loan::getDueDate));
32822 ranu 5185
 
32842 amit.gupta 5186
        String title = "SD Credit Alert!";
35877 amit 5187
        int whatsAppCount = 0;
32822 ranu 5188
        for (Loan defaultLoan : defaultLoans) {
35877 amit 5189
            double principal = defaultLoan.getPendingAmount().doubleValue();
5190
            double interest = defaultLoan.getInterestAccrued().doubleValue() - defaultLoan.getInterestPaid().doubleValue();
5191
            double total = principal + interest;
32822 ranu 5192
 
5193
            com.spice.profitmandi.dao.entity.user.User user = userUserRepository.selectById(defaultLoan.getFofoId());
5194
 
5195
            Address address = addressRepository.selectById(user.getAddressId());
5196
 
35877 amit 5197
            // WhatsApp: only top 2 most overdue loans
5198
            if (whatsAppCount < 2) {
5199
                String whatsAppMessage = getWhatsAppMessageForDefaultLoan(defaultLoan, total, user.getName());
32850 amit.gupta 5200
                notificationService.sendWhatsappMessage(whatsAppMessage, title, address.getPhoneNumber());
35877 amit 5201
                whatsAppCount++;
32850 amit.gupta 5202
            }
5203
 
35877 amit 5204
            String emailMessage = getEmailMessageForDefaultLoan(defaultLoan, principal, interest, total, user.getName());
32822 ranu 5205
            String[] email = {user.getEmailId()};
36473 amit 5206
            sendMailOfHtmlFormat(googleMailSender, email, emailMessage, null, "Loan Alert - SmartDukaan");
32822 ranu 5207
        }
5208
    }
5209
 
35877 amit 5210
    private String getEmailMessageForDefaultLoan(Loan loan, double principal, double interest, double total, String name) {
5211
        String formattedTotal = FormattingUtils.formatDecimal(total);
5212
        String formattedPrincipal = FormattingUtils.formatDecimal(principal);
5213
        String formattedInterest = FormattingUtils.formatDecimal(interest);
5214
        long daysInDefault = ChronoUnit.DAYS.between(loan.getPenaltyDate(), LocalDate.now());
32822 ranu 5215
 
5216
        StringBuilder sb = new StringBuilder();
35877 amit 5217
        sb.append("<html><body>");
5218
        sb.append("<p><b>Credit Default Alert!</b></p><br/>");
5219
        sb.append("<p>Dear " + name + ",</p>");
5220
        sb.append("<p>Your credit payment has been in default for " + daysInDefault + " days. " +
35915 amit 5221
                "A penalty interest of " + (loan.getPenaltyRate() != null ? loan.getPenaltyRate() : ProfitMandiConstants.NEW_DELAYED_INTEREST_RATE) + "% per day is being charged.</p>");
35877 amit 5222
        sb.append("<p><b>Total Outstanding: Rs. " + formattedTotal + "</b><br/>");
5223
        sb.append("Principal: Rs. " + formattedPrincipal + "<br/>");
5224
        sb.append("Interest: Rs. " + formattedInterest + "</p>");
5225
        sb.append("<p>Continued default will impact your Credit score and may result in legal action. " +
5226
                "Please settle the outstanding amount immediately.</p>");
5227
        sb.append("<p>To make the payment, please add Rs. " + formattedTotal + " to your wallet.</p>");
5228
        sb.append("<p>Team SmartDukaan</p>");
32822 ranu 5229
        sb.append("</body></html>");
5230
        return sb.toString();
5231
    }
5232
 
35877 amit 5233
    private String getWhatsAppMessageForDefaultLoan(Loan loan, double total, String name) {
5234
        String formattedAmount = FormattingUtils.formatDecimal(total);
5235
        long daysInDefault = ChronoUnit.DAYS.between(loan.getPenaltyDate(), LocalDate.now());
32822 ranu 5236
 
35877 amit 5237
        return String.format(
5238
                "Dear %s, Your credit payment has been in default for %d days. " +
5239
                "A penalty interest of %s%% per day is being charged on your outstanding amount of Rs. %s. " +
5240
                "Please settle immediately to avoid legal action.\n\nTeam SmartDukaan",
35915 amit 5241
                name, daysInDefault, loan.getPenaltyRate() != null ? loan.getPenaltyRate() : ProfitMandiConstants.NEW_DELAYED_INTEREST_RATE, formattedAmount);
32822 ranu 5242
    }
5243
 
33874 ranu 5244
    @Autowired
5245
    private FofoOpeningStockRepository fofoOpeningStockRepository;
34450 ranu 5246
    @Autowired
5247
    private SmartCartService smartCartService;
33874 ranu 5248
 
5249
    public void createOpeningStockPartyWise() throws Exception {
5250
        // Get all partner stock data
35329 ranu 5251
        Map<Integer, List<PartnerOpeningStockByTodayModel>> partnerOpeningStockByTodayInStockMap = currentInventorySnapshotRepository.getAllPartnerTodayInstock();
5252
        Map<Integer, List<PartnerOpeningStockByTodayModel>> partnerOpeningStockByTodayGrnPending = currentInventorySnapshotRepository.getAllPartnerTodayGrnPending();
5253
 
5254
        Map<Integer, List<PartnerOpeningStockByTodayModel>> partnerOpeningStockByTodayMap =
5255
                new HashMap<>();
5256
 
5257
// STEP 1: Copy in-stock data
5258
        partnerOpeningStockByTodayInStockMap.forEach((fofoId, list) ->
5259
                partnerOpeningStockByTodayMap.put(
5260
                        fofoId,
5261
                        new ArrayList<>(list)   // deep list copy
5262
                )
5263
        );
5264
 
5265
// STEP 2: Merge GRN pending using streams
5266
        partnerOpeningStockByTodayGrnPending.forEach((fofoId, grnList) -> {
5267
 
5268
            // If FOFO missing → simply insert GRN list (deep copy)
5269
            partnerOpeningStockByTodayMap
5270
                    .computeIfAbsent(fofoId, x -> new ArrayList<>())
5271
                    .addAll(
5272
                            grnList.stream()
5273
                                    .map(g -> new PartnerOpeningStockByTodayModel(
5274
                                            g.getFofoId(),
5275
                                            g.getCatalogId(),
5276
                                            g.getModelNumber(),
5277
                                            g.getOpeningQty()
5278
                                    ))
5279
                                    .collect(Collectors.toList())
5280
                    );
5281
        });
5282
 
5283
// STEP 3: Now merge duplicates per catalogId using grouping
5284
        partnerOpeningStockByTodayMap.replaceAll((fofoId, list) ->
5285
                list.stream()
5286
                        .collect(Collectors.toMap(
5287
                                PartnerOpeningStockByTodayModel::getCatalogId,
5288
                                m -> new PartnerOpeningStockByTodayModel(
5289
                                        m.getFofoId(),
5290
                                        m.getCatalogId(),
5291
                                        m.getModelNumber(),
5292
                                        m.getOpeningQty()
5293
                                ),
5294
                                // merge function: sum openingQty
5295
                                (m1, m2) -> {
5296
                                    m1.setOpeningQty(m1.getOpeningQty() + m2.getOpeningQty());
5297
                                    return m1;
5298
                                }
5299
                        ))
5300
                        .values()
5301
                        .stream()
5302
                        .collect(Collectors.toList())
5303
        );
5304
 
5305
 
34460 ranu 5306
        Map<Integer, Map<Integer, Integer>> activatedButNotBilledCatalogQtyMap = smartCartService.activatedButNotBilledCatalogQtyMap();
34502 amit.gupta 5307
        LOGGER.info("PartnerOpeningStockByTodayModel {}", partnerOpeningStockByTodayMap);
33874 ranu 5308
        for (Map.Entry<Integer, List<PartnerOpeningStockByTodayModel>> entry : partnerOpeningStockByTodayMap.entrySet()) {
5309
            int fofoId = entry.getKey();
5310
            List<PartnerOpeningStockByTodayModel> partnerStockList = entry.getValue();
34450 ranu 5311
            // Get the sold (activated-but-not-billed) quantity for this fofo and catalog
34460 ranu 5312
            Map<Integer, Integer> activatedButNotBilledQtyMap = activatedButNotBilledCatalogQtyMap.getOrDefault(fofoId, Collections.emptyMap());
33874 ranu 5313
 
34450 ranu 5314
            //  if stock is avaialble in snapshot
33874 ranu 5315
            for (PartnerOpeningStockByTodayModel partnerStock : partnerStockList) {
5316
                int catalogId = partnerStock.getCatalogId();
34450 ranu 5317
                int stockCurrentQty = partnerStock.getOpeningQty();
33874 ranu 5318
                LocalDate openingDate = partnerStock.getOpeningDate();
5319
 
34460 ranu 5320
                int soldButNotBilledQty = activatedButNotBilledQtyMap.getOrDefault(catalogId, 0);
34450 ranu 5321
 
35521 amit 5322
                if (catalogId == 1025656 && fofoId == 175140232) {
5323
                    LOGGER.info("catalogId {}", catalogId);
5324
                    LOGGER.info("fofoId {}", fofoId);
5325
                    LOGGER.info("soldButNotBilledQty {}", soldButNotBilledQty);
5326
                    LOGGER.info("stockCurrentQty {}", stockCurrentQty);
35329 ranu 5327
                }
5328
 
34450 ranu 5329
                // Subtract soldQty from partnerCurrentQty
34460 ranu 5330
                int partnerCurrentQty = Math.max(stockCurrentQty - soldButNotBilledQty, 0); // Ensure it doesn't go negative
34450 ranu 5331
 
5332
 
33874 ranu 5333
                // Check if an entry already exists in the FofoOpeningStock table
5334
                FofoOpeningStock existingStock = fofoOpeningStockRepository.findByFofoIdAndCatalogId(fofoId, catalogId);
5335
 
34162 ranu 5336
 
33874 ranu 5337
                if (existingStock != null) {
34363 ranu 5338
                    if (partnerCurrentQty < 1 && existingStock.getOpeningDate().isBefore(LocalDate.now().minusDays(5))) {
34160 tejus.loha 5339
                        fofoOpeningStockRepository.delete(existingStock);
5340
                    }
34162 ranu 5341
                    if (existingStock.getOpeningQty() < partnerCurrentQty) {
5342
                        existingStock.setOpeningQty(partnerCurrentQty);
5343
                        existingStock.setCurrentQty(partnerCurrentQty);
33874 ranu 5344
                        existingStock.setOpeningDate(openingDate);
5345
                        LOGGER.info("if condition exist {}");
34275 tejus.loha 5346
                    } else if (existingStock.getCurrentQty() >= existingStock.getOpeningQty()) {
5347
                        existingStock.setOpeningQty(existingStock.getCurrentQty());
5348
                        existingStock.setCurrentQty(partnerCurrentQty);
5349
                        existingStock.setOpeningDate(LocalDate.now());
34363 ranu 5350
                    } else if (existingStock.getOpeningDate().isBefore(LocalDate.now().minusDays(5))) {
33878 ranu 5351
                        int averageQty = Math.round((existingStock.getCurrentQty() + existingStock.getOpeningQty()) / 2.0f);
5352
 
5353
                        if (averageQty == 1 && existingStock.getOpeningQty() == 1 && existingStock.getCurrentQty() == 0) {
5354
                            // Delete the existing stock entry from the table
5355
                            fofoOpeningStockRepository.delete(existingStock);
5356
                            LOGGER.info("Deleted record with fofoId: {}, catalogId: {} because averageQty, openingQty, and currentQty meet deletion criteria", fofoId, catalogId);
5357
                        } else {
5358
                            // Update the existing stock with the new average quantity
5359
                            existingStock.setOpeningQty(averageQty);
34244 ranu 5360
                            existingStock.setCurrentQty(partnerCurrentQty);
33878 ranu 5361
                            existingStock.setOpeningDate(LocalDate.now());
34363 ranu 5362
                            LOGGER.info("Updated due to date being older than 5 days with average quantity: {}", averageQty);
33878 ranu 5363
                        }
34275 tejus.loha 5364
                    } else {
34244 ranu 5365
                        existingStock.setCurrentQty(partnerCurrentQty);
33874 ranu 5366
                    }
5367
                } else {
5368
                    LOGGER.info("else condition exist");
5369
                    FofoOpeningStock newStock = new FofoOpeningStock();
5370
                    newStock.setFofoId(fofoId);
5371
                    newStock.setCatalogId(catalogId);
34162 ranu 5372
                    newStock.setOpeningQty(partnerCurrentQty);
5373
                    newStock.setCurrentQty(partnerCurrentQty);
33874 ranu 5374
                    newStock.setOpeningDate(openingDate);
5375
                    fofoOpeningStockRepository.persist(newStock);
5376
 
5377
                }
5378
            }
34162 ranu 5379
 
5380
//            if stock is not available in snapshot but available in opening stock
34275 tejus.loha 5381
            List<FofoOpeningStock> fofoOpeningStockList = fofoOpeningStockRepository.selectAllByFofoId(fofoId);
34162 ranu 5382
 
34275 tejus.loha 5383
            for (FofoOpeningStock fofoOpeningStock : fofoOpeningStockList) {
34162 ranu 5384
 
34275 tejus.loha 5385
                if (!partnerStockList.stream().anyMatch(partnerStock -> partnerStock.getCatalogId() == fofoOpeningStock.getCatalogId())) {
34363 ranu 5386
                    if (fofoOpeningStock.getOpeningDate().isBefore(LocalDate.now().minusDays(5))) {
34275 tejus.loha 5387
                        LOGGER.info("not match stock{}", fofoOpeningStock);
5388
                        fofoOpeningStockRepository.delete(fofoOpeningStock);
5389
                    } else {
5390
                        LOGGER.info("not match stock2{}", fofoOpeningStock);
5391
                        fofoOpeningStock.setCurrentQty(0);
5392
                    }
34162 ranu 5393
 
34275 tejus.loha 5394
                }
5395
            }
34162 ranu 5396
 
33874 ranu 5397
        }
5398
    }
5399
 
5400
 
34162 ranu 5401
    @Autowired
5402
    private CategorisedCatalogRepository categorisedCatalogRepository;
5403
 
5404
    public void groupHidCatalogsByWeeks() throws ProfitMandiBusinessException, MessagingException, IOException {
5405
        List<CategorisedCatalogListModel> categorisedCatalogs = categorisedCatalogRepository.getListByStatus(CatalogMovingEnum.HID);
5406
        LocalDate currentDate = LocalDate.now();
5407
        LocalDate oneWeekAgo = currentDate.minusDays(7);
5408
        LocalDate twoWeeksAgo = currentDate.minusDays(14);
5409
        LocalDate threeWeeksAgo = currentDate.minusDays(21);
5410
 
5411
        // This Week (inclusive of the current date)
5412
        List<CategorisedCatalogListModel> thisWeekCatalogs = categorisedCatalogs.stream()
5413
                .filter(catalog -> !catalog.getStatusCreatedDate().isBefore(oneWeekAgo))
5414
                .collect(Collectors.toList());
5415
 
5416
        // Last Week (from one week ago to two weeks ago, exclusive of this week)
5417
        List<CategorisedCatalogListModel> lastWeekCatalogs = categorisedCatalogs.stream()
5418
                .filter(catalog -> catalog.getStatusCreatedDate().isBefore(oneWeekAgo) && !catalog.getStatusCreatedDate().isBefore(twoWeeksAgo))
5419
                .collect(Collectors.toList());
5420
 
5421
        // Two Weeks Ago (from two weeks ago to three weeks ago, exclusive of last week)
5422
        List<CategorisedCatalogListModel> twoWeeksAgoCatalogs = categorisedCatalogs.stream()
5423
                .filter(catalog -> catalog.getStatusCreatedDate().isBefore(twoWeeksAgo) && !catalog.getStatusCreatedDate().isBefore(threeWeeksAgo))
5424
                .collect(Collectors.toList());
5425
 
5426
        // Older than Two Weeks Ago (anything older than three weeks ago)
5427
        List<CategorisedCatalogListModel> olderCatalogs = categorisedCatalogs.stream()
5428
                .filter(catalog -> catalog.getStatusCreatedDate().isBefore(threeWeeksAgo))
5429
                .collect(Collectors.toList());
5430
 
5431
 
5432
        String subject = "Hid Catalogs";
5433
        StringBuilder sb = new StringBuilder();
5434
 
5435
        sb.append("<html><body><p>Hi Catagory Team,\n");
5436
        sb.append("<p style='font-weight:500;'>Please review the HID catalogs for this week:</p>\n" + "<table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
5437
 
5438
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
5439
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
5440
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
5441
        sb.append("<th style='border:1px solid black;padding: 5px'>Catalog Id</th>\n");
5442
        sb.append("<th style='border:1px solid black;padding: 5px'>Start Date</th>\n");
5443
        sb.append("<th style='border:1px solid black;padding: 5px'>End Date</th>\n");
5444
        sb.append("</tr>\n");
5445
 
5446
        for (CategorisedCatalogListModel catalog : thisWeekCatalogs) {
5447
            sb.append("<tr>");
5448
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getBrand() + "</td>\n");
5449
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelNumber() + "</td>\n");
5450
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelId() + "</td>\n");
5451
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getCurrentStatus() + "</td>\n");
5452
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusCreatedDate() + "</td>\n");
5453
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusEndDate() + "</td>\n");
5454
 
5455
            sb.append("</tr>\n");
5456
 
5457
        }
5458
 
5459
        sb.append("</table>");
5460
 
5461
        sb.append("</br>");
5462
        sb.append("</br>");
5463
        sb.append("</br>");
5464
        sb.append("<p style='font-weight:500;'>Please review the HID catalogs for last week:</p>\n" + "<table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
5465
 
5466
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
5467
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
5468
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
5469
        sb.append("<th style='border:1px solid black;padding: 5px'>Catalog Id</th>\n");
5470
        sb.append("<th style='border:1px solid black;padding: 5px'>Start Date</th>\n");
5471
        sb.append("<th style='border:1px solid black;padding: 5px'>End Date</th>\n");
5472
        sb.append("</tr>\n");
5473
 
5474
        for (CategorisedCatalogListModel catalog : lastWeekCatalogs) {
5475
            sb.append("<tr>");
5476
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getBrand() + "</td>\n");
5477
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelNumber() + "</td>\n");
5478
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelId() + "</td>\n");
5479
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getCurrentStatus() + "</td>\n");
5480
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusCreatedDate() + "</td>\n");
5481
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusEndDate() + "</td>\n");
5482
 
5483
            sb.append("</tr>\n");
5484
 
5485
        }
5486
        sb.append("</table>");
5487
 
5488
        sb.append("</br>");
5489
        sb.append("</br>");
5490
        sb.append("</br>");
5491
        sb.append("<p style='font-weight:500;'>Please review the HID catalogs for two week ago:</p>\n" + "<table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
5492
 
5493
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
5494
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
5495
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
5496
        sb.append("<th style='border:1px solid black;padding: 5px'>Catalog Id</th>\n");
5497
        sb.append("<th style='border:1px solid black;padding: 5px'>Start Date</th>\n");
5498
        sb.append("<th style='border:1px solid black;padding: 5px'>End Date</th>\n");
5499
        sb.append("</tr>\n");
5500
 
5501
        for (CategorisedCatalogListModel catalog : twoWeeksAgoCatalogs) {
5502
            sb.append("<tr>");
5503
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getBrand() + "</td>\n");
5504
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelNumber() + "</td>\n");
5505
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelId() + "</td>\n");
5506
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getCurrentStatus() + "</td>\n");
5507
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusCreatedDate() + "</td>\n");
5508
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusEndDate() + "</td>\n");
5509
 
5510
            sb.append("</tr>\n");
5511
 
5512
        }
5513
        sb.append("</table>");
5514
 
5515
        sb.append("</br>");
5516
        sb.append("</br>");
5517
        sb.append("</br>");
5518
        sb.append("<p style='font-weight:500;'>Please review the HID catalogs for older than two weeks ago:</p>\n" + "<table style='border:1px solid black ;padding: 5px; border-collapse: collapse;'>");
5519
 
5520
        sb.append("<th style='border:1px solid black;padding: 5px'>Brand</th>\n");
5521
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Number</th>\n");
5522
        sb.append("<th style='border:1px solid black;padding: 5px'>Model Name</th>\n");
5523
        sb.append("<th style='border:1px solid black;padding: 5px'>Catalog Id</th>\n");
5524
        sb.append("<th style='border:1px solid black;padding: 5px'>Start Date</th>\n");
5525
        sb.append("<th style='border:1px solid black;padding: 5px'>End Date</th>\n");
5526
        sb.append("</tr>\n");
5527
 
5528
        for (CategorisedCatalogListModel catalog : olderCatalogs) {
5529
            sb.append("<tr>");
5530
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getBrand() + "</td>\n");
5531
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelNumber() + "</td>\n");
5532
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getModelId() + "</td>\n");
5533
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getCurrentStatus() + "</td>\n");
5534
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusCreatedDate() + "</td>\n");
5535
            sb.append("<td style='border:1px solid black;padding: 5px'>" + catalog.getStatusEndDate() + "</td>\n");
5536
 
5537
            sb.append("</tr>\n");
5538
 
5539
        }
5540
        sb.append("</table>");
5541
        sb.append("</body></html>");
5542
 
34275 tejus.loha 5543
        List<String> sendTo = Arrays.asList("uday.singh@smartdukaan.com", "kuldeep.kumar@smartdukaan.com", "nishant.ohri@smartdukaan.com", "ritesh.chauhan1@smartdukaan.com", "shobhit.tandon@smartdukaan.com", "tarun.verma@smartdukaan.com", "niranjan.kala@smartdukaan.com");
34162 ranu 5544
 
5545
 
5546
        String[] email = sendTo.toArray(new String[sendTo.size()]);
5547
 
36402 amit 5548
        this.sendMailOfHtmlFormat(gmailRelaySender, email, sb.toString(), null, subject);
34162 ranu 5549
    }
5550
 
34275 tejus.loha 5551
    public void send10OrMoreOlderStockReport() throws Exception {
35094 ranu 5552
        System.out.print("testSTart");
34352 amit.gupta 5553
        purSaleService.moreThen10DaysEgedStockReport();
35094 ranu 5554
        System.out.print("testEnd");
34162 ranu 5555
 
34275 tejus.loha 5556
    }
34162 ranu 5557
 
34791 aman.kumar 5558
    public void sendUpdateMobileBrandMarketShareQuaterlyMail() throws Exception {
5559
        String subject = "Reminder: Please Update Brand-wise Market Share";
5560
 
5561
        String body = "Dear Team,\n\n" +
5562
                "This is a gentle reminder to kindly update the brand-wise market share data for the current quarter.\n\n" +
5563
                "Best regards,\n" +
5564
                "SmartDukaan Team";
5565
 
35959 amit 5566
        mailOutboxService.queueMailViaGoogle(
34791 aman.kumar 5567
                new String[]{"sm.@smartdukaan.com"},
5568
                new String[]{"tech@smartdukaan.com"},
5569
                subject,
35959 amit 5570
                body,
5571
                "ScheduledTasks.sendUpdateMobileBrandMarketShareQuaterlyMail"
34791 aman.kumar 5572
        );
5573
    }
5574
 
5575
 
32210 jai.hind 5576
}
33664 amit.gupta 5577
// 2284"