Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21612 ashik.ali 1
package com.spice.profitmandi.web.controller;
2
 
21689 ashik.ali 3
import java.io.ByteArrayInputStream;
4
import java.io.ByteArrayOutputStream;
5
import java.io.InputStream;
23638 amit.gupta 6
import java.time.LocalDateTime;
7
import java.time.temporal.ChronoUnit;
24844 amit.gupta 8
import java.util.ArrayList;
23654 amit.gupta 9
import java.util.Arrays;
23343 ashik.ali 10
import java.util.HashMap;
21612 ashik.ali 11
import java.util.HashSet;
21680 ashik.ali 12
import java.util.List;
13
import java.util.Map;
21612 ashik.ali 14
import java.util.Set;
23638 amit.gupta 15
import java.util.stream.Collectors;
21612 ashik.ali 16
 
17
import javax.servlet.http.HttpServletRequest;
21689 ashik.ali 18
import javax.servlet.http.HttpServletResponse;
21612 ashik.ali 19
 
23638 amit.gupta 20
import org.apache.logging.log4j.LogManager;
23568 govind 21
import org.apache.logging.log4j.Logger;
21612 ashik.ali 22
import org.springframework.beans.factory.annotation.Autowired;
21689 ashik.ali 23
import org.springframework.core.io.InputStreamResource;
24
import org.springframework.http.HttpHeaders;
25
import org.springframework.http.HttpStatus;
26
import org.springframework.http.MediaType;
27
import org.springframework.http.ResponseEntity;
21612 ashik.ali 28
import org.springframework.stereotype.Controller;
22064 ashik.ali 29
import org.springframework.transaction.annotation.Transactional;
21985 kshitij.so 30
import org.springframework.ui.Model;
24880 govind 31
import org.springframework.web.bind.annotation.GetMapping;
23654 amit.gupta 32
import org.springframework.web.bind.annotation.PathVariable;
24105 govind 33
import org.springframework.web.bind.annotation.PutMapping;
21612 ashik.ali 34
import org.springframework.web.bind.annotation.RequestBody;
35
import org.springframework.web.bind.annotation.RequestMapping;
36
import org.springframework.web.bind.annotation.RequestMethod;
21689 ashik.ali 37
import org.springframework.web.bind.annotation.RequestParam;
21612 ashik.ali 38
 
26817 amit.gupta 39
import com.google.gson.Gson;
23203 ashik.ali 40
import com.spice.profitmandi.common.enumuration.SearchType;
21612 ashik.ali 41
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
21985 kshitij.so 42
import com.spice.profitmandi.common.model.CartFofo;
22860 ashik.ali 43
import com.spice.profitmandi.common.model.CreateOrderRequest;
23654 amit.gupta 44
import com.spice.profitmandi.common.model.CreditNotePdfModel;
23584 ashik.ali 45
import com.spice.profitmandi.common.model.CustomCustomer;
26647 tejbeer 46
import com.spice.profitmandi.common.model.CustomRetailer;
23638 amit.gupta 47
import com.spice.profitmandi.common.model.FoiBadReturnRequest;
24105 govind 48
import com.spice.profitmandi.common.model.PaymentOptionTransactionModel;
22660 ashik.ali 49
import com.spice.profitmandi.common.model.PdfModel;
22581 ashik.ali 50
import com.spice.profitmandi.common.model.PriceModel;
21612 ashik.ali 51
import com.spice.profitmandi.common.model.ProfitMandiConstants;
21689 ashik.ali 52
import com.spice.profitmandi.common.util.PdfUtils;
23638 amit.gupta 53
import com.spice.profitmandi.common.util.StringUtils;
22244 ashik.ali 54
import com.spice.profitmandi.common.web.util.ResponseSender;
23638 amit.gupta 55
import com.spice.profitmandi.dao.entity.catalog.Item;
22217 ashik.ali 56
import com.spice.profitmandi.dao.entity.dtr.InsurancePolicy;
23343 ashik.ali 57
import com.spice.profitmandi.dao.entity.dtr.InsuranceProvider;
23548 ashik.ali 58
import com.spice.profitmandi.dao.entity.dtr.PaymentOptionTransaction;
26647 tejbeer 59
import com.spice.profitmandi.dao.entity.fofo.CurrentInventorySnapshot;
21728 ashik.ali 60
import com.spice.profitmandi.dao.entity.fofo.Customer;
61
import com.spice.profitmandi.dao.entity.fofo.CustomerAddress;
23654 amit.gupta 62
import com.spice.profitmandi.dao.entity.fofo.CustomerCreditNote;
63
import com.spice.profitmandi.dao.entity.fofo.CustomerReturnItem;
23638 amit.gupta 64
import com.spice.profitmandi.dao.entity.fofo.FofoLineItem;
22927 ashik.ali 65
import com.spice.profitmandi.dao.entity.fofo.FofoOrder;
22860 ashik.ali 66
import com.spice.profitmandi.dao.entity.fofo.FofoOrderItem;
21728 ashik.ali 67
import com.spice.profitmandi.dao.entity.fofo.PaymentOption;
26647 tejbeer 68
import com.spice.profitmandi.dao.entity.fofo.PendingOrder;
69
import com.spice.profitmandi.dao.entity.fofo.PendingOrderItem;
23298 ashik.ali 70
import com.spice.profitmandi.dao.entity.user.Address;
23548 ashik.ali 71
import com.spice.profitmandi.dao.enumuration.dtr.PaymentOptionReferenceType;
27046 tejbeer 72
import com.spice.profitmandi.dao.enumuration.transaction.OrderStatus;
23638 amit.gupta 73
import com.spice.profitmandi.dao.repository.catalog.ItemRepository;
26647 tejbeer 74
import com.spice.profitmandi.dao.repository.dtr.FofoStoreRepository;
22217 ashik.ali 75
import com.spice.profitmandi.dao.repository.dtr.InsurancePolicyRepository;
23343 ashik.ali 76
import com.spice.profitmandi.dao.repository.dtr.InsuranceProviderRepository;
23638 amit.gupta 77
import com.spice.profitmandi.dao.repository.dtr.PaymentOptionTransactionRepository;
23298 ashik.ali 78
import com.spice.profitmandi.dao.repository.dtr.RetailerRegisteredAddressRepository;
26647 tejbeer 79
import com.spice.profitmandi.dao.repository.fofo.CurrentInventorySnapshotRepository;
21728 ashik.ali 80
import com.spice.profitmandi.dao.repository.fofo.CustomerAddressRepository;
81
import com.spice.profitmandi.dao.repository.fofo.CustomerRepository;
23650 amit.gupta 82
import com.spice.profitmandi.dao.repository.fofo.CustomerReturnItemRepository;
22860 ashik.ali 83
import com.spice.profitmandi.dao.repository.fofo.FofoOrderItemRepository;
21728 ashik.ali 84
import com.spice.profitmandi.dao.repository.fofo.FofoOrderRepository;
23366 ashik.ali 85
import com.spice.profitmandi.dao.repository.fofo.FofoPartnerPaymentOptionRepository;
21728 ashik.ali 86
import com.spice.profitmandi.dao.repository.fofo.PaymentOptionRepository;
26647 tejbeer 87
import com.spice.profitmandi.dao.repository.fofo.PendingOrderItemRepository;
88
import com.spice.profitmandi.dao.repository.fofo.PendingOrderRepository;
24440 amit.gupta 89
import com.spice.profitmandi.dao.repository.inventory.StateRepository;
23298 ashik.ali 90
import com.spice.profitmandi.dao.repository.user.AddressRepository;
23798 amit.gupta 91
import com.spice.profitmandi.service.authentication.RoleManager;
25726 amit.gupta 92
import com.spice.profitmandi.service.integrations.zest.InsuranceService;
24440 amit.gupta 93
import com.spice.profitmandi.service.integrations.zest.MobileInsurancePlan;
23366 ashik.ali 94
import com.spice.profitmandi.service.order.OrderService;
22069 ashik.ali 95
import com.spice.profitmandi.service.pricing.PricingService;
26647 tejbeer 96
import com.spice.profitmandi.service.user.RetailerService;
22139 amit.gupta 97
import com.spice.profitmandi.web.model.LoginDetails;
22069 ashik.ali 98
import com.spice.profitmandi.web.util.CookiesProcessor;
24105 govind 99
import com.spice.profitmandi.web.util.MVCResponseSender;
21612 ashik.ali 100
 
