Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21615 kshitij.so 1
package com.spice.profitmandi.web.controller;
2
 
24288 amit.gupta 3
import java.time.LocalDate;
24276 amit.gupta 4
import java.time.LocalDateTime;
24880 govind 5
import java.time.LocalTime;
24339 amit.gupta 6
import java.util.ArrayList;
25152 amit.gupta 7
import java.util.Arrays;
25136 amit.gupta 8
import java.util.LinkedHashMap;
23884 amit.gupta 9
import java.util.List;
24880 govind 10
import java.util.Map;
11
import java.util.stream.Collectors;
23568 govind 12
 
22086 amit.gupta 13
import javax.servlet.http.HttpServletRequest;
14
 
23786 amit.gupta 15
import org.apache.logging.log4j.LogManager;
23568 govind 16
import org.apache.logging.log4j.Logger;
22481 ashik.ali 17
import org.springframework.beans.factory.annotation.Autowired;
23379 ashik.ali 18
import org.springframework.beans.factory.annotation.Value;
21615 kshitij.so 19
import org.springframework.stereotype.Controller;
22481 ashik.ali 20
import org.springframework.transaction.annotation.Transactional;
22073 ashik.ali 21
import org.springframework.ui.Model;
21615 kshitij.so 22
import org.springframework.web.bind.annotation.RequestMapping;
23
import org.springframework.web.bind.annotation.RequestMethod;
24
 
24996 amit.gupta 25
import com.mongodb.DBObject;
25152 amit.gupta 26
import com.spice.profitmandi.common.enumuration.ItemType;
22481 ashik.ali 27
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
24996 amit.gupta 28
import com.spice.profitmandi.common.model.BrandStockPrice;
25152 amit.gupta 29
import com.spice.profitmandi.common.model.InventoryItemAgingModel;
24203 amit.gupta 30
import com.spice.profitmandi.common.model.ProfitMandiConstants;
24880 govind 31
import com.spice.profitmandi.dao.entity.fofo.FofoOrderItem;
22654 ashik.ali 32
import com.spice.profitmandi.dao.entity.fofo.FofoStore;
24288 amit.gupta 33
import com.spice.profitmandi.dao.entity.fofo.PartnerDailyInvestment;
24880 govind 34
import com.spice.profitmandi.dao.repository.catalog.ItemRepository;
22481 ashik.ali 35
import com.spice.profitmandi.dao.repository.dtr.FofoStoreRepository;
24880 govind 36
import com.spice.profitmandi.dao.repository.dtr.InsurancePolicyRepository;
37
import com.spice.profitmandi.dao.repository.dtr.InsuranceProviderRepository;
24996 amit.gupta 38
import com.spice.profitmandi.dao.repository.dtr.Mongo;
24098 tejbeer 39
import com.spice.profitmandi.dao.repository.dtr.NotificationPanelRepository;
24880 govind 40
import com.spice.profitmandi.dao.repository.dtr.RechargeTransactionRepository;
24203 amit.gupta 41
import com.spice.profitmandi.dao.repository.fofo.CurrentInventorySnapshotRepository;
24880 govind 42
import com.spice.profitmandi.dao.repository.fofo.FofoOrderItemRepository;
24288 amit.gupta 43
import com.spice.profitmandi.dao.repository.fofo.PartnerDailyInvestmentRepository;
24336 amit.gupta 44
import com.spice.profitmandi.service.PartnerInvestmentService;
23844 amit.gupta 45
import com.spice.profitmandi.service.authentication.RoleManager;
23884 amit.gupta 46
import com.spice.profitmandi.service.inventory.InventoryService;
47
import com.spice.profitmandi.service.transaction.TransactionService;
22481 ashik.ali 48
import com.spice.profitmandi.web.model.LoginDetails;
49
import com.spice.profitmandi.web.util.CookiesProcessor;
24263 tejbeer 50
import com.spice.profitmandi.web.util.MVCResponseSender;
22481 ashik.ali 51
 
