Subversion Repositories SmartDukaan

Rev

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

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