101
@Controller
23973 govind 102
@Transactional(rollbackFor = Throwable.class)
21612 ashik.ali 103
public class OrderController {
104
 
23568 govind 105
	private static final Logger LOGGER = LogManager.getLogger(OrderController.class);
21985 kshitij.so 106
 
21612 ashik.ali 107
	@Autowired
22860 ashik.ali 108
	private CustomerRepository customerRepository;
23973 govind 109
 
23821 amit.gupta 110
	private boolean accessoriesDeals = true;
21985 kshitij.so 111
 
21612 ashik.ali 112
	@Autowired
23786 amit.gupta 113
	private RoleManager roleManager;
23973 govind 114
 
23786 amit.gupta 115
	@Autowired
26817 amit.gupta 116
	private Gson gson;
27046 tejbeer 117
 
26817 amit.gupta 118
	@Autowired
23654 amit.gupta 119
	private CustomerReturnItemRepository customerReturnItemRepository;
23973 govind 120
 
23654 amit.gupta 121
	@Autowired
23638 amit.gupta 122
	private FofoOrderItemRepository fofoOrderItemRepository;
21985 kshitij.so 123
 
21612 ashik.ali 124
	@Autowired
22860 ashik.ali 125
	private PaymentOptionRepository paymentOptionRepository;
24844 amit.gupta 126
 
24440 amit.gupta 127
	@Autowired
128
	private StateRepository stateRepository;
23973 govind 129
 
23638 amit.gupta 130
	@Autowired
131
	private ItemRepository itemRepository;
21985 kshitij.so 132
 
21680 ashik.ali 133
	@Autowired
24105 govind 134
	private MVCResponseSender mvcResponseSender;
24844 amit.gupta 135
 
24440 amit.gupta 136
	@Autowired
25726 amit.gupta 137
	private InsuranceService insuranceService;
24105 govind 138
 
139
	@Autowired
22860 ashik.ali 140
	private FofoOrderRepository fofoOrderRepository;
21985 kshitij.so 141
 
21680 ashik.ali 142
	@Autowired
22860 ashik.ali 143
	private CustomerAddressRepository customerAddressRepository;
23973 govind 144
 
22217 ashik.ali 145
	@Autowired
22860 ashik.ali 146
	private InsurancePolicyRepository insurancePolicyRepository;
23973 govind 147
 
23343 ashik.ali 148
	@Autowired
149
	private InsuranceProviderRepository insuranceProviderRepository;
21985 kshitij.so 150
 
21896 ashik.ali 151
	@Autowired
22860 ashik.ali 152
	private CookiesProcessor cookiesProcessor;
23973 govind 153
 
22069 ashik.ali 154
	@Autowired
22860 ashik.ali 155
	private PricingService pricingService;
23973 govind 156
 
22354 ashik.ali 157
	@Autowired
22860 ashik.ali 158
	private OrderService orderService;
23973 govind 159
 
23298 ashik.ali 160
	@Autowired
161
	private RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
23973 govind 162
 
22354 ashik.ali 163
	@Autowired
23298 ashik.ali 164
	private AddressRepository addressRepository;
23973 govind 165
 
23298 ashik.ali 166
	@Autowired
23548 ashik.ali 167
	private PaymentOptionTransactionRepository fofoOrderPaymentOptionRepository;
23973 govind 168
 
23366 ashik.ali 169
	@Autowired
170
	private FofoPartnerPaymentOptionRepository fofoPartnerPaymentOptionRepository;
23973 govind 171
 
23419 ashik.ali 172
	@Autowired
22860 ashik.ali 173
	private ResponseSender<?> responseSender;
23973 govind 174
 
26647 tejbeer 175
	@Autowired
176
	private PendingOrderRepository pendingOrderRepository;
177
 
178
	@Autowired
179
	private PendingOrderItemRepository pendingOrderItemRepository;
180
 
181
	@Autowired
182
	private FofoStoreRepository fofoStoreRepository;
183
 
184
	@Autowired
185
	private RetailerService retailerService;
186
 
187
	@Autowired
188
	private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
189
 
21985 kshitij.so 190
	@RequestMapping(value = "/order")
23973 govind 191
	public String orderIndex(HttpServletRequest request, @RequestParam(name = "cartData") String cartData, Model model)
192
			throws ProfitMandiBusinessException {
193
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
194
		;
195
 
23298 ashik.ali 196
		int addressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(loginDetails.getFofoId());
197
		Address address = addressRepository.selectById(addressId);
23973 govind 198
 
22860 ashik.ali 199
		List<CartFofo> cartItems = orderService.cartCheckout(cartData);
200
		Set<Integer> itemIds = new HashSet<>();
23973 govind 201
		for (CartFofo cartFofo : cartItems) {
22860 ashik.ali 202
			itemIds.add(cartFofo.getItemId());
21985 kshitij.so 203
		}
23973 govind 204
		Map<Integer, PriceModel> mopPriceMap = pricingService.getPurchasePriceMopPriceNotFound(itemIds,
205
				loginDetails.getFofoId());
206
		List<Integer> paymentOptionIds = fofoPartnerPaymentOptionRepository
207
				.selectPaymentOptionIdsByFofoId(loginDetails.getFofoId());
23366 ashik.ali 208
		List<PaymentOption> paymentOptions = paymentOptionRepository.selectByIds(new HashSet<>(paymentOptionIds));
22860 ashik.ali 209
		LOGGER.info("mopPriceMap {}", mopPriceMap);
24844 amit.gupta 210
		model.addAttribute("stateNames",
211
				stateRepository.selectAll().stream().map(x -> x.getName()).collect(Collectors.toList()));
23298 ashik.ali 212
		model.addAttribute("retailerStateName", address.getState());
24440 amit.gupta 213
		model.addAttribute("cartItems", cartItems);
22860 ashik.ali 214
		model.addAttribute("mopPriceMap", mopPriceMap);
23366 ashik.ali 215
		model.addAttribute("paymentOptions", paymentOptions);
23821 amit.gupta 216
		model.addAttribute("accessoriesDeals", accessoriesDeals);
22860 ashik.ali 217
		return "order-index";
21985 kshitij.so 218
	}
23973 govind 219
 
24440 amit.gupta 220
	@RequestMapping(value = "/checkplans", method = RequestMethod.GET)
25726 amit.gupta 221
	public String getInsurancePrices(HttpServletRequest request, @RequestParam float price, Model model,
222
			@RequestParam int itemId) throws ProfitMandiBusinessException {
22244 ashik.ali 223
		LOGGER.info("Request received at url : {}", request.getRequestURI());
24844 amit.gupta 224
 
24440 amit.gupta 225
		try {
25726 amit.gupta 226
			String response = mvcResponseSender.createResponseString(this.getPlans(price, itemId));
24440 amit.gupta 227
			model.addAttribute("response", response);
228
		} catch (Exception e) {
229
			// TODO Auto-generated catch block
230
			e.printStackTrace();
231
			throw new ProfitMandiBusinessException("Plans", "Plans API", "Error formatting insurance plans");
232
		}
24844 amit.gupta 233
 
24440 amit.gupta 234
		return "response";
22244 ashik.ali 235
	}
23973 govind 236
 
21985 kshitij.so 237
	@RequestMapping(value = "/get-order", method = RequestMethod.GET)
23973 govind 238
	public String getOrder(HttpServletRequest request, @RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId,
239
			Model model) throws ProfitMandiBusinessException {
22927 ashik.ali 240
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
241
		FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoDetails.getFofoId(), orderId);
23638 amit.gupta 242
		List<FofoOrderItem> fofoLineItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
22927 ashik.ali 243
		CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
23973 govind 244
		Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
22927 ashik.ali 245
		customerAddress.setPhoneNumber(customer.getMobileNumber());
23973 govind 246
		List<PaymentOptionTransaction> paymentOptionTransactions = fofoOrderPaymentOptionRepository
247
				.selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
248
		Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = this
249
				.paymentOptionIdPaymentOptionMap(paymentOptionTransactions);
250
		List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
251
				.selectByRetailerIdInvoiceNumber(fofoOrder.getFofoId(), fofoOrder.getInvoiceNumber());
23343 ashik.ali 252
		this.addInsuranceProvider(insurancePolicies);
24087 amit.gupta 253
 
22927 ashik.ali 254
		model.addAttribute("fofoOrder", fofoOrder);
255
		model.addAttribute("fofoLineItems", fofoLineItems);
256
		model.addAttribute("customerBillingAddress", orderService.getBillingAddress(customerAddress));
257
		model.addAttribute("customerBillingAddressObj", customerAddress);
23548 ashik.ali 258
		model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
23366 ashik.ali 259
		model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
22927 ashik.ali 260
		model.addAttribute("insurancePolicies", insurancePolicies);
261
		return "order-details";
21985 kshitij.so 262
	}