21615 kshitij.so 52
@Controller
22481 ashik.ali 53
@Transactional(rollbackFor = Throwable.class)
21615 kshitij.so 54
public class DashboardController {
23923 amit.gupta 55
 
23379 ashik.ali 56
	@Value("${web.api.host}")
57
	private String webApiHost;
23923 amit.gupta 58
 
24072 amit.gupta 59
	@Value("${web.api.scheme}")
60
	private String webApiScheme;
24288 amit.gupta 61
 
24078 amit.gupta 62
	@Value("${web.api.root}")
63
	private String webApiRoot;
64
 
23379 ashik.ali 65
	@Value("${web.api.port}")
66
	private int webApiPort;
21615 kshitij.so 67
 
22481 ashik.ali 68
	@Autowired
22927 ashik.ali 69
	private CookiesProcessor cookiesProcessor;
23923 amit.gupta 70
 
23568 govind 71
	@Autowired
24880 govind 72
	private ItemRepository itemRepository;
73
 
74
	@Autowired
23786 amit.gupta 75
	private RoleManager roleManager;
23923 amit.gupta 76
 
23838 ashik.ali 77
	@Autowired
78
	private FofoStoreRepository fofoStoreRepository;
23884 amit.gupta 79
 
80
	@Autowired
24880 govind 81
	private PartnerDailyInvestmentRepository partnerDailyInvestmentRepository;
23923 amit.gupta 82
 
23884 amit.gupta 83
	@Autowired
24880 govind 84
	private PartnerInvestmentService partnerInvestmentService;
24288 amit.gupta 85
 
23884 amit.gupta 86
	@Autowired
24880 govind 87
	private InsurancePolicyRepository insurancePolicyRepository;
23923 amit.gupta 88
	/*
89
	 * @Autowired private ScanRepository scanRepository;
90
	 */
24880 govind 91
	@Autowired
92
	private RechargeTransactionRepository rechargeTransactionRepository;
23923 amit.gupta 93
 
23884 amit.gupta 94
	@Autowired
95
	private TransactionService transactionService;
25136 amit.gupta 96
 
24996 amit.gupta 97
	@Autowired
98
	private InventoryService inventoryService;
24263 tejbeer 99
 
24098 tejbeer 100
	@Autowired
24263 tejbeer 101
	private MVCResponseSender mvcResponseSender;
102
 
103
	@Autowired
24098 tejbeer 104
	private NotificationPanelRepository notificationPanelRepository;
23923 amit.gupta 105
 
24203 amit.gupta 106
	@Autowired
107
	private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
108
 
24880 govind 109
	@Autowired
110
	private FofoOrderItemRepository fofoOrderItemRepository;
111
 
112
	@Autowired
113
	private InsuranceProviderRepository insuranceProviderRepository;
25136 amit.gupta 114
 
24996 amit.gupta 115
	@Autowired
116
	private Mongo mongoClient;
24880 govind 117
 
23568 govind 118
	private static final Logger LOGGER = LogManager.getLogger(DashboardController.class);
23923 amit.gupta 119
 
25136 amit.gupta 120
	@RequestMapping(value = "/12dashboard34", method = RequestMethod.GET)
25140 amit.gupta 121
	public String dashboard1(HttpServletRequest request, Model model) throws Exception {
25136 amit.gupta 122
		LOGGER.info("In Dashboard1");
123
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
25140 amit.gupta 124
		model.addAttribute("brandStockPrices", this.getBrandStockPrices(loginDetails.getFofoId()));
125
		model.addAttribute("salesMap", this.getSales(loginDetails.getFofoId()));
25136 amit.gupta 126
		model.addAttribute("investments", this.getInvestments(loginDetails.getFofoId()));
127
		return "dashboard1";
128
	}
129
 
130
	private Map<String, Object> getInvestments(int fofoId) throws Exception {
131
		Map<String, Object> investments = new LinkedHashMap<>();
132
		PartnerDailyInvestment investment = partnerInvestmentService.getInvestment(fofoId, 1);
133
		LocalDate currentMonthStart = LocalDate.now().withDayOfMonth(1);
134
		LocalDate yesterDate = LocalDate.now().minusDays(1);
135
		PartnerDailyInvestment yesterdayInvestment = partnerDailyInvestmentRepository.select(fofoId, yesterDate);
136
		if (yesterdayInvestment == null) {
137
			yesterdayInvestment = new PartnerDailyInvestment();
138
		}
139
 
140
		List<PartnerDailyInvestment> currentMonthInvestments = partnerDailyInvestmentRepository.selectAll(fofoId,
141
				currentMonthStart, currentMonthStart.withDayOfMonth(currentMonthStart.lengthOfMonth()));
142
 
25140 amit.gupta 143
		long okInvestmentDays = currentMonthInvestments.stream().filter(x -> x.getShortPercentage() <= 10)
25136 amit.gupta 144
				.collect(Collectors.counting());
25140 amit.gupta 145
		investments.put("today", investment.getTotalInvestment());
146
		investments.put("investment", investment);
147
		investments.put("inStock", investment.getInStockAmount());
148
		investments.put("minimum", investment.getMinInvestment());
149
		investments.put("short", investment.getShortPercentage());
150
		investments.put("okDays", okInvestmentDays);
25136 amit.gupta 151
		return investments;
152
	}
153
 
25140 amit.gupta 154
	private Map<String, Double> getSales(int fofoId) {
155
		Map<String, Double> salesMap = new LinkedHashMap<>();
156
		LocalDateTime curDate = LocalDate.now().atStartOfDay();
157
		List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectBetweenCreatedTime(fofoId, curDate,
158
				curDate.with(LocalTime.MAX));
159
		List<FofoOrderItem> mtdFofoOrderItems = fofoOrderItemRepository.selectBetweenCreatedTime(fofoId,
160
				curDate.withDayOfMonth(1), curDate.with(LocalTime.MAX));
161
		double todaySale = fofoOrderItems.stream()
162
				.collect(Collectors.summingDouble(x -> x.getSellingPrice() * x.getQuantity()));
163
		double mtdSale = mtdFofoOrderItems.stream()
164
				.collect(Collectors.summingDouble(x -> x.getSellingPrice() * x.getQuantity()));
165
		salesMap.put("todaySale", todaySale);
166
		salesMap.put("mtdSale", mtdSale);
25136 amit.gupta 167
		return salesMap;
168
	}
169
 
25152 amit.gupta 170
	private List<BrandStockPrice> getBrandStockPrices(int fofoId) throws Exception {
25140 amit.gupta 171
		Map<String, BrandStockPrice> brandStockPricesMap = inventoryService.getBrandWiseStockValue(fofoId);
25152 amit.gupta 172
		List<InventoryItemAgingModel> models = inventoryService.getItemAgingByInterval(fofoId, Arrays.asList(30));
173
		Map<String,Integer> brandWiseQty = models.stream()
174
				.filter(x->x.getItemType().equals(ItemType.SERIALIZED.toString()))
175
				.collect(
176
						Collectors.groupingBy(x->x.getBrand(), 
177
						Collectors.summingInt(x->x.getValues().get(1).getQuantity())));
178
		Map<String,Double> brandWiseValue = models.stream()
179
				.filter(x->x.getItemType().equals(ItemType.SERIALIZED.toString()))
180
				.collect(
181
						Collectors.groupingBy(x->x.getBrand(), 
182
								Collectors.summingDouble(x->x.getValues().get(1).getQuantity()*x.getValues().get(1).getPrice())));
25140 amit.gupta 183
		List<DBObject> mobileBrands = mongoClient.getMongoBrands(fofoId, "", 3);
25136 amit.gupta 184
		List<BrandStockPrice> brandStockPrices = new ArrayList<>();
25152 amit.gupta 185
 
25140 amit.gupta 186
		mobileBrands.stream().forEach(x -> {
187
			String brand = (String) x.get("name");
188
			if (brandStockPricesMap.containsKey(brand)) {
189
				BrandStockPrice brandStockPrice = brandStockPricesMap.get(brand);
25152 amit.gupta 190
				brandStockPrice.setAgedQty(brandWiseQty.get(brand));
191
				brandStockPrice.setAgedValue(brandWiseValue.get(brand));
25140 amit.gupta 192
				brandStockPrice.setBrandUrl((String) x.get("url"));
193
				brandStockPrice.setRank(((Double) x.get("rank")).intValue());
194
				brandStockPrices.add(brandStockPrice);
195
			} else {
196
			}
197
		});
198
 
199
		return brandStockPrices.stream().sorted((x, y) -> y.getRank() - x.getRank()).collect(Collectors.toList());
25136 amit.gupta 200
	}
201
 
21615 kshitij.so 202
	@RequestMapping(value = "/dashboard", method = RequestMethod.GET)
25140 amit.gupta 203
	public String dashboard(HttpServletRequest request, Model model)
204
			throws Exception {
205
 
22927 ashik.ali 206
		LoginDetails loginDetails = cookiesProcessor.getCookiesObject(request);
23923 amit.gupta 207
 
22481 ashik.ali 208
		FofoStore fofoStore = null;
209
		try {
22927 ashik.ali 210
			fofoStore = fofoStoreRepository.selectByRetailerId(loginDetails.getFofoId());
22481 ashik.ali 211
		} catch (ProfitMandiBusinessException e) {
22927 ashik.ali 212
			LOGGER.error("FofoStore Code not found of fofoId {}", loginDetails.getFofoId());
22481 ashik.ali 213
		}
23848 ashik.ali 214
		model.addAttribute("fofoStore", fofoStore);
25140 amit.gupta 215
		model.addAttribute("isAdmin", roleManager.isAdmin(loginDetails.getRoleIds()));
23379 ashik.ali 216
		model.addAttribute("webApiHost", webApiHost);
217
		model.addAttribute("webApiPort", webApiPort);
24072 amit.gupta 218
		model.addAttribute("webApiScheme", webApiScheme);
24077 amit.gupta 219
		model.addAttribute("webApiRoot", webApiRoot);
24203 amit.gupta 220
		model.addAttribute("hasGift", hasGift(loginDetails.getFofoId()));
221
		model.addAttribute("giftItemId", ProfitMandiConstants.GIFT_ID);
24098 tejbeer 222
 
25140 amit.gupta 223
		model.addAttribute("brandStockPrices", this.getBrandStockPrices(loginDetails.getFofoId()));
224
		model.addAttribute("salesMap", this.getSales(loginDetails.getFofoId()));
225
		model.addAttribute("investments", this.getInvestments(loginDetails.getFofoId()));
226
		model.addAttribute("isInvestmentOk", partnerInvestmentService.isInvestmentOk(loginDetails.getFofoId(), 10, 30));
227
		return "dashboard1";
21615 kshitij.so 228
	}
23923 amit.gupta 229
 
24288 amit.gupta 230
	// This method is currently hardcoded to faciliate watches sold as gift.
24203 amit.gupta 231
	private boolean hasGift(int fofoId) {
232
		try {
24288 amit.gupta 233
			return currentInventorySnapshotRepository.selectByItemIdAndFofoId(ProfitMandiConstants.GIFT_ID, fofoId)
234
					.getAvailability() > 0;
24203 amit.gupta 235
		} catch (ProfitMandiBusinessException e) {
236
			return false;
237
		}
238
	}
24288 amit.gupta 239
 
22354 ashik.ali 240
	@RequestMapping(value = "/contactUs", method = RequestMethod.GET)
23923 amit.gupta 241
	public String contactUs(HttpServletRequest request, Model model) throws Throwable {
22354 ashik.ali 242
		model.addAttribute("appContextPath", request.getContextPath());
243
		return "contact-us";
244
	}
23923 amit.gupta 245
 
21615 kshitij.so 246
}