Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
28300 tejbeer 1
package com.spice.profitmandi.web.controller;
2
 
3
import java.time.LocalDateTime;
4
import java.util.ArrayList;
5
import java.util.HashMap;
6
import java.util.List;
7
import java.util.Map;
8
import java.util.stream.Collectors;
9
 
10
import javax.servlet.http.HttpServletRequest;
11
 
12
import org.apache.logging.log4j.LogManager;
13
import org.apache.logging.log4j.Logger;
14
import org.springframework.beans.factory.annotation.Autowired;
15
import org.springframework.stereotype.Controller;
16
import org.springframework.transaction.annotation.Transactional;
17
import org.springframework.ui.Model;
18
import org.springframework.web.bind.annotation.RequestMapping;
19
import org.springframework.web.bind.annotation.RequestMethod;
20
import org.springframework.web.bind.annotation.RequestParam;
21
 
28499 amit.gupta 22
import com.spice.profitmandi.dao.entity.inventory.State;
23
import com.spice.profitmandi.dao.entity.inventory.Warehouse;
24
import com.spice.profitmandi.dao.entity.transaction.Seller;
25
import com.spice.profitmandi.dao.entity.transaction.SellerWarehouse;
26
import com.spice.profitmandi.dao.entity.transaction.WarehouseAddressMapping;
27
import com.spice.profitmandi.dao.entity.transaction.WarehouseAddressMaster;
28
import com.spice.profitmandi.dao.enumuration.inventory.InventoryType;
29
import com.spice.profitmandi.dao.enumuration.inventory.WarehouseType;
30
import com.spice.profitmandi.dao.repository.inventory.StateRepository;
28493 tejbeer 31
import com.spice.profitmandi.dao.repository.inventory.WarehouseRepository;
28300 tejbeer 32
import com.spice.profitmandi.dao.repository.transaction.SellerRepository;
33
import com.spice.profitmandi.dao.repository.transaction.SellerWarehouseRepository;
34
import com.spice.profitmandi.dao.repository.transaction.WareHouseAddressMappingRepository;
35
import com.spice.profitmandi.dao.repository.transaction.WareHouseAddressMasterRepository;
36
 
28499 amit.gupta 37
 