23973 govind 263
 
264
	private Map<Integer, InsuranceProvider> toInsuranceProviderIdInsuranceProvider(
265
			List<InsuranceProvider> insuranceProviders) {
23343 ashik.ali 266
		Map<Integer, InsuranceProvider> insuranceProviderIdInsuranceProviderMap = new HashMap<>();
23973 govind 267
		for (InsuranceProvider insuranceProvider : insuranceProviders) {
23343 ashik.ali 268
			insuranceProviderIdInsuranceProviderMap.put(insuranceProvider.getId(), insuranceProvider);
269
		}
270
		return insuranceProviderIdInsuranceProviderMap;
271
	}
23973 govind 272
 
273
	private void addInsuranceProvider(List<InsurancePolicy> insurancePolicies) {
274
		if (insurancePolicies.isEmpty()) {
23343 ashik.ali 275
			return;
276
		}
277
		Set<Integer> insuranceProviderIds = new HashSet<>();
23973 govind 278
		for (InsurancePolicy insurancePolicy : insurancePolicies) {
23343 ashik.ali 279
			insuranceProviderIds.add(insurancePolicy.getProviderId());
280
		}
281
		LOGGER.info("insuranceProviderIds {}", insuranceProviderIds);
282
		List<InsuranceProvider> insuranceProviders = insuranceProviderRepository.selectByIds(insuranceProviderIds);
23973 govind 283
		Map<Integer, InsuranceProvider> insuranceProviderIdInsuranceProviderMap = this
284
				.toInsuranceProviderIdInsuranceProvider(insuranceProviders);
285
		for (InsurancePolicy insurancePolicy : insurancePolicies) {
286
			insurancePolicy
287
					.setInsuranceProvider(insuranceProviderIdInsuranceProviderMap.get(insurancePolicy.getProviderId()));
23343 ashik.ali 288
		}
289
	}
23973 govind 290
 
22244 ashik.ali 291
	@RequestMapping(value = "/saleDetails", method = RequestMethod.GET)
23973 govind 292
	public String getSaleDetails(HttpServletRequest request,
293
			@RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId, Model model) throws Exception {
22927 ashik.ali 294
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
25562 amit.gupta 295
		boolean isAdmin = roleManager.isAdmin(fofoDetails.getRoleIds());
22927 ashik.ali 296
		FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoDetails.getFofoId(), orderId);
23654 amit.gupta 297
		List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
22927 ashik.ali 298
		CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
23973 govind 299
		List<PaymentOptionTransaction> paymentOptionTransactions = fofoOrderPaymentOptionRepository
300
				.selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
301
 
302
		// Added Migration info as we lost it.
303
		if (paymentOptionTransactions == null || paymentOptionTransactions.size() == 0) {
23952 amit.gupta 304
			PaymentOptionTransaction pot = new PaymentOptionTransaction();
305
			pot.setAmount(fofoOrder.getTotalAmount());
306
			pot.setCreateTimestamp(fofoOrder.getCreateTimestamp());
23973 govind 307
			// Mark it paid through cash
23952 amit.gupta 308
			pot.setPaymentOptionId(1);
309
			pot.setReferenceType(PaymentOptionReferenceType.ORDER);
310
			fofoOrderPaymentOptionRepository.persist(pot);
311
			paymentOptionTransactions.add(pot);
312
			LOGGER.info("Added to get invoice");
313
		}
23973 govind 314
		Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = this
315
				.paymentOptionIdPaymentOptionMap(paymentOptionTransactions);
316
		List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
317
				.selectByRetailerIdInvoiceNumber(fofoOrder.getFofoId(), fofoOrder.getInvoiceNumber());
23343 ashik.ali 318
		this.addInsuranceProvider(insurancePolicies);
23973 govind 319
		Map<Integer, Item> itemsMap = fofoOrderItems.stream().collect(Collectors.toMap(x -> x.getItemId(), x -> {
23638 amit.gupta 320
			try {
321
				return itemRepository.selectById(x.getItemId());
322
			} catch (ProfitMandiBusinessException e) {
323
				// TODO Auto-generated catch block
324
				return null;
325
			}
326
		}));
23973 govind 327
		Map<Integer, Set<FofoLineItem>> fofoOrderItemIdLineItemMap = fofoOrderItems.stream()
328
				.collect(Collectors.toMap(FofoOrderItem::getId, FofoOrderItem::getFofoLineItems));
23654 amit.gupta 329
 
23973 govind 330
		Map<Integer, List<CustomerReturnItem>> foiIdCustomerReturnInventoryItemsMap = fofoOrderItems.stream()
331
				.collect(Collectors.toMap(foi -> foi.getId(),
332
						foi -> customerReturnItemRepository.selectAllByOrderItemId(foi.getId())));
