| 23365 |
ashik.ali |
1 |
package com.spice.profitmandi.service.order;
|
| 22859 |
ashik.ali |
2 |
|
| 24264 |
amit.gupta |
3 |
import com.spice.profitmandi.common.enumuration.ItemType;
|
| 23202 |
ashik.ali |
4 |
import com.spice.profitmandi.common.enumuration.SearchType;
|
| 33838 |
ranu |
5 |
import com.spice.profitmandi.common.enumuration.UpgradeOfferPaymentStatus;
|
| 22859 |
ashik.ali |
6 |
import com.spice.profitmandi.common.exception.ProfitMandiBusinessException;
|
| 32420 |
amit.gupta |
7 |
import com.spice.profitmandi.common.model.*;
|
| 23650 |
amit.gupta |
8 |
import com.spice.profitmandi.common.util.FormattingUtils;
|
| 22859 |
ashik.ali |
9 |
import com.spice.profitmandi.common.util.StringUtils;
|
| 23172 |
ashik.ali |
10 |
import com.spice.profitmandi.common.util.Utils;
|
| 29515 |
tejbeer |
11 |
import com.spice.profitmandi.common.web.client.RestClient;
|
| 33873 |
ranu |
12 |
import com.spice.profitmandi.dao.cart.SmartCartService;
|
| 22859 |
ashik.ali |
13 |
import com.spice.profitmandi.dao.entity.catalog.Item;
|
| 25103 |
amit.gupta |
14 |
import com.spice.profitmandi.dao.entity.catalog.TagListing;
|
| 33795 |
ranu |
15 |
import com.spice.profitmandi.dao.entity.catalog.UpgradeOffer;
|
| 32420 |
amit.gupta |
16 |
import com.spice.profitmandi.dao.entity.dtr.*;
|
|
|
17 |
import com.spice.profitmandi.dao.entity.fofo.*;
|
| 28978 |
amit.gupta |
18 |
import com.spice.profitmandi.dao.entity.inventory.State;
|
| 24917 |
tejbeer |
19 |
import com.spice.profitmandi.dao.entity.transaction.Order;
|
| 22859 |
ashik.ali |
20 |
import com.spice.profitmandi.dao.entity.user.Address;
|
|
|
21 |
import com.spice.profitmandi.dao.entity.user.Counter;
|
|
|
22 |
import com.spice.profitmandi.dao.entity.user.PrivateDealUser;
|
| 27516 |
amit.gupta |
23 |
import com.spice.profitmandi.dao.entity.warehouse.WarehouseInventoryItem;
|
| 24264 |
amit.gupta |
24 |
import com.spice.profitmandi.dao.enumuration.catalog.SchemeType;
|
| 23546 |
ashik.ali |
25 |
import com.spice.profitmandi.dao.enumuration.dtr.PaymentOptionReferenceType;
|
| 23650 |
amit.gupta |
26 |
import com.spice.profitmandi.dao.enumuration.fofo.ReturnType;
|
| 22859 |
ashik.ali |
27 |
import com.spice.profitmandi.dao.enumuration.fofo.ScanType;
|
| 23655 |
amit.gupta |
28 |
import com.spice.profitmandi.dao.enumuration.fofo.SettlementType;
|
| 29515 |
tejbeer |
29 |
import com.spice.profitmandi.dao.enumuration.inventory.ScratchedGift;
|
| 28339 |
tejbeer |
30 |
import com.spice.profitmandi.dao.enumuration.transaction.OrderStatus;
|
| 33795 |
ranu |
31 |
import com.spice.profitmandi.dao.repository.catalog.*;
|
| 32420 |
amit.gupta |
32 |
import com.spice.profitmandi.dao.repository.dtr.*;
|
|
|
33 |
import com.spice.profitmandi.dao.repository.fofo.*;
|
| 24854 |
amit.gupta |
34 |
import com.spice.profitmandi.dao.repository.inventory.StateRepository;
|
| 24917 |
tejbeer |
35 |
import com.spice.profitmandi.dao.repository.transaction.OrderRepository;
|
| 22859 |
ashik.ali |
36 |
import com.spice.profitmandi.dao.repository.user.AddressRepository;
|
|
|
37 |
import com.spice.profitmandi.dao.repository.user.CounterRepository;
|
|
|
38 |
import com.spice.profitmandi.dao.repository.user.PrivateDealUserRepository;
|
| 27516 |
amit.gupta |
39 |
import com.spice.profitmandi.dao.repository.warehouse.WarehouseInventoryItemRepository;
|
| 34798 |
ranu |
40 |
import com.spice.profitmandi.service.integrations.bharti.model.PlanVariant;
|
| 25724 |
amit.gupta |
41 |
import com.spice.profitmandi.service.integrations.zest.InsuranceService;
|
| 31274 |
amit.gupta |
42 |
import com.spice.profitmandi.service.integrations.zest.MobileInsurancePlan;
|
| 23418 |
ashik.ali |
43 |
import com.spice.profitmandi.service.inventory.InventoryService;
|
| 23655 |
amit.gupta |
44 |
import com.spice.profitmandi.service.inventory.PurchaseReturnService;
|
| 26891 |
amit.gupta |
45 |
import com.spice.profitmandi.service.inventory.SaholicInventoryService;
|
| 28166 |
tejbeer |
46 |
import com.spice.profitmandi.service.offers.ItemCriteria;
|
| 22859 |
ashik.ali |
47 |
import com.spice.profitmandi.service.pricing.PricingService;
|
|
|
48 |
import com.spice.profitmandi.service.scheme.SchemeService;
|
| 23655 |
amit.gupta |
49 |
import com.spice.profitmandi.service.user.RetailerService;
|
| 32420 |
amit.gupta |
50 |
import org.apache.logging.log4j.LogManager;
|
|
|
51 |
import org.apache.logging.log4j.Logger;
|
|
|
52 |
import org.hibernate.Session;
|
|
|
53 |
import org.hibernate.SessionFactory;
|
|
|
54 |
import org.json.JSONObject;
|
|
|
55 |
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
56 |
import org.springframework.beans.factory.annotation.Qualifier;
|
|
|
57 |
import org.springframework.beans.factory.annotation.Value;
|
|
|
58 |
import org.springframework.cache.annotation.Cacheable;
|
|
|
59 |
import org.springframework.core.io.InputStreamResource;
|
|
|
60 |
import org.springframework.http.HttpHeaders;
|
|
|
61 |
import org.springframework.http.HttpStatus;
|
|
|
62 |
import org.springframework.http.ResponseEntity;
|
|
|
63 |
import org.springframework.stereotype.Component;
|
| 22859 |
ashik.ali |
64 |
|
| 32420 |
amit.gupta |
65 |
import javax.persistence.criteria.CriteriaBuilder;
|
|
|
66 |
import javax.persistence.criteria.CriteriaQuery;
|
|
|
67 |
import javax.persistence.criteria.Predicate;
|
|
|
68 |
import javax.persistence.criteria.Root;
|
|
|
69 |
import java.io.ByteArrayInputStream;
|
|
|
70 |
import java.io.InputStream;
|
|
|
71 |
import java.time.LocalDate;
|
|
|
72 |
import java.time.LocalDateTime;
|
|
|
73 |
import java.time.LocalTime;
|
|
|
74 |
import java.util.AbstractMap.SimpleEntry;
|
|
|
75 |
import java.util.*;
|
|
|
76 |
import java.util.function.Function;
|
|
|
77 |
import java.util.stream.Collectors;
|
|
|
78 |
|
| 22859 |
ashik.ali |
79 |
@Component
|
|
|
80 |
public class OrderServiceImpl implements OrderService {
|
|
|
81 |
|
| 32145 |
tejbeer |
82 |
private static final Logger LOGGER = LogManager.getLogger(OrderServiceImpl.class);
|
| 22859 |
ashik.ali |
83 |
|
| 32145 |
tejbeer |
84 |
private static Map<String, Integer> serialNumberOrderIdMap = new HashMap<>();
|
| 31030 |
amit.gupta |
85 |
|
| 32145 |
tejbeer |
86 |
static {
|
|
|
87 |
serialNumberOrderIdMap.put("862897055749275", 67228);
|
|
|
88 |
}
|
| 31030 |
amit.gupta |
89 |
|
| 32145 |
tejbeer |
90 |
@Autowired
|
|
|
91 |
@Qualifier("fofoInventoryItemRepository")
|
|
|
92 |
private InventoryItemRepository inventoryItemRepository;
|
| 27083 |
amit.gupta |
93 |
|
| 32145 |
tejbeer |
94 |
@Autowired
|
|
|
95 |
private StateGstRateRepository stateGstRateRepository;
|
| 23650 |
amit.gupta |
96 |
|
| 32145 |
tejbeer |
97 |
@Autowired
|
|
|
98 |
private SaholicInventoryService saholicInventoryService;
|
| 27083 |
amit.gupta |
99 |
|
| 32145 |
tejbeer |
100 |
@Autowired
|
|
|
101 |
private LiveDemoBillingRespository liveDemoBillingRespository;
|
| 24823 |
amit.gupta |
102 |
|
| 32145 |
tejbeer |
103 |
@Autowired
|
|
|
104 |
private InsuranceService insuranceService;
|
| 25724 |
amit.gupta |
105 |
|
| 32145 |
tejbeer |
106 |
@Autowired
|
|
|
107 |
@Qualifier("fofoCurrentInventorySnapshotRepository")
|
|
|
108 |
private CurrentInventorySnapshotRepository currentInventorySnapshotRepository;
|
| 22859 |
ashik.ali |
109 |
|
| 32145 |
tejbeer |
110 |
@Autowired
|
|
|
111 |
private InvoiceNumberGenerationSequenceRepository invoiceNumberGenerationSequenceRepository;
|
| 22859 |
ashik.ali |
112 |
|
| 32145 |
tejbeer |
113 |
@Autowired
|
|
|
114 |
private PurchaseReturnService purchaseReturnService;
|
| 23655 |
amit.gupta |
115 |
|
| 32145 |
tejbeer |
116 |
@Autowired
|
|
|
117 |
private RetailerService retailerService;
|
| 23655 |
amit.gupta |
118 |
|
| 32145 |
tejbeer |
119 |
@Autowired
|
|
|
120 |
private CustomerRepository customerRepository;
|
| 23650 |
amit.gupta |
121 |
|
| 32145 |
tejbeer |
122 |
@Autowired
|
|
|
123 |
private PurchaseReturnItemRepository purchaseReturnItemRepository;
|
| 22859 |
ashik.ali |
124 |
|
| 32145 |
tejbeer |
125 |
@Autowired
|
|
|
126 |
private AddressRepository addressRepository;
|
| 22859 |
ashik.ali |
127 |
|
| 32145 |
tejbeer |
128 |
@Autowired
|
|
|
129 |
private FofoLineItemRepository fofoLineItemRepository;
|
| 22859 |
ashik.ali |
130 |
|
| 32145 |
tejbeer |
131 |
@Autowired
|
| 32816 |
ranu |
132 |
private FofoNonSerializeSerialRepository fofoNonSerializeSerialRepository;
|
|
|
133 |
|
|
|
134 |
@Autowired
|
| 32145 |
tejbeer |
135 |
private WarehouseInventoryItemRepository warehouseInventoryItemRepository;
|
| 27516 |
amit.gupta |
136 |
|
| 32145 |
tejbeer |
137 |
@Autowired
|
|
|
138 |
private FofoOrderItemRepository fofoOrderItemRepository;
|
| 23650 |
amit.gupta |
139 |
|
| 32145 |
tejbeer |
140 |
@Autowired
|
|
|
141 |
private PaymentOptionRepository paymentOptionRepository;
|
| 22859 |
ashik.ali |
142 |
|
| 32145 |
tejbeer |
143 |
@Autowired
|
|
|
144 |
private CustomerReturnItemRepository customerReturnItemRepository;
|
| 23650 |
amit.gupta |
145 |
|
| 32145 |
tejbeer |
146 |
@Autowired
|
|
|
147 |
@Qualifier("fofoScanRecordRepository")
|
|
|
148 |
private ScanRecordRepository scanRecordRepository;
|
| 22859 |
ashik.ali |
149 |
|
| 32145 |
tejbeer |
150 |
@Autowired
|
|
|
151 |
private FofoOrderRepository fofoOrderRepository;
|
| 22859 |
ashik.ali |
152 |
|
| 32145 |
tejbeer |
153 |
@Autowired
|
|
|
154 |
private RetailerRepository retailerRepository;
|
| 22859 |
ashik.ali |
155 |
|
| 32145 |
tejbeer |
156 |
@Autowired
|
|
|
157 |
private UserRepository userRepository;
|
| 22859 |
ashik.ali |
158 |
|
| 32145 |
tejbeer |
159 |
@Autowired
|
|
|
160 |
private UserAccountRepository userAccountRepository;
|
| 22859 |
ashik.ali |
161 |
|
| 32145 |
tejbeer |
162 |
@Autowired
|
|
|
163 |
private RetailerRegisteredAddressRepository retailerRegisteredAddressRepository;
|
| 22859 |
ashik.ali |
164 |
|
| 32145 |
tejbeer |
165 |
@Autowired
|
|
|
166 |
private CustomerAddressRepository customerAddressRepository;
|
| 22859 |
ashik.ali |
167 |
|
| 32145 |
tejbeer |
168 |
@Autowired
|
|
|
169 |
@Qualifier("catalogItemRepository")
|
|
|
170 |
private ItemRepository itemRepository;
|
| 23650 |
amit.gupta |
171 |
|
| 32145 |
tejbeer |
172 |
@Autowired
|
|
|
173 |
private InsuranceProviderRepository insuranceProviderRepository;
|
| 23650 |
amit.gupta |
174 |
|
| 32145 |
tejbeer |
175 |
@Autowired
|
|
|
176 |
private InsurancePolicyRepository insurancePolicyRepository;
|
| 24917 |
tejbeer |
177 |
|
| 32145 |
tejbeer |
178 |
@Autowired
|
|
|
179 |
private StateRepository stateRepository;
|
| 23650 |
amit.gupta |
180 |
|
| 32145 |
tejbeer |
181 |
@Autowired
|
|
|
182 |
private PolicyNumberGenerationSequenceRepository policyNumberGenerationSequenceRepository;
|
| 23650 |
amit.gupta |
183 |
|
| 32145 |
tejbeer |
184 |
@Autowired
|
|
|
185 |
private PricingService pricingService;
|
| 23650 |
amit.gupta |
186 |
|
| 32145 |
tejbeer |
187 |
@Autowired
|
|
|
188 |
private PrivateDealUserRepository privateDealUserRepository;
|
| 23650 |
amit.gupta |
189 |
|
| 32145 |
tejbeer |
190 |
@Autowired
|
|
|
191 |
private TagListingRepository tagListingRepository;
|
| 24823 |
amit.gupta |
192 |
|
| 32145 |
tejbeer |
193 |
@Autowired
|
|
|
194 |
private CounterRepository counterRepository;
|
| 23650 |
amit.gupta |
195 |
|
| 32145 |
tejbeer |
196 |
@Autowired
|
|
|
197 |
private FofoStoreRepository fofoStoreRepository;
|
| 23650 |
amit.gupta |
198 |
|
| 32145 |
tejbeer |
199 |
@Autowired
|
|
|
200 |
private PaymentOptionTransactionRepository paymentOptionTransactionRepository;
|
| 23650 |
amit.gupta |
201 |
|
| 32145 |
tejbeer |
202 |
@Autowired
|
|
|
203 |
private SchemeService schemeService;
|
| 23650 |
amit.gupta |
204 |
|
| 32145 |
tejbeer |
205 |
private static final List<Integer> orderIdsConsumed = new ArrayList<>();
|
| 28166 |
tejbeer |
206 |
|
| 32145 |
tejbeer |
207 |
@Autowired
|
|
|
208 |
@Qualifier("fofoInventoryService")
|
|
|
209 |
private InventoryService inventoryService;
|
| 23650 |
amit.gupta |
210 |
|
| 32145 |
tejbeer |
211 |
@Autowired
|
|
|
212 |
private CustomerCreditNoteRepository customerCreditNoteRepository;
|
| 23650 |
amit.gupta |
213 |
|
| 32145 |
tejbeer |
214 |
@Autowired
|
|
|
215 |
private OrderRepository orderRepository;
|
| 24917 |
tejbeer |
216 |
|
| 32145 |
tejbeer |
217 |
@Autowired
|
|
|
218 |
private HygieneDataRepository hygieneDataRepository;
|
| 25640 |
tejbeer |
219 |
|
| 32145 |
tejbeer |
220 |
@Autowired
|
|
|
221 |
private SessionFactory sessionFactory;
|
| 28166 |
tejbeer |
222 |
|
| 32145 |
tejbeer |
223 |
@Autowired
|
|
|
224 |
private Mongo mongoClient;
|
| 28964 |
tejbeer |
225 |
|
| 32145 |
tejbeer |
226 |
@Autowired
|
|
|
227 |
private PendingOrderRepository pendingOrderRepository;
|
| 28964 |
tejbeer |
228 |
|
| 32145 |
tejbeer |
229 |
@Autowired
|
| 33399 |
ranu |
230 |
|
|
|
231 |
private PendingOrderService pendingOrderService;
|
|
|
232 |
|
|
|
233 |
@Autowired
|
| 32145 |
tejbeer |
234 |
private PendingOrderItemRepository pendingOrderItemRepository;
|
| 28166 |
tejbeer |
235 |
|
| 32145 |
tejbeer |
236 |
@Autowired
|
|
|
237 |
private ScratchOfferRepository scratchOfferRepository;
|
| 29515 |
tejbeer |
238 |
|
| 32145 |
tejbeer |
239 |
@Autowired
|
|
|
240 |
RestClient restClient;
|
| 29515 |
tejbeer |
241 |
|
| 33715 |
ranu |
242 |
@Autowired
|
|
|
243 |
UpSaleOrderRepository upSaleOrderRepository;
|
|
|
244 |
|
| 33795 |
ranu |
245 |
@Autowired
|
|
|
246 |
private CustomerOfferRepository customerOfferRepository;
|
|
|
247 |
|
|
|
248 |
@Autowired
|
|
|
249 |
private CustomerOfferItemRepository customerOfferItemRepository;
|
|
|
250 |
|
|
|
251 |
@Autowired
|
|
|
252 |
private UpgradeOfferRepository upgradeOfferRepository;
|
|
|
253 |
|
| 33873 |
ranu |
254 |
@Autowired
|
|
|
255 |
private SmartCartService smartCartService;
|
|
|
256 |
|
| 33895 |
ranu |
257 |
@Autowired
|
|
|
258 |
private PartnerTypeChangeService partnerTypeChangeService;
|
|
|
259 |
|
| 32145 |
tejbeer |
260 |
@Value("${prod}")
|
|
|
261 |
private boolean prodEnv;
|
| 29515 |
tejbeer |
262 |
|
| 32145 |
tejbeer |
263 |
private static final String SMS_GATEWAY = "http://api.pinnacle.in/index.php/sms/send";
|
|
|
264 |
private static final String SENDER = "SMTDKN";
|
| 29515 |
tejbeer |
265 |
|
| 32145 |
tejbeer |
266 |
public static final String APP_DOWNLOAD_BILLING_TEMPLATE_ID = "1507163542403945677";
|
| 29515 |
tejbeer |
267 |
|
| 32145 |
tejbeer |
268 |
public static final String APP_DOWNLOAD_BILLING_OFFER = "Dear Customer, Thank you for purchasing from SmartDukaan pls click %s to download our app to see you invoice and special offers. SmartDukaan";
|
| 29515 |
tejbeer |
269 |
|
| 34342 |
ranu |
270 |
static Map<Double, List<ScratchedGift>> GIFT_SERIES = new TreeMap<>(Comparator.reverseOrder());
|
|
|
271 |
|
| 34340 |
ranu |
272 |
// Define eligible partners for LED & Microwave Oven
|
| 34351 |
ranu |
273 |
private static final Set<Integer> PREMIUM_ELIGIBLE_PARTNERS = new HashSet<>(Arrays.asList(175139615, 175139583));
|
| 34342 |
ranu |
274 |
private static Map<ScratchedGift, Integer> GIFT_QUANTITIES = new HashMap<>();
|
|
|
275 |
List<Double> PRICE_RANGE = Arrays.asList(0.0, Double.MAX_VALUE);
|
| 33899 |
ranu |
276 |
|
| 34340 |
ranu |
277 |
static {
|
| 34365 |
ranu |
278 |
GIFT_QUANTITIES.put(ScratchedGift.ACCESSORIES_50_PERCENT_OFF, 500);
|
| 34340 |
ranu |
279 |
GIFT_QUANTITIES.put(ScratchedGift.NECK_BAND, 280);
|
|
|
280 |
GIFT_QUANTITIES.put(ScratchedGift.LED, 1);
|
|
|
281 |
GIFT_QUANTITIES.put(ScratchedGift.MICROWAVE_OVEN, 1);
|
|
|
282 |
}
|
|
|
283 |
|
|
|
284 |
static {
|
|
|
285 |
GIFT_SERIES.put(0.0, Arrays.asList(ScratchedGift.ACCESSORIES_50_PERCENT_OFF, ScratchedGift.NECK_BAND));
|
| 34365 |
ranu |
286 |
GIFT_SERIES.put(30001.0, Arrays.asList(ScratchedGift.NECK_BAND, ScratchedGift.MICROWAVE_OVEN, ScratchedGift.LED));
|
| 34340 |
ranu |
287 |
}
|
|
|
288 |
|
| 33899 |
ranu |
289 |
private void persistNonSerializedWithCustomSerialNumber(CustomFofoOrderItem customFofoOrderItem, int orderItemId) {
|
|
|
290 |
// Create a new instance of FofoNonSerializeSerial
|
|
|
291 |
for (String accSerialNumber : customFofoOrderItem.getCustomSerialNumbers()) {
|
|
|
292 |
if (!accSerialNumber.isEmpty()) {
|
|
|
293 |
FofoNonSerializeSerial nonSerializeSerial = new FofoNonSerializeSerial();
|
|
|
294 |
|
|
|
295 |
// Populate the entity with relevant information
|
|
|
296 |
nonSerializeSerial.setOrderItemId(orderItemId);
|
|
|
297 |
nonSerializeSerial.setSerialNumber(accSerialNumber);
|
|
|
298 |
|
|
|
299 |
// Save the entity to the database
|
|
|
300 |
fofoNonSerializeSerialRepository.persist(nonSerializeSerial);
|
|
|
301 |
}
|
|
|
302 |
|
|
|
303 |
}
|
|
|
304 |
}
|
|
|
305 |
|
|
|
306 |
|
|
|
307 |
public void sendAppDownloadBillingOffer(String mobileNumber) throws Exception {
|
|
|
308 |
String sdurl = "http://surl.li/anhfn";
|
|
|
309 |
try {
|
|
|
310 |
if (prodEnv) {
|
|
|
311 |
this.sendSms(APP_DOWNLOAD_BILLING_TEMPLATE_ID, String.format(APP_DOWNLOAD_BILLING_OFFER, sdurl), mobileNumber);
|
|
|
312 |
}
|
|
|
313 |
} catch (Exception e) {
|
|
|
314 |
e.printStackTrace();
|
|
|
315 |
}
|
|
|
316 |
|
|
|
317 |
}
|
|
|
318 |
|
|
|
319 |
public void sendSms(String dltTemplateId, String message, String mobileNumber) throws Exception {
|
|
|
320 |
Map<String, String> map = new HashMap<>();
|
|
|
321 |
|
|
|
322 |
map.put("sender", SENDER);
|
|
|
323 |
map.put("messagetype", "TXT");
|
|
|
324 |
map.put("apikey", "b866f7-c6c483-682ff5-054420-ad9e2c");
|
|
|
325 |
|
|
|
326 |
map.put("numbers", "91" + mobileNumber);
|
|
|
327 |
LOGGER.info("Message {}", message);
|
|
|
328 |
// OTP Message Template
|
|
|
329 |
map.put("message", message);
|
|
|
330 |
map.put("dlttempid", dltTemplateId);
|
|
|
331 |
|
|
|
332 |
String response = restClient.post(SMS_GATEWAY, map, new HashMap<>());
|
|
|
333 |
LOGGER.info(response);
|
|
|
334 |
|
|
|
335 |
}
|
|
|
336 |
|
|
|
337 |
|
|
|
338 |
private void createScratchOffer(int fofoId, String invoiceNumber, int customerId) {
|
|
|
339 |
|
|
|
340 |
//ScratchedGift gift = getScratchedGiftRandom(fofoId, customerId);
|
|
|
341 |
|
|
|
342 |
|
|
|
343 |
// LocalDateTime endDate = LocalDateTime.of(LocalDate.now().getYear(), LocalDate.now().getMonth(), 27, 21, 00);
|
|
|
344 |
List<ScratchOffer> scratchOffers = scratchOfferRepository.selectBycCustomerIdAndDate(customerId, ProfitMandiConstants.SCRATCH_OFFER_START_DATE, ProfitMandiConstants.SCRATCH_OFFER_END_DATE);
|
|
|
345 |
if (scratchOffers.size() == 0) {
|
|
|
346 |
ScratchOffer so2 = new ScratchOffer();
|
|
|
347 |
so2.setInvoiceNumber(invoiceNumber);
|
|
|
348 |
so2.setScratched(false);
|
|
|
349 |
so2.setCreatedTimestamp(LocalDateTime.now());
|
|
|
350 |
so2.setExpiredTimestamp(ProfitMandiConstants.SCRATCH_OFFER_END_DATE.plusDays(1).atTime(LocalTime.MAX));
|
| 34474 |
aman.kumar |
351 |
so2.setOfferName(String.valueOf(ScratchedGift.BLNT));
|
| 33899 |
ranu |
352 |
so2.setCustomerId(customerId);
|
|
|
353 |
|
|
|
354 |
LocalDateTime today830PM = LocalDate.now().atTime(20, 30);
|
|
|
355 |
LocalDateTime today9PM = LocalDate.now().atTime(21, 0);
|
|
|
356 |
so2.setUnlockedAt(LocalDateTime.now());
|
|
|
357 |
|
|
|
358 |
// if (LocalDateTime.now().isAfter(today830PM)) {
|
|
|
359 |
// so2.setUnlockedAt(today9PM.plusDays(0));
|
|
|
360 |
// } else {
|
|
|
361 |
// so2.setUnlockedAt(today9PM);
|
|
|
362 |
// }
|
|
|
363 |
scratchOfferRepository.persist(so2);
|
|
|
364 |
}
|
|
|
365 |
}
|
|
|
366 |
|
| 34341 |
ranu |
367 |
|
| 32145 |
tejbeer |
368 |
@Override
|
| 34194 |
ranu |
369 |
public int createOrder(CreateOrderRequest createOrderRequest, int fofoId, boolean accessoriesDeals) throws Exception {
|
| 32145 |
tejbeer |
370 |
LOGGER.info("fofoId -- {} Order Request -- {}", fofoId, createOrderRequest);
|
|
|
371 |
CustomCustomer customCustomer = createOrderRequest.getCustomer();
|
|
|
372 |
Customer customer = customerRepository.selectById(customCustomer.getCustomerId());
|
| 22872 |
ashik.ali |
373 |
|
| 35156 |
aman |
374 |
if ((createOrderRequest.getCustomer().getGender() != null && createOrderRequest.getCustomer().getGender().equals("2"))) {
|
| 35097 |
ranu |
375 |
customer.setGender("Female");
|
|
|
376 |
} else {
|
|
|
377 |
|
|
|
378 |
customer.setGender("Male");
|
|
|
379 |
}
|
|
|
380 |
|
| 32145 |
tejbeer |
381 |
if (!StringUtils.isValidGstNumber(customCustomer.getGstNumber())) {
|
|
|
382 |
LOGGER.error("invalid customer gstNumber {} ", customCustomer.getGstNumber());
|
|
|
383 |
throw new ProfitMandiBusinessException(ProfitMandiConstants.CUSTOMER_GST_NUMBER, customCustomer.getGstNumber(), "VE_1072");
|
|
|
384 |
}
|
| 23650 |
amit.gupta |
385 |
|
| 32145 |
tejbeer |
386 |
Map<Integer, Integer> itemIdQuantity = new HashMap<>(); // this is for error
|
|
|
387 |
Map<Integer, CustomFofoOrderItem> itemIdCustomFofoOrderItemMap = new HashMap<>();
|
|
|
388 |
Map<Integer, Float> lineItemPrice = new HashMap<>(); // this is for pricing error
|
| 23650 |
amit.gupta |
389 |
|
| 32145 |
tejbeer |
390 |
float totalAmount = 0;
|
|
|
391 |
boolean noGST = false;
|
| 33520 |
amit.gupta |
392 |
int changedTotalBillAmount = 0;
|
|
|
393 |
for (CustomPaymentOption cpo : createOrderRequest.getPaymentOptions()) {
|
| 33399 |
ranu |
394 |
changedTotalBillAmount += cpo.getAmount();
|
|
|
395 |
}
|
| 32145 |
tejbeer |
396 |
for (CustomFofoOrderItem customFofoOrderItem : createOrderRequest.getFofoOrderItems()) {
|
| 33520 |
amit.gupta |
397 |
if (customFofoOrderItem.getPoiId() > 0) {
|
| 33399 |
ranu |
398 |
PendingOrderItem pendingOrderItem = pendingOrderItemRepository.selectById(customFofoOrderItem.getPoiId());
|
| 33520 |
amit.gupta |
399 |
if (customFofoOrderItem.getQuantity() > pendingOrderItem.getQuantity()) {
|
| 33414 |
amit.gupta |
400 |
throw new ProfitMandiBusinessException("itemIdQuantity", customFofoOrderItem.getItemId(), "Quantity should not be greater than order item quantity");
|
| 33399 |
ranu |
401 |
}
|
| 33520 |
amit.gupta |
402 |
if (pendingOrderItem.getQuantity() > customFofoOrderItem.getQuantity()) {
|
|
|
403 |
pendingOrderService.duplicatePendingOrder(pendingOrderItem, customFofoOrderItem.getQuantity());
|
| 33399 |
ranu |
404 |
}
|
|
|
405 |
}
|
| 32145 |
tejbeer |
406 |
// itemIds.add(customFofoOrderItem.getItemId());
|
|
|
407 |
Set<String> serialNumbers = this.serialNumberDetailsToSerialNumbers(customFofoOrderItem.getSerialNumberDetails());
|
|
|
408 |
if (!serialNumbers.isEmpty() && customFofoOrderItem.getQuantity() != serialNumbers.size()) {
|
|
|
409 |
itemIdQuantity.put(customFofoOrderItem.getItemId(), customFofoOrderItem.getQuantity());
|
|
|
410 |
}
|
|
|
411 |
if (!(customFofoOrderItem.getSellingPrice() > 0)) {
|
|
|
412 |
lineItemPrice.put(customFofoOrderItem.getItemId(), customFofoOrderItem.getSellingPrice());
|
|
|
413 |
} else {
|
| 33554 |
tejus.loha |
414 |
totalAmount = totalAmount + customFofoOrderItem.getSellingPrice() * customFofoOrderItem.getQuantity();
|
| 32145 |
tejbeer |
415 |
for (SerialNumberDetail serialNumberDetail : customFofoOrderItem.getSerialNumberDetails()) {
|
|
|
416 |
if (serialNumberDetail.getAmount() > 0) {
|
|
|
417 |
totalAmount = totalAmount + serialNumberDetail.getAmount();
|
|
|
418 |
}
|
|
|
419 |
}
|
|
|
420 |
}
|
| 23650 |
amit.gupta |
421 |
|
| 32145 |
tejbeer |
422 |
itemIdCustomFofoOrderItemMap.put(customFofoOrderItem.getItemId(), customFofoOrderItem);
|
|
|
423 |
}
|
|
|
424 |
if (!itemIdQuantity.isEmpty()) {
|
|
|
425 |
// if item quantity does not match with given serialnumbers size
|
|
|
426 |
LOGGER.error("itemId's quantity should be equal to given serialnumber size {} ", itemIdQuantity);
|
|
|
427 |
throw new ProfitMandiBusinessException("itemIdQuantity", itemIdQuantity, "FFORDR_1001");
|
|
|
428 |
// return "error";
|
|
|
429 |
}
|
| 23650 |
amit.gupta |
430 |
|
| 32145 |
tejbeer |
431 |
this.validatePaymentOptionsAndTotalAmount(createOrderRequest.getPaymentOptions(), totalAmount);
|
| 23650 |
amit.gupta |
432 |
|
| 32145 |
tejbeer |
433 |
if (!lineItemPrice.isEmpty()) {
|
|
|
434 |
// given fofo line item price must be greater than zero
|
|
|
435 |
LOGGER.error("requested itemId's selling price must greater than 0");
|
|
|
436 |
throw new ProfitMandiBusinessException(ProfitMandiConstants.PRICE, lineItemPrice, "FFORDR_1002");
|
|
|
437 |
}
|
| 22859 |
ashik.ali |
438 |
|
| 32145 |
tejbeer |
439 |
List<CurrentInventorySnapshot> currentInventorySnapshots = currentInventorySnapshotRepository.selectByFofoItemIds(fofoId, itemIdCustomFofoOrderItemMap.keySet());
|
| 23650 |
amit.gupta |
440 |
|
| 32145 |
tejbeer |
441 |
this.validateCurrentInventorySnapshotQuantities(currentInventorySnapshots, itemIdCustomFofoOrderItemMap);
|
| 22859 |
ashik.ali |
442 |
|
| 32145 |
tejbeer |
443 |
List<Item> items = itemRepository.selectByIds(itemIdCustomFofoOrderItemMap.keySet());
|
|
|
444 |
if (items.size() != itemIdCustomFofoOrderItemMap.keySet().size()) {
|
|
|
445 |
LOGGER.error("Requested ItemIds not found in catalog");
|
|
|
446 |
// invalid itemIds
|
|
|
447 |
throw new ProfitMandiBusinessException("invalidItemIds", itemIdCustomFofoOrderItemMap.keySet(), "FFORDR_1003");
|
|
|
448 |
}
|
| 23650 |
amit.gupta |
449 |
|
| 32145 |
tejbeer |
450 |
Map<Integer, Item> itemMap = this.toItemMap(items);
|
| 23650 |
amit.gupta |
451 |
|
| 32145 |
tejbeer |
452 |
Set<Integer> nonSerializedItemIds = new HashSet<>();
|
|
|
453 |
Set<String> serialNumbers = new HashSet<>();
|
|
|
454 |
List<InsuranceModel> insuredModels = new ArrayList<>();
|
|
|
455 |
for (CustomFofoOrderItem customFofoOrderItem : createOrderRequest.getFofoOrderItems()) {
|
|
|
456 |
Item item = itemMap.get(customFofoOrderItem.getItemId());
|
|
|
457 |
noGST = item.getHsnCode().equals("NOGST");
|
|
|
458 |
if (item.getType().equals(ItemType.SERIALIZED)) {
|
|
|
459 |
for (SerialNumberDetail serialNumberDetail : customFofoOrderItem.getSerialNumberDetails()) {
|
|
|
460 |
serialNumbers.add(serialNumberDetail.getSerialNumber());
|
|
|
461 |
if (serialNumberDetail.getAmount() > 0) {
|
|
|
462 |
if (customer.getEmailId() == null || customer.getEmailId().equals("")) {
|
|
|
463 |
throw new ProfitMandiBusinessException("Email Id is required for insurance", "Email Id is required for insurance", "Email Id is required for insurance");
|
|
|
464 |
}
|
| 34194 |
ranu |
465 |
|
| 32145 |
tejbeer |
466 |
InsuranceModel im = new InsuranceModel();
|
|
|
467 |
im.setBrand(item.getBrand());
|
|
|
468 |
im.setColor(item.getColor());
|
|
|
469 |
im.setModelName(item.getModelName() + item.getModelNumber());
|
|
|
470 |
im.setInsuranceAmount(serialNumberDetail.getAmount());
|
|
|
471 |
im.setDeviceSellingPrice(customFofoOrderItem.getSellingPrice());
|
| 34194 |
ranu |
472 |
im.setInsuranceUId(serialNumberDetail.getInsurance());
|
| 34798 |
ranu |
473 |
im.setCorrelationId(serialNumberDetail.getCorrelationId());
|
|
|
474 |
|
|
|
475 |
PlanVariant oneAssistpremium = insuranceService.getOneAssistPremiumByVariantId(serialNumberDetail.getInsurance());
|
|
|
476 |
if (oneAssistpremium != null) {
|
|
|
477 |
im.setInsuranceId(String.valueOf(oneAssistpremium.getId()));
|
|
|
478 |
} else {
|
|
|
479 |
im.setInsuranceId(String.valueOf(insuranceService.getICICIPremiumByVariantId(serialNumberDetail.getInsurance()).getId()));
|
|
|
480 |
}
|
| 32145 |
tejbeer |
481 |
im.setSerialNumber(serialNumberDetail.getSerialNumber());
|
|
|
482 |
im.setMemory(serialNumberDetail.getMemory());
|
|
|
483 |
im.setRam(serialNumberDetail.getRam());
|
|
|
484 |
im.setMfgDate(serialNumberDetail.getMfgDate());
|
|
|
485 |
insuredModels.add(im);
|
|
|
486 |
// Check for free insurance code
|
|
|
487 |
try {
|
| 33520 |
amit.gupta |
488 |
Map<String, List<MobileInsurancePlan>> mobileInsurancePlanMap = insuranceService.getAllPlans(item.getId(), im.getDeviceSellingPrice(), false);
|
| 32145 |
tejbeer |
489 |
MobileInsurancePlan mobileInsurancePlan = mobileInsurancePlanMap.entrySet().stream().flatMap(x -> x.getValue().stream()).filter(x -> x.getProductId().equals(serialNumberDetail.getInsurance())).findFirst().get();
|
| 34798 |
ranu |
490 |
/* if (mobileInsurancePlan.getPlanName().equals("OneAssist Damage Protection Plan")) {
|
|
|
491 |
MobileInsurancePlan freePlan = mobileInsurancePlanMap.get("Prolong Extendended Warranty(SmartDukaan Special Price)").get(0);
|
|
|
492 |
InsuranceModel imFree = new InsuranceModel();
|
|
|
493 |
imFree.setBrand(item.getBrand());
|
|
|
494 |
imFree.setColor(item.getColor());
|
|
|
495 |
imFree.setModelName(item.getModelName() + item.getModelNumber());
|
|
|
496 |
imFree.setInsuranceAmount(0);
|
|
|
497 |
imFree.setDeviceSellingPrice(customFofoOrderItem.getSellingPrice());
|
|
|
498 |
LOGGER.info("freePlan.getProductId() {}", freePlan.getProductId());
|
|
|
499 |
imFree.setInsuranceUId(freePlan.getProductId());
|
|
|
500 |
imFree.setInsuranceId(String.valueOf(insuranceService.getOneAssistPremiumByVariantId(freePlan.getProductId()).getId()));
|
|
|
501 |
imFree.setSerialNumber(serialNumberDetail.getSerialNumber());
|
|
|
502 |
imFree.setMemory(serialNumberDetail.getMemory());
|
|
|
503 |
imFree.setRam(serialNumberDetail.getRam());
|
|
|
504 |
imFree.setMfgDate(serialNumberDetail.getMfgDate());
|
|
|
505 |
insuredModels.add(imFree);
|
|
|
506 |
}*/
|
| 32145 |
tejbeer |
507 |
} catch (Exception e) {
|
|
|
508 |
LOGGER.error("Exception - {}", e);
|
|
|
509 |
throw new ProfitMandiBusinessException("problem fetching plans", "problem fetching plans", "problem fetching plans");
|
|
|
510 |
}
|
|
|
511 |
}
|
| 31274 |
amit.gupta |
512 |
|
| 32145 |
tejbeer |
513 |
}
|
|
|
514 |
} else {
|
|
|
515 |
nonSerializedItemIds.add(customFofoOrderItem.getItemId());
|
|
|
516 |
}
|
|
|
517 |
}
|
| 23650 |
amit.gupta |
518 |
|
| 32145 |
tejbeer |
519 |
Map<Integer, Set<InventoryItem>> serializedInventoryItemMap = new HashMap<>();
|
|
|
520 |
Map<Integer, Set<InventoryItem>> nonSerializedInventoryItemMap = new HashMap<>();
|
|
|
521 |
// Map<String, Float> serialNumberItemPrice = new HashMap<>();
|
| 23650 |
amit.gupta |
522 |
|
| 32145 |
tejbeer |
523 |
if (!serialNumbers.isEmpty()) {
|
|
|
524 |
List<InventoryItem> serializedInventoryItems = inventoryItemRepository.selectByFofoIdSerialNumbers(fofoId, serialNumbers, false);
|
|
|
525 |
LOGGER.info("serializedInventoryItems {}", serializedInventoryItems);
|
|
|
526 |
for (InventoryItem inventoryItem : serializedInventoryItems) {
|
|
|
527 |
if (inventoryItem.getGoodQuantity() == 1) {
|
|
|
528 |
if (serializedInventoryItemMap.containsKey(inventoryItem.getItemId())) {
|
|
|
529 |
serializedInventoryItemMap.get(inventoryItem.getItemId()).add(inventoryItem);
|
|
|
530 |
} else {
|
|
|
531 |
Set<InventoryItem> itemIdInventoryItems = new HashSet<>();
|
|
|
532 |
itemIdInventoryItems.add(inventoryItem);
|
|
|
533 |
serializedInventoryItemMap.put(inventoryItem.getItemId(), itemIdInventoryItems);
|
|
|
534 |
}
|
|
|
535 |
}
|
|
|
536 |
}
|
|
|
537 |
}
|
| 23418 |
ashik.ali |
538 |
|
| 32145 |
tejbeer |
539 |
if (!nonSerializedItemIds.isEmpty()) {
|
|
|
540 |
List<InventoryItem> nonSerializedInventoryItems = inventoryItemRepository.selectByFofoIdItemIds(fofoId, nonSerializedItemIds);
|
|
|
541 |
LOGGER.info("nonSerializedInventoryItems {}", nonSerializedInventoryItems);
|
|
|
542 |
for (InventoryItem it : nonSerializedInventoryItems) {
|
|
|
543 |
if (it.getGoodQuantity() > 0) {
|
|
|
544 |
if (nonSerializedInventoryItemMap.containsKey(it.getItemId())) {
|
|
|
545 |
nonSerializedInventoryItemMap.get(it.getItemId()).add(it);
|
|
|
546 |
} else {
|
|
|
547 |
Set<InventoryItem> tmp = new HashSet<>();
|
|
|
548 |
tmp.add(it);
|
|
|
549 |
nonSerializedInventoryItemMap.put(it.getItemId(), tmp);
|
|
|
550 |
}
|
|
|
551 |
}
|
|
|
552 |
}
|
|
|
553 |
}
|
| 23650 |
amit.gupta |
554 |
|
| 32145 |
tejbeer |
555 |
this.validateItemsSerializedNonSerialized(items, itemIdCustomFofoOrderItemMap);
|
| 22859 |
ashik.ali |
556 |
|
| 32145 |
tejbeer |
557 |
Map<Integer, Set<InventoryItem>> inventoryItemsToBill = new HashMap<>();
|
|
|
558 |
Map<Integer, Integer> inventoryItemIdQuantityUsed = new HashMap<>(); // to keep track of inventoryitem quanity
|
|
|
559 |
// used for scan records insertion
|
| 22859 |
ashik.ali |
560 |
|
| 32145 |
tejbeer |
561 |
LOGGER.info("itemMap keys {}", itemMap.keySet());
|
|
|
562 |
// Lets reduce quantity and decide what inventory items to use.
|
|
|
563 |
for (Item item : items) {
|
|
|
564 |
if (item.getType().equals(ItemType.SERIALIZED)) {
|
|
|
565 |
// TODO:handle null
|
|
|
566 |
if (serializedInventoryItemMap.get(item.getId()) == null || itemIdCustomFofoOrderItemMap.get(item.getId()).getSerialNumberDetails().size() != serializedInventoryItemMap.get(item.getId()).size()) {
|
| 24440 |
amit.gupta |
567 |
|
| 32145 |
tejbeer |
568 |
List<String> invalidSerialNumbers = itemIdCustomFofoOrderItemMap.get(item.getId()).getSerialNumberDetails().stream().map(x -> x.getSerialNumber()).collect(Collectors.toList());
|
|
|
569 |
throw new ProfitMandiBusinessException("invalidSerialNumbers", invalidSerialNumbers, "FFORDR_1004");
|
|
|
570 |
}
|
|
|
571 |
List<String> serialNumberList = liveDemoBillingRespository.selectAllSerialNumber();
|
| 24823 |
amit.gupta |
572 |
|
| 32145 |
tejbeer |
573 |
Set<InventoryItem> inventoryItemsSerializedserialized = serializedInventoryItemMap.get(item.getId());
|
|
|
574 |
for (InventoryItem inventoryItem : inventoryItemsSerializedserialized) {
|
|
|
575 |
inventoryItem.setGoodQuantity(0);
|
|
|
576 |
inventoryItemIdQuantityUsed.put(inventoryItem.getId(), 1);
|
|
|
577 |
if (serialNumberList.contains(inventoryItem.getSerialNumber())) {
|
|
|
578 |
LiveDemoSerialNumber liveDemoSerialNumber = liveDemoBillingRespository.selectBySerialNumber(inventoryItem.getSerialNumber());
|
|
|
579 |
liveDemoBillingRespository.delete(liveDemoSerialNumber);
|
|
|
580 |
}
|
|
|
581 |
}
|
|
|
582 |
inventoryItemsToBill.put(item.getId(), inventoryItemsSerializedserialized);
|
|
|
583 |
} else {
|
|
|
584 |
Set<InventoryItem> inventoryItemsNonSerialized = nonSerializedInventoryItemMap.get(item.getId());
|
|
|
585 |
int quantityToBill = itemIdCustomFofoOrderItemMap.get(item.getId()).getQuantity();
|
|
|
586 |
int totalLeft = quantityToBill;
|
|
|
587 |
Set<InventoryItem> inventoryItemsNonSerializedUsed = new HashSet<>();
|
|
|
588 |
if (inventoryItemsNonSerialized != null) {
|
|
|
589 |
for (InventoryItem inventoryItem : inventoryItemsNonSerialized) {
|
|
|
590 |
if (totalLeft > 0) {
|
|
|
591 |
int toUse = Math.min(totalLeft, inventoryItem.getGoodQuantity());
|
|
|
592 |
inventoryItemIdQuantityUsed.put(inventoryItem.getId(), toUse);
|
|
|
593 |
inventoryItem.setGoodQuantity(inventoryItem.getGoodQuantity() - toUse);
|
|
|
594 |
totalLeft = totalLeft - toUse;
|
|
|
595 |
inventoryItemsNonSerializedUsed.add(inventoryItem);
|
|
|
596 |
}
|
|
|
597 |
}
|
|
|
598 |
}
|
| 23650 |
amit.gupta |
599 |
|
| 32145 |
tejbeer |
600 |
if (totalLeft > 0) {
|
|
|
601 |
// not enough quanity for non-serialized
|
|
|
602 |
LOGGER.error("not enough quanity for non-serialized");
|
|
|
603 |
throw new ProfitMandiBusinessException("notEnoughQuantityForNonSerialized", totalLeft, "FFORDR_1005");
|
|
|
604 |
}
|
|
|
605 |
inventoryItemsToBill.put(item.getId(), inventoryItemsNonSerializedUsed);
|
|
|
606 |
}
|
|
|
607 |
}
|
| 23650 |
amit.gupta |
608 |
|
| 32145 |
tejbeer |
609 |
Map<Integer, PriceModel> itemIdMopPriceMap = pricingService.getPurchasePriceMopPriceNotFound(itemIdCustomFofoOrderItemMap.keySet(), fofoId);
|
|
|
610 |
LOGGER.info("itemIdMopMap {}", itemIdMopPriceMap);
|
|
|
611 |
if (accessoriesDeals) {
|
| 32420 |
amit.gupta |
612 |
this.validateDpPrice(fofoId, itemIdMopPriceMap, itemIdCustomFofoOrderItemMap);
|
| 32145 |
tejbeer |
613 |
} else {
|
| 32420 |
amit.gupta |
614 |
this.validateMopPrice(fofoId, itemIdMopPriceMap, itemIdCustomFofoOrderItemMap);
|
| 32145 |
tejbeer |
615 |
}
|
| 23650 |
amit.gupta |
616 |
|
| 32145 |
tejbeer |
617 |
String fofoStoreCode = this.getFofoStoreCode(fofoId);
|
|
|
618 |
String documentNumber = null;
|
|
|
619 |
if (noGST) {
|
|
|
620 |
documentNumber = this.getSecurityDepositNumber(fofoId, fofoStoreCode);
|
| 24275 |
amit.gupta |
621 |
|
| 32145 |
tejbeer |
622 |
} else {
|
|
|
623 |
documentNumber = this.getInvoiceNumber(fofoId, fofoStoreCode);
|
|
|
624 |
}
|
| 22859 |
ashik.ali |
625 |
|
| 32627 |
ranu |
626 |
CustomerAddress customerAddress = null;
|
|
|
627 |
if (customCustomer.getCustomerAddressId() != 0) {
|
|
|
628 |
customerAddress = customer.getCustomerAddress().stream().filter(x -> x.getId() == customCustomer.getCustomerAddressId()).findFirst().get();
|
|
|
629 |
}
|
| 34381 |
vikas.jang |
630 |
FofoOrder fofoOrder = this.createAndGetFofoOrder(customer.getId(), customCustomer.getGstNumber(), fofoId, documentNumber, totalAmount, customCustomer.getCustomerAddressId(), createOrderRequest.getPoId());
|
| 23650 |
amit.gupta |
631 |
|
| 32145 |
tejbeer |
632 |
this.createPaymentOptions(fofoOrder, createOrderRequest.getPaymentOptions());
|
| 23650 |
amit.gupta |
633 |
|
| 32145 |
tejbeer |
634 |
int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(fofoId);
|
| 23650 |
amit.gupta |
635 |
|
| 32145 |
tejbeer |
636 |
Address retailerAddress = addressRepository.selectById(retailerAddressId);
|
| 23650 |
amit.gupta |
637 |
|
| 32145 |
tejbeer |
638 |
Integer stateId = null;
|
| 32634 |
amit.gupta |
639 |
if (customerAddress == null || customerAddress.getState() == null || customerAddress.getState().equals(retailerAddress.getState())) {
|
| 32145 |
tejbeer |
640 |
try {
|
| 32634 |
amit.gupta |
641 |
State state = stateRepository.selectByName(retailerAddress.getState());
|
| 32145 |
tejbeer |
642 |
stateId = Long.valueOf(state.getId()).intValue();
|
|
|
643 |
} catch (Exception e) {
|
|
|
644 |
LOGGER.error("Unable to get state rates");
|
|
|
645 |
}
|
|
|
646 |
}
|
| 23650 |
amit.gupta |
647 |
|
| 32145 |
tejbeer |
648 |
for (CustomFofoOrderItem customFofoOrderItem : createOrderRequest.getFofoOrderItems()) {
|
|
|
649 |
FofoOrderItem fofoOrderItem = this.createAndGetFofoOrderItem(customFofoOrderItem, fofoOrder.getId(), itemMap, inventoryItemsToBill.get(customFofoOrderItem.getItemId()), stateId);
|
| 23650 |
amit.gupta |
650 |
|
| 32816 |
ranu |
651 |
Item item = itemMap.get(customFofoOrderItem.getItemId());
|
|
|
652 |
if (item.getType().equals(ItemType.NON_SERIALIZED)) {
|
|
|
653 |
if (customFofoOrderItem.getCustomSerialNumbers() != null && !customFofoOrderItem.getCustomSerialNumbers().isEmpty()) {
|
|
|
654 |
persistNonSerializedWithCustomSerialNumber(customFofoOrderItem, fofoOrderItem.getId());
|
|
|
655 |
} else {
|
|
|
656 |
LOGGER.info("Custom serial numbers are empty. Not persisting data.");
|
|
|
657 |
}
|
|
|
658 |
}
|
|
|
659 |
|
|
|
660 |
|
| 32145 |
tejbeer |
661 |
Set<InventoryItem> inventoryItems = inventoryItemsToBill.get(customFofoOrderItem.getItemId());
|
| 23650 |
amit.gupta |
662 |
|
| 32145 |
tejbeer |
663 |
this.createFofoLineItem(fofoOrderItem.getId(), inventoryItems, inventoryItemIdQuantityUsed);
|
| 23650 |
amit.gupta |
664 |
|
| 32145 |
tejbeer |
665 |
this.updateCurrentInventorySnapshot(currentInventorySnapshots, fofoId, customFofoOrderItem.getItemId(), customFofoOrderItem.getQuantity());
|
| 23650 |
amit.gupta |
666 |
|
| 32145 |
tejbeer |
667 |
this.updateInventoryItemsAndScanRecord(inventoryItems, fofoId, inventoryItemIdQuantityUsed, fofoOrder.getId());
|
|
|
668 |
}
|
| 23650 |
amit.gupta |
669 |
|
| 32145 |
tejbeer |
670 |
List<FofoOrderItem> fofoItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
| 25647 |
tejbeer |
671 |
|
| 32145 |
tejbeer |
672 |
boolean smartPhone = false;
|
| 32892 |
ranu |
673 |
for (FofoOrderItem fofoOrderItem : fofoItems) {
|
|
|
674 |
Item item = itemRepository.selectById(fofoOrderItem.getItemId());
|
|
|
675 |
|
|
|
676 |
if (item.isSmartPhone()) {
|
|
|
677 |
LOGGER.info("fofoItem {}", fofoOrderItem);
|
| 32145 |
tejbeer |
678 |
smartPhone = true;
|
|
|
679 |
}
|
| 32892 |
ranu |
680 |
}
|
| 31172 |
tejbeer |
681 |
|
| 32892 |
ranu |
682 |
if (!smartPhone) {
|
|
|
683 |
LOGGER.warn("No smartphones found in fofoItems.");
|
| 32145 |
tejbeer |
684 |
}
|
| 31172 |
tejbeer |
685 |
|
| 32892 |
ranu |
686 |
|
| 32145 |
tejbeer |
687 |
if (smartPhone) {
|
|
|
688 |
this.createAndGetHygieneData(fofoOrder.getId(), fofoOrder.getFofoId());
|
|
|
689 |
}
|
|
|
690 |
// insurance calculation is insurance flag is enabled
|
|
|
691 |
//
|
|
|
692 |
if (insuredModels.size() > 0) {
|
|
|
693 |
LOGGER.info("Processing insurane for serialNumbers");
|
|
|
694 |
LOGGER.info("InsuranceModels {}", insuredModels);
|
|
|
695 |
LocalDate customerDateOfBirth = LocalDate.from(createOrderRequest.getCustomer().getDateOfBirth());
|
|
|
696 |
fofoOrder.setDateOfBirth(customerDateOfBirth);
|
|
|
697 |
for (InsuranceModel insuranceModel : insuredModels) {
|
| 34207 |
ranu |
698 |
LOGGER.info("G- {}", insuranceModel.getInsuranceId());
|
|
|
699 |
LOGGER.info("insuranceModel- {}", insuranceModel);
|
| 33715 |
ranu |
700 |
insuranceService.createInsurance(fofoOrder, insuranceModel, false);
|
| 32145 |
tejbeer |
701 |
}
|
|
|
702 |
}
|
| 28339 |
tejbeer |
703 |
|
| 32145 |
tejbeer |
704 |
schemeService.processSchemeOut(fofoOrder.getId(), fofoId);
|
| 31993 |
amit.gupta |
705 |
|
| 32145 |
tejbeer |
706 |
if (createOrderRequest.getPoId() != 0) {
|
|
|
707 |
PendingOrder po = pendingOrderRepository.selectById(createOrderRequest.getPoId());
|
|
|
708 |
po.setBilledAmount(po.getBilledAmount() + totalAmount);
|
| 33520 |
amit.gupta |
709 |
for (CustomFofoOrderItem cfoi : createOrderRequest.getFofoOrderItems()) {
|
| 33399 |
ranu |
710 |
PendingOrderItem poi = pendingOrderItemRepository.selectById(cfoi.getPoiId());
|
|
|
711 |
poi.setStatus(OrderStatus.BILLED);
|
|
|
712 |
poi.setBilledTimestamp(LocalDateTime.now());
|
|
|
713 |
}
|
| 33436 |
ranu |
714 |
po.setStatus(OrderStatus.BILLED);
|
| 32145 |
tejbeer |
715 |
}
|
| 32961 |
amit.gupta |
716 |
//Process scratch
|
|
|
717 |
this.processScratchOffer(fofoOrder);
|
| 29515 |
tejbeer |
718 |
|
| 33795 |
ranu |
719 |
// persist the data of upgrade offer table
|
|
|
720 |
for (CustomFofoOrderItem customFofoOrderItem : createOrderRequest.getFofoOrderItems()) {
|
| 34805 |
ranu |
721 |
if (customFofoOrderItem.getCustomerOfferItemId().size() > 0) {
|
|
|
722 |
for (Integer customerOfferItemId : customFofoOrderItem.getCustomerOfferItemId()) {
|
|
|
723 |
UpgradeOffer upgradeOffer = new UpgradeOffer();
|
|
|
724 |
upgradeOffer.setOrderId(fofoOrder.getId());
|
|
|
725 |
upgradeOffer.setCustomerOfferItemId(customerOfferItemId);
|
|
|
726 |
upgradeOffer.setItemId(customFofoOrderItem.getItemId());
|
| 33795 |
ranu |
727 |
|
| 34805 |
ranu |
728 |
Set<SerialNumberDetail> serialNumberDetails = customFofoOrderItem.getSerialNumberDetails();
|
| 33795 |
ranu |
729 |
|
| 34805 |
ranu |
730 |
if (!customFofoOrderItem.getSerialNumberDetails().isEmpty()) {
|
|
|
731 |
String serialNumber = serialNumberDetails.iterator().next().getSerialNumber();
|
|
|
732 |
upgradeOffer.setSerialNumber(serialNumber);
|
| 33795 |
ranu |
733 |
|
| 34805 |
ranu |
734 |
// Set<String> serialNumbersSet = this.serialNumberDetailsToSerialNumbers(customFofoOrderItem.getSerialNumberDetails());
|
|
|
735 |
// LOGGER.info("serialNumbersSet.toString() {}",serialNumbersSet.toString());
|
|
|
736 |
// upgradeOffer.setSerialNumber(serialNumbersSet.toString());
|
|
|
737 |
} else {
|
|
|
738 |
upgradeOffer.setSerialNumber(null); // Handle case where there is no serial number detail
|
|
|
739 |
}
|
|
|
740 |
upgradeOffer.setCreatedTimestamp(LocalDateTime.now());
|
|
|
741 |
upgradeOffer.setPaymentStatus(UpgradeOfferPaymentStatus.PENDING);
|
|
|
742 |
upgradeOffer.setStatusDescription(UpgradeOfferPaymentStatus.PENDING.getValue());
|
|
|
743 |
upgradeOfferRepository.persist(upgradeOffer);
|
| 33795 |
ranu |
744 |
}
|
| 34805 |
ranu |
745 |
|
| 33795 |
ranu |
746 |
}
|
|
|
747 |
}
|
|
|
748 |
|
|
|
749 |
// enable it fo upsell call
|
| 33715 |
ranu |
750 |
if (smartPhone) {
|
|
|
751 |
if (fofoOrder.getId() > 0) {
|
|
|
752 |
List<InsurancePolicy> insurancePolicies = insurancePolicyRepository
|
|
|
753 |
.selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
|
|
|
754 |
if (insurancePolicies.isEmpty()) {
|
|
|
755 |
List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
756 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
757 |
Item item = itemRepository.selectById(fofoOrderItem.getItemId());
|
|
|
758 |
if (item.isSmartPhone()) {
|
|
|
759 |
UpSaleOrder upSaleOrder = new UpSaleOrder();
|
|
|
760 |
upSaleOrder.setCreatedTimestamp(LocalDateTime.now());
|
|
|
761 |
upSaleOrder.setOrderId(fofoOrder.getId());
|
| 33718 |
ranu |
762 |
upSaleOrder.setFofoId(fofoOrder.getFofoId());
|
| 33715 |
ranu |
763 |
upSaleOrderRepository.persist(upSaleOrder);
|
|
|
764 |
break; // Exit the loop after persisting the UpSaleOrder for the first smartphone
|
|
|
765 |
}
|
|
|
766 |
}
|
|
|
767 |
}
|
|
|
768 |
}
|
|
|
769 |
}
|
| 33674 |
ranu |
770 |
|
| 33873 |
ranu |
771 |
// Update Partner Opening Stock current qty
|
| 33899 |
ranu |
772 |
if (fofoOrder.getId() > 0) {
|
| 33873 |
ranu |
773 |
List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
774 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
775 |
Item item = itemRepository.selectById(fofoOrderItem.getItemId());
|
| 33899 |
ranu |
776 |
smartCartService.minusOpeningStock(item.getId(), fofoOrder.getFofoId(), fofoOrderItem.getQuantity());
|
| 33873 |
ranu |
777 |
}
|
|
|
778 |
}
|
|
|
779 |
|
|
|
780 |
|
| 32961 |
amit.gupta |
781 |
return fofoOrder.getId();
|
|
|
782 |
}
|
|
|
783 |
|
| 33665 |
ranu |
784 |
@Override
|
|
|
785 |
public void processScratchOffer(FofoOrder fofoOrder) throws ProfitMandiBusinessException {
|
|
|
786 |
boolean isSmartPhonePurchased = false;
|
|
|
787 |
float maxPurchaseValue = 0;
|
|
|
788 |
List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
789 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
790 |
Item item = itemRepository.selectById(fofoOrderItem.getItemId());
|
|
|
791 |
|
|
|
792 |
if (item.isSmartPhone()) {
|
|
|
793 |
LOGGER.info("fofoItem {}", fofoOrderItem);
|
|
|
794 |
isSmartPhonePurchased = true;
|
|
|
795 |
maxPurchaseValue = Math.max(fofoOrderItem.getSellingPrice(), maxPurchaseValue);
|
|
|
796 |
|
|
|
797 |
}
|
|
|
798 |
}
|
|
|
799 |
LocalDate startDate = ProfitMandiConstants.SCRATCH_OFFER_START_DATE;
|
|
|
800 |
LocalDate endDate = ProfitMandiConstants.SCRATCH_OFFER_END_DATE;
|
|
|
801 |
boolean specificPriceOffer = ProfitMandiConstants.SPECIFIC_PRICE_OFFER;
|
|
|
802 |
boolean randomOffer = ProfitMandiConstants.RANDOM_OFFER;
|
|
|
803 |
|
|
|
804 |
if (isSmartPhonePurchased) {
|
|
|
805 |
|
|
|
806 |
if (LocalDateTime.now().isAfter(startDate.atStartOfDay()) && LocalDateTime.now().isBefore(endDate.atTime(Utils.MAX_TIME))) {
|
|
|
807 |
Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
|
|
|
808 |
try {
|
|
|
809 |
this.sendAppDownloadBillingOffer(customer.getMobileNumber());
|
|
|
810 |
} catch (Exception e) {
|
|
|
811 |
// TODO Auto-generated catch block
|
|
|
812 |
e.printStackTrace();
|
|
|
813 |
}
|
|
|
814 |
if (specificPriceOffer) {
|
| 33899 |
ranu |
815 |
this.createSpecificPriceScratchOffer(fofoOrder.getInvoiceNumber(), fofoOrder.getCustomerId(), fofoOrder.getFofoId(), maxPurchaseValue);
|
| 33665 |
ranu |
816 |
} else if (randomOffer) {
|
|
|
817 |
this.createRandomScratchOffer(fofoOrder.getInvoiceNumber(), fofoOrder.getCustomerId());
|
|
|
818 |
LOGGER.info("randomOffer {}", randomOffer);
|
|
|
819 |
} else {
|
|
|
820 |
this.createScratchOffer(fofoOrder.getFofoId(), fofoOrder.getInvoiceNumber(), fofoOrder.getCustomerId());
|
|
|
821 |
}
|
|
|
822 |
|
|
|
823 |
}
|
|
|
824 |
}
|
|
|
825 |
}
|
|
|
826 |
|
|
|
827 |
@Override
|
| 33899 |
ranu |
828 |
public ScratchedGift getSelectedGift(double purchaseAmount, int fofoId) throws ProfitMandiBusinessException {
|
| 34351 |
ranu |
829 |
Map<ScratchedGift, Long> scratchOfferCountMap = scratchOfferRepository.countOffersByDateRange(
|
|
|
830 |
ProfitMandiConstants.SCRATCH_OFFER_START_DATE, ProfitMandiConstants.SCRATCH_OFFER_END_DATE
|
|
|
831 |
);
|
|
|
832 |
LOGGER.info("scratchOfferCountMap {}", scratchOfferCountMap);
|
|
|
833 |
|
|
|
834 |
LocalDateTime startDateTime = ProfitMandiConstants.SCRATCH_OFFER_START_DATE.atStartOfDay();
|
| 34365 |
ranu |
835 |
LocalDateTime endDateTime = ProfitMandiConstants.SCRATCH_OFFER_START_DATE.atTime(LocalTime.MAX);
|
| 34351 |
ranu |
836 |
|
| 34365 |
ranu |
837 |
LOGGER.info("start date {}", startDateTime);
|
|
|
838 |
LOGGER.info("end date {}", endDateTime);
|
|
|
839 |
|
| 33899 |
ranu |
840 |
RandomCollection<ScratchedGift> giftRandomCollection = createDynamicGiftSeries(scratchOfferCountMap, purchaseAmount, fofoId);
|
| 34351 |
ranu |
841 |
|
| 33665 |
ranu |
842 |
if (giftRandomCollection.size() > 0) {
|
| 34340 |
ranu |
843 |
ScratchedGift selectedGift = giftRandomCollection.next();
|
|
|
844 |
|
| 34353 |
ranu |
845 |
// Ensure one LED for 175139615 and one Oven for 175139583
|
| 34351 |
ranu |
846 |
if (selectedGift == ScratchedGift.LED || selectedGift == ScratchedGift.MICROWAVE_OVEN) {
|
| 34340 |
ranu |
847 |
if (!PREMIUM_ELIGIBLE_PARTNERS.contains(fofoId)) {
|
|
|
848 |
LOGGER.info("Partner {} not eligible for {}", fofoId, selectedGift);
|
| 34351 |
ranu |
849 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF; // Default alternate gift
|
| 34340 |
ranu |
850 |
}
|
|
|
851 |
|
| 34351 |
ranu |
852 |
// Restrict LED to Partner 175139615 and Oven to Partner 175139583
|
|
|
853 |
if ((selectedGift == ScratchedGift.LED && fofoId != 175139615) ||
|
|
|
854 |
(selectedGift == ScratchedGift.MICROWAVE_OVEN && fofoId != 175139583)) {
|
|
|
855 |
LOGGER.info("Partner {} not eligible for {}", fofoId, selectedGift);
|
|
|
856 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
857 |
}
|
|
|
858 |
|
| 34340 |
ranu |
859 |
// Ensure only one LED and one Microwave Oven per day
|
| 34351 |
ranu |
860 |
long ledCount = scratchOfferCountMap.getOrDefault(ScratchedGift.LED, 0L);
|
|
|
861 |
long ovenCount = scratchOfferCountMap.getOrDefault(ScratchedGift.MICROWAVE_OVEN, 0L);
|
|
|
862 |
if ((selectedGift == ScratchedGift.LED || selectedGift == ScratchedGift.MICROWAVE_OVEN)
|
|
|
863 |
&& (ledCount > 0 && ovenCount > 0)) {
|
|
|
864 |
LOGGER.info("Both LED and Microwave Oven already given today.");
|
| 34340 |
ranu |
865 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
866 |
}
|
| 34354 |
ranu |
867 |
|
|
|
868 |
if ((selectedGift == ScratchedGift.LED && ledCount > 0)) {
|
|
|
869 |
LOGGER.info("LED already given today.");
|
|
|
870 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
871 |
}
|
| 34367 |
ranu |
872 |
|
|
|
873 |
if ((selectedGift == ScratchedGift.LED)) {
|
|
|
874 |
LOGGER.info("LED already given today.");
|
|
|
875 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
876 |
}
|
|
|
877 |
|
| 34354 |
ranu |
878 |
if ((selectedGift == ScratchedGift.MICROWAVE_OVEN && ovenCount > 0)) {
|
|
|
879 |
LOGGER.info("Oven already given today.");
|
|
|
880 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
881 |
}
|
| 34340 |
ranu |
882 |
}
|
|
|
883 |
|
| 34353 |
ranu |
884 |
// Ensure only one Neckband per partner per day
|
| 34351 |
ranu |
885 |
if (selectedGift == ScratchedGift.NECK_BAND) {
|
|
|
886 |
List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startDateTime, endDateTime, 0, 0);
|
|
|
887 |
List<String> invoiceNumbers = fofoOrders.stream().map(FofoOrder::getInvoiceNumber).collect(Collectors.toList());
|
|
|
888 |
List<ScratchOffer> offers = scratchOfferRepository.selectByInvoiceNumbers(invoiceNumbers);
|
|
|
889 |
LOGGER.info("offers for partner {}", offers);
|
| 34340 |
ranu |
890 |
|
| 34474 |
aman.kumar |
891 |
boolean neckbandGivenToday = offers.stream().anyMatch(offer -> offer.getOfferName().equals(ScratchedGift.NECK_BAND));
|
| 34351 |
ranu |
892 |
if (neckbandGivenToday) {
|
|
|
893 |
LOGGER.info("Neckband already given today for partner {}", fofoId);
|
| 34340 |
ranu |
894 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
|
|
895 |
}
|
|
|
896 |
}
|
|
|
897 |
|
|
|
898 |
return selectedGift;
|
| 33665 |
ranu |
899 |
}
|
| 34351 |
ranu |
900 |
|
|
|
901 |
return ScratchedGift.ACCESSORIES_50_PERCENT_OFF;
|
| 33665 |
ranu |
902 |
}
|
|
|
903 |
|
| 34340 |
ranu |
904 |
|
| 34351 |
ranu |
905 |
public RandomCollection<ScratchedGift> createDynamicGiftSeries(Map<ScratchedGift, Long> soldGiftContMap, Double sellingPrice, int fofoId) throws ProfitMandiBusinessException {
|
| 33665 |
ranu |
906 |
int index = 0;
|
|
|
907 |
RandomCollection<ScratchedGift> randomCollection = new RandomCollection<>();
|
| 33899 |
ranu |
908 |
PartnerType partnerType = partnerTypeChangeService.getTypeOnDate(fofoId, LocalDate.now());
|
|
|
909 |
LOGGER.info("partnerType {}", partnerType);
|
|
|
910 |
|
| 33895 |
ranu |
911 |
if (partnerType.equals(PartnerType.BRONZE)) {
|
| 33899 |
ranu |
912 |
LOGGER.info("partnerType if- {}", partnerType);
|
| 33895 |
ranu |
913 |
sellingPrice = 0.0;
|
|
|
914 |
}
|
| 33899 |
ranu |
915 |
|
|
|
916 |
for (int i = 0; i < PRICE_RANGE.size(); i++) {
|
|
|
917 |
Double price = PRICE_RANGE.get(i);
|
| 34351 |
ranu |
918 |
Double nextPrice = Double.MAX_VALUE;
|
|
|
919 |
if (i != PRICE_RANGE.size() - 1) {
|
|
|
920 |
nextPrice = PRICE_RANGE.get(i + 1);
|
|
|
921 |
}
|
| 33899 |
ranu |
922 |
if (sellingPrice >= price && sellingPrice < nextPrice) {
|
| 33665 |
ranu |
923 |
int divisor = PRICE_RANGE.size() - index;
|
| 33899 |
ranu |
924 |
LOGGER.info("Processing price range: {}, sellingPrice: {}", price, sellingPrice);
|
|
|
925 |
|
| 33665 |
ranu |
926 |
for (ScratchedGift gift : GIFT_SERIES.get(price)) {
|
| 34351 |
ranu |
927 |
int remainingQty = GIFT_QUANTITIES.get(gift) - soldGiftContMap.getOrDefault(gift, 0L).intValue();
|
| 33899 |
ranu |
928 |
LOGGER.info("Checking gift: {}, remainingQty: {}", gift, remainingQty);
|
|
|
929 |
|
| 33897 |
ranu |
930 |
if (remainingQty > 0) {
|
|
|
931 |
int weight = (remainingQty > divisor) ? remainingQty / divisor : remainingQty;
|
| 34351 |
ranu |
932 |
randomCollection.add(weight, gift);
|
|
|
933 |
LOGGER.info("Added gift: {}, weight: {}", gift, weight);
|
| 33665 |
ranu |
934 |
}
|
|
|
935 |
}
|
| 34351 |
ranu |
936 |
break; // Exit the loop once the correct price range is processed
|
| 33665 |
ranu |
937 |
}
|
| 33897 |
ranu |
938 |
index++;
|
| 33665 |
ranu |
939 |
}
|
| 33899 |
ranu |
940 |
|
| 34351 |
ranu |
941 |
// If no gifts were added, log and handle potential issues here
|
| 33899 |
ranu |
942 |
if (randomCollection.size() == 0) {
|
|
|
943 |
LOGGER.info("No gifts added for sellingPrice: {} in createDynamicGiftSeries", sellingPrice);
|
|
|
944 |
}
|
|
|
945 |
|
| 34351 |
ranu |
946 |
LOGGER.info("randomCollectionSize {}, partnerType {}, sellingPrice {}", randomCollection.size(), partnerType, sellingPrice);
|
| 33665 |
ranu |
947 |
return randomCollection;
|
|
|
948 |
}
|
|
|
949 |
|
| 33899 |
ranu |
950 |
|
|
|
951 |
|
| 33665 |
ranu |
952 |
/*static {
|
| 32960 |
amit.gupta |
953 |
RandomCollection<ScratchedGift> map1 = new RandomCollection<ScratchedGift>().
|
|
|
954 |
add(100d, ScratchedGift.GIFT_BOWL);
|
|
|
955 |
GIFT_SERIES.put(0.0, map1);
|
|
|
956 |
//Map<ScratchedGift, Double> map2 = new HashMap<>();
|
|
|
957 |
RandomCollection<ScratchedGift> map2 = new RandomCollection<ScratchedGift>()
|
|
|
958 |
.add(40d, ScratchedGift.GIFT_BOWL)
|
|
|
959 |
.add(20d, ScratchedGift.NECK_BAND)
|
|
|
960 |
.add(30d, ScratchedGift.FLASKNMUG)
|
|
|
961 |
.add(10d, ScratchedGift.ELECTRIC_KETTLE);
|
|
|
962 |
GIFT_SERIES.put(10001.0, map2);
|
|
|
963 |
RandomCollection<ScratchedGift> map3 = new RandomCollection<ScratchedGift>()
|
|
|
964 |
.add(25d, ScratchedGift.GIFT_BOWL)
|
|
|
965 |
.add(30d, ScratchedGift.NECK_BAND)
|
|
|
966 |
.add(10d, ScratchedGift.SPEAKER)
|
|
|
967 |
.add(25d, ScratchedGift.FLASKNMUG)
|
|
|
968 |
.add(10d, ScratchedGift.ELECTRIC_KETTLE);
|
|
|
969 |
GIFT_SERIES.put(18001.0, map3);
|
|
|
970 |
RandomCollection<ScratchedGift> map4 = new RandomCollection<ScratchedGift>()
|
|
|
971 |
.add(30d, ScratchedGift.NECK_BAND)
|
|
|
972 |
.add(20d, ScratchedGift.SPEAKER)
|
|
|
973 |
.add(20d, ScratchedGift.FLASKNMUG)
|
|
|
974 |
.add(30d, ScratchedGift.ELECTRIC_KETTLE);
|
|
|
975 |
GIFT_SERIES.put(25001.0, map4);
|
|
|
976 |
RandomCollection<ScratchedGift> map5 = new RandomCollection<ScratchedGift>()
|
|
|
977 |
.add(40d, ScratchedGift.SPEAKER)
|
|
|
978 |
.add(60d, ScratchedGift.SMART_WATCH);
|
| 32892 |
ranu |
979 |
|
| 32960 |
amit.gupta |
980 |
GIFT_SERIES.put(50001.0, map5);
|
| 33665 |
ranu |
981 |
}*/
|
| 32892 |
ranu |
982 |
|
| 32960 |
amit.gupta |
983 |
|
| 33895 |
ranu |
984 |
private void createSpecificPriceScratchOffer(String invoiceNumber, int customerId, int fofoId, float purchaseAmount) throws ProfitMandiBusinessException {
|
| 33899 |
ranu |
985 |
ScratchedGift selectedGift = getSelectedGift(purchaseAmount, fofoId);
|
| 33142 |
ranu |
986 |
List<ScratchOffer> scratchOffers = scratchOfferRepository.selectBycCustomerIdAndDate(customerId, ProfitMandiConstants.SCRATCH_OFFER_START_DATE, ProfitMandiConstants.SCRATCH_OFFER_END_DATE);
|
|
|
987 |
if (scratchOffers.size() == 0) {
|
|
|
988 |
ScratchOffer so2 = new ScratchOffer();
|
|
|
989 |
so2.setInvoiceNumber(invoiceNumber);
|
|
|
990 |
so2.setScratched(false);
|
|
|
991 |
so2.setCreatedTimestamp(LocalDateTime.now());
|
| 33679 |
ranu |
992 |
so2.setExpiredTimestamp(ProfitMandiConstants.SCRATCH_OFFER_END_DATE.plusDays(1).atTime(LocalTime.MAX));
|
| 34474 |
aman.kumar |
993 |
so2.setOfferName(String.valueOf(selectedGift));
|
| 33142 |
ranu |
994 |
so2.setCustomerId(customerId);
|
|
|
995 |
so2.setUnlockedAt(LocalDateTime.now());
|
|
|
996 |
scratchOfferRepository.persist(so2);
|
|
|
997 |
}
|
|
|
998 |
}
|
| 32960 |
amit.gupta |
999 |
|
| 33142 |
ranu |
1000 |
private void createRandomScratchOffer(String invoiceNumber, int customerId) {
|
|
|
1001 |
ScratchedGift selectedGift = getScratchedGiftRandomAccordingQuantity(customerId);
|
| 32892 |
ranu |
1002 |
List<ScratchOffer> scratchOffers = scratchOfferRepository.selectBycCustomerIdAndDate(customerId, ProfitMandiConstants.SCRATCH_OFFER_START_DATE, ProfitMandiConstants.SCRATCH_OFFER_END_DATE);
|
|
|
1003 |
if (scratchOffers.size() == 0) {
|
|
|
1004 |
ScratchOffer so2 = new ScratchOffer();
|
|
|
1005 |
so2.setInvoiceNumber(invoiceNumber);
|
|
|
1006 |
so2.setScratched(false);
|
|
|
1007 |
so2.setCreatedTimestamp(LocalDateTime.now());
|
| 33679 |
ranu |
1008 |
so2.setExpiredTimestamp(ProfitMandiConstants.SCRATCH_OFFER_END_DATE.plusDays(1).atTime(LocalTime.MAX));
|
| 34474 |
aman.kumar |
1009 |
so2.setOfferName(String.valueOf(selectedGift));
|
| 32892 |
ranu |
1010 |
so2.setCustomerId(customerId);
|
|
|
1011 |
so2.setUnlockedAt(LocalDateTime.now());
|
|
|
1012 |
scratchOfferRepository.persist(so2);
|
|
|
1013 |
}
|
|
|
1014 |
}
|
|
|
1015 |
|
| 33247 |
ranu |
1016 |
private ScratchedGift getScratchedGiftRandom(int fofoId, int customerId) throws ProfitMandiBusinessException {
|
| 32218 |
tejbeer |
1017 |
Map<Integer, ScratchedGift> giftSeries = new HashMap<>();
|
|
|
1018 |
giftSeries.put(1, ScratchedGift.MINI_CHOPPER);
|
|
|
1019 |
giftSeries.put(2, ScratchedGift.FRUIT_JUICER);
|
|
|
1020 |
giftSeries.put(3, ScratchedGift.STEAM_IRON);
|
|
|
1021 |
|
|
|
1022 |
|
| 32579 |
amit.gupta |
1023 |
List<FofoOrder> fofoOrders = fofoOrderRepository.selectByFofoIdBetweenCreatedTimeStamp(fofoId, ProfitMandiConstants.SCRATCH_OFFER_START_DATE.atStartOfDay(),
|
|
|
1024 |
ProfitMandiConstants.SCRATCH_OFFER_END_DATE.atTime(Utils.MAX_TIME));
|
| 32218 |
tejbeer |
1025 |
|
|
|
1026 |
ScratchedGift gift = ScratchedGift.BLNT;
|
|
|
1027 |
|
|
|
1028 |
Random random = new Random();
|
| 32672 |
amit.gupta |
1029 |
int rand;
|
| 32218 |
tejbeer |
1030 |
while (true) {
|
|
|
1031 |
rand = random.nextInt(4);
|
|
|
1032 |
if (rand != 0) break;
|
|
|
1033 |
}
|
|
|
1034 |
if (fofoOrders.isEmpty()) {
|
|
|
1035 |
gift = giftSeries.get(rand);
|
|
|
1036 |
} else {
|
|
|
1037 |
|
|
|
1038 |
List<String> invoiceNumbers = fofoOrders.stream().filter(x -> x.getCancelledTimestamp() == null).map(x -> x.getInvoiceNumber()).collect(Collectors.toList());
|
|
|
1039 |
|
|
|
1040 |
List<ScratchOffer> scratchOffers = scratchOfferRepository.selectByInvoiceNumbers(invoiceNumbers);
|
|
|
1041 |
if (scratchOffers.isEmpty()) {
|
|
|
1042 |
gift = giftSeries.get(rand);
|
|
|
1043 |
} else {
|
|
|
1044 |
List<ScratchOffer> bigGifts = scratchOffers.stream().filter(x -> !x.getOfferName().equals(ScratchedGift.BLNT) && !x.getOfferName().equals(ScratchedGift.EW)).collect(Collectors.toList());
|
|
|
1045 |
if (bigGifts.size() <= 10) {
|
|
|
1046 |
List<Integer> scratchCustomerIds = scratchOffers.stream().map(x -> x.getCustomerId()).collect(Collectors.toList());
|
|
|
1047 |
if (scratchCustomerIds.contains(customerId)) {
|
|
|
1048 |
|
|
|
1049 |
|
|
|
1050 |
gift = ScratchedGift.BLNT;
|
|
|
1051 |
|
|
|
1052 |
LOGGER.info("gift2 {}", gift);
|
|
|
1053 |
|
|
|
1054 |
} else {
|
|
|
1055 |
|
|
|
1056 |
int miniChopper = (int) bigGifts.stream().filter(x -> x.getOfferName().equals(ScratchedGift.MINI_CHOPPER)).count();
|
|
|
1057 |
int fruitJuicer = (int) bigGifts.stream().filter(x -> x.getOfferName().equals(ScratchedGift.FRUIT_JUICER)).count();
|
|
|
1058 |
int streanIron = (int) bigGifts.stream().filter(x -> x.getOfferName().equals(ScratchedGift.STEAM_IRON)).count();
|
|
|
1059 |
|
|
|
1060 |
if (rand == 1) {
|
|
|
1061 |
if (miniChopper < 4) {
|
|
|
1062 |
LOGGER.info("miniChopper {}", miniChopper);
|
|
|
1063 |
|
|
|
1064 |
|
|
|
1065 |
gift = giftSeries.get(rand);
|
|
|
1066 |
}
|
|
|
1067 |
}
|
|
|
1068 |
|
|
|
1069 |
if (rand == 2) {
|
|
|
1070 |
if (fruitJuicer < 3) {
|
|
|
1071 |
|
|
|
1072 |
LOGGER.info("fruitJuicer {}", fruitJuicer);
|
|
|
1073 |
|
|
|
1074 |
gift = giftSeries.get(rand);
|
|
|
1075 |
}
|
|
|
1076 |
}
|
|
|
1077 |
|
|
|
1078 |
if (rand == 3) {
|
|
|
1079 |
if (streanIron < 3) {
|
|
|
1080 |
|
|
|
1081 |
LOGGER.info("streanIron {}", streanIron);
|
|
|
1082 |
|
|
|
1083 |
|
|
|
1084 |
gift = giftSeries.get(rand);
|
|
|
1085 |
|
|
|
1086 |
}
|
|
|
1087 |
}
|
|
|
1088 |
|
|
|
1089 |
LOGGER.info("gift4 {}", gift);
|
|
|
1090 |
}
|
|
|
1091 |
}
|
|
|
1092 |
}
|
|
|
1093 |
|
|
|
1094 |
|
|
|
1095 |
}
|
| 32586 |
ranu |
1096 |
return gift;
|
| 32145 |
tejbeer |
1097 |
}
|
| 29515 |
tejbeer |
1098 |
|
| 33142 |
ranu |
1099 |
private ScratchedGift getScratchedGiftRandomAccordingQuantity(int customerId) {
|
|
|
1100 |
RandomCollection<ScratchedGift> map1 = new RandomCollection<ScratchedGift>().
|
|
|
1101 |
add(50d, ScratchedGift.SOLOR_LAMP)
|
|
|
1102 |
.add(100d, ScratchedGift.BLUETOOTH_SPEAKER)
|
|
|
1103 |
.add(150d, ScratchedGift.RED_WATER_BOTTLE)
|
|
|
1104 |
.add(200d, ScratchedGift.GIFT_BOWL)
|
|
|
1105 |
.add(100d, ScratchedGift.EARBUDS);
|
|
|
1106 |
|
| 33665 |
ranu |
1107 |
ScratchedGift gift;
|
| 33142 |
ranu |
1108 |
|
| 33665 |
ranu |
1109 |
List<ScratchOffer> lastScratchOffers = scratchOfferRepository.selectBycCustomerIdAndDate(customerId, ProfitMandiConstants.LAST_SCRATCH_OFFER_START_DATE, ProfitMandiConstants.LAST_SCRATCH_OFFER_END_DATE);
|
|
|
1110 |
|
|
|
1111 |
if (lastScratchOffers.isEmpty()) {
|
|
|
1112 |
gift = map1.next();
|
|
|
1113 |
} else {
|
|
|
1114 |
gift = ScratchedGift.RED_WATER_BOTTLE;
|
|
|
1115 |
LOGGER.info("RED_WATER_BOTTLE {}", gift);
|
| 33142 |
ranu |
1116 |
}
|
|
|
1117 |
return gift;
|
|
|
1118 |
}
|
|
|
1119 |
|
| 32145 |
tejbeer |
1120 |
private HygieneData createAndGetHygieneData(int id, int fofoId) {
|
|
|
1121 |
HygieneData hygieneData = new HygieneData();
|
|
|
1122 |
hygieneData.setOrderId(id);
|
|
|
1123 |
hygieneData.setFofoId(fofoId);
|
|
|
1124 |
hygieneData.setCreatedTimestamp(LocalDateTime.now());
|
|
|
1125 |
hygieneDataRepository.persist(hygieneData);
|
| 25640 |
tejbeer |
1126 |
|
| 32145 |
tejbeer |
1127 |
return hygieneData;
|
|
|
1128 |
}
|
| 25640 |
tejbeer |
1129 |
|
| 33665 |
ranu |
1130 |
|
| 32145 |
tejbeer |
1131 |
@Override
|
|
|
1132 |
public String getInvoiceNumber(int fofoId, String fofoStoreCode) {
|
|
|
1133 |
InvoiceNumberGenerationSequence invoiceNumberGenerationSequence = null;
|
|
|
1134 |
try {
|
|
|
1135 |
invoiceNumberGenerationSequence = invoiceNumberGenerationSequenceRepository.selectByFofoId(fofoId);
|
|
|
1136 |
invoiceNumberGenerationSequence.setSequence(invoiceNumberGenerationSequence.getSequence() + 1);
|
|
|
1137 |
} catch (ProfitMandiBusinessException profitMandiBusinessException) {
|
|
|
1138 |
invoiceNumberGenerationSequence = new InvoiceNumberGenerationSequence();
|
|
|
1139 |
invoiceNumberGenerationSequence.setFofoId(fofoId);
|
|
|
1140 |
invoiceNumberGenerationSequence.setPrefix(fofoStoreCode);
|
|
|
1141 |
invoiceNumberGenerationSequence.setSequence(1);
|
|
|
1142 |
}
|
|
|
1143 |
invoiceNumberGenerationSequenceRepository.persist(invoiceNumberGenerationSequence);
|
|
|
1144 |
return invoiceNumberGenerationSequence.getPrefix() + "/" + invoiceNumberGenerationSequence.getSequence();
|
|
|
1145 |
}
|
| 24275 |
amit.gupta |
1146 |
|
| 32145 |
tejbeer |
1147 |
private String getSecurityDepositNumber(int fofoId, String fofoStoreCode) {
|
|
|
1148 |
InvoiceNumberGenerationSequence invoiceNumberGenerationSequence = null;
|
|
|
1149 |
try {
|
|
|
1150 |
invoiceNumberGenerationSequence = invoiceNumberGenerationSequenceRepository.selectByFofoId(fofoId);
|
|
|
1151 |
invoiceNumberGenerationSequence.setChallanNumberSequence(invoiceNumberGenerationSequence.getChallanNumberSequence() + 1);
|
|
|
1152 |
} catch (ProfitMandiBusinessException profitMandiBusinessException) {
|
|
|
1153 |
invoiceNumberGenerationSequence = new InvoiceNumberGenerationSequence();
|
|
|
1154 |
invoiceNumberGenerationSequence.setFofoId(fofoId);
|
|
|
1155 |
invoiceNumberGenerationSequence.setPrefix(fofoStoreCode);
|
|
|
1156 |
invoiceNumberGenerationSequence.setChallanNumberSequence(1);
|
|
|
1157 |
}
|
|
|
1158 |
invoiceNumberGenerationSequenceRepository.persist(invoiceNumberGenerationSequence);
|
|
|
1159 |
return invoiceNumberGenerationSequence.getPrefix() + "/SEC" + invoiceNumberGenerationSequence.getChallanNumberSequence();
|
|
|
1160 |
}
|
| 24226 |
amit.gupta |
1161 |
|
| 32145 |
tejbeer |
1162 |
private Set<String> serialNumberDetailsToSerialNumbers(Set<SerialNumberDetail> serialNumberDetails) {
|
|
|
1163 |
Set<String> serialNumbers = new HashSet<>();
|
|
|
1164 |
for (SerialNumberDetail serialNumberDetail : serialNumberDetails) {
|
|
|
1165 |
if (serialNumberDetail.getSerialNumber() != null && !serialNumberDetail.getSerialNumber().isEmpty()) {
|
|
|
1166 |
serialNumbers.add(serialNumberDetail.getSerialNumber());
|
|
|
1167 |
}
|
|
|
1168 |
}
|
|
|
1169 |
return serialNumbers;
|
|
|
1170 |
}
|
| 23650 |
amit.gupta |
1171 |
|
| 32145 |
tejbeer |
1172 |
@Override
|
|
|
1173 |
public InvoicePdfModel getInvoicePdfModel(int orderId) throws ProfitMandiBusinessException {
|
|
|
1174 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(orderId);
|
|
|
1175 |
return this.getInvoicePdfModel(fofoOrder);
|
|
|
1176 |
}
|
| 23650 |
amit.gupta |
1177 |
|
| 32145 |
tejbeer |
1178 |
@Override
|
|
|
1179 |
@Cacheable(value = "order.dummymodel", cacheManager = "oneDayCacheManager")
|
|
|
1180 |
public InvoicePdfModel getDummyPdfModel(String serialNumber) throws ProfitMandiBusinessException {
|
|
|
1181 |
List<WarehouseInventoryItem> warehouseInventoryItems = warehouseInventoryItemRepository.selectWarehouseInventoryItemBySerailNumbers(Arrays.asList(serialNumber));
|
|
|
1182 |
if (warehouseInventoryItems.size() > 0) {
|
|
|
1183 |
WarehouseInventoryItem warehouseInventoryItem = warehouseInventoryItems.get(0);
|
|
|
1184 |
int currentQuantity = warehouseInventoryItems.get(0).getCurrentQuantity();
|
|
|
1185 |
if (currentQuantity > 0) {
|
|
|
1186 |
throw new ProfitMandiBusinessException("Serial Number", serialNumber, "Serial Number exist in our warehouse");
|
|
|
1187 |
} else {
|
|
|
1188 |
try {
|
|
|
1189 |
InventoryItem inventoryItem = inventoryItemRepository.selectBySerialNumber(serialNumber);
|
|
|
1190 |
if (inventoryItem.getGoodQuantity() > 0) {
|
|
|
1191 |
throw new ProfitMandiBusinessException("Serial Number", serialNumber, "Serial Number is not yet billed by the partner");
|
|
|
1192 |
} else {
|
|
|
1193 |
List<ScanRecord> scanRecords = scanRecordRepository.selectByInventoryItemId(inventoryItem.getId());
|
|
|
1194 |
Optional<ScanRecord> scanRecord = scanRecords.stream().filter(x -> x.getOrderId() != 0).findFirst();
|
|
|
1195 |
if (scanRecord.isPresent()) {
|
|
|
1196 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(scanRecord.get().getOrderId());
|
|
|
1197 |
orderIdsConsumed.add(fofoOrder.getId());
|
|
|
1198 |
return this.getInvoicePdfModel(fofoOrder);
|
|
|
1199 |
} else {
|
|
|
1200 |
throw new ProfitMandiBusinessException("Serial Number", serialNumber, "Serial Number returned by partner, but in transit");
|
|
|
1201 |
}
|
|
|
1202 |
}
|
|
|
1203 |
} catch (Exception e) {
|
|
|
1204 |
int itemId = warehouseInventoryItem.getItemId();
|
|
|
1205 |
if (serialNumberOrderIdMap.containsKey(serialNumber)) {
|
|
|
1206 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(serialNumberOrderIdMap.get(serialNumber));
|
|
|
1207 |
InvoicePdfModel pdfModel = this.getInvoicePdfModel(fofoOrder.getId());
|
|
|
1208 |
this.modifyDummyModel(fofoOrder, pdfModel, itemId, serialNumber);
|
|
|
1209 |
return pdfModel;
|
|
|
1210 |
}
|
|
|
1211 |
// Map this serialNumber for dummy billing
|
|
|
1212 |
LocalDateTime grnDate = warehouseInventoryItem.getCreated();
|
|
|
1213 |
Random random = new Random();
|
|
|
1214 |
int randomDays = random.ints(2, 15).findFirst().getAsInt();
|
|
|
1215 |
LocalDateTime saleDate = grnDate.plusDays(randomDays);
|
|
|
1216 |
if (saleDate.isAfter(LocalDate.now().atStartOfDay())) {
|
|
|
1217 |
saleDate = LocalDateTime.now().minusDays(2);
|
|
|
1218 |
}
|
|
|
1219 |
Random offsetRandom = new Random();
|
|
|
1220 |
int offset = offsetRandom.ints(2, 100).findFirst().getAsInt();
|
|
|
1221 |
FofoOrder fofoOrder = fofoOrderRepository.selectFirstOrderAfterDate(saleDate, offset);
|
|
|
1222 |
while (orderIdsConsumed.contains(fofoOrder.getId())) {
|
|
|
1223 |
Random offsetRandom2 = new Random();
|
|
|
1224 |
int offset2 = offsetRandom2.ints(2, 100).findFirst().getAsInt();
|
|
|
1225 |
FofoOrder fofoOrder2 = fofoOrderRepository.selectFirstOrderAfterDate(saleDate, offset2);
|
|
|
1226 |
if (fofoOrder2 != null) {
|
|
|
1227 |
fofoOrder = fofoOrder2;
|
|
|
1228 |
}
|
|
|
1229 |
}
|
|
|
1230 |
InvoicePdfModel pdfModel = this.getInvoicePdfModel(fofoOrder.getId());
|
|
|
1231 |
orderIdsConsumed.add(fofoOrder.getId());
|
|
|
1232 |
this.modifyDummyModel(fofoOrder, pdfModel, itemId, serialNumber);
|
|
|
1233 |
return pdfModel;
|
| 27516 |
amit.gupta |
1234 |
|
| 32145 |
tejbeer |
1235 |
}
|
|
|
1236 |
}
|
|
|
1237 |
} else {
|
|
|
1238 |
throw new ProfitMandiBusinessException("Serial Number", serialNumber, "Serial Number does not exist in our warehouse");
|
|
|
1239 |
}
|
|
|
1240 |
}
|
| 27516 |
amit.gupta |
1241 |
|
| 33665 |
ranu |
1242 |
void modifyDummyModel(FofoOrder fofoOrder, InvoicePdfModel pdfModel, int itemId, String serialNumber) throws
|
|
|
1243 |
ProfitMandiBusinessException {
|
| 28166 |
tejbeer |
1244 |
|
| 32145 |
tejbeer |
1245 |
int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(fofoOrder.getFofoId());
|
| 27516 |
amit.gupta |
1246 |
|
| 32145 |
tejbeer |
1247 |
Address retailerAddress = addressRepository.selectById(retailerAddressId);
|
|
|
1248 |
Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
|
| 27516 |
amit.gupta |
1249 |
|
| 32145 |
tejbeer |
1250 |
CustomerAddress customerAddress = customer.getCustomerAddress().stream().filter(x -> x.getId() == fofoOrder.getCustomerAddressId()).findFirst().get();
|
| 27516 |
amit.gupta |
1251 |
|
| 32145 |
tejbeer |
1252 |
Integer stateId = null;
|
|
|
1253 |
if (customerAddress.getState().equals(retailerAddress.getState())) {
|
|
|
1254 |
try {
|
|
|
1255 |
// stateId =
|
|
|
1256 |
// Long.valueOf(Utils.getStateInfo(customerAddress.getState()).getId()).intValue();
|
| 30527 |
tejbeer |
1257 |
|
| 32145 |
tejbeer |
1258 |
stateId = Long.valueOf(stateRepository.selectByName(customerAddress.getState()).getId()).intValue();
|
|
|
1259 |
} catch (Exception e) {
|
|
|
1260 |
LOGGER.error("Unable to get state rates");
|
|
|
1261 |
}
|
|
|
1262 |
}
|
|
|
1263 |
CustomOrderItem cli = pdfModel.getOrderItems().stream().findFirst().get();
|
|
|
1264 |
List<FofoOrderItem> fofoOrderItems = Arrays.asList(this.getDummyFofoOrderItem(itemId, fofoOrder.getId(), serialNumber, stateId));
|
|
|
1265 |
pdfModel.setPaymentOptions(pdfModel.getPaymentOptions().stream().limit(1).collect(Collectors.toList()));
|
|
|
1266 |
CustomPaymentOption paymentOption = pdfModel.getPaymentOptions().get(0);
|
|
|
1267 |
paymentOption.setAmount(fofoOrderItems.get(0).getMop());
|
| 33298 |
amit.gupta |
1268 |
List<CustomOrderItem> customerFofoOrderItems = new ArrayList<>();
|
| 32145 |
tejbeer |
1269 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
1270 |
CustomOrderItem customFofoOrderItem = new CustomOrderItem();
|
|
|
1271 |
float totalTaxRate = fofoOrderItem.getIgstRate() + fofoOrderItem.getSgstRate() + fofoOrderItem.getCgstRate();
|
|
|
1272 |
float taxableSellingPrice = fofoOrderItem.getSellingPrice() / (1 + totalTaxRate / 100);
|
|
|
1273 |
float taxableDiscountPrice = fofoOrderItem.getDiscount() / (1 + totalTaxRate / 100);
|
| 27516 |
amit.gupta |
1274 |
|
| 32145 |
tejbeer |
1275 |
customFofoOrderItem.setAmount(fofoOrderItem.getQuantity() * (taxableSellingPrice - taxableDiscountPrice));
|
|
|
1276 |
customFofoOrderItem.setDescription(fofoOrderItem.getBrand() + " " + fofoOrderItem.getModelName() + " " + fofoOrderItem.getModelNumber() + "-" + fofoOrderItem.getColor());
|
|
|
1277 |
Set<String> serialNumbers = this.toSerialNumbers(fofoOrderItem.getFofoLineItems());
|
|
|
1278 |
// LOGGER.info("serialNumbers {}", serialNumbers);
|
|
|
1279 |
// LOGGER.info("serialNumbers is empty {}", serialNumbers.isEmpty());
|
|
|
1280 |
if (!serialNumbers.isEmpty()) {
|
|
|
1281 |
customFofoOrderItem.setDescription(
|
|
|
1282 |
customFofoOrderItem.getDescription() + "\n IMEIS - " + String.join(", ", serialNumbers));
|
|
|
1283 |
}
|
|
|
1284 |
customFofoOrderItem.setRate(taxableSellingPrice);
|
|
|
1285 |
customFofoOrderItem.setDiscount(taxableDiscountPrice);
|
|
|
1286 |
customFofoOrderItem.setQuantity(fofoOrderItem.getQuantity());
|
|
|
1287 |
customFofoOrderItem.setNetAmount(
|
|
|
1288 |
(fofoOrderItem.getSellingPrice() - fofoOrderItem.getDiscount()) * fofoOrderItem.getQuantity());
|
|
|
1289 |
float igstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getIgstRate()) / 100;
|
|
|
1290 |
float cgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getCgstRate()) / 100;
|
|
|
1291 |
float sgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getSgstRate()) / 100;
|
|
|
1292 |
customFofoOrderItem.setIgstRate(fofoOrderItem.getIgstRate());
|
|
|
1293 |
customFofoOrderItem.setIgstAmount(igstAmount);
|
|
|
1294 |
customFofoOrderItem.setCgstRate(fofoOrderItem.getCgstRate());
|
|
|
1295 |
customFofoOrderItem.setCgstAmount(cgstAmount);
|
|
|
1296 |
customFofoOrderItem.setSgstRate(fofoOrderItem.getSgstRate());
|
|
|
1297 |
customFofoOrderItem.setSgstAmount(sgstAmount);
|
|
|
1298 |
customFofoOrderItem.setHsnCode(fofoOrderItem.getHsnCode());
|
|
|
1299 |
customerFofoOrderItems.add(customFofoOrderItem);
|
|
|
1300 |
}
|
|
|
1301 |
pdfModel.setTotalAmount(paymentOption.getAmount());
|
|
|
1302 |
pdfModel.setOrderItems(customerFofoOrderItems);
|
| 28166 |
tejbeer |
1303 |
|
| 32145 |
tejbeer |
1304 |
}
|
| 27516 |
amit.gupta |
1305 |
|
| 35034 |
amit |
1306 |
@Override
|
|
|
1307 |
public InvoicePdfModel getInvoicePdfModel(FofoOrder fofoOrder) throws ProfitMandiBusinessException {
|
| 23650 |
amit.gupta |
1308 |
|
| 32145 |
tejbeer |
1309 |
List<PaymentOptionTransaction> paymentOptionTransactions = paymentOptionTransactionRepository.selectByReferenceIdAndTypes(fofoOrder.getId(), Arrays.asList(PaymentOptionReferenceType.ORDER, PaymentOptionReferenceType.INSURANCE));
|
| 23650 |
amit.gupta |
1310 |
|
| 32145 |
tejbeer |
1311 |
List<CustomPaymentOption> paymentOptions = new ArrayList<>();
|
| 23552 |
amit.gupta |
1312 |
|
| 32145 |
tejbeer |
1313 |
InvoicePdfModel pdfModel = new InvoicePdfModel();
|
| 33795 |
ranu |
1314 |
|
|
|
1315 |
|
|
|
1316 |
List<FofoOrderItem> fofoOrderItems = this.getByOrderId(fofoOrder.getId());
|
|
|
1317 |
|
|
|
1318 |
double upgradePartnerDiscount = 0;
|
|
|
1319 |
|
| 35055 |
ranu |
1320 |
/* for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
| 33795 |
ranu |
1321 |
|
|
|
1322 |
Set<String> serialNumbers = this.toSerialNumbers(fofoOrderItem.getFofoLineItems());
|
|
|
1323 |
for (String serialNumber : serialNumbers) {
|
|
|
1324 |
UpgradeOffer upgradeOffer = upgradeOfferRepository.selectBySerialNumber(serialNumber);
|
|
|
1325 |
if (upgradeOffer != null) {
|
|
|
1326 |
CustomerOfferItem customerOfferItem = customerOfferItemRepository.selectById(upgradeOffer.getCustomerOfferItemId());
|
|
|
1327 |
upgradePartnerDiscount += customerOfferItem.getDealerPayout();
|
|
|
1328 |
}
|
|
|
1329 |
}
|
| 35055 |
ranu |
1330 |
}*/
|
| 33795 |
ranu |
1331 |
|
|
|
1332 |
boolean hasSamsungUpgrade = paymentOptionTransactions.stream()
|
|
|
1333 |
.anyMatch(transaction ->
|
|
|
1334 |
"SAMSUNG UPGRADE".equals(paymentOptionRepository
|
|
|
1335 |
.selectById(transaction.getPaymentOptionId())
|
|
|
1336 |
.getName()));
|
|
|
1337 |
|
|
|
1338 |
LOGGER.info("paymentOptionTransactions - {}", paymentOptionTransactions);
|
|
|
1339 |
LOGGER.info("hasSamsungUpgrade - {}", hasSamsungUpgrade);
|
|
|
1340 |
|
|
|
1341 |
double cashDiscount = paymentOptionTransactions.stream()
|
|
|
1342 |
.filter(x -> "CASH DISCOUNT".equals(paymentOptionRepository.selectById(x.getPaymentOptionId()).getName())).mapToDouble(x -> x.getAmount()).findFirst().orElse(0);
|
|
|
1343 |
|
|
|
1344 |
LOGGER.info("cashDiscount - {}", cashDiscount);
|
|
|
1345 |
|
| 32145 |
tejbeer |
1346 |
for (PaymentOptionTransaction paymentOptionTransaction : paymentOptionTransactions) {
|
| 33795 |
ranu |
1347 |
String paymentOptionName = paymentOptionRepository.selectById(paymentOptionTransaction.getPaymentOptionId()).getName();
|
|
|
1348 |
|
| 32145 |
tejbeer |
1349 |
CustomPaymentOption cpi = new CustomPaymentOption();
|
| 33795 |
ranu |
1350 |
LOGGER.info("paymentOptionName {}", paymentOptionName);
|
|
|
1351 |
|
|
|
1352 |
float amountToSet = paymentOptionTransaction.getAmount();
|
|
|
1353 |
|
|
|
1354 |
if ("SAMSUNG UPGRADE".equals(paymentOptionName) && hasSamsungUpgrade) {
|
|
|
1355 |
if (cashDiscount > upgradePartnerDiscount) {
|
|
|
1356 |
amountToSet += (float) upgradePartnerDiscount;
|
|
|
1357 |
} else {
|
|
|
1358 |
amountToSet += (float) cashDiscount;
|
|
|
1359 |
}
|
|
|
1360 |
|
|
|
1361 |
} else if ("CASH".equals(paymentOptionName) && !hasSamsungUpgrade) {
|
|
|
1362 |
amountToSet += ((float) cashDiscount - (float) upgradePartnerDiscount);
|
|
|
1363 |
|
|
|
1364 |
} else if ("CASH".equals(paymentOptionName) && hasSamsungUpgrade && (cashDiscount > upgradePartnerDiscount)) {
|
|
|
1365 |
amountToSet += ((float) cashDiscount - (float) upgradePartnerDiscount);
|
|
|
1366 |
|
|
|
1367 |
}
|
|
|
1368 |
|
|
|
1369 |
cpi.setAmount(amountToSet);
|
|
|
1370 |
cpi.setPaymentOption(paymentOptionName);
|
|
|
1371 |
|
| 32145 |
tejbeer |
1372 |
paymentOptions.add(cpi);
|
|
|
1373 |
}
|
| 24215 |
amit.gupta |
1374 |
|
| 33795 |
ranu |
1375 |
|
| 32145 |
tejbeer |
1376 |
pdfModel.setTitle("Retailer Invoice");
|
|
|
1377 |
Optional<FofoOrderItem> fofoOrderItemOptional = fofoOrderItems.stream().findAny();
|
|
|
1378 |
if (fofoOrderItemOptional.isPresent() && fofoOrderItemOptional.get().equals("NOGST")) {
|
|
|
1379 |
pdfModel.setTitle("Security Deposit Receipt");
|
|
|
1380 |
}
|
|
|
1381 |
pdfModel.setPaymentOptions(paymentOptions);
|
|
|
1382 |
pdfModel.setAuther("SmartDukaan");
|
|
|
1383 |
pdfModel.setInvoiceDate(FormattingUtils.formatDate(fofoOrder.getCreateTimestamp()));
|
| 23650 |
amit.gupta |
1384 |
|
| 32145 |
tejbeer |
1385 |
// insurance calculation
|
|
|
1386 |
List<InsurancePolicy> insurancePolicies = insurancePolicyRepository.selectByRetailerIdInvoiceNumber(fofoOrder.getInvoiceNumber());
|
| 33298 |
amit.gupta |
1387 |
List<CustomInsurancePolicy> customInsurancePolicies = new ArrayList<>();
|
| 32145 |
tejbeer |
1388 |
final float totalInsuranceTaxRate = 18;
|
|
|
1389 |
for (InsurancePolicy insurancePolicy : insurancePolicies) {
|
|
|
1390 |
float taxableInsurancePrice = insurancePolicy.getSaleAmount() / (1 + totalInsuranceTaxRate / 100);
|
|
|
1391 |
CustomInsurancePolicy customInsurancePolicy = new CustomInsurancePolicy();
|
|
|
1392 |
customInsurancePolicy.setDescription(insurancePolicy.getPolicyPlan() + " for Device #" + insurancePolicy.getSerialNumber() + "\n Plan Reference - " + insurancePolicy.getPolicyNumber());
|
|
|
1393 |
customInsurancePolicy.setHsnCode("998716");
|
|
|
1394 |
customInsurancePolicy.setRate(taxableInsurancePrice);
|
|
|
1395 |
customInsurancePolicy.setIgstRate(18);
|
|
|
1396 |
customInsurancePolicy.setIgstAmount(taxableInsurancePrice * 18 / 100);
|
|
|
1397 |
customInsurancePolicy.setCgstRate(9);
|
|
|
1398 |
customInsurancePolicy.setCgstAmount(taxableInsurancePrice * 9 / 100);
|
|
|
1399 |
customInsurancePolicy.setSgstRate(9);
|
|
|
1400 |
customInsurancePolicy.setSgstAmount(taxableInsurancePrice * 9 / 100);
|
|
|
1401 |
customInsurancePolicy.setNetAmount(insurancePolicy.getSaleAmount());
|
|
|
1402 |
customInsurancePolicies.add(customInsurancePolicy);
|
|
|
1403 |
}
|
|
|
1404 |
pdfModel.setInsurancePolicies(customInsurancePolicies);
|
| 24275 |
amit.gupta |
1405 |
|
| 32145 |
tejbeer |
1406 |
Retailer retailer = retailerRepository.selectById(fofoOrder.getFofoId());
|
|
|
1407 |
PrivateDealUser privateDealUser = null;
|
|
|
1408 |
try {
|
|
|
1409 |
privateDealUser = privateDealUserRepository.selectById(retailer.getId());
|
|
|
1410 |
} catch (ProfitMandiBusinessException profitMandiBusinessException) {
|
|
|
1411 |
LOGGER.error("Private Deal User not found : ", profitMandiBusinessException);
|
|
|
1412 |
}
|
| 23650 |
amit.gupta |
1413 |
|
| 32145 |
tejbeer |
1414 |
User user = userRepository.selectById(userAccountRepository.selectUserIdByRetailerId(retailer.getId()));
|
|
|
1415 |
CustomRetailer customRetailer = new CustomRetailer();
|
|
|
1416 |
customRetailer.setBusinessName(retailer.getName());
|
|
|
1417 |
customRetailer.setMobileNumber(user.getMobileNumber());
|
|
|
1418 |
// customRetailer.setTinNumber(retailer.getNumber());
|
|
|
1419 |
if (privateDealUser == null) {
|
|
|
1420 |
customRetailer.setGstNumber(null);
|
|
|
1421 |
} else {
|
|
|
1422 |
if (null != privateDealUser.getCounterId()) {
|
|
|
1423 |
Counter counter = counterRepository.selectById(privateDealUser.getCounterId());
|
|
|
1424 |
customRetailer.setGstNumber(counter.getGstin());
|
|
|
1425 |
} else {
|
|
|
1426 |
customRetailer.setGstNumber(null);
|
|
|
1427 |
}
|
|
|
1428 |
}
|
|
|
1429 |
Address retailerAddress = addressRepository.selectById(retailerRegisteredAddressRepository.selectAddressIdByRetailerId(retailer.getId()));
|
|
|
1430 |
customRetailer.setAddress(this.createCustomAddress(retailerAddress));
|
|
|
1431 |
pdfModel.setRetailer(customRetailer);
|
| 23650 |
amit.gupta |
1432 |
|
| 33089 |
amit.gupta |
1433 |
pdfModel.setCustomer(getCustomCustomer(fofoOrder, customRetailer.getAddress()));
|
|
|
1434 |
pdfModel.setInvoiceNumber(fofoOrder.getInvoiceNumber());
|
|
|
1435 |
pdfModel.setTotalAmount(fofoOrder.getTotalAmount());
|
|
|
1436 |
|
|
|
1437 |
|
| 33298 |
amit.gupta |
1438 |
List<CustomOrderItem> customerFofoOrderItems = new ArrayList<>();
|
| 32145 |
tejbeer |
1439 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
1440 |
float discount = fofoOrderItem.getDiscount();
|
|
|
1441 |
CustomOrderItem customFofoOrderItem = new CustomOrderItem();
|
|
|
1442 |
float totalTaxRate = fofoOrderItem.getIgstRate() + fofoOrderItem.getSgstRate() + fofoOrderItem.getCgstRate();
|
|
|
1443 |
float taxableSellingPrice = (fofoOrderItem.getSellingPrice() + discount) / (1 + totalTaxRate / 100);
|
|
|
1444 |
float taxableDiscountPrice = discount / (1 + totalTaxRate / 100);
|
| 23650 |
amit.gupta |
1445 |
|
| 32145 |
tejbeer |
1446 |
customFofoOrderItem.setAmount(fofoOrderItem.getQuantity() * (taxableSellingPrice - taxableDiscountPrice));
|
|
|
1447 |
customFofoOrderItem.setDescription(fofoOrderItem.getBrand() + " " + fofoOrderItem.getModelName() + " " + fofoOrderItem.getModelNumber() + "-" + fofoOrderItem.getColor());
|
|
|
1448 |
Set<String> serialNumbers = this.toSerialNumbers(fofoOrderItem.getFofoLineItems());
|
| 32816 |
ranu |
1449 |
List<FofoNonSerializeSerial> nonSerializeSerials = fofoNonSerializeSerialRepository.selectByItemIdAndOrderId(fofoOrderItem.getId());
|
|
|
1450 |
// Extract serial numbers from FofoNonSerializeSerial entities
|
|
|
1451 |
List<String> customSerialNumbers = nonSerializeSerials.stream().map(FofoNonSerializeSerial::getSerialNumber).collect(Collectors.toList());
|
|
|
1452 |
LOGGER.info("nonSerializeSerials {}", nonSerializeSerials);
|
| 32145 |
tejbeer |
1453 |
if (!serialNumbers.isEmpty()) {
|
|
|
1454 |
customFofoOrderItem.setDescription(
|
|
|
1455 |
customFofoOrderItem.getDescription() + "\n IMEIS - " + String.join(", ", serialNumbers));
|
|
|
1456 |
}
|
| 32816 |
ranu |
1457 |
if (!customSerialNumbers.isEmpty()) {
|
|
|
1458 |
customFofoOrderItem.setDescription(
|
|
|
1459 |
customFofoOrderItem.getDescription() + "\n SerialNumber - " + String.join(", ", customSerialNumbers));
|
|
|
1460 |
}
|
| 32145 |
tejbeer |
1461 |
customFofoOrderItem.setRate(taxableSellingPrice);
|
|
|
1462 |
customFofoOrderItem.setDiscount(taxableDiscountPrice);
|
|
|
1463 |
customFofoOrderItem.setQuantity(fofoOrderItem.getQuantity());
|
|
|
1464 |
customFofoOrderItem.setNetAmount(fofoOrderItem.getSellingPrice() * fofoOrderItem.getQuantity());
|
|
|
1465 |
float igstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getIgstRate()) / 100;
|
|
|
1466 |
float cgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getCgstRate()) / 100;
|
|
|
1467 |
float sgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getSgstRate()) / 100;
|
|
|
1468 |
customFofoOrderItem.setIgstRate(fofoOrderItem.getIgstRate());
|
|
|
1469 |
customFofoOrderItem.setIgstAmount(igstAmount);
|
|
|
1470 |
customFofoOrderItem.setCgstRate(fofoOrderItem.getCgstRate());
|
|
|
1471 |
customFofoOrderItem.setCgstAmount(cgstAmount);
|
|
|
1472 |
customFofoOrderItem.setSgstRate(fofoOrderItem.getSgstRate());
|
|
|
1473 |
customFofoOrderItem.setSgstAmount(sgstAmount);
|
|
|
1474 |
customFofoOrderItem.setHsnCode(fofoOrderItem.getHsnCode());
|
|
|
1475 |
customerFofoOrderItems.add(customFofoOrderItem);
|
|
|
1476 |
}
|
|
|
1477 |
pdfModel.setOrderItems(customerFofoOrderItems);
|
| 32627 |
ranu |
1478 |
String customerAddressStateCode = "";
|
| 32145 |
tejbeer |
1479 |
String partnerAddressStateCode = stateRepository.selectByName(pdfModel.getRetailer().getAddress().getState()).getCode();
|
| 32627 |
ranu |
1480 |
if (pdfModel.getCustomer() != null && pdfModel.getCustomer().getAddress() != null &&
|
|
|
1481 |
pdfModel.getCustomer().getAddress().getState() != null &&
|
|
|
1482 |
!pdfModel.getCustomer().getAddress().getState().trim().isEmpty()) {
|
|
|
1483 |
customerAddressStateCode = stateRepository.selectByName(pdfModel.getCustomer().getAddress().getState()).getCode();
|
|
|
1484 |
}
|
|
|
1485 |
|
| 32145 |
tejbeer |
1486 |
pdfModel.setPartnerAddressStateCode(partnerAddressStateCode);
|
| 32627 |
ranu |
1487 |
if (!customerAddressStateCode.equals("")) {
|
|
|
1488 |
pdfModel.setCustomerAddressStateCode(customerAddressStateCode);
|
|
|
1489 |
}
|
| 32145 |
tejbeer |
1490 |
pdfModel.setCancelled(fofoOrder.getCancelledTimestamp() != null);
|
|
|
1491 |
List<String> tncs = new ArrayList<>();
|
| 34999 |
amit |
1492 |
tncs.add("I agree that goods received are in good working condition.");
|
|
|
1493 |
tncs.add("Goods once sold cannot be exchanged or taken back.");
|
| 32145 |
tejbeer |
1494 |
tncs.add("Warranty for the goods received by me is the responsibility of the manufacturer only.");
|
|
|
1495 |
if (pdfModel.getInsurancePolicies() != null && pdfModel.getInsurancePolicies().size() > 0) {
|
| 35000 |
amit |
1496 |
tncs.add("Extended Warranty/ Damage Protection related issues are to be handled directly by the respective providers.");
|
| 32145 |
tejbeer |
1497 |
}
|
|
|
1498 |
pdfModel.setTncs(tncs);
|
|
|
1499 |
return pdfModel;
|
| 23650 |
amit.gupta |
1500 |
|
| 32145 |
tejbeer |
1501 |
}
|
| 23650 |
amit.gupta |
1502 |
|
| 33665 |
ranu |
1503 |
private CustomCustomer getCustomCustomer(FofoOrder fofoOrder, CustomAddress retailerAddress) throws
|
|
|
1504 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1505 |
Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
|
|
|
1506 |
CustomCustomer customCustomer = new CustomCustomer();
|
|
|
1507 |
customCustomer.setFirstName(customer.getFirstName());
|
|
|
1508 |
customCustomer.setLastName(customer.getLastName());
|
|
|
1509 |
customCustomer.setEmailId(customer.getEmailId());
|
|
|
1510 |
customCustomer.setMobileNumber(customer.getMobileNumber());
|
|
|
1511 |
customCustomer.setGstNumber(fofoOrder.getCustomerGstNumber());
|
| 32627 |
ranu |
1512 |
if (fofoOrder.getCustomerAddressId() != 0) {
|
|
|
1513 |
CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
|
|
|
1514 |
customCustomer.setAddress(this.createCustomAddress(customerAddress));
|
|
|
1515 |
} else {
|
| 33089 |
amit.gupta |
1516 |
|
|
|
1517 |
customCustomer.setAddress(this.createCustomAddressWithoutId(customCustomer, retailerAddress));
|
| 32627 |
ranu |
1518 |
}
|
| 32145 |
tejbeer |
1519 |
return customCustomer;
|
| 32627 |
ranu |
1520 |
|
| 32145 |
tejbeer |
1521 |
}
|
| 23655 |
amit.gupta |
1522 |
|
| 32145 |
tejbeer |
1523 |
@Override
|
|
|
1524 |
public InvoicePdfModel getInvoicePdfModel(int fofoId, int orderId) throws ProfitMandiBusinessException {
|
|
|
1525 |
FofoOrder fofoOrder = fofoOrderRepository.selectByFofoIdAndOrderId(fofoId, orderId);
|
|
|
1526 |
return this.getInvoicePdfModel(fofoOrder);
|
|
|
1527 |
}
|
| 23650 |
amit.gupta |
1528 |
|
| 32145 |
tejbeer |
1529 |
public String getBillingAddress(CustomerAddress customerAddress) {
|
|
|
1530 |
StringBuilder address = new StringBuilder();
|
|
|
1531 |
if ((customerAddress.getLine1() != null) && (!customerAddress.getLine1().isEmpty())) {
|
|
|
1532 |
address.append(customerAddress.getLine1());
|
|
|
1533 |
address.append(", ");
|
|
|
1534 |
}
|
| 22859 |
ashik.ali |
1535 |
|
| 32145 |
tejbeer |
1536 |
if ((customerAddress.getLine2() != null) && (!customerAddress.getLine2().isEmpty())) {
|
|
|
1537 |
address.append(customerAddress.getLine2());
|
|
|
1538 |
address.append(", ");
|
|
|
1539 |
}
|
| 22859 |
ashik.ali |
1540 |
|
| 32145 |
tejbeer |
1541 |
if ((customerAddress.getLandmark() != null) && (!customerAddress.getLandmark().isEmpty())) {
|
|
|
1542 |
address.append(customerAddress.getLandmark());
|
|
|
1543 |
address.append(", ");
|
|
|
1544 |
}
|
| 22859 |
ashik.ali |
1545 |
|
| 32145 |
tejbeer |
1546 |
if ((customerAddress.getCity() != null) && (!customerAddress.getCity().isEmpty())) {
|
|
|
1547 |
address.append(customerAddress.getCity());
|
|
|
1548 |
address.append(", ");
|
|
|
1549 |
}
|
| 22859 |
ashik.ali |
1550 |
|
| 32145 |
tejbeer |
1551 |
if ((customerAddress.getState() != null) && (!customerAddress.getState().isEmpty())) {
|
|
|
1552 |
address.append(customerAddress.getState());
|
|
|
1553 |
}
|
| 22859 |
ashik.ali |
1554 |
|
| 32145 |
tejbeer |
1555 |
if ((customerAddress.getPinCode() != null) && (!customerAddress.getPinCode().isEmpty())) {
|
|
|
1556 |
address.append("- ");
|
|
|
1557 |
address.append(customerAddress.getPinCode());
|
|
|
1558 |
}
|
| 22859 |
ashik.ali |
1559 |
|
| 32145 |
tejbeer |
1560 |
return address.toString();
|
|
|
1561 |
}
|
| 23650 |
amit.gupta |
1562 |
|
| 32145 |
tejbeer |
1563 |
@Override
|
|
|
1564 |
public List<CartFofo> cartCheckout(String cartJson) throws ProfitMandiBusinessException {
|
|
|
1565 |
try {
|
|
|
1566 |
JSONObject cartObject = new JSONObject(cartJson);
|
|
|
1567 |
Iterator<?> keys = cartObject.keys();
|
| 23650 |
amit.gupta |
1568 |
|
| 32145 |
tejbeer |
1569 |
Set<Integer> itemIds = new HashSet<>();
|
|
|
1570 |
List<CartFofo> cartItems = new ArrayList<CartFofo>();
|
| 23650 |
amit.gupta |
1571 |
|
| 32145 |
tejbeer |
1572 |
while (keys.hasNext()) {
|
|
|
1573 |
String key = (String) keys.next();
|
|
|
1574 |
if (cartObject.get(key) instanceof JSONObject) {
|
|
|
1575 |
LOGGER.info(cartObject.get(key).toString());
|
|
|
1576 |
}
|
|
|
1577 |
CartFofo cf = new CartFofo();
|
|
|
1578 |
cf.setItemId(cartObject.getJSONObject(key).getInt("itemId"));
|
|
|
1579 |
cf.setQuantity(cartObject.getJSONObject(key).getInt("quantity"));
|
|
|
1580 |
if (cartObject.getJSONObject(key).has("poId")) {
|
| 23650 |
amit.gupta |
1581 |
|
| 32145 |
tejbeer |
1582 |
cf.setPoId(cartObject.getJSONObject(key).getInt("poId"));
|
|
|
1583 |
cf.setPoItemId(cartObject.getJSONObject(key).getInt("poItemId"));
|
|
|
1584 |
}
|
|
|
1585 |
if (cf.getQuantity() <= 0) {
|
|
|
1586 |
continue;
|
|
|
1587 |
}
|
|
|
1588 |
cartItems.add(cf);
|
|
|
1589 |
itemIds.add(cartObject.getJSONObject(key).getInt("itemId"));
|
|
|
1590 |
}
|
|
|
1591 |
Map<Integer, Item> itemMap = new HashMap<Integer, Item>();
|
|
|
1592 |
if (itemIds.size() > 0) {
|
|
|
1593 |
List<Item> items = itemRepository.selectByIds(itemIds);
|
|
|
1594 |
for (Item i : items) {
|
|
|
1595 |
itemMap.put(i.getId(), i);
|
|
|
1596 |
}
|
| 23650 |
amit.gupta |
1597 |
|
| 32145 |
tejbeer |
1598 |
}
|
|
|
1599 |
for (CartFofo cf : cartItems) {
|
|
|
1600 |
Item i = itemMap.get(cf.getItemId());
|
|
|
1601 |
if (i == null) {
|
|
|
1602 |
continue;
|
|
|
1603 |
}
|
|
|
1604 |
cf.setDisplayName(getValidName(i.getBrand()) + " " + getValidName(i.getModelName()) + " " + getValidName(i.getModelNumber()) + " " + getValidName(i.getColor()).replaceAll("\\s+", " "));
|
|
|
1605 |
cf.setItemType(i.getType());
|
|
|
1606 |
}
|
|
|
1607 |
return cartItems;
|
|
|
1608 |
} catch (Exception e) {
|
|
|
1609 |
LOGGER.error("Unable to Prepare cart to place order...", e);
|
|
|
1610 |
throw new ProfitMandiBusinessException("cartData", cartJson, "FFORDR_1006");
|
|
|
1611 |
}
|
|
|
1612 |
}
|
| 23650 |
amit.gupta |
1613 |
|
| 32145 |
tejbeer |
1614 |
@Override
|
| 33665 |
ranu |
1615 |
public Map<String, Object> getSaleHistory(int fofoId, SearchType searchType, String searchValue, LocalDateTime
|
|
|
1616 |
startDate, LocalDateTime endDate, int offset, int limit) throws ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1617 |
long countItems = 0;
|
|
|
1618 |
List<FofoOrder> fofoOrders = new ArrayList<>();
|
| 23650 |
amit.gupta |
1619 |
|
| 32145 |
tejbeer |
1620 |
if (searchType == SearchType.CUSTOMER_MOBILE_NUMBER && !searchValue.isEmpty()) {
|
|
|
1621 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndCustomerMobileNumber(fofoId, searchValue, null, null, offset, limit);
|
|
|
1622 |
countItems = fofoOrderRepository.selectCountByCustomerMobileNumber(fofoId, searchValue, null, null);
|
|
|
1623 |
} else if (searchType == SearchType.CUSTOMER_NAME && !searchValue.isEmpty()) {
|
|
|
1624 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndCustomerName(fofoId, searchValue, null, null, offset, limit);
|
|
|
1625 |
countItems = fofoOrderRepository.selectCountByCustomerName(fofoId, searchValue, null, null);
|
|
|
1626 |
} else if (searchType == SearchType.IMEI && !searchValue.isEmpty()) {
|
|
|
1627 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndSerialNumber(fofoId, searchValue, null, null, offset, limit);
|
|
|
1628 |
countItems = fofoOrderRepository.selectCountBySerialNumber(fofoId, searchValue, null, null);
|
|
|
1629 |
} else if (searchType == SearchType.ITEM_NAME && !searchValue.isEmpty()) {
|
|
|
1630 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndItemName(fofoId, searchValue, null, null, offset, limit);
|
|
|
1631 |
countItems = fofoOrderRepository.selectCountByItemName(fofoId, searchValue, null, null);
|
|
|
1632 |
} else if (searchType == SearchType.INVOICE_NUMBER && !searchValue.isEmpty()) {
|
|
|
1633 |
fofoOrders = Arrays.asList(fofoOrderRepository.selectByFofoIdAndInvoiceNumber(fofoId, searchValue));
|
|
|
1634 |
countItems = fofoOrders.size();
|
|
|
1635 |
} else if (searchType == SearchType.DATE_RANGE) {
|
|
|
1636 |
fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startDate, endDate, offset, limit);
|
|
|
1637 |
countItems = fofoOrderRepository.selectCountByFofoId(fofoId, startDate, endDate);
|
|
|
1638 |
}
|
|
|
1639 |
Map<String, Object> map = new HashMap<>();
|
| 23650 |
amit.gupta |
1640 |
|
| 32145 |
tejbeer |
1641 |
map.put("saleHistories", fofoOrders);
|
|
|
1642 |
map.put("start", offset + 1);
|
|
|
1643 |
map.put("size", countItems);
|
|
|
1644 |
map.put("searchType", searchType);
|
|
|
1645 |
map.put("searchTypes", SearchType.values());
|
|
|
1646 |
map.put("startDate", startDate);
|
|
|
1647 |
map.put("searchValue", searchValue);
|
|
|
1648 |
map.put(ProfitMandiConstants.END_TIME, endDate);
|
|
|
1649 |
if (fofoOrders.size() < limit) {
|
|
|
1650 |
map.put("end", offset + fofoOrders.size());
|
|
|
1651 |
} else {
|
|
|
1652 |
map.put("end", offset + limit);
|
|
|
1653 |
}
|
|
|
1654 |
return map;
|
|
|
1655 |
}
|
| 30426 |
tejbeer |
1656 |
|
| 33665 |
ranu |
1657 |
public ResponseEntity<?> downloadReportInCsv(org.apache.commons.io.output.ByteArrayOutputStream
|
|
|
1658 |
baos, List<List<?>> rows, String fileName) {
|
| 32145 |
tejbeer |
1659 |
final HttpHeaders headers = new HttpHeaders();
|
|
|
1660 |
headers.set("Content-Type", "text/csv");
|
| 30426 |
tejbeer |
1661 |
|
| 32145 |
tejbeer |
1662 |
headers.set("Content-disposition", "inline; filename=" + fileName + ".csv");
|
|
|
1663 |
headers.setContentLength(baos.toByteArray().length);
|
| 23202 |
ashik.ali |
1664 |
|
| 32145 |
tejbeer |
1665 |
final InputStream inputStream = new ByteArrayInputStream(baos.toByteArray());
|
|
|
1666 |
final InputStreamResource inputStreamResource = new InputStreamResource(inputStream);
|
| 30426 |
tejbeer |
1667 |
|
| 33454 |
amit.gupta |
1668 |
return new ResponseEntity<>(inputStreamResource, headers, HttpStatus.OK);
|
| 32145 |
tejbeer |
1669 |
}
|
| 30157 |
manish |
1670 |
|
| 32145 |
tejbeer |
1671 |
@Override
|
| 33665 |
ranu |
1672 |
public Map<String, Object> getSaleHistoryPaginated(int fofoId, SearchType searchType, String
|
|
|
1673 |
searchValue, LocalDateTime startDate, LocalDateTime endDate, int offset, int limit) throws
|
|
|
1674 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1675 |
List<FofoOrder> fofoOrders = new ArrayList<>();
|
| 23650 |
amit.gupta |
1676 |
|
| 32145 |
tejbeer |
1677 |
if (searchType == SearchType.CUSTOMER_MOBILE_NUMBER && !searchValue.isEmpty()) {
|
|
|
1678 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndCustomerMobileNumber(fofoId, searchValue, startDate, endDate, offset, limit);
|
|
|
1679 |
} else if (searchType == SearchType.CUSTOMER_NAME && !searchValue.isEmpty()) {
|
|
|
1680 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndCustomerName(fofoId, searchValue, startDate, endDate, offset, limit);
|
|
|
1681 |
} else if (searchType == SearchType.IMEI && !searchValue.isEmpty()) {
|
|
|
1682 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndSerialNumber(fofoId, searchValue, startDate, endDate, offset, limit);
|
|
|
1683 |
} else if (searchType == SearchType.ITEM_NAME && !searchValue.isEmpty()) {
|
|
|
1684 |
fofoOrders = fofoOrderRepository.selectByFofoIdAndItemName(fofoId, searchValue, startDate, endDate, offset, limit);
|
| 24275 |
amit.gupta |
1685 |
|
| 32145 |
tejbeer |
1686 |
} else if (searchType == SearchType.DATE_RANGE) {
|
|
|
1687 |
fofoOrders = fofoOrderRepository.selectByFofoId(fofoId, startDate, endDate, offset, limit);
|
|
|
1688 |
}
|
|
|
1689 |
Map<String, Object> map = new HashMap<>();
|
|
|
1690 |
map.put("saleHistories", fofoOrders);
|
|
|
1691 |
map.put("searchType", searchType);
|
|
|
1692 |
map.put("searchTypes", SearchType.values());
|
|
|
1693 |
map.put("startDate", startDate);
|
|
|
1694 |
map.put("searchValue", searchValue);
|
|
|
1695 |
map.put(ProfitMandiConstants.END_TIME, endDate);
|
|
|
1696 |
return map;
|
|
|
1697 |
}
|
| 23650 |
amit.gupta |
1698 |
|
| 32145 |
tejbeer |
1699 |
private String getFofoStoreCode(int fofoId) throws ProfitMandiBusinessException {
|
|
|
1700 |
FofoStore fofoStore = fofoStoreRepository.selectByRetailerId(fofoId);
|
|
|
1701 |
return fofoStore.getCode();
|
|
|
1702 |
}
|
| 23650 |
amit.gupta |
1703 |
|
| 32145 |
tejbeer |
1704 |
private String getValidName(String name) {
|
|
|
1705 |
return name != null ? name : "";
|
|
|
1706 |
}
|
| 23650 |
amit.gupta |
1707 |
|
| 32145 |
tejbeer |
1708 |
private Set<String> toSerialNumbers(Set<FofoLineItem> fofoLineItems) {
|
|
|
1709 |
Set<String> serialNumbers = new HashSet<>();
|
|
|
1710 |
for (FofoLineItem fofoLineItem : fofoLineItems) {
|
|
|
1711 |
if (fofoLineItem.getSerialNumber() != null && !fofoLineItem.getSerialNumber().isEmpty()) {
|
|
|
1712 |
serialNumbers.add(fofoLineItem.getSerialNumber());
|
|
|
1713 |
}
|
|
|
1714 |
}
|
|
|
1715 |
return serialNumbers;
|
|
|
1716 |
}
|
| 23650 |
amit.gupta |
1717 |
|
| 33520 |
amit.gupta |
1718 |
static final List<String> MOP_VOILATED_BRANDS = Arrays.asList("Live Demo", "Almost New");
|
|
|
1719 |
|
| 33665 |
ranu |
1720 |
private void validateDpPrice(int fofoId, Map<
|
|
|
1721 |
Integer, PriceModel> itemIdMopPriceMap, Map<Integer, CustomFofoOrderItem> itemIdCustomFofoLineItemMap) throws
|
|
|
1722 |
ProfitMandiBusinessException {
|
| 32420 |
amit.gupta |
1723 |
if (pricingService.getMopVoilatedRetailerIds().contains(fofoId)) return;
|
| 32145 |
tejbeer |
1724 |
for (Map.Entry<Integer, CustomFofoOrderItem> entry : itemIdCustomFofoLineItemMap.entrySet()) {
|
|
|
1725 |
int itemId = entry.getKey();
|
|
|
1726 |
CustomFofoOrderItem customFofoOrderItem = entry.getValue();
|
|
|
1727 |
LOGGER.info("CustomFofoOrderItem -- {}", customFofoOrderItem);
|
|
|
1728 |
PriceModel priceModel = itemIdMopPriceMap.get(itemId);
|
|
|
1729 |
Item item = itemRepository.selectById(itemId);
|
| 34994 |
ranu |
1730 |
// Comment this as of now 11 sep 2025 as per tarun sir
|
|
|
1731 |
/*if (!MOP_VOILATED_BRANDS.contains(item.getBrand()) && (item.getCategoryId() == ProfitMandiConstants.MOBILE_CATEGORY_ID || item.getCategoryId() == ProfitMandiConstants.TABLET_CATEGORY_ID || item.getCategoryId() == ProfitMandiConstants.LED_CATEGORY_ID) && customFofoOrderItem.getSerialNumberDetails().stream().filter(x -> org.apache.commons.lang.StringUtils.isNotEmpty(x.getSerialNumber())).collect(Collectors.toList()).size() > 0) {
|
| 32145 |
tejbeer |
1732 |
if (Utils.compareFloat(priceModel.getPrice(), customFofoOrderItem.getSellingPrice() + customFofoOrderItem.getDiscountAmount()) > 0) {
|
|
|
1733 |
throw new ProfitMandiBusinessException("Selling Price for ", item.getItemDescription(), "FFORDR_1010");
|
|
|
1734 |
}
|
|
|
1735 |
} else {
|
| 33520 |
amit.gupta |
1736 |
if (!MOP_VOILATED_BRANDS.contains(item.getBrand()) && priceModel.getPurchasePrice() > customFofoOrderItem.getSellingPrice()) {
|
| 32145 |
tejbeer |
1737 |
throw new ProfitMandiBusinessException("Selling Price", itemRepository.selectById(itemId).getItemDescription(), "Selling Price should not be less than DP");
|
|
|
1738 |
}
|
| 34994 |
ranu |
1739 |
}*/
|
| 32145 |
tejbeer |
1740 |
}
|
|
|
1741 |
}
|
| 24275 |
amit.gupta |
1742 |
|
| 33665 |
ranu |
1743 |
private void validateMopPrice(int fofoId, Map<
|
|
|
1744 |
Integer, PriceModel> itemIdMopPriceMap, Map<Integer, CustomFofoOrderItem> itemIdCustomFofoLineItemMap) throws
|
|
|
1745 |
ProfitMandiBusinessException {
|
| 32420 |
amit.gupta |
1746 |
if (pricingService.getMopVoilatedRetailerIds().contains(fofoId)) return;
|
| 32145 |
tejbeer |
1747 |
Map<Integer, Float> invalidMopItemIdPriceMap = new HashMap<>();
|
|
|
1748 |
for (Map.Entry<Integer, PriceModel> entry : itemIdMopPriceMap.entrySet()) {
|
|
|
1749 |
CustomFofoOrderItem customFofoOrderItem = itemIdCustomFofoLineItemMap.get(entry.getKey());
|
|
|
1750 |
Item item = itemRepository.selectById(customFofoOrderItem.getItemId());
|
| 33520 |
amit.gupta |
1751 |
if (!(MOP_VOILATED_BRANDS.contains(item.getBrand()) || item.getCategoryId() != ProfitMandiConstants.MOBILE_CATEGORY_ID || item.getCategoryId() != ProfitMandiConstants.TABLET_CATEGORY_ID) && customFofoOrderItem.getSellingPrice() + customFofoOrderItem.getDiscountAmount() < entry.getValue().getPrice()) {
|
| 32145 |
tejbeer |
1752 |
invalidMopItemIdPriceMap.put(entry.getKey(), customFofoOrderItem.getSellingPrice());
|
|
|
1753 |
}
|
|
|
1754 |
}
|
| 34994 |
ranu |
1755 |
// Comment this as of now 11 sep 2025 as per tarun sir
|
|
|
1756 |
/*if (!invalidMopItemIdPriceMap.isEmpty()) {
|
| 32145 |
tejbeer |
1757 |
LOGGER.error("Invalid itemIds selling prices{} should be greater than mop prices {}", invalidMopItemIdPriceMap, itemIdMopPriceMap);
|
|
|
1758 |
throw new ProfitMandiBusinessException("invalidMopItemIdPrice", invalidMopItemIdPriceMap, "FFORDR_1010");
|
| 34994 |
ranu |
1759 |
}*/
|
| 23650 |
amit.gupta |
1760 |
|
| 32145 |
tejbeer |
1761 |
}
|
| 23650 |
amit.gupta |
1762 |
|
| 33665 |
ranu |
1763 |
private void updateInventoryItemsAndScanRecord(Set<InventoryItem> inventoryItems, int fofoId, Map<
|
|
|
1764 |
Integer, Integer> inventoryItemQuantityUsed, int fofoOrderId) {
|
| 32145 |
tejbeer |
1765 |
for (InventoryItem inventoryItem : inventoryItems) {
|
|
|
1766 |
inventoryItem.setLastScanType(ScanType.SALE);
|
| 33087 |
amit.gupta |
1767 |
inventoryItem.setUpdateTimestamp(LocalDateTime.now());
|
| 32145 |
tejbeer |
1768 |
ScanRecord scanRecord = new ScanRecord();
|
|
|
1769 |
scanRecord.setInventoryItemId(inventoryItem.getId());
|
|
|
1770 |
scanRecord.setFofoId(fofoId);
|
|
|
1771 |
scanRecord.setOrderId(fofoOrderId);
|
|
|
1772 |
// correct this
|
|
|
1773 |
scanRecord.setQuantity(inventoryItemQuantityUsed.get(inventoryItem.getId()));
|
|
|
1774 |
scanRecord.setType(ScanType.SALE);
|
|
|
1775 |
scanRecordRepository.persist(scanRecord);
|
|
|
1776 |
purchaseReturnItemRepository.deleteById(inventoryItem.getId());
|
| 23650 |
amit.gupta |
1777 |
|
| 32145 |
tejbeer |
1778 |
}
|
|
|
1779 |
}
|
| 23650 |
amit.gupta |
1780 |
|
| 33665 |
ranu |
1781 |
private void createFofoLineItem(int fofoOrderItemId, Set<
|
|
|
1782 |
InventoryItem> inventoryItems, Map<Integer, Integer> inventoryItemIdQuantityUsed) {
|
| 32145 |
tejbeer |
1783 |
for (InventoryItem inventoryItem : inventoryItems) {
|
|
|
1784 |
FofoLineItem fofoLineItem = new FofoLineItem();
|
|
|
1785 |
fofoLineItem.setFofoOrderItemId(fofoOrderItemId);
|
|
|
1786 |
fofoLineItem.setSerialNumber(inventoryItem.getSerialNumber());
|
|
|
1787 |
fofoLineItem.setInventoryItemId(inventoryItem.getId());
|
|
|
1788 |
fofoLineItem.setQuantity(inventoryItemIdQuantityUsed.get(inventoryItem.getId()));
|
|
|
1789 |
fofoLineItemRepository.persist(fofoLineItem);
|
|
|
1790 |
}
|
|
|
1791 |
}
|
| 23650 |
amit.gupta |
1792 |
|
| 33665 |
ranu |
1793 |
private FofoOrderItem createAndGetFofoOrderItem(CustomFofoOrderItem customFofoOrderItem, int fofoOrderId, Map<
|
|
|
1794 |
Integer, Item> itemMap, Set<InventoryItem> inventoryItems, Integer stateId) throws
|
|
|
1795 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1796 |
FofoOrderItem fofoOrderItem = new FofoOrderItem();
|
|
|
1797 |
fofoOrderItem.setItemId(customFofoOrderItem.getItemId());
|
|
|
1798 |
fofoOrderItem.setQuantity(customFofoOrderItem.getQuantity());
|
|
|
1799 |
fofoOrderItem.setSellingPrice(customFofoOrderItem.getSellingPrice());
|
| 34381 |
vikas.jang |
1800 |
fofoOrderItem.setPendingOrderItemId(customFofoOrderItem.getPoiId());
|
| 32145 |
tejbeer |
1801 |
fofoOrderItem.setOrderId(fofoOrderId);
|
|
|
1802 |
TagListing tl = tagListingRepository.selectByItemId(customFofoOrderItem.getItemId());
|
|
|
1803 |
// In case listing gets removed rebill it using the selling price
|
|
|
1804 |
if (tl != null) {
|
|
|
1805 |
fofoOrderItem.setDp(tl.getSellingPrice());
|
|
|
1806 |
fofoOrderItem.setMop(tl.getMop());
|
|
|
1807 |
} else {
|
|
|
1808 |
fofoOrderItem.setDp(customFofoOrderItem.getSellingPrice());
|
|
|
1809 |
fofoOrderItem.setMop(customFofoOrderItem.getSellingPrice());
|
|
|
1810 |
}
|
|
|
1811 |
fofoOrderItem.setDiscount(customFofoOrderItem.getDiscountAmount());
|
| 24823 |
amit.gupta |
1812 |
|
| 32145 |
tejbeer |
1813 |
Item item = itemMap.get(customFofoOrderItem.getItemId());
|
|
|
1814 |
Map<Integer, GstRate> itemIdStateTaxRateMap = null;
|
|
|
1815 |
if (stateId != null) {
|
|
|
1816 |
itemIdStateTaxRateMap = stateGstRateRepository.getStateTaxRate(new ArrayList<>(itemMap.keySet()), stateId);
|
|
|
1817 |
} else {
|
|
|
1818 |
itemIdStateTaxRateMap = stateGstRateRepository.getIgstTaxRate(new ArrayList<>(itemMap.keySet()));
|
|
|
1819 |
}
|
|
|
1820 |
for (InventoryItem inventoryItem : inventoryItems) {
|
| 23650 |
amit.gupta |
1821 |
|
| 32145 |
tejbeer |
1822 |
fofoOrderItem.setIgstRate(itemIdStateTaxRateMap.get(inventoryItem.getItemId()).getIgstRate());
|
| 23650 |
amit.gupta |
1823 |
|
| 32145 |
tejbeer |
1824 |
fofoOrderItem.setCgstRate(itemIdStateTaxRateMap.get(inventoryItem.getItemId()).getCgstRate());
|
|
|
1825 |
fofoOrderItem.setSgstRate(itemIdStateTaxRateMap.get(inventoryItem.getItemId()).getSgstRate());
|
| 27516 |
amit.gupta |
1826 |
|
|
|
1827 |
|
| 32145 |
tejbeer |
1828 |
fofoOrderItem.setHsnCode(inventoryItem.getHsnCode());
|
|
|
1829 |
break;
|
|
|
1830 |
}
|
|
|
1831 |
fofoOrderItem.setBrand(item.getBrand());
|
|
|
1832 |
fofoOrderItem.setModelName(item.getModelName());
|
|
|
1833 |
fofoOrderItem.setModelNumber(item.getModelNumber());
|
|
|
1834 |
fofoOrderItem.setColor(item.getColor());
|
|
|
1835 |
fofoOrderItemRepository.persist(fofoOrderItem);
|
|
|
1836 |
return fofoOrderItem;
|
|
|
1837 |
}
|
| 27516 |
amit.gupta |
1838 |
|
| 33665 |
ranu |
1839 |
private FofoOrderItem getDummyFofoOrderItem(int itemId, int fofoOrderId, String serialNumber, Integer stateId) throws
|
|
|
1840 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1841 |
Item item = itemRepository.selectById(itemId);
|
|
|
1842 |
TagListing tl = tagListingRepository.selectByItemId(itemId);
|
|
|
1843 |
FofoOrderItem fofoOrderItem = new FofoOrderItem();
|
|
|
1844 |
fofoOrderItem.setItemId(itemId);
|
|
|
1845 |
fofoOrderItem.setQuantity(1);
|
|
|
1846 |
fofoOrderItem.setSellingPrice(tl.getMop());
|
|
|
1847 |
fofoOrderItem.setOrderId(fofoOrderId);
|
|
|
1848 |
// In case listing gets removed rebill it using the selling price
|
|
|
1849 |
fofoOrderItem.setDp(tl.getSellingPrice());
|
|
|
1850 |
fofoOrderItem.setMop(tl.getMop());
|
|
|
1851 |
fofoOrderItem.setDiscount(0);
|
| 27516 |
amit.gupta |
1852 |
|
| 32145 |
tejbeer |
1853 |
Map<Integer, GstRate> itemIdStateTaxRateMap = null;
|
|
|
1854 |
if (stateId != null) {
|
|
|
1855 |
itemIdStateTaxRateMap = stateGstRateRepository.getStateTaxRate(Arrays.asList(itemId), stateId);
|
|
|
1856 |
} else {
|
|
|
1857 |
itemIdStateTaxRateMap = stateGstRateRepository.getIgstTaxRate(Arrays.asList(itemId));
|
|
|
1858 |
}
|
| 27516 |
amit.gupta |
1859 |
|
| 32145 |
tejbeer |
1860 |
fofoOrderItem.setIgstRate(itemIdStateTaxRateMap.get(itemId).getIgstRate());
|
| 27516 |
amit.gupta |
1861 |
|
| 32145 |
tejbeer |
1862 |
fofoOrderItem.setCgstRate(itemIdStateTaxRateMap.get(itemId).getCgstRate());
|
|
|
1863 |
fofoOrderItem.setSgstRate(itemIdStateTaxRateMap.get(itemId).getSgstRate());
|
| 23650 |
amit.gupta |
1864 |
|
|
|
1865 |
|
| 32145 |
tejbeer |
1866 |
fofoOrderItem.setHsnCode(item.getHsnCode());
|
|
|
1867 |
fofoOrderItem.setBrand(item.getBrand());
|
|
|
1868 |
fofoOrderItem.setModelName(item.getModelName());
|
|
|
1869 |
fofoOrderItem.setModelNumber(item.getModelNumber());
|
|
|
1870 |
fofoOrderItem.setColor(item.getColor());
|
| 23650 |
amit.gupta |
1871 |
|
| 32145 |
tejbeer |
1872 |
Set<FofoLineItem> fofoLineItems = new HashSet<>();
|
|
|
1873 |
FofoLineItem fli = new FofoLineItem();
|
|
|
1874 |
fli.setQuantity(1);
|
|
|
1875 |
fli.setSerialNumber(serialNumber);
|
|
|
1876 |
fofoLineItems.add(fli);
|
|
|
1877 |
fofoOrderItem.setFofoLineItems(fofoLineItems);
|
| 22859 |
ashik.ali |
1878 |
|
| 32145 |
tejbeer |
1879 |
return fofoOrderItem;
|
|
|
1880 |
}
|
| 22859 |
ashik.ali |
1881 |
|
| 33665 |
ranu |
1882 |
private void updateCurrentInventorySnapshot(List<CurrentInventorySnapshot> currentInventorySnapshots,
|
|
|
1883 |
int fofoId, int itemId, int quantity) throws ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1884 |
for (CurrentInventorySnapshot currentInventorySnapshot : currentInventorySnapshots) {
|
|
|
1885 |
if (currentInventorySnapshot.getItemId() == itemId && currentInventorySnapshot.getFofoId() == fofoId) {
|
|
|
1886 |
currentInventorySnapshotRepository.updateAvailabilityByItemIdAndFofoId(itemId, fofoId, currentInventorySnapshot.getAvailability() - quantity);
|
|
|
1887 |
}
|
|
|
1888 |
}
|
|
|
1889 |
}
|
| 23650 |
amit.gupta |
1890 |
|
| 33665 |
ranu |
1891 |
private void createPaymentOptions(FofoOrder fofoOrder, Set<CustomPaymentOption> customPaymentOptions) throws
|
|
|
1892 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1893 |
for (CustomPaymentOption customPaymentOption : customPaymentOptions) {
|
|
|
1894 |
if (customPaymentOption.getAmount() > 0) {
|
|
|
1895 |
PaymentOptionTransaction paymentOptionTransaction = new PaymentOptionTransaction();
|
|
|
1896 |
paymentOptionTransaction.setReferenceId(fofoOrder.getId());
|
|
|
1897 |
paymentOptionTransaction.setPaymentOptionId(customPaymentOption.getPaymentOptionId());
|
|
|
1898 |
paymentOptionTransaction.setReferenceType(PaymentOptionReferenceType.ORDER);
|
|
|
1899 |
paymentOptionTransaction.setAmount(customPaymentOption.getAmount());
|
|
|
1900 |
paymentOptionTransaction.setFofoId(fofoOrder.getFofoId());
|
|
|
1901 |
paymentOptionTransactionRepository.persist(paymentOptionTransaction);
|
|
|
1902 |
}
|
|
|
1903 |
}
|
|
|
1904 |
}
|
| 22859 |
ashik.ali |
1905 |
|
| 33665 |
ranu |
1906 |
private FofoOrder createAndGetFofoOrder(int customerId, String customerGstNumber, int fofoId, String
|
| 34381 |
vikas.jang |
1907 |
documentNumber, float totalAmount, int customerAddressId, int poId) {
|
| 32145 |
tejbeer |
1908 |
FofoOrder fofoOrder = new FofoOrder();
|
|
|
1909 |
fofoOrder.setCustomerGstNumber(customerGstNumber);
|
|
|
1910 |
fofoOrder.setCustomerId(customerId);
|
|
|
1911 |
fofoOrder.setFofoId(fofoId);
|
| 34381 |
vikas.jang |
1912 |
fofoOrder.setPendingOrderId(poId);
|
| 32145 |
tejbeer |
1913 |
fofoOrder.setInvoiceNumber(documentNumber);
|
|
|
1914 |
fofoOrder.setTotalAmount(totalAmount);
|
|
|
1915 |
fofoOrder.setCustomerAddressId(customerAddressId);
|
|
|
1916 |
fofoOrderRepository.persist(fofoOrder);
|
|
|
1917 |
return fofoOrder;
|
|
|
1918 |
}
|
| 23650 |
amit.gupta |
1919 |
|
| 33665 |
ranu |
1920 |
private void validateItemsSerializedNonSerialized
|
|
|
1921 |
(List<Item> items, Map<Integer, CustomFofoOrderItem> customFofoOrderItemMap) throws
|
|
|
1922 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1923 |
List<Integer> invalidItemIdSerialNumbers = new ArrayList<Integer>();
|
|
|
1924 |
List<Integer> itemIdNonSerializedSerialNumbers = new ArrayList<Integer>();
|
|
|
1925 |
for (Item i : items) {
|
|
|
1926 |
CustomFofoOrderItem customFofoOrderItem = customFofoOrderItemMap.get(i.getId());
|
|
|
1927 |
if (i.getType().equals(ItemType.SERIALIZED)) {
|
|
|
1928 |
if (customFofoOrderItem == null || customFofoOrderItem.getSerialNumberDetails().isEmpty()) {
|
|
|
1929 |
invalidItemIdSerialNumbers.add(i.getId());
|
|
|
1930 |
}
|
|
|
1931 |
} else {
|
|
|
1932 |
Set<String> serialNumbers = this.serialNumberDetailsToSerialNumbers(customFofoOrderItem.getSerialNumberDetails());
|
|
|
1933 |
if (customFofoOrderItem == null || !serialNumbers.isEmpty()) {
|
|
|
1934 |
itemIdNonSerializedSerialNumbers.add(i.getId());
|
|
|
1935 |
}
|
|
|
1936 |
}
|
|
|
1937 |
}
|
| 23650 |
amit.gupta |
1938 |
|
| 32145 |
tejbeer |
1939 |
if (!invalidItemIdSerialNumbers.isEmpty()) {
|
|
|
1940 |
LOGGER.error("Invalid itemId's serialNumbers for serialized{}", invalidItemIdSerialNumbers);
|
|
|
1941 |
// itemId's are serialized you are saying these are not serialized
|
|
|
1942 |
throw new ProfitMandiBusinessException("invalidItemIdSerialNumbers", invalidItemIdSerialNumbers, "FFORDR_1013");
|
|
|
1943 |
}
|
| 22859 |
ashik.ali |
1944 |
|
| 32145 |
tejbeer |
1945 |
if (!itemIdNonSerializedSerialNumbers.isEmpty()) {
|
|
|
1946 |
LOGGER.error("Invalid itemId's serialNumbers for non serialized{}", itemIdNonSerializedSerialNumbers);
|
|
|
1947 |
// itemId's are non serialized you are saying these are serialized
|
|
|
1948 |
throw new ProfitMandiBusinessException("itemIdNonSerializedSerialNumbers", itemIdNonSerializedSerialNumbers, "FFORDR_1014");
|
|
|
1949 |
}
|
|
|
1950 |
}
|
| 22859 |
ashik.ali |
1951 |
|
| 33665 |
ranu |
1952 |
private void validateCurrentInventorySnapshotQuantities
|
|
|
1953 |
(List<CurrentInventorySnapshot> currentInventorySnapshots, Map<Integer, CustomFofoOrderItem> itemIdCustomFofoOrderItemMap) throws
|
|
|
1954 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
1955 |
if (itemIdCustomFofoOrderItemMap.keySet().size() != currentInventorySnapshots.size()) {
|
|
|
1956 |
throw new ProfitMandiBusinessException("quantiiesSize", currentInventorySnapshots.size(), "");
|
|
|
1957 |
}
|
|
|
1958 |
List<ItemIdQuantityAvailability> itemIdQuantityAvailabilities = new ArrayList<>(); // this is for error
|
|
|
1959 |
LOGGER.info("currentInventorySnapshots " + currentInventorySnapshots);
|
|
|
1960 |
LOGGER.info("CustomFofoLineItemMap {}", itemIdCustomFofoOrderItemMap);
|
|
|
1961 |
for (CurrentInventorySnapshot currentInventorySnapshot : currentInventorySnapshots) {
|
|
|
1962 |
CustomFofoOrderItem customFofoOrderItem = itemIdCustomFofoOrderItemMap.get(currentInventorySnapshot.getItemId());
|
|
|
1963 |
LOGGER.info("customFofoOrderItem {}", customFofoOrderItem);
|
|
|
1964 |
if (customFofoOrderItem.getQuantity() > currentInventorySnapshot.getAvailability()) {
|
|
|
1965 |
ItemIdQuantityAvailability itemIdQuantityAvailability = new ItemIdQuantityAvailability();
|
|
|
1966 |
itemIdQuantityAvailability.setItemId(customFofoOrderItem.getItemId());
|
|
|
1967 |
Quantity quantity = new Quantity();
|
|
|
1968 |
quantity.setAvailable(currentInventorySnapshot.getAvailability());
|
|
|
1969 |
quantity.setRequested(customFofoOrderItem.getQuantity());
|
|
|
1970 |
itemIdQuantityAvailability.setQuantity(quantity);
|
|
|
1971 |
itemIdQuantityAvailabilities.add(itemIdQuantityAvailability);
|
|
|
1972 |
}
|
|
|
1973 |
}
|
| 22859 |
ashik.ali |
1974 |
|
| 32145 |
tejbeer |
1975 |
if (!itemIdQuantityAvailabilities.isEmpty()) {
|
|
|
1976 |
// itemIdQuantity request is not valid
|
|
|
1977 |
LOGGER.error("Requested quantities should not be greater than currently available quantities {}", itemIdQuantityAvailabilities);
|
|
|
1978 |
throw new ProfitMandiBusinessException("itemIdQuantityAvailabilities", itemIdQuantityAvailabilities, "FFORDR_1015");
|
|
|
1979 |
}
|
|
|
1980 |
}
|
| 22859 |
ashik.ali |
1981 |
|
| 33665 |
ranu |
1982 |
private int getItemIdFromSerialNumber(Map<Integer, CustomFofoOrderItem> itemIdCustomFofoOrderItemMap, String
|
|
|
1983 |
serialNumber) {
|
| 32145 |
tejbeer |
1984 |
int itemId = 0;
|
|
|
1985 |
for (Map.Entry<Integer, CustomFofoOrderItem> entry : itemIdCustomFofoOrderItemMap.entrySet()) {
|
|
|
1986 |
Set<SerialNumberDetail> serialNumberDetails = entry.getValue().getSerialNumberDetails();
|
|
|
1987 |
for (SerialNumberDetail serialNumberDetail : serialNumberDetails) {
|
|
|
1988 |
if (serialNumberDetail.getSerialNumber().equals(serialNumber)) {
|
|
|
1989 |
itemId = entry.getKey();
|
|
|
1990 |
break;
|
|
|
1991 |
}
|
|
|
1992 |
}
|
|
|
1993 |
}
|
|
|
1994 |
return itemId;
|
|
|
1995 |
}
|
| 23650 |
amit.gupta |
1996 |
|
| 32145 |
tejbeer |
1997 |
private Map<Integer, Item> toItemMap(List<Item> items) {
|
|
|
1998 |
Function<Item, Integer> itemIdFunction = new Function<Item, Integer>() {
|
|
|
1999 |
@Override
|
|
|
2000 |
public Integer apply(Item item) {
|
|
|
2001 |
return item.getId();
|
|
|
2002 |
}
|
|
|
2003 |
};
|
|
|
2004 |
Function<Item, Item> itemFunction = new Function<Item, Item>() {
|
|
|
2005 |
@Override
|
|
|
2006 |
public Item apply(Item item) {
|
|
|
2007 |
return item;
|
|
|
2008 |
}
|
|
|
2009 |
};
|
|
|
2010 |
return items.stream().collect(Collectors.toMap(itemIdFunction, itemFunction));
|
|
|
2011 |
}
|
| 23650 |
amit.gupta |
2012 |
|
| 32145 |
tejbeer |
2013 |
private void setCustomerAddress(CustomerAddress customerAddress, CustomAddress customAddress) {
|
|
|
2014 |
customerAddress.setName(customAddress.getName());
|
|
|
2015 |
customerAddress.setLastName(customAddress.getLastName());
|
|
|
2016 |
customerAddress.setLine1(customAddress.getLine1());
|
|
|
2017 |
customerAddress.setLine2(customAddress.getLine2());
|
|
|
2018 |
customerAddress.setLandmark(customAddress.getLandmark());
|
|
|
2019 |
customerAddress.setCity(customAddress.getCity());
|
|
|
2020 |
customerAddress.setPinCode(customAddress.getPinCode());
|
|
|
2021 |
customerAddress.setState(customAddress.getState());
|
|
|
2022 |
customerAddress.setCountry(customAddress.getCountry());
|
|
|
2023 |
customerAddress.setPhoneNumber(customAddress.getPhoneNumber());
|
|
|
2024 |
}
|
| 23650 |
amit.gupta |
2025 |
|
| 32145 |
tejbeer |
2026 |
private CustomAddress createCustomAddress(Address address) {
|
|
|
2027 |
CustomAddress customAddress = new CustomAddress();
|
|
|
2028 |
customAddress.setName(address.getName());
|
|
|
2029 |
customAddress.setLine1(address.getLine1());
|
|
|
2030 |
customAddress.setLine2(address.getLine2());
|
|
|
2031 |
customAddress.setLandmark(address.getLandmark());
|
|
|
2032 |
customAddress.setCity(address.getCity());
|
|
|
2033 |
customAddress.setPinCode(address.getPinCode());
|
|
|
2034 |
customAddress.setState(address.getState());
|
|
|
2035 |
customAddress.setCountry(address.getCountry());
|
|
|
2036 |
customAddress.setPhoneNumber(address.getPhoneNumber());
|
|
|
2037 |
return customAddress;
|
|
|
2038 |
}
|
| 23650 |
amit.gupta |
2039 |
|
| 32145 |
tejbeer |
2040 |
private CustomAddress createCustomAddress(CustomerAddress customerAddress) {
|
|
|
2041 |
CustomAddress customAddress = new CustomAddress();
|
|
|
2042 |
customAddress.setName(customerAddress.getName());
|
|
|
2043 |
customAddress.setLastName(customerAddress.getLastName());
|
|
|
2044 |
customAddress.setLine1(customerAddress.getLine1());
|
|
|
2045 |
customAddress.setLine2(customerAddress.getLine2());
|
|
|
2046 |
customAddress.setLandmark(customerAddress.getLandmark());
|
|
|
2047 |
customAddress.setCity(customerAddress.getCity());
|
|
|
2048 |
customAddress.setPinCode(customerAddress.getPinCode());
|
|
|
2049 |
customAddress.setState(customerAddress.getState());
|
|
|
2050 |
customAddress.setCountry(customerAddress.getCountry());
|
|
|
2051 |
customAddress.setPhoneNumber(customerAddress.getPhoneNumber());
|
|
|
2052 |
return customAddress;
|
|
|
2053 |
}
|
| 23650 |
amit.gupta |
2054 |
|
| 33665 |
ranu |
2055 |
private CustomAddress createCustomAddressWithoutId(CustomCustomer customerAddress, CustomAddress
|
|
|
2056 |
retailerAddress) {
|
| 32627 |
ranu |
2057 |
CustomAddress customAddress = new CustomAddress();
|
|
|
2058 |
customAddress.setName(customerAddress.getFirstName());
|
|
|
2059 |
customAddress.setLastName(customerAddress.getLastName());
|
|
|
2060 |
customAddress.setLine1("");
|
|
|
2061 |
customAddress.setLine2("");
|
|
|
2062 |
customAddress.setLandmark("");
|
| 33089 |
amit.gupta |
2063 |
customAddress.setCity(retailerAddress.getCity());
|
|
|
2064 |
customAddress.setPinCode(retailerAddress.getPinCode());
|
|
|
2065 |
customAddress.setState(retailerAddress.getState());
|
| 32627 |
ranu |
2066 |
customAddress.setCountry("");
|
|
|
2067 |
customAddress.setPhoneNumber(customerAddress.getMobileNumber());
|
|
|
2068 |
return customAddress;
|
|
|
2069 |
}
|
|
|
2070 |
|
| 33665 |
ranu |
2071 |
private void validatePaymentOptionsAndTotalAmount(Set<CustomPaymentOption> customPaymentOptions,
|
|
|
2072 |
float totalAmount) throws ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2073 |
Set<Integer> paymentOptionIds = new HashSet<>();
|
| 23650 |
amit.gupta |
2074 |
|
| 32145 |
tejbeer |
2075 |
float calculatedAmount = 0;
|
|
|
2076 |
for (CustomPaymentOption customPaymentOption : customPaymentOptions) {
|
|
|
2077 |
paymentOptionIds.add(customPaymentOption.getPaymentOptionId());
|
|
|
2078 |
calculatedAmount = calculatedAmount + customPaymentOption.getAmount();
|
|
|
2079 |
}
|
|
|
2080 |
if (calculatedAmount != totalAmount) {
|
|
|
2081 |
LOGGER.warn("Error occured while validating payment options amount - {} != TotalAmount {}", calculatedAmount, totalAmount);
|
|
|
2082 |
throw new ProfitMandiBusinessException(ProfitMandiConstants.PAYMENT_OPTION_CALCULATED_AMOUNT, calculatedAmount, "FFORDR_1016");
|
|
|
2083 |
}
|
| 23418 |
ashik.ali |
2084 |
|
| 32145 |
tejbeer |
2085 |
List<Integer> foundPaymentOptionIds = paymentOptionRepository.selectIdsByIds(paymentOptionIds);
|
|
|
2086 |
if (foundPaymentOptionIds.size() != paymentOptionIds.size()) {
|
|
|
2087 |
paymentOptionIds.removeAll(foundPaymentOptionIds);
|
|
|
2088 |
throw new ProfitMandiBusinessException(ProfitMandiConstants.PAYMENT_OPTION_ID, paymentOptionIds, "FFORDR_1017");
|
|
|
2089 |
}
|
|
|
2090 |
}
|
| 25101 |
amit.gupta |
2091 |
|
| 32145 |
tejbeer |
2092 |
@Override
|
|
|
2093 |
public List<FofoOrderItem> getByOrderId(int orderId) throws ProfitMandiBusinessException {
|
|
|
2094 |
List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(orderId);
|
|
|
2095 |
if (!fofoOrderItems.isEmpty()) {
|
|
|
2096 |
List<FofoOrderItem> newFofoOrderItems = new ArrayList<>();
|
|
|
2097 |
Map<Integer, Set<FofoLineItem>> fofoOrderItemIdFofoLineItemsMap = this.toFofoOrderItemIdFofoLineItems(fofoOrderItems);
|
|
|
2098 |
Iterator<FofoOrderItem> fofoOrderItemsIterator = fofoOrderItems.iterator();
|
|
|
2099 |
while (fofoOrderItemsIterator.hasNext()) {
|
|
|
2100 |
FofoOrderItem fofoOrderItem = fofoOrderItemsIterator.next();
|
|
|
2101 |
fofoOrderItem.setFofoLineItems(fofoOrderItemIdFofoLineItemsMap.get(fofoOrderItem.getId()));
|
|
|
2102 |
newFofoOrderItems.add(fofoOrderItem);
|
|
|
2103 |
fofoOrderItemsIterator.remove();
|
|
|
2104 |
}
|
|
|
2105 |
fofoOrderItems = newFofoOrderItems;
|
|
|
2106 |
}
|
|
|
2107 |
return fofoOrderItems;
|
|
|
2108 |
}
|
| 25101 |
amit.gupta |
2109 |
|
| 32145 |
tejbeer |
2110 |
private Set<Integer> toFofoOrderItemIds(List<FofoOrderItem> fofoOrderItems) {
|
|
|
2111 |
Function<FofoOrderItem, Integer> fofoOrderItemToFofoOrderItemIdFunction = new Function<FofoOrderItem, Integer>() {
|
|
|
2112 |
@Override
|
|
|
2113 |
public Integer apply(FofoOrderItem fofoOrderItem) {
|
|
|
2114 |
return fofoOrderItem.getId();
|
|
|
2115 |
}
|
|
|
2116 |
};
|
|
|
2117 |
return fofoOrderItems.stream().map(fofoOrderItemToFofoOrderItemIdFunction).collect(Collectors.toSet());
|
|
|
2118 |
}
|
| 25101 |
amit.gupta |
2119 |
|
| 33665 |
ranu |
2120 |
private Map<Integer, Set<FofoLineItem>> toFofoOrderItemIdFofoLineItems(List<FofoOrderItem> fofoOrderItems) throws
|
|
|
2121 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2122 |
Set<Integer> fofoOrderItemIds = this.toFofoOrderItemIds(fofoOrderItems);
|
|
|
2123 |
List<FofoLineItem> fofoLineItems = fofoLineItemRepository.selectByFofoOrderItemIds(fofoOrderItemIds);
|
|
|
2124 |
Map<Integer, Set<FofoLineItem>> fofoOrderItemIdFofoLineItemsMap = new HashMap<>();
|
|
|
2125 |
for (FofoLineItem fofoLineItem : fofoLineItems) {
|
|
|
2126 |
if (!fofoOrderItemIdFofoLineItemsMap.containsKey(fofoLineItem.getFofoOrderItemId())) {
|
|
|
2127 |
Set<FofoLineItem> fofoLineItems2 = new HashSet<>();
|
|
|
2128 |
fofoLineItems2.add(fofoLineItem);
|
|
|
2129 |
fofoOrderItemIdFofoLineItemsMap.put(fofoLineItem.getFofoOrderItemId(), fofoLineItems2);
|
|
|
2130 |
} else {
|
|
|
2131 |
fofoOrderItemIdFofoLineItemsMap.get(fofoLineItem.getFofoOrderItemId()).add(fofoLineItem);
|
|
|
2132 |
}
|
|
|
2133 |
}
|
|
|
2134 |
return fofoOrderItemIdFofoLineItemsMap;
|
|
|
2135 |
}
|
| 25101 |
amit.gupta |
2136 |
|
| 32145 |
tejbeer |
2137 |
@Override
|
| 33665 |
ranu |
2138 |
public void updateCustomerDetails(CustomCustomer customCustomer, String invoiceNumber) throws
|
|
|
2139 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2140 |
FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
|
| 34718 |
aman.kumar |
2141 |
LOGGER.info("fofoOrder{}", fofoOrder);
|
| 32145 |
tejbeer |
2142 |
Customer customer = customerRepository.selectById(fofoOrder.getCustomerId());
|
| 34718 |
aman.kumar |
2143 |
LOGGER.info("customer{}", customer);
|
| 32145 |
tejbeer |
2144 |
customer.setFirstName(customCustomer.getFirstName());
|
|
|
2145 |
customer.setLastName(customCustomer.getLastName());
|
|
|
2146 |
customer.setMobileNumber(customCustomer.getMobileNumber());
|
|
|
2147 |
customer.setEmailId(customCustomer.getEmailId());
|
|
|
2148 |
customerRepository.persist(customer);
|
| 34338 |
ranu |
2149 |
if (fofoOrder.getCustomerAddressId() == 0) {
|
|
|
2150 |
CustomAddress customAddress = customCustomer.getAddress();
|
|
|
2151 |
|
|
|
2152 |
if (customAddress == null ||
|
|
|
2153 |
isNullOrEmpty(customAddress.getName()) ||
|
|
|
2154 |
isNullOrEmpty(customAddress.getLastName()) ||
|
|
|
2155 |
isNullOrEmpty(customAddress.getLine1()) ||
|
|
|
2156 |
isNullOrEmpty(customAddress.getCity()) ||
|
|
|
2157 |
isNullOrEmpty(customAddress.getPinCode()) ||
|
|
|
2158 |
isNullOrEmpty(customAddress.getState()) ||
|
| 34718 |
aman.kumar |
2159 |
// isNullOrEmpty(customAddress.getCountry()) ||
|
| 34338 |
ranu |
2160 |
isNullOrEmpty(customAddress.getPhoneNumber())) {
|
|
|
2161 |
throw new IllegalArgumentException("Required customer address fields are missing.");
|
|
|
2162 |
}
|
|
|
2163 |
|
|
|
2164 |
CustomerAddress customerAddress = new CustomerAddress();
|
|
|
2165 |
customerAddress.setCustomerId(fofoOrder.getCustomerId());
|
|
|
2166 |
customerAddress.setName(customAddress.getName());
|
|
|
2167 |
customerAddress.setLastName(customAddress.getLastName());
|
|
|
2168 |
customerAddress.setLine1(customAddress.getLine1());
|
|
|
2169 |
customerAddress.setLine2(customAddress.getLine2());
|
|
|
2170 |
customerAddress.setLandmark(customAddress.getLandmark());
|
|
|
2171 |
customerAddress.setCity(customAddress.getCity());
|
|
|
2172 |
customerAddress.setPinCode(customAddress.getPinCode());
|
|
|
2173 |
customerAddress.setState(customAddress.getState());
|
| 34718 |
aman.kumar |
2174 |
// customerAddress.setCountry(customAddress.getCountry());
|
| 34338 |
ranu |
2175 |
customerAddress.setPhoneNumber(customAddress.getPhoneNumber());
|
|
|
2176 |
customerAddressRepository.persist(customerAddress);
|
|
|
2177 |
fofoOrder.setCustomerAddressId(customerAddress.getId());
|
|
|
2178 |
|
|
|
2179 |
}
|
| 32145 |
tejbeer |
2180 |
CustomerAddress customerAddress = customerAddressRepository.selectById(fofoOrder.getCustomerAddressId());
|
|
|
2181 |
if (!customerAddress.getState().equalsIgnoreCase(customCustomer.getAddress().getState())) {
|
|
|
2182 |
List<FofoOrderItem> fofoOrderItems = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
2183 |
resetTaxation(fofoOrder.getFofoId(), customerAddress, fofoOrderItems);
|
|
|
2184 |
}
|
|
|
2185 |
this.setCustomerAddress(customerAddress, customCustomer.getAddress());
|
|
|
2186 |
fofoOrder.setCustomerGstNumber(customCustomer.getGstNumber());
|
|
|
2187 |
}
|
| 23638 |
amit.gupta |
2188 |
|
| 34338 |
ranu |
2189 |
private boolean isNullOrEmpty(String str) {
|
|
|
2190 |
return str == null || str.trim().isEmpty();
|
|
|
2191 |
}
|
|
|
2192 |
|
| 33665 |
ranu |
2193 |
private void resetTaxation(int fofoId, CustomerAddress customerAddress, List<FofoOrderItem> fofoOrderItems) throws
|
|
|
2194 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2195 |
int retailerAddressId = retailerRegisteredAddressRepository.selectAddressIdByRetailerId(fofoId);
|
| 23650 |
amit.gupta |
2196 |
|
| 32145 |
tejbeer |
2197 |
Address retailerAddress = addressRepository.selectById(retailerAddressId);
|
| 24275 |
amit.gupta |
2198 |
|
| 32145 |
tejbeer |
2199 |
Integer stateId = null;
|
|
|
2200 |
if (customerAddress.getState().equalsIgnoreCase(retailerAddress.getState())) {
|
|
|
2201 |
try {
|
|
|
2202 |
stateId = Long.valueOf(stateRepository.selectByName(customerAddress.getState()).getId()).intValue();
|
|
|
2203 |
} catch (Exception e) {
|
|
|
2204 |
LOGGER.error("Unable to get state rates");
|
|
|
2205 |
}
|
|
|
2206 |
}
|
|
|
2207 |
List<Integer> itemIds = fofoOrderItems.stream().map(x -> x.getItemId()).collect(Collectors.toList());
|
|
|
2208 |
final Map<Integer, GstRate> gstRates;
|
|
|
2209 |
if (stateId != null) {
|
|
|
2210 |
gstRates = stateGstRateRepository.getStateTaxRate(itemIds, stateId);
|
|
|
2211 |
} else {
|
|
|
2212 |
gstRates = stateGstRateRepository.getIgstTaxRate(itemIds);
|
|
|
2213 |
}
|
|
|
2214 |
for (FofoOrderItem fofoOrderItem : fofoOrderItems) {
|
|
|
2215 |
GstRate rate = gstRates.get(fofoOrderItem.getItemId());
|
|
|
2216 |
fofoOrderItem.setCgstRate(rate.getCgstRate());
|
|
|
2217 |
fofoOrderItem.setSgstRate(rate.getSgstRate());
|
|
|
2218 |
fofoOrderItem.setIgstRate(rate.getIgstRate());
|
|
|
2219 |
}
|
|
|
2220 |
}
|
|
|
2221 |
@Override
|
| 33665 |
ranu |
2222 |
public CustomerCreditNote badReturn(int fofoId, FoiBadReturnRequest foiBadReturnRequest) throws
|
|
|
2223 |
ProfitMandiBusinessException {
|
| 34141 |
tejus.loha |
2224 |
return this.badReturn(null, fofoId, foiBadReturnRequest);
|
|
|
2225 |
}
|
|
|
2226 |
@Override
|
|
|
2227 |
public CustomerCreditNote badReturn(String loginMail,int fofoId, FoiBadReturnRequest foiBadReturnRequest) throws
|
|
|
2228 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2229 |
FofoOrderItem foi = fofoOrderItemRepository.selectById(foiBadReturnRequest.getFofoOrderItemId());
|
|
|
2230 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(foi.getOrderId());
|
|
|
2231 |
if (fofoOrder.getFofoId() != fofoId) {
|
|
|
2232 |
throw new ProfitMandiBusinessException("Partner Auth", "", "Invalid Order");
|
|
|
2233 |
}
|
|
|
2234 |
int billedQty = foi.getQuantity() - customerReturnItemRepository.selectAllByOrderItemId(foi.getId()).size();
|
|
|
2235 |
if (foiBadReturnRequest.getMarkedBadArr().size() > billedQty) {
|
|
|
2236 |
throw new ProfitMandiBusinessException("Cant bad return more than what is billed", "", "Invalid Quantity");
|
|
|
2237 |
}
|
|
|
2238 |
List<CustomerReturnItem> customerReturnItems = new ArrayList<>();
|
|
|
2239 |
for (BadReturnRequest badReturnRequest : foiBadReturnRequest.getMarkedBadArr()) {
|
|
|
2240 |
CustomerReturnItem customerReturnItem = new CustomerReturnItem();
|
|
|
2241 |
customerReturnItem.setFofoId(fofoId);
|
|
|
2242 |
customerReturnItem.setFofoOrderItemId(foiBadReturnRequest.getFofoOrderItemId());
|
|
|
2243 |
customerReturnItem.setFofoOrderId(fofoOrder.getId());
|
|
|
2244 |
customerReturnItem.setRemarks(badReturnRequest.getRemarks());
|
|
|
2245 |
customerReturnItem.setInventoryItemId(badReturnRequest.getInventoryItemId());
|
|
|
2246 |
customerReturnItem.setQuantity(1);
|
|
|
2247 |
customerReturnItem.setType(ReturnType.BAD);
|
|
|
2248 |
// customerReturnItemRepository.persist(customerReturnItem);
|
|
|
2249 |
inventoryService.saleReturnInventoryItem(customerReturnItem);
|
|
|
2250 |
customerReturnItems.add(customerReturnItem);
|
|
|
2251 |
}
|
|
|
2252 |
CustomerCreditNote creditNote = generateCreditNote(fofoOrder, customerReturnItems);
|
|
|
2253 |
for (CustomerReturnItem customerReturnItem : customerReturnItems) {
|
|
|
2254 |
purchaseReturnService.returnInventoryItem(fofoId, false, customerReturnItem.getInventoryItemId(), ReturnType.BAD);
|
|
|
2255 |
}
|
|
|
2256 |
// This should cancel the order
|
|
|
2257 |
fofoOrder.setCancelledTimestamp(LocalDateTime.now());
|
|
|
2258 |
this.reverseScheme(fofoOrder);
|
|
|
2259 |
return creditNote;
|
|
|
2260 |
}
|
| 23638 |
amit.gupta |
2261 |
|
| 33665 |
ranu |
2262 |
private CustomerCreditNote generateCreditNote(FofoOrder
|
|
|
2263 |
fofoOrder, List<CustomerReturnItem> customerReturnItems) throws ProfitMandiBusinessException {
|
| 24275 |
amit.gupta |
2264 |
|
| 32145 |
tejbeer |
2265 |
InvoiceNumberGenerationSequence sequence = invoiceNumberGenerationSequenceRepository.selectByFofoId(fofoOrder.getFofoId());
|
|
|
2266 |
sequence.setCreditNoteSequence(sequence.getCreditNoteSequence() + 1);
|
|
|
2267 |
invoiceNumberGenerationSequenceRepository.persist(sequence);
|
| 24275 |
amit.gupta |
2268 |
|
| 32145 |
tejbeer |
2269 |
String creditNoteNumber = sequence.getPrefix() + "/" + sequence.getCreditNoteSequence();
|
|
|
2270 |
CustomerCreditNote creditNote = new CustomerCreditNote();
|
|
|
2271 |
creditNote.setCreditNoteNumber(creditNoteNumber);
|
|
|
2272 |
creditNote.setFofoId(fofoOrder.getFofoId());
|
|
|
2273 |
creditNote.setFofoOrderId(fofoOrder.getId());
|
|
|
2274 |
creditNote.setFofoOrderItemId(customerReturnItems.get(0).getFofoOrderItemId());
|
|
|
2275 |
creditNote.setSettlementType(SettlementType.UNSETTLED);
|
|
|
2276 |
customerCreditNoteRepository.persist(creditNote);
|
| 24275 |
amit.gupta |
2277 |
|
| 32145 |
tejbeer |
2278 |
for (CustomerReturnItem customerReturnItem : customerReturnItems) {
|
|
|
2279 |
customerReturnItem.setCreditNoteId(creditNote.getId());
|
|
|
2280 |
customerReturnItemRepository.persist(customerReturnItem);
|
|
|
2281 |
}
|
|
|
2282 |
// this.returnInventoryItems(inventoryItems, debitNote);
|
| 23655 |
amit.gupta |
2283 |
|
| 32145 |
tejbeer |
2284 |
return creditNote;
|
|
|
2285 |
}
|
| 23655 |
amit.gupta |
2286 |
|
| 32145 |
tejbeer |
2287 |
@Override
|
|
|
2288 |
public CreditNotePdfModel getCreditNotePdfModel(int customerCreditNoteId) throws ProfitMandiBusinessException {
|
|
|
2289 |
CustomerCreditNote creditNote = customerCreditNoteRepository.selectById(customerCreditNoteId);
|
|
|
2290 |
return getCreditNotePdfModel(creditNote);
|
|
|
2291 |
}
|
| 24275 |
amit.gupta |
2292 |
|
| 33665 |
ranu |
2293 |
private CreditNotePdfModel getCreditNotePdfModel(CustomerCreditNote creditNote) throws
|
|
|
2294 |
ProfitMandiBusinessException {
|
| 32145 |
tejbeer |
2295 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(creditNote.getFofoOrderId());
|
|
|
2296 |
List<CustomerReturnItem> customerReturnItems = customerReturnItemRepository.selectAllByCreditNoteId(creditNote.getId());
|
| 33090 |
amit.gupta |
2297 |
CustomRetailer customRetailer = retailerService.getFofoRetailer(fofoOrder.getFofoId());
|
|
|
2298 |
CustomCustomer customCustomer = getCustomCustomer(fofoOrder, customRetailer.getAddress());
|
| 24275 |
amit.gupta |
2299 |
|
| 33298 |
amit.gupta |
2300 |
List<CustomOrderItem> customerFofoOrderItems = new ArrayList<>();
|
| 23655 |
amit.gupta |
2301 |
|
| 32145 |
tejbeer |
2302 |
FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectById(creditNote.getFofoOrderItemId());
|
|
|
2303 |
float totalTaxRate = fofoOrderItem.getIgstRate() + fofoOrderItem.getSgstRate() + fofoOrderItem.getCgstRate();
|
|
|
2304 |
float taxableSellingPrice = fofoOrderItem.getSellingPrice() / (1 + totalTaxRate / 100);
|
|
|
2305 |
float taxableDiscountPrice = fofoOrderItem.getDiscount() / (1 + totalTaxRate / 100);
|
| 24275 |
amit.gupta |
2306 |
|
| 32145 |
tejbeer |
2307 |
CustomOrderItem customFofoOrderItem = new CustomOrderItem();
|
|
|
2308 |
customFofoOrderItem.setAmount(customerReturnItems.size() * (taxableSellingPrice - taxableDiscountPrice));
|
|
|
2309 |
customFofoOrderItem.setDescription(fofoOrderItem.getBrand() + " " + fofoOrderItem.getModelName() + " " + fofoOrderItem.getModelNumber() + "-" + fofoOrderItem.getColor());
|
| 24275 |
amit.gupta |
2310 |
|
| 32145 |
tejbeer |
2311 |
if (ItemType.SERIALIZED.equals(itemRepository.selectById(fofoOrderItem.getItemId()).getType())) {
|
|
|
2312 |
Set<Integer> inventoryItemIds = customerReturnItems.stream().map(x -> x.getInventoryItemId()).collect(Collectors.toSet());
|
|
|
2313 |
List<String> serialNumbers = inventoryItemRepository.selectByIds(inventoryItemIds).stream().map(x -> x.getSerialNumber()).collect(Collectors.toList());
|
|
|
2314 |
customFofoOrderItem.setDescription(
|
|
|
2315 |
customFofoOrderItem.getDescription() + "\n IMEIS - " + String.join(", ", serialNumbers));
|
|
|
2316 |
}
|
| 23638 |
amit.gupta |
2317 |
|
| 32145 |
tejbeer |
2318 |
customFofoOrderItem.setRate(taxableSellingPrice);
|
|
|
2319 |
customFofoOrderItem.setDiscount(taxableDiscountPrice);
|
|
|
2320 |
customFofoOrderItem.setQuantity(customerReturnItems.size());
|
|
|
2321 |
customFofoOrderItem.setNetAmount(
|
|
|
2322 |
(fofoOrderItem.getSellingPrice() - fofoOrderItem.getDiscount()) * customFofoOrderItem.getQuantity());
|
| 29707 |
tejbeer |
2323 |
|
| 32145 |
tejbeer |
2324 |
float igstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getIgstRate()) / 100;
|
|
|
2325 |
float cgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getCgstRate()) / 100;
|
|
|
2326 |
float sgstAmount = (customFofoOrderItem.getAmount() * fofoOrderItem.getSgstRate()) / 100;
|
|
|
2327 |
LOGGER.info("fofoOrderItem - {}", fofoOrderItem);
|
|
|
2328 |
customFofoOrderItem.setIgstRate(fofoOrderItem.getIgstRate());
|
|
|
2329 |
customFofoOrderItem.setIgstAmount(igstAmount);
|
|
|
2330 |
customFofoOrderItem.setCgstRate(fofoOrderItem.getCgstRate());
|
|
|
2331 |
customFofoOrderItem.setCgstAmount(cgstAmount);
|
|
|
2332 |
customFofoOrderItem.setSgstRate(fofoOrderItem.getSgstRate());
|
|
|
2333 |
customFofoOrderItem.setSgstAmount(sgstAmount);
|
|
|
2334 |
customFofoOrderItem.setHsnCode(fofoOrderItem.getHsnCode());
|
|
|
2335 |
customFofoOrderItem.setOrderId(1);
|
|
|
2336 |
customerFofoOrderItems.add(customFofoOrderItem);
|
| 29707 |
tejbeer |
2337 |
|
| 32145 |
tejbeer |
2338 |
InvoicePdfModel pdfModel = new InvoicePdfModel();
|
|
|
2339 |
pdfModel.setAuther("NSSPL");
|
|
|
2340 |
pdfModel.setCustomer(customCustomer);
|
|
|
2341 |
pdfModel.setInvoiceNumber(fofoOrder.getInvoiceNumber());
|
|
|
2342 |
pdfModel.setInvoiceDate(FormattingUtils.formatDate(fofoOrder.getCreateTimestamp()));
|
|
|
2343 |
pdfModel.setTitle("Credit Note");
|
|
|
2344 |
pdfModel.setRetailer(customRetailer);
|
|
|
2345 |
pdfModel.setTotalAmount(customFofoOrderItem.getNetAmount());
|
|
|
2346 |
pdfModel.setOrderItems(customerFofoOrderItems);
|
| 29707 |
tejbeer |
2347 |
|
| 32145 |
tejbeer |
2348 |
CreditNotePdfModel creditNotePdfModel = new CreditNotePdfModel();
|
|
|
2349 |
creditNotePdfModel.setCreditNoteDate(FormattingUtils.formatDate(creditNote.getCreateTimestamp()));
|
|
|
2350 |
creditNotePdfModel.setCreditNoteNumber(creditNote.getCreditNoteNumber());
|
|
|
2351 |
creditNotePdfModel.setPdfModel(pdfModel);
|
|
|
2352 |
return creditNotePdfModel;
|
|
|
2353 |
}
|
| 24264 |
amit.gupta |
2354 |
|
| 32145 |
tejbeer |
2355 |
// This will remove the order and maintain order record and reverse inventory
|
|
|
2356 |
// and scheme
|
|
|
2357 |
@Override
|
|
|
2358 |
public void cancelOrder(List<String> invoiceNumbers) throws ProfitMandiBusinessException {
|
|
|
2359 |
for (String invoiceNumber : invoiceNumbers) {
|
|
|
2360 |
// Cancel only when not cancelled
|
|
|
2361 |
FofoOrder fofoOrder = fofoOrderRepository.selectByInvoiceNumber(invoiceNumber);
|
|
|
2362 |
if (fofoOrder.getCancelledTimestamp() == null) {
|
|
|
2363 |
fofoOrder.setCancelledTimestamp(LocalDateTime.now());
|
|
|
2364 |
PaymentOptionTransaction paymentTransaction = new PaymentOptionTransaction();
|
|
|
2365 |
paymentTransaction.setAmount(-fofoOrder.getTotalAmount());
|
|
|
2366 |
paymentTransaction.setFofoId(fofoOrder.getFofoId());
|
|
|
2367 |
paymentTransaction.setReferenceId(fofoOrder.getId());
|
|
|
2368 |
paymentTransaction.setReferenceType(PaymentOptionReferenceType.ORDER);
|
|
|
2369 |
paymentTransaction.setPaymentOptionId(1);
|
|
|
2370 |
paymentOptionTransactionRepository.persist(paymentTransaction);
|
| 31030 |
amit.gupta |
2371 |
|
| 32145 |
tejbeer |
2372 |
List<FofoOrderItem> fois = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
2373 |
if (fois.size() > 0) {
|
|
|
2374 |
List<InventoryItem> inventoryItems = new ArrayList<>();
|
|
|
2375 |
fois.stream().forEach(x -> {
|
|
|
2376 |
x.getFofoLineItems().stream().forEach(y -> {
|
|
|
2377 |
inventoryService.rollbackInventory(y.getInventoryItemId(), y.getQuantity(), fofoOrder.getFofoId());
|
|
|
2378 |
inventoryItems.add(inventoryItemRepository.selectById(y.getInventoryItemId()));
|
|
|
2379 |
});
|
|
|
2380 |
});
|
|
|
2381 |
// if(invoice)
|
|
|
2382 |
this.reverseScheme(fofoOrder);
|
|
|
2383 |
}
|
|
|
2384 |
insuranceService.cancelInsurance(fofoOrder);
|
|
|
2385 |
}
|
|
|
2386 |
}
|
|
|
2387 |
}
|
| 31030 |
amit.gupta |
2388 |
|
| 32145 |
tejbeer |
2389 |
@Override
|
|
|
2390 |
public void reverseScheme(FofoOrder fofoOrder) throws ProfitMandiBusinessException {
|
|
|
2391 |
String reversalReason = "Order Rolledback/Cancelled/Returned for Invoice #" + fofoOrder.getInvoiceNumber();
|
|
|
2392 |
List<FofoOrderItem> fois = fofoOrderItemRepository.selectByOrderId(fofoOrder.getId());
|
|
|
2393 |
Set<Integer> inventoryItemIds = fois.stream().flatMap(x -> x.getFofoLineItems().stream().map(y -> y.getInventoryItemId())).collect(Collectors.toSet());
|
|
|
2394 |
List<InventoryItem> inventoryItems = inventoryItemRepository.selectByIds(inventoryItemIds);
|
| 34486 |
amit.gupta |
2395 |
schemeService.reverseSchemes(inventoryItems, fofoOrder.getId(), reversalReason, SchemeType.OUT_SCHEME_TYPES);
|
| 34504 |
amit.gupta |
2396 |
//schemeService.reverseSchemes(inventoryItems, fofoOrder.getId(), reversalReason, Arrays.asList(SchemeType.INVESTMENT));
|
| 32145 |
tejbeer |
2397 |
schemeService.reverseSchemes(inventoryItems, fofoOrder.getId(), reversalReason, Arrays.asList(SchemeType.SPECIAL_SUPPORT));
|
| 31030 |
amit.gupta |
2398 |
|
| 32145 |
tejbeer |
2399 |
}
|
| 24271 |
amit.gupta |
2400 |
|
| 32145 |
tejbeer |
2401 |
@Override
|
|
|
2402 |
public void reverseActivationScheme(List<Integer> inventoryItemIds) throws ProfitMandiBusinessException {
|
|
|
2403 |
List<InventoryItem> inventoryItems = inventoryItemRepository.selectAllByIds(inventoryItemIds);
|
|
|
2404 |
for (InventoryItem inventoryItem : inventoryItems) {
|
|
|
2405 |
List<FofoLineItem> fofoLineItems = fofoLineItemRepository.selectByInventoryItemId(inventoryItem.getId());
|
|
|
2406 |
FofoLineItem fofoLineItem = fofoLineItems.get(0);
|
|
|
2407 |
FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectById(fofoLineItem.getFofoOrderItemId());
|
|
|
2408 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(fofoOrderItem.getOrderId());
|
|
|
2409 |
String reversalReason = "Scheme rolled back as activation date is invalid for imei " + inventoryItem.getSerialNumber();
|
| 34319 |
amit.gupta |
2410 |
//schemeService.reverseSchemes(Arrays.asList(inventoryItem), fofoOrder.getId(), reversalReason, Arrays.asList(SchemeType.ACTIVATION));
|
| 32145 |
tejbeer |
2411 |
schemeService.reverseSchemes(Arrays.asList(inventoryItem), fofoOrder.getId(), reversalReason, Arrays.asList(SchemeType.SPECIAL_SUPPORT));
|
| 27083 |
amit.gupta |
2412 |
|
| 32145 |
tejbeer |
2413 |
}
|
| 24271 |
amit.gupta |
2414 |
|
| 32145 |
tejbeer |
2415 |
}
|
| 24271 |
amit.gupta |
2416 |
|
| 32145 |
tejbeer |
2417 |
@Override
|
|
|
2418 |
public float getSales(int fofoId, LocalDateTime startDate, LocalDateTime endDate) {
|
|
|
2419 |
Float sales = fofoOrderRepository.selectSaleSumGroupByFofoIds(startDate, endDate).get(fofoId);
|
|
|
2420 |
return sales == null ? 0f : sales;
|
|
|
2421 |
}
|
| 24271 |
amit.gupta |
2422 |
|
| 32145 |
tejbeer |
2423 |
@Override
|
|
|
2424 |
public LocalDateTime getMaxSalesDate(int fofoId, LocalDateTime startDate, LocalDateTime endDate) {
|
|
|
2425 |
LocalDateTime dateTime = fofoOrderRepository.selectMaxSaleDateGroupByFofoIds(startDate, endDate).get(fofoId);
|
|
|
2426 |
return dateTime;
|
|
|
2427 |
}
|
| 25101 |
amit.gupta |
2428 |
|
| 32145 |
tejbeer |
2429 |
@Override
|
|
|
2430 |
// Only being used internally
|
|
|
2431 |
public float getSales(int fofoId, LocalDate onDate) {
|
|
|
2432 |
LocalDateTime startTime = LocalDateTime.of(onDate, LocalTime.MIDNIGHT);
|
|
|
2433 |
LocalDateTime endTime = LocalDateTime.of(onDate, LocalTime.MIDNIGHT).plusDays(1);
|
|
|
2434 |
return this.getSales(fofoId, startTime, endTime);
|
|
|
2435 |
}
|
| 24917 |
tejbeer |
2436 |
|
| 32145 |
tejbeer |
2437 |
@Override
|
|
|
2438 |
public float getSales(LocalDateTime onDate) {
|
|
|
2439 |
// TODO Auto-generated method stub
|
|
|
2440 |
return 0;
|
|
|
2441 |
}
|
| 28166 |
tejbeer |
2442 |
|
| 32145 |
tejbeer |
2443 |
@Override
|
|
|
2444 |
public float getSales(LocalDateTime startDate, LocalDateTime endDate) {
|
|
|
2445 |
// TODO Auto-generated method stub
|
|
|
2446 |
return 0;
|
|
|
2447 |
}
|
| 28166 |
tejbeer |
2448 |
|
| 32145 |
tejbeer |
2449 |
@Override
|
|
|
2450 |
public boolean notifyColorChange(int orderId, int itemId) throws ProfitMandiBusinessException {
|
|
|
2451 |
Order order = orderRepository.selectById(orderId);
|
|
|
2452 |
saholicInventoryService.reservationCountByColor(itemId, order);
|
| 28166 |
tejbeer |
2453 |
|
| 32145 |
tejbeer |
2454 |
order.getLineItem().setItemId(itemId);
|
|
|
2455 |
Item item = itemRepository.selectById(itemId);
|
|
|
2456 |
order.getLineItem().setColor(item.getColor());
|
|
|
2457 |
return true;
|
|
|
2458 |
}
|
| 28166 |
tejbeer |
2459 |
|
| 32145 |
tejbeer |
2460 |
@Override
|
|
|
2461 |
public FofoOrder getOrderByInventoryItemId(int inventoryItemId) throws Exception {
|
|
|
2462 |
List<FofoLineItem> lineItems = fofoLineItemRepository.selectByInventoryItemId(inventoryItemId);
|
|
|
2463 |
if (lineItems.size() > 0) {
|
|
|
2464 |
FofoOrderItem fofoOrderItem = fofoOrderItemRepository.selectById(lineItems.get(0).getFofoOrderItemId());
|
|
|
2465 |
fofoOrderItem.setFofoLineItems(new HashSet<>(lineItems));
|
|
|
2466 |
FofoOrder fofoOrder = fofoOrderRepository.selectByOrderId(fofoOrderItem.getOrderId());
|
|
|
2467 |
fofoOrder.setOrderItem(fofoOrderItem);
|
|
|
2468 |
return fofoOrder;
|
|
|
2469 |
} else {
|
|
|
2470 |
throw new Exception(String.format("Could not find inventoryItemId - %s", inventoryItemId));
|
|
|
2471 |
}
|
|
|
2472 |
}
|
| 28166 |
tejbeer |
2473 |
|
| 32145 |
tejbeer |
2474 |
@Override
|
|
|
2475 |
public Map<Integer, Long> carryBagCreditCount(int fofoId) throws ProfitMandiBusinessException {
|
| 28166 |
tejbeer |
2476 |
|
| 32145 |
tejbeer |
2477 |
FofoStore fs = fofoStoreRepository.selectByRetailerId(fofoId);
|
|
|
2478 |
LocalDateTime lastCredit = fs.getBagsLastCredited();
|
|
|
2479 |
/*
|
|
|
2480 |
* long carryBagCount = 0; List<FofoOrder> fofoOrders =
|
|
|
2481 |
* fofoOrderRepository.selectByFofoIdBetweenCreatedTimeStamp(fofoId,
|
|
|
2482 |
* lastCredit.atStartOfDay(), LocalDate.now().plusDays(1).atStartOfDay()); for
|
|
|
2483 |
* (FofoOrder fo : fofoOrders) { carryBagCount +=
|
|
|
2484 |
* fofoOrderItemRepository.selectByOrderId(fo.getId()).stream() .filter(x ->
|
|
|
2485 |
* x.getSellingPrice() >= 12000).count();
|
|
|
2486 |
*
|
|
|
2487 |
* }
|
|
|
2488 |
*/
|
| 28166 |
tejbeer |
2489 |
|
| 32145 |
tejbeer |
2490 |
Session session = sessionFactory.getCurrentSession();
|
|
|
2491 |
CriteriaBuilder cb = session.getCriteriaBuilder();
|
|
|
2492 |
|
|
|
2493 |
CriteriaQuery<SimpleEntry> query = cb.createQuery(SimpleEntry.class);
|
|
|
2494 |
Root<FofoOrder> fofoOrder = query.from(FofoOrder.class);
|
|
|
2495 |
Root<FofoOrderItem> fofoOrderItem = query.from(FofoOrderItem.class);
|
|
|
2496 |
Root<TagListing> tagListingRoot = query.from(TagListing.class);
|
|
|
2497 |
Root<Item> itemRoot = query.from(Item.class);
|
|
|
2498 |
|
|
|
2499 |
Predicate p2 = cb.between(fofoOrder.get(ProfitMandiConstants.CREATE_TIMESTAMP), lastCredit, LocalDate.now().atStartOfDay());
|
|
|
2500 |
Predicate p3 = cb.isNull(fofoOrder.get("cancelledTimestamp"));
|
|
|
2501 |
Predicate joinPredicate = cb.and(
|
|
|
2502 |
cb.equal(fofoOrder.get(ProfitMandiConstants.ID), fofoOrderItem.get(ProfitMandiConstants.ORDER_ID)), cb.equal(fofoOrderItem.get("itemId"), tagListingRoot.get("itemId")), cb.equal(itemRoot.get("id"), tagListingRoot.get("itemId")), cb.equal(fofoOrder.get(ProfitMandiConstants.FOFO_ID), fofoId));
|
|
|
2503 |
ItemCriteria itemCriteria = new ItemCriteria();
|
|
|
2504 |
itemCriteria.setBrands(mongoClient.getMongoBrands(fofoId, null, 3).stream().map(x -> (String) x.get("name")).collect(Collectors.toList()));
|
|
|
2505 |
float startValue = 12000;
|
|
|
2506 |
itemCriteria.setStartPrice(startValue);
|
|
|
2507 |
itemCriteria.setEndPrice(0);
|
|
|
2508 |
itemCriteria.setFeaturedPhone(false);
|
|
|
2509 |
itemCriteria.setSmartPhone(true);
|
|
|
2510 |
itemCriteria.setCatalogIds(new ArrayList<>());
|
|
|
2511 |
itemCriteria.setExcludeCatalogIds(new ArrayList<>());
|
|
|
2512 |
Predicate itemPredicate = itemRepository.getItemPredicate(itemCriteria, cb, itemRoot, tagListingRoot.get("itemId"), tagListingRoot.get("sellingPrice"));
|
|
|
2513 |
Predicate finalPredicate = cb.and(itemPredicate, p2, p3, joinPredicate);
|
|
|
2514 |
query = query.multiselect(fofoOrder.get(ProfitMandiConstants.FOFO_ID), cb.count(fofoOrder)).where(finalPredicate).groupBy(fofoOrder.get(ProfitMandiConstants.FOFO_ID));
|
|
|
2515 |
List<SimpleEntry> simpleEntries = session.createQuery(query).getResultList();
|
|
|
2516 |
Map<Integer, Long> returnMap = new HashMap<>();
|
|
|
2517 |
|
|
|
2518 |
for (SimpleEntry simpleEntry : simpleEntries) {
|
|
|
2519 |
returnMap.put((Integer) simpleEntry.getKey(), (Long) simpleEntry.getValue());
|
|
|
2520 |
}
|
|
|
2521 |
return returnMap;
|
|
|
2522 |
|
|
|
2523 |
}
|
| 32607 |
ranu |
2524 |
|
|
|
2525 |
@Override
|
|
|
2526 |
public void createMissingScratchOffers() {
|
|
|
2527 |
List<FofoOrder> fofoOrders = fofoOrderRepository.selectFromSaleDate(LocalDate.of(2023, 11, 6).atStartOfDay());
|
|
|
2528 |
for (FofoOrder fofoOrder : fofoOrders) {
|
|
|
2529 |
if (fofoOrder.getCancelledTimestamp() == null) { // Check if cancelled_timestamp is not null
|
|
|
2530 |
try {
|
|
|
2531 |
this.createScratchOffer(fofoOrder.getFofoId(), fofoOrder.getInvoiceNumber(), fofoOrder.getCustomerId());
|
|
|
2532 |
} catch (Exception e) {
|
|
|
2533 |
LOGGER.error("Error while processing missing scratch offer invoice orderId", fofoOrder.getId());
|
|
|
2534 |
}
|
|
|
2535 |
}
|
|
|
2536 |
}
|
|
|
2537 |
}
|
| 32724 |
amit.gupta |
2538 |
|
|
|
2539 |
@Override
|
| 33665 |
ranu |
2540 |
public boolean refundOrder(int orderId, String refundedBy, String refundReason) throws
|
|
|
2541 |
ProfitMandiBusinessException {
|
| 32724 |
amit.gupta |
2542 |
/*def refund_order(order_id, refunded_by, reason):
|
|
|
2543 |
"""
|
|
|
2544 |
If the order is in RTO_RECEIVED_PRESTINE, DOA_CERT_VALID or DOA_CERT_INVALID state, it does the following:
|
|
|
2545 |
1. Creates a refund request for batch processing.
|
|
|
2546 |
2. Creates a return order for the warehouse executive to return the shipped material.
|
|
|
2547 |
3. Marks the current order as RTO_REFUNDED, DOA_VALID_REFUNDED or DOA_INVALID_REFUNDED final states.
|
|
|
2548 |
|
|
|
2549 |
If the order is in SUBMITTED_FOR_PROCESSING or INVENTORY_LOW state, it does the following:
|
|
|
2550 |
1. Creates a refund request for batch processing.
|
|
|
2551 |
2. Cancels the reservation of the item in the warehouse.
|
|
|
2552 |
3. Marks the current order as the REFUNDED final state.
|
|
|
2553 |
|
|
|
2554 |
For all COD orders, if the order is in INIT, SUBMITTED_FOR_PROCESSING or INVENTORY_LOW state, it does the following:
|
|
|
2555 |
1. Cancels the reservation of the item in the warehouse.
|
|
|
2556 |
2. Marks the current order as CANCELED.
|
|
|
2557 |
|
|
|
2558 |
In all cases, it updates the reason for cancellation or refund and the person who performed the action.
|
|
|
2559 |
|
|
|
2560 |
Returns True if it is successful, False otherwise.
|
|
|
2561 |
|
|
|
2562 |
Throws an exception if the order with the given id couldn't be found.
|
|
|
2563 |
|
|
|
2564 |
Parameters:
|
|
|
2565 |
- order_id
|
|
|
2566 |
- refunded_by
|
|
|
2567 |
- reason
|
|
|
2568 |
"""
|
|
|
2569 |
LOGGER.info("Refunding order id: {}", orderId);
|
|
|
2570 |
Order order = orderRepository.selectById(orderId);
|
|
|
2571 |
|
|
|
2572 |
if order.cod:
|
|
|
2573 |
logging.info("Refunding COD order with status " + str(order.status))
|
|
|
2574 |
status_transition = refund_status_transition
|
|
|
2575 |
if order.status not in status_transition.keys():
|
|
|
2576 |
raise TransactionServiceException(114, "This order can't be refunded")
|
|
|
2577 |
|
|
|
2578 |
if order.status in [OrderStatus.COD_VERIFICATION_PENDING, OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.INVENTORY_LOW, OrderStatus.LOW_INV_PO_RAISED, OrderStatus.LOW_INV_REVERSAL_IN_PROCESS, OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT, OrderStatus.ACCEPTED]:
|
|
|
2579 |
__update_inventory_reservation(order, refund=True)
|
|
|
2580 |
order.statusDescription = "Order Cancelled"
|
|
|
2581 |
#Shipment Id and Airway Bill No should be none in case of Cancellation
|
|
|
2582 |
order.logisticsTransactionId = None
|
|
|
2583 |
order.tracking_id = None
|
|
|
2584 |
order.airwaybill_no = None
|
|
|
2585 |
elif order.status == OrderStatus.BILLED:
|
|
|
2586 |
__create_return_order(order)
|
|
|
2587 |
order.statusDescription = "Order Cancelled"
|
|
|
2588 |
elif order.status in [OrderStatus.RTO_RECEIVED_PRESTINE, OrderStatus.RTO_RECEIVED_DAMAGED, OrderStatus.RTO_LOST_IN_TRANSIT]:
|
|
|
2589 |
if order.status != OrderStatus.RTO_LOST_IN_TRANSIT:
|
|
|
2590 |
__create_return_order(order)
|
|
|
2591 |
order.statusDescription = "RTO Refunded"
|
|
|
2592 |
elif order.status in [OrderStatus.LOST_IN_TRANSIT]:
|
|
|
2593 |
#__create_return_order(order)
|
|
|
2594 |
order.statusDescription = "Lost in Transit Refunded"
|
|
|
2595 |
elif order.status in [OrderStatus.DOA_CERT_INVALID, OrderStatus.DOA_CERT_VALID, OrderStatus.DOA_RECEIVED_DAMAGED, OrderStatus.DOA_LOST_IN_TRANSIT] :
|
|
|
2596 |
if order.status != OrderStatus.DOA_LOST_IN_TRANSIT:
|
|
|
2597 |
__create_return_order(order)
|
|
|
2598 |
__create_refund(order, 0, 'Should be unreachable for now')
|
|
|
2599 |
order.statusDescription = "DOA Refunded"
|
|
|
2600 |
elif order.status in [OrderStatus.RET_PRODUCT_UNUSABLE, OrderStatus.RET_PRODUCT_USABLE, OrderStatus.RET_RECEIVED_DAMAGED, OrderStatus.RET_LOST_IN_TRANSIT] :
|
|
|
2601 |
if order.status != OrderStatus.RET_LOST_IN_TRANSIT:
|
|
|
2602 |
__create_return_order(order)
|
|
|
2603 |
__create_refund(order, 0, 'Should be unreachable for now')
|
|
|
2604 |
order.statusDescription = "Return Refunded"
|
|
|
2605 |
elif order.status == OrderStatus.CANCEL_REQUEST_CONFIRMED:
|
|
|
2606 |
if order.previousStatus in [OrderStatus.COD_VERIFICATION_PENDING, OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.INVENTORY_LOW, OrderStatus.LOW_INV_PO_RAISED, OrderStatus.LOW_INV_REVERSAL_IN_PROCESS, OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT, OrderStatus.ACCEPTED]:
|
|
|
2607 |
__update_inventory_reservation(order, refund=True)
|
|
|
2608 |
order.statusDescription = "Order Cancelled on customer request"
|
|
|
2609 |
elif order.previousStatus == OrderStatus.BILLED:
|
|
|
2610 |
__create_return_order(order)
|
|
|
2611 |
order.statusDescription = "Order Cancelled on customer request"
|
|
|
2612 |
order.received_return_timestamp = datetime.datetime.now()
|
|
|
2613 |
else:
|
|
|
2614 |
status_transition = {OrderStatus.LOST_IN_TRANSIT : OrderStatus.LOST_IN_TRANSIT_REFUNDED,
|
|
|
2615 |
OrderStatus.RTO_RECEIVED_PRESTINE : OrderStatus.RTO_REFUNDED,
|
|
|
2616 |
OrderStatus.RTO_RECEIVED_DAMAGED : OrderStatus.RTO_DAMAGED_REFUNDED,
|
|
|
2617 |
OrderStatus.RTO_LOST_IN_TRANSIT : OrderStatus.RTO_LOST_IN_TRANSIT_REFUNDED,
|
|
|
2618 |
OrderStatus.DOA_CERT_INVALID : OrderStatus.DOA_INVALID_REFUNDED,
|
|
|
2619 |
OrderStatus.DOA_CERT_VALID : OrderStatus.DOA_VALID_REFUNDED,
|
|
|
2620 |
OrderStatus.DOA_RECEIVED_DAMAGED : OrderStatus.DOA_REFUNDED_RCVD_DAMAGED,
|
|
|
2621 |
OrderStatus.DOA_LOST_IN_TRANSIT : OrderStatus.DOA_REFUNDED_LOST_IN_TRANSIT,
|
|
|
2622 |
OrderStatus.RET_PRODUCT_UNUSABLE : OrderStatus.RET_PRODUCT_UNUSABLE_REFUNDED,
|
|
|
2623 |
OrderStatus.RET_PRODUCT_USABLE : OrderStatus.RET_PRODUCT_USABLE_REFUNDED,
|
|
|
2624 |
OrderStatus.RET_RECEIVED_DAMAGED : OrderStatus.RET_REFUNDED_RCVD_DAMAGED,
|
|
|
2625 |
OrderStatus.RET_LOST_IN_TRANSIT : OrderStatus.RET_REFUNDED_LOST_IN_TRANSIT,
|
|
|
2626 |
OrderStatus.SUBMITTED_FOR_PROCESSING : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2627 |
OrderStatus.INVENTORY_LOW : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2628 |
OrderStatus.LOW_INV_PO_RAISED : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2629 |
OrderStatus.LOW_INV_REVERSAL_IN_PROCESS : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2630 |
OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2631 |
OrderStatus.ACCEPTED : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2632 |
OrderStatus.BILLED : OrderStatus.CANCELLED_DUE_TO_LOW_INVENTORY,
|
|
|
2633 |
OrderStatus.CANCEL_REQUEST_CONFIRMED : OrderStatus.CANCELLED_ON_CUSTOMER_REQUEST,
|
|
|
2634 |
OrderStatus.PAYMENT_FLAGGED : OrderStatus.PAYMENT_FLAGGED_DENIED
|
|
|
2635 |
}
|
|
|
2636 |
if order.status not in status_transition.keys():
|
|
|
2637 |
raise TransactionServiceException(114, "This order can't be refunded")
|
|
|
2638 |
|
|
|
2639 |
if order.status in [OrderStatus.RTO_RECEIVED_PRESTINE, OrderStatus.RTO_RECEIVED_DAMAGED, OrderStatus.RTO_LOST_IN_TRANSIT] :
|
|
|
2640 |
if order.status != OrderStatus.RTO_LOST_IN_TRANSIT:
|
|
|
2641 |
__create_return_order(order)
|
|
|
2642 |
__create_refund(order, order.wallet_amount, 'Order #{0} is RTO refunded'.format(order.id))
|
|
|
2643 |
order.statusDescription = "RTO Refunded"
|
|
|
2644 |
#Start:- Added By Manish Sharma for Creating a new Ticket: Category- RTO Refund on 21-Jun-2013
|
|
|
2645 |
try:
|
|
|
2646 |
crmServiceClient = CRMClient().get_client()
|
|
|
2647 |
ticket =Ticket()
|
|
|
2648 |
activity = Activity()
|
|
|
2649 |
|
|
|
2650 |
description = "Creating Ticket for " + order.statusDescription + " Order"
|
|
|
2651 |
ticket.creatorId = 1
|
|
|
2652 |
ticket.assigneeId = 34
|
|
|
2653 |
ticket.category = TicketCategory.RTO_REFUND
|
|
|
2654 |
ticket.priority = TicketPriority.MEDIUM
|
|
|
2655 |
ticket.status = TicketStatus.OPEN
|
|
|
2656 |
ticket.description = description
|
|
|
2657 |
ticket.orderId = order.id
|
|
|
2658 |
|
|
|
2659 |
activity.creatorId = 1
|
|
|
2660 |
activity.ticketAssigneeId = ticket.assigneeId
|
|
|
2661 |
activity.type = ActivityType.OTHER
|
|
|
2662 |
activity.description = description
|
|
|
2663 |
activity.ticketCategory = ticket.category
|
|
|
2664 |
activity.ticketDescription = ticket.description
|
|
|
2665 |
activity.ticketPriority = ticket.priority
|
|
|
2666 |
activity.ticketStatus = ticket.status
|
|
|
2667 |
|
|
|
2668 |
ticket.customerId= order.customer_id
|
|
|
2669 |
ticket.customerEmailId = order.customer_email
|
|
|
2670 |
ticket.customerMobileNumber = order.customer_mobilenumber
|
|
|
2671 |
ticket.customerName = order.customer_name
|
|
|
2672 |
activity.customerId = ticket.customerId
|
|
|
2673 |
activity.customerEmailId = order.customer_email
|
|
|
2674 |
activity.customerMobileNumber = order.customer_mobilenumber
|
|
|
2675 |
activity.customerName = order.customer_name
|
|
|
2676 |
|
|
|
2677 |
crmServiceClient.insertTicket(ticket, activity)
|
|
|
2678 |
|
|
|
2679 |
except:
|
|
|
2680 |
print "Ticket for RTO Refund is not created."
|
|
|
2681 |
#End:- Added By Manish Sharma for Creating a new Ticket: Category- RTO Refund on 21-Jun-2013
|
|
|
2682 |
elif order.status in [OrderStatus.LOST_IN_TRANSIT]:
|
|
|
2683 |
#__create_return_order(order)
|
|
|
2684 |
__create_refund(order, order.wallet_amount, 'Order #{0} is Lost in Transit'.format(order.id))
|
|
|
2685 |
order.statusDescription = "Lost in Transit Refunded"
|
|
|
2686 |
elif order.status in [OrderStatus.DOA_CERT_INVALID, OrderStatus.DOA_CERT_VALID, OrderStatus.DOA_RECEIVED_DAMAGED, OrderStatus.DOA_LOST_IN_TRANSIT] :
|
|
|
2687 |
if order.status != OrderStatus.DOA_LOST_IN_TRANSIT:
|
|
|
2688 |
__create_return_order(order)
|
|
|
2689 |
__create_refund(order, 0, 'This should be unreachable')
|
|
|
2690 |
order.statusDescription = "DOA Refunded"
|
|
|
2691 |
elif order.status in [OrderStatus.RET_PRODUCT_UNUSABLE, OrderStatus.RET_PRODUCT_USABLE, OrderStatus.RET_RECEIVED_DAMAGED, OrderStatus.RET_LOST_IN_TRANSIT] :
|
|
|
2692 |
if order.status != OrderStatus.RET_LOST_IN_TRANSIT:
|
|
|
2693 |
__create_return_order(order)
|
|
|
2694 |
__create_refund(order, 0, 'This should be unreachable')
|
|
|
2695 |
order.statusDescription = "Return Refunded"
|
|
|
2696 |
elif order.status in [OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.INVENTORY_LOW, OrderStatus.LOW_INV_PO_RAISED, OrderStatus.LOW_INV_REVERSAL_IN_PROCESS, OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT, OrderStatus.ACCEPTED]:
|
|
|
2697 |
__update_inventory_reservation(order, refund=True)
|
|
|
2698 |
order.statusDescription = "Order Refunded"
|
|
|
2699 |
elif order.status == OrderStatus.CANCEL_REQUEST_CONFIRMED:
|
|
|
2700 |
if order.previousStatus in [OrderStatus.SUBMITTED_FOR_PROCESSING, OrderStatus.INVENTORY_LOW, OrderStatus.LOW_INV_PO_RAISED, OrderStatus.LOW_INV_REVERSAL_IN_PROCESS, OrderStatus.LOW_INV_NOT_AVAILABLE_AT_HOTSPOT, OrderStatus.PAYMENT_FLAGGED, OrderStatus.ACCEPTED]:
|
|
|
2701 |
__update_inventory_reservation(order, refund=True)
|
|
|
2702 |
order.statusDescription = "Order Cancelled on customer request"
|
|
|
2703 |
elif order.previousStatus == OrderStatus.BILLED:
|
|
|
2704 |
__create_refund(order, order.wallet_amount, 'Order #{0} Cancelled on customer request'.format(order.id))
|
|
|
2705 |
order.statusDescription = "Order Cancelled on customer request"
|
|
|
2706 |
|
|
|
2707 |
elif order.status == OrderStatus.PAYMENT_FLAGGED:
|
|
|
2708 |
__update_inventory_reservation(order, refund=True)
|
|
|
2709 |
order.statusDescription = "Order Cancelled due to payment flagged"
|
|
|
2710 |
|
|
|
2711 |
# For orders that are cancelled after being billed, we need to scan in the scanned out
|
|
|
2712 |
# inventory item and change availability accordingly
|
|
|
2713 |
inventoryClient = InventoryClient().get_client()
|
|
|
2714 |
warehouse = inventoryClient.getWarehouse(order.warehouse_id)
|
|
|
2715 |
if warehouse.billingType == BillingType.OURS or warehouse.billingType == BillingType.OURS_EXTERNAL:
|
|
|
2716 |
#Now BILLED orders can also be refunded directly with low inventory cancellations
|
|
|
2717 |
if order.status in [OrderStatus.BILLED, OrderStatus.SHIPPED_TO_LOGST, OrderStatus.SHIPPED_FROM_WH]:
|
|
|
2718 |
__create_refund(order, order.wallet_amount, reason)
|
|
|
2719 |
if order.status in [OrderStatus.BILLED, OrderStatus.SHIPPED_TO_LOGST, OrderStatus.SHIPPED_FROM_WH] or (order.status == OrderStatus.CANCEL_REQUEST_CONFIRMED and order.previousStatus in [OrderStatus.BILLED, OrderStatus.SHIPPED_TO_LOGST, OrderStatus.SHIPPED_FROM_WH]):
|
|
|
2720 |
lineitem = order.lineitems[0]
|
|
|
2721 |
catalogClient = CatalogClient().get_client()
|
|
|
2722 |
item = catalogClient.getItem(lineitem.item_id)
|
|
|
2723 |
warehouseClient = WarehouseClient().get_client()
|
|
|
2724 |
if warehouse.billingType == BillingType.OURS:
|
|
|
2725 |
if ItemType.SERIALIZED == item.type:
|
|
|
2726 |
for serial_number in str(lineitem.serial_number).split(','):
|
|
|
2727 |
warehouseClient.scanSerializedItemForOrder(serial_number, ScanType.SALE_RET, order.id, order.fulfilmentWarehouseId, 1, order.warehouse_id)
|
|
|
2728 |
else:
|
|
|
2729 |
warehouseClient.scanForOrder(None, ScanType.SALE_RET, lineitem.quantity, order.id, order.fulfilmentWarehouseId, order.warehouse_id)
|
|
|
2730 |
if warehouse.billingType == BillingType.OURS_EXTERNAL:
|
|
|
2731 |
warehouseClient.scanForOursExternalSaleReturn(order.id, lineitem.transfer_price)
|
|
|
2732 |
if order.freebieItemId:
|
|
|
2733 |
warehouseClient.scanfreebie(order.id, order.freebieItemId, 0, ScanType.SALE_RET)
|
|
|
2734 |
|
|
|
2735 |
order.status = status_transition[order.status]
|
|
|
2736 |
order.statusDescription = OrderStatus._VALUES_TO_NAMES[order.status]
|
|
|
2737 |
order.refund_timestamp = datetime.datetime.now()
|
|
|
2738 |
order.refunded_by = refunded_by
|
|
|
2739 |
order.refund_reason = reason
|
|
|
2740 |
#to re evaluate the shipping charge if any order is being cancelled.
|
|
|
2741 |
#_revaluate_shiping(order_id)
|
|
|
2742 |
session.commit()
|
|
|
2743 |
return True*/
|
|
|
2744 |
return true;
|
|
|
2745 |
}
|
|
|
2746 |
|
|
|
2747 |
@Autowired
|
|
|
2748 |
DebitNoteRepository debitNoteRepository;
|
|
|
2749 |
|
|
|
2750 |
//initiate refund only if the stock is returned
|
|
|
2751 |
|
| 25724 |
amit.gupta |
2752 |
}
|