28300 tejbeer 38
@Controller
39
@Transactional(rollbackFor = Throwable.class)
40
public class SellerController {
41
 
42
	@Autowired
43
	private SellerRepository sellerRepository;
44
 
45
	@Autowired
28499 amit.gupta 46
	private StateRepository stateRepository;
47
 
48
 
49
	@Autowired
28493 tejbeer 50
	WarehouseRepository warehouseRepository;
51
 
52
	@Autowired
28300 tejbeer 53
	WareHouseAddressMasterRepository wareHouseAddressMasterRepository;
54
 
55
	@Autowired
56
	private SellerWarehouseRepository sellerWarehouseRepository;
57
 
58
	@Autowired
59
	private WareHouseAddressMappingRepository wareHouseAddressMappingRepository;
60
 
61
	private static final Logger LOGGER = LogManager.getLogger(SellerController.class);
62
 
63
	@RequestMapping(value = "/createNewWarehouse", method = RequestMethod.POST)
64
	public String getViewOurSales(HttpServletRequest request,
65
			@RequestParam(name = "address", required = true, defaultValue = "0") int address,
66
			@RequestParam(name = "prefix", required = true, defaultValue = "0") String prefix,
67
			@RequestParam(name = "sellerId", required = true, defaultValue = "0") int sellerId,
28493 tejbeer 68
			@RequestParam(name = "warehouseName", required = true, defaultValue = "0") String warehouseName,
69
			@RequestParam(name = "pinCode", required = true, defaultValue = "0") String pinCode, Model model)
28300 tejbeer 70
 
71
			throws Exception {
72
 
28493 tejbeer 73
		Seller seller = sellerRepository.sellerSelectById(sellerId);
74
 
75
 
76
		Warehouse warehouse = new Warehouse();
77
		warehouse.setDisplayName(warehouseName);
78
		warehouse.setLocation(seller.getAddress());
79
		warehouse.setGstin(seller.getGstin());
80
		warehouse.setStateId(seller.getStateId());
81
		warehouse.setStatus(3);
82
		warehouse.setAddedOn(LocalDateTime.now());
83
		warehouse.setLastCheckedOn(LocalDateTime.now());
84
		warehouse.setTinNumber(null);
85
    	warehouse.setPincode(pinCode);
86
		warehouse.setLogisticsLocation(0);
87
		warehouse.setVendor(1);
88
		warehouse.setBillingType(1);
89
		warehouse.setInventoryType(InventoryType.GOOD);
90
		warehouse.setWarehouseType(WarehouseType.THIRD_PARTY);
91
		warehouse.setIsAvailabilityMonitored(1);
92
		warehouse.setSource(0);
93
		warehouseRepository.persist(warehouse);
94
 
95
		LOGGER.info("warehouseId" + warehouse.getId());
96
 
28300 tejbeer 97
		SellerWarehouse sellerWarehouse = new SellerWarehouse();
98
		sellerWarehouse.setActive(true);
28493 tejbeer 99
		sellerWarehouse.setWarehouseId(warehouse.getId());
28300 tejbeer 100
		sellerWarehouse.setChallanSequence(0);
101
		sellerWarehouse.setCreateTimestamp(LocalDateTime.now());
102
		sellerWarehouse.setInvoiceSequence(0);
103
		sellerWarehouse.setPrefix(prefix);
104
		sellerWarehouse.setOrderType(0);
105
		sellerWarehouse.setSellerId(sellerId);
106
		sellerWarehouseRepository.persist(sellerWarehouse);
107
 
108
		WarehouseAddressMapping warehouseAddressMapping = new WarehouseAddressMapping();
109
		warehouseAddressMapping.setAddressId(address);
110
		warehouseAddressMapping.setCreated(LocalDateTime.now());
111
		warehouseAddressMapping.setUpdated(null);
28493 tejbeer 112
		warehouseAddressMapping.setWarehouseId(warehouse.getId());
28300 tejbeer 113
		warehouseAddressMapping.setAddressId(address);
114
		wareHouseAddressMappingRepository.persist(warehouseAddressMapping);
115
 
28493 tejbeer 116
 
28300 tejbeer 117
		return "seller";
118
 
119
	}
120
 
121
	@RequestMapping(value = "/createNewSeller", method = RequestMethod.POST)
122
	public String getNewSeller(HttpServletRequest request,
123
			@RequestParam(name = "label", required = true, defaultValue = "0") String label,
124
			@RequestParam(name = "address", required = true, defaultValue = "0") String address,
125
			@RequestParam(name = "gst", required = true, defaultValue = "0") String gst,
126
			@RequestParam(name = "state", required = true, defaultValue = "0") int state, Model model)
127
			throws Exception {
128
 
129
		Seller seller = new Seller();
130
 
131
		seller.setAddress(address);
132
		seller.setLabel(label);
133
		seller.setGstin(gst);
134
		seller.setStateId(state);
135
		seller.setOrganisationId(7);
136
		sellerRepository.persist(seller);
137
 
138
		return "seller";
139
 
140
	}
141
 
142
	@RequestMapping(value = "/createNewAddress", method = RequestMethod.POST)
143
	public String getNewSeller(HttpServletRequest request,
144
			@RequestParam(name = "newAddress", required = true, defaultValue = "0") String address,
145
			@RequestParam(name = "pin", required = true, defaultValue = "0") String pin,
146
			@RequestParam(name = "stateId", required = true, defaultValue = "0") int stateId, Model model)
147
			throws Exception {
148
 
149
		WarehouseAddressMaster wham = new WarehouseAddressMaster();
150
		wham.setAddress(address);
151
		wham.setPin(pin);
152
		wham.setStateId(stateId);
153
		wham.setContacNumber("18002700273");
154
		wham.setContactPerson("Customer Care");
155
		wham.setCreated(LocalDateTime.now());
156
		wareHouseAddressMasterRepository.persist(wham);
157
 
158
		return "seller";
159
 
160
	}
161
 
162
	@RequestMapping(value = "/getAllSeller", method = RequestMethod.GET)
163
	public String getAllSeller(HttpServletRequest request, Model model) throws Exception {
164
 
28499 amit.gupta 165
		List<Seller> sellers = sellerRepository.selectAllSeller().stream().filter(x->x.getOrganisationId()==7).collect(Collectors.toList());
28300 tejbeer 166
 
167
		List<WarehouseAddressMaster> warehouseAddressMaster = sellerRepository.selectAllWarehouseAddressMaster();
168
 
28499 amit.gupta 169
		List<State> state = stateRepository.selectAll();
28300 tejbeer 170
		LOGGER.info("statemaster" + state);
171
		model.addAttribute("state", state);
172
 
28499 amit.gupta 173
		LOGGER.info("sellerLabel" + sellers);
28300 tejbeer 174
		LOGGER.info("warehouseAddressMaster" + warehouseAddressMaster);
28499 amit.gupta 175
		model.addAttribute("sellerLabel", sellers);
28300 tejbeer 176
		model.addAttribute("warehouseAddressMaster", warehouseAddressMaster);
177
 
178
		return "seller";
179
	}
180
 
181
	@RequestMapping(value = "/getSellerWareHouse", method = RequestMethod.GET)
182
	public String getSellerWareHouse(HttpServletRequest request,
183
			@RequestParam(name = "sellerId", required = true, defaultValue = "0") int sellerId, Model model)
184
			throws Exception {
185
 
186
		List<SellerWarehouse> sellerWarehouse = sellerWarehouseRepository.selectBySellerId(sellerId);
187
 
188
		List<WarehouseAddressMaster> allWarehouseAddressMaster = sellerRepository.selectAllWarehouseAddressMaster();
189
 
28499 amit.gupta 190
		Map<Integer, Seller> sellersMap = sellerRepository.selectById(sellerId).stream()
28300 tejbeer 191
				.collect(Collectors.toMap(x -> x.getId(), x -> x));
192
 
193
 
28500 amit.gupta 194
		List<Integer> sellerwarehouseIds = sellerWarehouse.stream().map(x -> x.getWarehouseId())
28300 tejbeer 195
				.collect(Collectors.toList());
196
 
28500 amit.gupta 197
		Map<Integer, WarehouseAddressMaster> wam = null;
198
		if(sellerwarehouseIds.size() > 0) {
199
			List<WarehouseAddressMapping> warehouseAddressMapping = wareHouseAddressMappingRepository
200
					.selectAllByIds(sellerwarehouseIds);
201
			wam = mapWarhouseIdAndAddress(warehouseAddressMapping);
202
		} else {
203
			wam = new HashMap<>();
204
		}
28300 tejbeer 205
 
206
		model.addAttribute("allWhm", allWarehouseAddressMaster);
207
 
208
		model.addAttribute("wam", wam);
28499 amit.gupta 209
		model.addAttribute("seller", sellersMap);
28300 tejbeer 210
		model.addAttribute("sellerId", sellerId);
211
		model.addAttribute("sellerWarehouse", sellerWarehouse);
212
		return "seller-warehouse-container";
213
	}
214
 
215
	private Map<Integer, WarehouseAddressMaster> mapWarhouseIdAndAddress(
216
			List<WarehouseAddressMapping> warehouseAddressMapping) {
217
		Map<Integer, WarehouseAddressMaster> wam = new HashMap<>();
218
		for (WarehouseAddressMapping wa : warehouseAddressMapping) {
219
			WarehouseAddressMaster wm = wareHouseAddressMasterRepository.selectByAddressId(wa.getAddressId());
220
			wam.put(wa.getWarehouseId(), wm);
221
		}
222
 
223
		return wam;
224
	}
225
 
226
}