23654 amit.gupta 333
 
334
		Map<Integer, Integer> inventoryItemBilledQtyMap = new HashMap<>();
23973 govind 335
 
336
		for (FofoOrderItem foi : fofoOrderItems) {
337
			for (FofoLineItem fli : foi.getFofoLineItems()) {
23654 amit.gupta 338
				inventoryItemBilledQtyMap.put(fli.getInventoryItemId(), fli.getQuantity());
339
			}
23973 govind 340
			List<CustomerReturnItem> customerReturnItems = customerReturnItemRepository
341
					.selectAllByOrderItemId(foi.getId());
25562 amit.gupta 342
			this.markDoa(fofoOrder, foi, isAdmin);
23973 govind 343
			for (CustomerReturnItem customerReturnItem : customerReturnItems) {
344
				inventoryItemBilledQtyMap.put(customerReturnItem.getInventoryItemId(),
345
						inventoryItemBilledQtyMap.get(customerReturnItem.getInventoryItemId()) - 1);
23654 amit.gupta 346
			}
347
		}
23973 govind 348
 
23654 amit.gupta 349
		LOGGER.info("fofoOrderItemIdLineItemMap {}", fofoOrderItemIdLineItemMap);
22927 ashik.ali 350
		model.addAttribute("fofoOrder", fofoOrder);
23638 amit.gupta 351
		model.addAttribute("itemsMap", itemsMap);
23654 amit.gupta 352
		model.addAttribute("fofoOrderItemIdLineItemsMap", StringUtils.toString(fofoOrderItemIdLineItemMap));
23973 govind 353
		model.addAttribute("foiIdCustomerReturnInventoryItemsMap",
354
				StringUtils.toString(foiIdCustomerReturnInventoryItemsMap));
23654 amit.gupta 355
		model.addAttribute("fofoOrderItems", fofoOrderItems);
356
		model.addAttribute("inventoryItemBilledQtyMap", StringUtils.toString(inventoryItemBilledQtyMap));
22927 ashik.ali 357
		model.addAttribute("customerBillingAddress", orderService.getBillingAddress(customerAddress));
358
		model.addAttribute("customerBillingAddressObj", customerAddress);
23548 ashik.ali 359
		model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
23366 ashik.ali 360
		model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
22927 ashik.ali 361
		model.addAttribute("insurancePolicies", insurancePolicies);
23638 amit.gupta 362
		model.addAttribute("markDefective", this.markDefective(fofoOrder));
22927 ashik.ali 363
		return "sale-details";
22244 ashik.ali 364
	}
23973 govind 365
 
25562 amit.gupta 366
	private void markDoa(FofoOrder fofoOrder, FofoOrderItem foi, boolean isAdmin) {
25606 tejbeer 367
		if (isAdmin) {
24094 amit.gupta 368
			foi.setDoa(true);
25562 amit.gupta 369
			return;
24094 amit.gupta 370
		}
371
		LocalDateTime buyDate = fofoOrder.getCreateTimestamp().truncatedTo(ChronoUnit.DAYS);
372
		LocalDateTime curDate = LocalDateTime.now().truncatedTo(ChronoUnit.DAYS);
373
		if (buyDate.isAfter(curDate.minusDays(45))) {
374
			foi.setDoa(true);
375
		} else
376
			foi.setDoa(
377
					foi.getBrand().equals("Nokia") && foi.getCost() < 4990 && buyDate.isAfter(curDate.minusYears(1)));
23638 amit.gupta 378
	}
23973 govind 379
 
23638 amit.gupta 380
	private boolean markDefective(FofoOrder fofoOrder) {
23973 govind 381
		return fofoOrder.getCreateTimestamp().truncatedTo(ChronoUnit.DAYS).plusDays(180)
382
				.isAfter(LocalDateTime.now().truncatedTo(ChronoUnit.DAYS));
383
 
23638 amit.gupta 384
	}
23973 govind 385
 
23584 ashik.ali 386
	@RequestMapping(value = "/getSearchOrder")
23973 govind 387
	public String getSearchOrder(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
23584 ashik.ali 388
		return "search-order";
389
	}
23973 govind 390
 
23584 ashik.ali 391
	@RequestMapping(value = "/customerDetails", method = RequestMethod.PUT)
23973 govind 392
	public String updateCustomerDetails(HttpServletRequest request, @RequestBody CustomCustomer customCustomer,
393
			@RequestParam(name = ProfitMandiConstants.INVOICE_NUMBER) String invoiceNumber, Model model)
24281 amit.gupta 394
			throws Exception {
23973 govind 395
 
23584 ashik.ali 396
		orderService.updateCustomerDetails(customCustomer, invoiceNumber);
397
		return this.getSearchOrderDetails(request, invoiceNumber, model);
398
	}
23973 govind 399
 
23584 ashik.ali 400
	@RequestMapping(value = "/searchOrderDetails", method = RequestMethod.GET)
23973 govind 401
	public String getSearchOrderDetails(HttpServletRequest request,
402
			@RequestParam(name = ProfitMandiConstants.INVOICE_NUMBER) String invoiceNumber, Model model)
24281 amit.gupta 403
			throws Exception {
23973 govind 404
 
23584 ashik.ali 405
		FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
24271 amit.gupta 406
		List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
23584 ashik.ali 407
		Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
408
		CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
24105 govind 409
		List<Integer> fofoPartnerPaymentOptions = fofoPartnerPaymentOptionRepository
410
				.selectPaymentOptionIdsByFofoId(fofoOrder.getFofoId());
24844 amit.gupta 411
 
24276 amit.gupta 412
		Map<Integer, Item> itemsMap = fofoOrderItems.stream().collect(Collectors.toMap(x -> x.getItemId(), x -> {
413
			try {
414
				return itemRepository.selectById(x.getItemId());
415
			} catch (ProfitMandiBusinessException e) {
416
				// TODO Auto-generated catch block
417
				return null;
418
			}
419
		}));
24105 govind 420
		LOGGER.info("fofoPartnerPaymentOptions" + fofoPartnerPaymentOptions);
23973 govind 421
		List<PaymentOptionTransaction> paymentOptionTransactions = fofoOrderPaymentOptionRepository
422
				.selectByReferenceIdAndType(fofoOrder.getId(), PaymentOptionReferenceType.ORDER);
24105 govind 423
		LOGGER.info("paymentOptionTransactions" + paymentOptionTransactions);
23973 govind 424
		Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = this
24105 govind 425
				.paymentOptionIdPaymentOptionMapUsingPaymentOptions(fofoPartnerPaymentOptions);
426
		Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = this
427
				.paymentOptionIdPaymentOptionTransactionMap(paymentOptionTransactions);
428
		LOGGER.info("paymentOptionIdPaymentOptionTransactionMap" + paymentOptionIdPaymentOptionTransactionMap.keySet());
23973 govind 429
		List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
430
				.selectByRetailerIdInvoiceNumber(fofoOrder.getFofoId(), fofoOrder.getInvoiceNumber());
23584 ashik.ali 431
		this.addInsuranceProvider(insurancePolicies);
432
		model.addAttribute("fofoOrder", fofoOrder);
24844 amit.gupta 433
		for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
24271 amit.gupta 434
			fofoOrderItem.setDoa(true);
435
		}
24844 amit.gupta 436
 
24281 amit.gupta 437
		Map<Integer, Set<FofoLineItem>> fofoOrderItemIdLineItemMap = fofoOrderItems.stream()
438
				.collect(Collectors.toMap(FofoOrderItem::getId, FofoOrderItem::getFofoLineItems));
439
 
440
		Map<Integer, List<CustomerReturnItem>> foiIdCustomerReturnInventoryItemsMap = fofoOrderItems.stream()
441
				.collect(Collectors.toMap(foi -> foi.getId(),
442
						foi -> customerReturnItemRepository.selectAllByOrderItemId(foi.getId())));
443
 
444
		Map<Integer, Integer> inventoryItemBilledQtyMap = new HashMap<>();
445
 
446
		for (FofoOrderItem foi : fofoOrderItems) {
447
			for (FofoLineItem fli : foi.getFofoLineItems()) {
448
				inventoryItemBilledQtyMap.put(fli.getInventoryItemId(), fli.getQuantity());
449
			}
450
			List<CustomerReturnItem> customerReturnItems = customerReturnItemRepository
451
					.selectAllByOrderItemId(foi.getId());
452
			for (CustomerReturnItem customerReturnItem : customerReturnItems) {
453
				inventoryItemBilledQtyMap.put(customerReturnItem.getInventoryItemId(),
454
						inventoryItemBilledQtyMap.get(customerReturnItem.getInventoryItemId()) - 1);
455
			}
456
		}
457
		model.addAttribute("foiIdCustomerReturnInventoryItemsMap",
458
				StringUtils.toString(foiIdCustomerReturnInventoryItemsMap));
24271 amit.gupta 459
		model.addAttribute("fofoOrderItems", fofoOrderItems);
24281 amit.gupta 460
		model.addAttribute("inventoryItemBilledQtyMap", StringUtils.toString(inventoryItemBilledQtyMap));
461
		model.addAttribute("fofoOrderItemIdLineItemsMap", StringUtils.toString(fofoOrderItemIdLineItemMap));
24276 amit.gupta 462
		model.addAttribute("itemsMap", itemsMap);
24271 amit.gupta 463
		model.addAttribute("markDefective", true);
23584 ashik.ali 464
		model.addAttribute("customer", customer);
465
		model.addAttribute("customerAddress", customerAddress);
466
		model.addAttribute("paymentOptionTransactions", paymentOptionTransactions);
467
		model.addAttribute("paymentOptionIdPaymentOptionMap", paymentOptionIdPaymentOptionMap);
24105 govind 468
		model.addAttribute("paymentOptionIdPaymentOptionTransactionMap", paymentOptionIdPaymentOptionTransactionMap);
23584 ashik.ali 469
		model.addAttribute("insurancePolicies", insurancePolicies);
24105 govind 470
		model.addAttribute("fofoPartnerPaymentOptions", fofoPartnerPaymentOptions);
471
		model.addAttribute("totalNumberOfPaymentOptionId", fofoPartnerPaymentOptions.size());
24844 amit.gupta 472
		model.addAttribute("stateNames",
473
				stateRepository.selectAll().stream().map(x -> x.getName()).collect(Collectors.toList()));
23584 ashik.ali 474
		return "search-order-details";
475
	}
23973 govind 476
 
477
	private Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap(
478
			List<PaymentOptionTransaction> paymentOptionTransactions) {
23366 ashik.ali 479
		Set<Integer> paymentOptionIds = new HashSet<>();
23973 govind 480
		for (PaymentOptionTransaction paymentOptionTransaction : paymentOptionTransactions) {
23548 ashik.ali 481
			paymentOptionIds.add(paymentOptionTransaction.getPaymentOptionId());
23366 ashik.ali 482
		}
483
		List<PaymentOption> paymentOptions = paymentOptionRepository.selectByIds(paymentOptionIds);
484
		Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = new HashMap<>();
23973 govind 485
		for (PaymentOption paymentOption : paymentOptions) {
23366 ashik.ali 486
			paymentOptionIdPaymentOptionMap.put(paymentOption.getId(), paymentOption);
487
		}
488
		return paymentOptionIdPaymentOptionMap;
489
	}
23973 govind 490
 
24105 govind 491
	private Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMapUsingPaymentOptions(
492
			List<Integer> fofoPartnerPaymentOptions) {
493
		List<PaymentOption> paymentOptions = paymentOptionRepository
494
				.selectByIds(new HashSet<>(fofoPartnerPaymentOptions));
495
		Map<Integer, PaymentOption> paymentOptionIdPaymentOptionMap = new HashMap<>();
496
		for (PaymentOption paymentOption : paymentOptions) {
497
			paymentOptionIdPaymentOptionMap.put(paymentOption.getId(), paymentOption);
498
		}
499
		return paymentOptionIdPaymentOptionMap;
500
	}
501
 
502
	private Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap(
503
			List<PaymentOptionTransaction> paymentOptionTransactions) {
504
		Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = new HashMap<>();
505
		for (PaymentOptionTransaction paymentOptionTransaction : paymentOptionTransactions) {
506
			paymentOptionIdPaymentOptionTransactionMap.put(paymentOptionTransaction.getPaymentOptionId(),
507
					paymentOptionTransaction);
508
		}
509
		return paymentOptionIdPaymentOptionTransactionMap;
510
	}
511
 
21985 kshitij.so 512
	@RequestMapping(value = "/create-order", method = RequestMethod.POST)
23973 govind 513
	public String createOrder(HttpServletRequest request, @RequestBody CreateOrderRequest createOrderRequest,
514
			Model model) throws ProfitMandiBusinessException {
26647 tejbeer 515
		// throw new ProfitMandiBusinessException("Billing is on hold temporarily",
516
		// "Billing is on hold temporarily", "Billing is on hold temporarily");
26531 amit.gupta 517
		LOGGER.info("request at uri {} body {}", request.getRequestURI(), createOrderRequest);
22927 ashik.ali 518
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
23973 govind 519
 
23823 amit.gupta 520
		int fofoOrderId = orderService.createOrder(createOrderRequest, fofoDetails.getFofoId(), accessoriesDeals);
22280 ashik.ali 521
		LOGGER.info("Order has been created successfully...");
26531 amit.gupta 522
		return "redirect:/get-order/?orderId=" + fofoOrderId;
21612 ashik.ali 523
	}
23973 govind 524
 
23638 amit.gupta 525
	@RequestMapping(value = "/order/bad_return", method = RequestMethod.POST)
23973 govind 526
	public ResponseEntity<?> badReturn(HttpServletRequest request, @RequestBody FoiBadReturnRequest foiBadReturnRequest,
527
			Model model) throws ProfitMandiBusinessException {
23638 amit.gupta 528
		LOGGER.info("request at uri {} body {}", request.getRequestURI(), foiBadReturnRequest);
529
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
24282 amit.gupta 530
		CustomerCreditNote custmoerCreditNote;
24844 amit.gupta 531
		if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
24282 amit.gupta 532
			FofoOrderItem foi = fofoOrderItemRepository.selectById(foiBadReturnRequest.getFofoOrderItemId());
533
			FofoOrder fo = fofoOrderRepository.selectByOrderId(foi.getOrderId());
534
			custmoerCreditNote = orderService.badReturn(fo.getFofoId(), foiBadReturnRequest);
535
		} else {
536
			custmoerCreditNote = orderService.badReturn(fofoDetails.getFofoId(), foiBadReturnRequest);
537
		}
23654 amit.gupta 538
		return responseSender.ok(custmoerCreditNote.getId());
23638 amit.gupta 539
	}
21985 kshitij.so 540
 
21689 ashik.ali 541
	@RequestMapping(value = "/generateInvoice")
23973 govind 542
	public ResponseEntity<?> generateInvoice(HttpServletRequest request, HttpServletResponse response,
543
			@RequestParam(name = ProfitMandiConstants.ORDER_ID) int orderId) throws ProfitMandiBusinessException {
544
		LOGGER.info("Request received at url {} with params [{}={}] ", request.getRequestURI(),
545
				ProfitMandiConstants.ORDER_ID, orderId);
22139 amit.gupta 546
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
23594 ashik.ali 547
		PdfModel pdfModel = null;
23973 govind 548
		if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
23594 ashik.ali 549
			pdfModel = orderService.getInvoicePdfModel(orderId);
23973 govind 550
		} else {
23594 ashik.ali 551
			pdfModel = orderService.getInvoicePdfModel(fofoDetails.getFofoId(), orderId);
552
		}
21689 ashik.ali 553
		ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
24844 amit.gupta 554
		PdfUtils.generateAndWrite(Arrays.asList(pdfModel), byteArrayOutputStream);
21689 ashik.ali 555
		LOGGER.info("Pdf Stream length {}", byteArrayOutputStream.toByteArray().length);
23973 govind 556
		final HttpHeaders headers = new HttpHeaders();
557
		headers.setContentType(MediaType.APPLICATION_PDF);
558
		headers.set("Content-disposition", "inline; filename=invoice-" + pdfModel.getInvoiceNumber() + ".pdf");
559
		headers.setContentLength(byteArrayOutputStream.toByteArray().length);
560
		final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
561
		final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
562
		return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
21689 ashik.ali 563
	}
23973 govind 564
 
24844 amit.gupta 565
	@RequestMapping(value = "/generateInvoices")
566
	public ResponseEntity<?> generateInvoice(HttpServletRequest request, HttpServletResponse response,
567
			@RequestParam LocalDateTime startDate, @RequestParam LocalDateTime endDate, @RequestParam int partnerId)
568
			throws ProfitMandiBusinessException {
569
		LoginDetails fofoDetails = cookiesProcessor.getCookiesObject(request);
570
		List<PdfModel> pdfModels = new ArrayList<>();
571
		if (roleManager.isAdmin(fofoDetails.getRoleIds())) {
572
			List<Integer> orderIds = fofoOrderRepository.selectByFofoId(partnerId, startDate, endDate, 0, 0).stream()
573
					.map(x -> x.getId()).collect(Collectors.toList());
574
			for (int orderId : orderIds) {
575
				pdfModels.add(orderService.getInvoicePdfModel(orderId));
576
			}
577
			ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
578
			PdfUtils.generateAndWrite(pdfModels, byteArrayOutputStream);
579
			LOGGER.info("Pdf Stream length {}", byteArrayOutputStream.toByteArray().length);
580
			final HttpHeaders headers = new HttpHeaders();
581
			headers.setContentType(MediaType.APPLICATION_PDF);
582
			headers.set("Content-disposition", "inline; filename=invoice-" + partnerId + ".pdf");
583
			headers.setContentLength(byteArrayOutputStream.toByteArray().length);
584
			final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
585
			final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
586
			return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
587
		} else {
588
			throw new ProfitMandiBusinessException("Auth", fofoDetails.getEmailId(), "Unauthorised access");
589
		}
590
	}
591
 
22244 ashik.ali 592
	@RequestMapping(value = "/saleHistory")
23973 govind 593
	public String saleHistory(HttpServletRequest request,
594
			@RequestParam(name = "searchValue", defaultValue = "") String searchValue,
595
			@RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
596
			@RequestParam(required = false) LocalDateTime startTime,
597
			@RequestParam(required = false) LocalDateTime endTime,
598
			@RequestParam(name = "offset", defaultValue = "0") int offset,
599
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
600
			throws ProfitMandiBusinessException {
22927 ashik.ali 601
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
23973 govind 602
 
603
		Map<String, Object> map = orderService.getSaleHistory(loginDetails.getFofoId(), searchType, searchValue,
604
				startTime, endTime, offset, limit);
23203 ashik.ali 605
		model.addAllAttributes(map);
22244 ashik.ali 606
		return "sale-history";
607
	}
23973 govind 608
 
25092 amit.gupta 609
	@RequestMapping(value = "/downloadInvoices")
610
	public ResponseEntity<?> downloadInvoices(HttpServletRequest request,
611
			@RequestParam(name = "searchValue", defaultValue = "") String searchValue,
612
			@RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
613
			@RequestParam(required = false) LocalDateTime startTime,
614
			@RequestParam(required = false) LocalDateTime endTime,
615
			@RequestParam(name = "offset", defaultValue = "0") int offset,
616
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
617
			throws ProfitMandiBusinessException {
618
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
619
 
620
		Map<String, Object> map = orderService.getSaleHistory(loginDetails.getFofoId(), searchType, searchValue,
621
				startTime, endTime, offset, 100);
25562 amit.gupta 622
		List<FofoOrder> fofoOrders = (List<FofoOrder>) map.get("saleHistories");
25092 amit.gupta 623
 
25562 amit.gupta 624
		if (fofoOrders.size() == 0) {
25092 amit.gupta 625
			throw new ProfitMandiBusinessException("Search criteria", "", "No orders found for criteria");
626
		}
627
 
25093 amit.gupta 628
		final HttpHeaders headers = new HttpHeaders();
25092 amit.gupta 629
		headers.setContentType(MediaType.APPLICATION_PDF);
630
		headers.set("Content-disposition", "inline; filename=invoices.pdf");
631
		ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
632
		List<PdfModel> pdfModels = new ArrayList<>();
25562 amit.gupta 633
		for (FofoOrder fofoOrder : fofoOrders) {
25092 amit.gupta 634
			try {
635
				pdfModels.add(orderService.getInvoicePdfModel(fofoOrder.getId()));
25606 tejbeer 636
			} catch (Exception e) {
637
				LOGGER.info("could not create invoice for {}, invoice number {}", fofoOrder.getId(),
638
						fofoOrder.getInvoiceNumber());
25092 amit.gupta 639
			}
640
		}
641
		PdfUtils.generateAndWrite(pdfModels, byteArrayOutputStream);
642
		headers.setContentLength(byteArrayOutputStream.toByteArray().length);
643
		final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
644
		final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
645
		return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
646
	}
647
 
23973 govind 648
	@RequestMapping(value = "/credit-note/{creditNoteId}")
649
	public ResponseEntity<?> downloadCreditNote(HttpServletRequest request, @PathVariable int creditNoteId)
650
			throws ProfitMandiBusinessException {
23654 amit.gupta 651
		CreditNotePdfModel creditNotePdfModel = orderService.getCreditNotePdfModel(creditNoteId);
652
		ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
653
		PdfUtils.generateAndWriteCustomerCreditNotes(Arrays.asList(creditNotePdfModel), byteArrayOutputStream);
654
		LOGGER.info("Pdf Stream length {}", byteArrayOutputStream.toByteArray().length);
23973 govind 655
		final HttpHeaders headers = new HttpHeaders();
656
		headers.setContentType(MediaType.APPLICATION_PDF);
657
		headers.set("Content-disposition",
658
				"inline; filename=invoice-" + creditNotePdfModel.getCreditNoteNumber() + ".pdf");
659
		headers.setContentLength(byteArrayOutputStream.toByteArray().length);
660
		final InputStream inputStream = new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
661
		final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
662
		return new ResponseEntity<InputStreamResource>(inputStreamResource, headers, HttpStatus.OK);
23654 amit.gupta 663
	}
23973 govind 664
 
22291 ashik.ali 665
	@RequestMapping(value = "/getPaginatedSaleHistory")
23973 govind 666
	public String getSaleHistoryPaginated(HttpServletRequest request,
667
			@RequestParam(name = "searchValue", defaultValue = "") String searchValue,
668
			@RequestParam(name = "searchType", defaultValue = "") SearchType searchType,
669
			@RequestParam(required = false) LocalDateTime startTime,
670
			@RequestParam(required = false) LocalDateTime endTime,
671
			@RequestParam(name = "offset", defaultValue = "0") int offset,
672
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
673
			throws ProfitMandiBusinessException {
22927 ashik.ali 674
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
23973 govind 675
		Map<String, Object> map = orderService.getSaleHistoryPaginated(loginDetails.getFofoId(), searchType,
676
				searchValue, startTime, endTime, offset, limit);
23203 ashik.ali 677
		model.addAllAttributes(map);
22291 ashik.ali 678
		return "sale-history-paginated";
679
	}
680
 
24105 govind 681
	@PutMapping(value = "/updatePaymentTransaction")
682
	public String updateTransactionDetails(HttpServletRequest request, @RequestParam String referenceType,
683
			@RequestParam int fofoId, @RequestParam int referenceId,
684
			@RequestBody List<PaymentOptionTransactionModel> paymentOptionTransactionModels, Model model)
685
			throws Exception {
686
		float amount = 0;
687
		LOGGER.info(paymentOptionTransactionModels);
688
 
689
		for (PaymentOptionTransactionModel paymentOptionTransactionModel : paymentOptionTransactionModels) {
690
			amount = amount + paymentOptionTransactionModel.getAmount();
691
		}
692
		FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoId, referenceId);
693
		LOGGER.info("FofoOrder amount" + fofoOrder.getTotalAmount() + "amount" + amount);
694
		if (amount == fofoOrder.getTotalAmount()) {
695
			if (paymentOptionTransactionModels.size() > 0) {
696
				List<PaymentOptionTransaction> paymentOptionTransactions = fofoOrderPaymentOptionRepository
697
						.selectByReferenceIdAndType(referenceId, PaymentOptionReferenceType.ORDER);
698
				Map<Integer, PaymentOptionTransaction> paymentOptionIdPaymentOptionTransactionMap = this
699
						.paymentOptionIdPaymentOptionTransactionMap(paymentOptionTransactions);
700
				LOGGER.info("paymentOptionIdPaymentOptionTransactionMap"
701
						+ paymentOptionIdPaymentOptionTransactionMap.keySet());
702
				for (PaymentOptionTransactionModel paymentOptionTransactionModel : paymentOptionTransactionModels) {
703
					if (paymentOptionIdPaymentOptionTransactionMap
704
							.containsKey(paymentOptionTransactionModel.getPaymentOptionId())) {
705
 
706
						PaymentOptionTransaction paymentOptionTransaction = paymentOptionIdPaymentOptionTransactionMap
707
								.get(paymentOptionTransactionModel.getPaymentOptionId());
708
 
709
						if (paymentOptionTransactionModel.getAmount() == 0) {
710
							fofoOrderPaymentOptionRepository.delete(paymentOptionTransaction);
711
							LOGGER.info("deleted successfully");
712
						} else {
713
 
714
							paymentOptionTransaction.setAmount(paymentOptionTransactionModel.getAmount());
715
							fofoOrderPaymentOptionRepository.persist(paymentOptionTransaction);
716
							LOGGER.info("updated successfully");
717
 
718
						}
719
					} else {
720
						if (paymentOptionTransactionModel.getAmount() > 0) {
721
							PaymentOptionTransaction paymentOptionTransaction = new PaymentOptionTransaction();
722
							paymentOptionTransaction.setReferenceId(referenceId);
723
							paymentOptionTransaction.setReferenceType(PaymentOptionReferenceType.ORDER);
724
							paymentOptionTransaction
725
									.setPaymentOptionId(paymentOptionTransactionModel.getPaymentOptionId());
726
							paymentOptionTransaction.setAmount(paymentOptionTransactionModel.getAmount());
727
							paymentOptionTransaction.setFofoId(fofoId);
24167 amit.gupta 728
							paymentOptionTransaction.setCreateTimestamp(fofoOrder.getCreateTimestamp());
24105 govind 729
							fofoOrderPaymentOptionRepository.persist(paymentOptionTransaction);
730
							LOGGER.info("inserted successfully");
731
						}
732
					}
733
 
734
				}
735
 
736
				model.addAttribute("response", mvcResponseSender.createResponseString(true));
737
			}
738
		} else {
739
			throw new ProfitMandiBusinessException("Amount", amount, "Sum of amount is not equal to total amount");
740
		}
741
 
742
		return "response";
743
	}
24440 amit.gupta 744
 
25726 amit.gupta 745
	private Map<String, List<MobileInsurancePlan>> getPlans(float sellingPrice, int itemId)
746
			throws ProfitMandiBusinessException {
747
		try {
748
			Map<String, List<MobileInsurancePlan>> productDurationPlans = insuranceService.getAllPlans(itemId,
749
					sellingPrice);
750
			return productDurationPlans;
751
		} catch (Exception e) {
752
			e.printStackTrace();
753
			throw new ProfitMandiBusinessException("Fetch Insurance Plans", "Insurance",
26647 tejbeer 754
					"Could not fetch insurance Plans");
25726 amit.gupta 755
		}
756
 
24440 amit.gupta 757
	}
24880 govind 758
 
759
	@GetMapping("/insuranceDetails")
760
	public String getInsuranceDetails(HttpServletRequest request,
761
			@RequestParam(name = "offset", defaultValue = "0") int offset,
762
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
763
			throws ProfitMandiBusinessException {
764
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
765
		long size = 0;
766
		List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerId(loginDetails.getFofoId(),
767
				offset, limit);
768
		size = insurancePolicyRepository.selectCountByRetailerId(loginDetails.getFofoId());
769
		Map<Integer, String> providerPolicyNameAndIdMap = insuranceProviderRepository
770
				.selectByIds(insurancePolicies.stream().map(x -> x.getProviderId()).collect(Collectors.toSet()))
771
				.stream().collect(Collectors.toMap(InsuranceProvider::getId, InsuranceProvider::getName));
772
		if (size < limit) {
773
			model.addAttribute("end", offset + size);
774
		} else {
775
			model.addAttribute("end", offset + limit);
776
		}
777
		model.addAttribute("start", offset + 1);
778
		model.addAttribute("size", size);
779
		model.addAttribute("insurancePolicies", insurancePolicies);
780
		model.addAttribute("providerPolicyNameAndIdMap", providerPolicyNameAndIdMap);
781
		return "insurance-details";
782
	}
25092 amit.gupta 783
 
24880 govind 784
	@GetMapping("/insuranceDetailsPaginated")
785
	public String getInsuranceDetailsPaginated(HttpServletRequest request,
786
			@RequestParam(name = "offset", defaultValue = "0") int offset,
787
			@RequestParam(name = "limit", defaultValue = "10") int limit, Model model)
788
			throws ProfitMandiBusinessException {
789
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
790
		List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerId(loginDetails.getFofoId(),
791
				offset, limit);
792
		Map<Integer, String> providerPolicyNameAndIdMap = insuranceProviderRepository
793
				.selectByIds(insurancePolicies.stream().map(x -> x.getProviderId()).collect(Collectors.toSet()))
794
				.stream().collect(Collectors.toMap(InsuranceProvider::getId, InsuranceProvider::getName));
795
		model.addAttribute("insurancePolicies", insurancePolicies);
796
		model.addAttribute("providerPolicyNameAndIdMap", providerPolicyNameAndIdMap);
797
		return "insurance-details-paginated";
798
	}
26647 tejbeer 799
 
800
	@GetMapping("/pendingOrders")
26663 tejbeer 801
	public String getPendingOrders(HttpServletRequest request, Model model) throws ProfitMandiBusinessException {
26647 tejbeer 802
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
803
		boolean isAdmin = roleManager.isAdmin(loginDetails.getRoleIds());
804
		List<Integer> fofoIds = fofoStoreRepository.selectActiveStores().stream().map(x -> x.getId())
805
				.collect(Collectors.toList());
806
 
27046 tejbeer 807
		if (isAdmin) {
26817 amit.gupta 808
			Map<Integer, CustomRetailer> customRetailersMap = retailerService.getFofoRetailers(fofoIds);
809
			model.addAttribute("customRetailersMap", customRetailersMap);
810
		}
811
		List<PendingOrder> pendingOrders = null;
26647 tejbeer 812
		if (isAdmin) {
27046 tejbeer 813
			pendingOrders = pendingOrderRepository.selectAllByStatus(OrderStatus.PENDING);
26647 tejbeer 814
		} else {
27046 tejbeer 815
			pendingOrders = pendingOrderRepository.selectByFofoId(loginDetails.getFofoId(), OrderStatus.PENDING);
26647 tejbeer 816
		}
27046 tejbeer 817
 
818
		if (!pendingOrders.isEmpty()) {
819
			List<Integer> customerIds = pendingOrders.stream().map(x -> x.getCustomerId()).collect(Collectors.toList());
820
 
821
			Map<Integer, Customer> customersMap = customerRepository.selectAllByIds(customerIds).stream()
822
					.collect(Collectors.toMap(x -> x.getId(), x -> x));
823
			pendingOrders.stream().forEach(x -> {
824
				x.setCustomer(customersMap.get(x.getCustomerId()));
825
			});
826
 
827
		}
828
 
26817 amit.gupta 829
		model.addAttribute("pendingOrder", pendingOrders);
830
		model.addAttribute("isAdmin", isAdmin);
26647 tejbeer 831
		return "pending_fofo_order";
832
	}
833
 
834
	@GetMapping("/getPendingOrderItem")
835
	public String getPendingOrderItem(HttpServletRequest request, @RequestParam int orderId, Model model)
836
			throws ProfitMandiBusinessException {
837
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
838
		Map<Integer, Item> itemMap = new HashMap<>();
839
		Map<Integer, CurrentInventorySnapshot> inventoryMap = new HashMap<>();
26817 amit.gupta 840
		PendingOrder pendingPO = pendingOrderRepository.selectById(orderId);
841
		Customer customer = customerRepository.selectById(pendingPO.getCustomerId());
26647 tejbeer 842
		List<PendingOrderItem> pendingOrderItems = pendingOrderItemRepository.selectByOrderId(orderId);
843
		for (PendingOrderItem pendingOrderItem : pendingOrderItems) {
844
			Item item = itemRepository.selectById(pendingOrderItem.getItemId());
845
			CurrentInventorySnapshot cis = currentInventorySnapshotRepository
846
					.selectByItemAndFofoId(pendingOrderItem.getItemId(), loginDetails.getFofoId());
847
			itemMap.put(pendingOrderItem.getItemId(), item);
848
			LOGGER.info("cis" + cis);
849
			inventoryMap.put(pendingOrderItem.getItemId(), cis);
850
		}
851
 
852
		LOGGER.info("inventoryMap" + inventoryMap);
853
		model.addAttribute("pendingOrderItems", pendingOrderItems);
854
		model.addAttribute("itemMap", itemMap);
855
		model.addAttribute("inventoryMap", inventoryMap);
26817 amit.gupta 856
		model.addAttribute("pendingPO", gson.toJson(pendingPO));
857
		model.addAttribute("pendingPOCustomer", gson.toJson(customer));
26721 tejbeer 858
		model.addAttribute("isAdmin", roleManager.isAdmin(loginDetails.getRoleIds()));
26647 tejbeer 859
		return "pending-order-item";
860
	}
26721 tejbeer 861
 
862
	@RequestMapping(value = "/cancelPendingOrder", method = RequestMethod.POST)
863
	public String cancelPendingOrder(HttpServletRequest request, @RequestParam int id, Model model) throws Exception {
27046 tejbeer 864
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
26721 tejbeer 865
		PendingOrder pendingOrder = pendingOrderRepository.selectById(id);
866
 
867
		List<PendingOrderItem> pendingOrderItem = pendingOrderItemRepository.selectByOrderId(id);
868
		for (PendingOrderItem poi : pendingOrderItem) {
27046 tejbeer 869
			poi.setStatus(OrderStatus.CANCELLED);
870
			poi.setStatusDescription(loginDetails.getEmailId());
26721 tejbeer 871
		}
27046 tejbeer 872
		pendingOrder.setStatus(OrderStatus.CLOSED);
26721 tejbeer 873
 
874
		pendingOrderRepository.persist(pendingOrder);
875
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
876
 
877
		return "response";
878
	}
879
 
880
	@RequestMapping(value = "/cancelPendingOrderItem", method = RequestMethod.POST)
881
	public String cancelPendingOrderItem(HttpServletRequest request, @RequestParam int id, Model model)
882
			throws Exception {
27046 tejbeer 883
 
884
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
26721 tejbeer 885
		PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(id);
886
 
27046 tejbeer 887
		pendingOrderItem.setStatus(OrderStatus.CANCELLED);
888
		pendingOrderItem.setStatusDescription(loginDetails.getEmailId());
27057 tejbeer 889
		PendingOrder pendingOrder = pendingOrderRepository.selectById(pendingOrderItem.getOrderId());
26721 tejbeer 890
 
27046 tejbeer 891
		List<OrderStatus> status = pendingOrderItemRepository.selectByOrderId(pendingOrderItem.getOrderId()).stream()
26721 tejbeer 892
				.map(x -> x.getStatus()).collect(Collectors.toList());
893
 
27046 tejbeer 894
		if (!status.contains(OrderStatus.PENDING)) {
895
			pendingOrder.setStatus(OrderStatus.CLOSED);
26721 tejbeer 896
		}
897
		pendingOrderItemRepository.persist(pendingOrderItem);
898
		model.addAttribute("response", mvcResponseSender.createResponseString(true));
899
 
900
		return "response";
901
	}
27046 tejbeer 902
 
21612 ashik.ali 903
}