Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
21714 ashik.ali 1
package com.spice.profitmandi.dao.entity.fofo;
21552 ashik.ali 2
 
21639 kshitij.so 3
import com.spice.profitmandi.dao.convertor.LocalDateTimeAttributeConverter;
21714 ashik.ali 4
import com.spice.profitmandi.dao.entity.catalog.Item;
5
import com.spice.profitmandi.dao.enumuration.fofo.ScanType;
30523 amit.gupta 6
import org.hibernate.annotations.UpdateTimestamp;
21552 ashik.ali 7
 
30523 amit.gupta 8
import javax.persistence.*;
9
import java.time.LocalDateTime;
10
import java.time.format.DateTimeFormatter;
11
import java.util.Objects;
12
 
21552 ashik.ali 13
@NamedQueries({
33115 shampa 14
        @NamedQuery(name = "InventoryItem.selectScannedCount", query = "select ii.itemId, sum(ii.initialQuantity) from InventoryItem ii "
15
                + "where ii.itemId in :itemIds and ii.fofoId = :fofoId and ii.purchaseId = :purchaseId group by ii.itemId"),
16
        //For Serialized models
17
        @NamedQuery(name = "InventoryItem.selectAllLineItemIdsByInventoryIds", query = "select new com.spice.profitmandi.dao.model.InventoryItemSaleModel(ii.id, lii.id)   from InventoryItem ii" +
18
                " join Purchase p on p.id = ii.purchaseId join Order o on o.invoiceNumber = p.purchaseReference" +
19
                " join LineItem li on li.orderId = o.id join LineItemImei lii on (lii.id=li.id and lii.serialNumber=ii.serialNumber)" +
33182 shampa 20
                "where ii.id in :inventoryItemIds"),
21
 
22
 
33306 amit.gupta 23
        @NamedQuery(name = "InventoryItem.selectPurchaseSummary",
24
                query = "select new com.spice.profitmandi.dao.model.ItemPurchaseSummaryModel(" +
25
                        "ii.id, o.billingTimestamp,o.invoiceNumber, cast(li.unitPrice as float), li.item)" +
33182 shampa 26
                        "from InventoryItem ii " +
27
                        "join Purchase p on p.id = ii.purchaseId " +
28
                        "join Order o on o.invoiceNumber = p.purchaseReference " +
29
                        "join LineItem li on li.orderId = o.id " +
30
                        "join LineItemImei lii on (lii.lineItemId=li.id and lii.serialNumber=ii.serialNumber) " +
33306 amit.gupta 31
                        "where ii.id in :inventoryItemIds")
33182 shampa 32
 
33
 
31163 amit.gupta 34
})
21552 ashik.ali 35
@Entity
31860 tejbeer 36
@Table(name = "fofo.inventory_item")
23983 amit.gupta 37
public class InventoryItem implements Comparable {
26213 amit.gupta 38
 
33115 shampa 39
    public InventoryItem(String serialNumber) {
40
        this.serialNumber = serialNumber;
41
    }
26213 amit.gupta 42
 
33115 shampa 43
    public InventoryItem() {
26213 amit.gupta 44
 
33115 shampa 45
    }
26213 amit.gupta 46
 
33115 shampa 47
    @Id
48
    @Column(name = "id", unique = true, updatable = false)
49
    @GeneratedValue(strategy = GenerationType.IDENTITY)
50
    private int id;
26213 amit.gupta 51
 
33115 shampa 52
    @Column(name = "item_id")
53
    private int itemId;
26213 amit.gupta 54
 
33115 shampa 55
    @Column(name = "fofo_id")
56
    private int fofoId;
26213 amit.gupta 57
 
33115 shampa 58
    @Column(name = "serial_number", length = 100)
59
    private String serialNumber;
26213 amit.gupta 60
 
33115 shampa 61
    @Column(name = "initial_quantity")
62
    private int initialQuantity;
26213 amit.gupta 63
 
33115 shampa 64
    @Column(name = "good_quantity")
65
    private int goodQuantity;
26213 amit.gupta 66
 
33115 shampa 67
    @Column(name = "bad_quantity")
68
    private int badQuantity;
31163 amit.gupta 69
 
33115 shampa 70
    @Column(name = "activation_timestamp")
71
    private LocalDateTime activationTimestamp;
26213 amit.gupta 72
 
33115 shampa 73
    @Column(name = "last_scan_type")
74
    @Enumerated(EnumType.STRING)
75
    private ScanType lastScanType;
26213 amit.gupta 76
 
33115 shampa 77
    @Column(name = "purchase_id")
78
    private int purchaseId;
26213 amit.gupta 79
 
33115 shampa 80
    @Column(name = "unit_price")
81
    private float unitPrice;
26213 amit.gupta 82
 
33115 shampa 83
    @Column(name = "price_drop_amount")
84
    private float priceDropAmount;
26213 amit.gupta 85
 
33115 shampa 86
    @Column(name = "buy_back", columnDefinition = "tinyint(1) default 1")
87
    private boolean buyBack;
26213 amit.gupta 88
 
33115 shampa 89
    @Column(name = "igst_rate")
90
    private float igstRate;
26213 amit.gupta 91
 
33115 shampa 92
    @Column(name = "cgst_rate")
93
    private float cgstRate;
26213 amit.gupta 94
 
33115 shampa 95
    @Column(name = "sgst_rate")
96
    private float sgstRate;
26213 amit.gupta 97
 
33115 shampa 98
    @Column(name = "hsn_code")
99
    private String hsnCode;
26213 amit.gupta 100
 
33115 shampa 101
    @Convert(converter = LocalDateTimeAttributeConverter.class)
102
    @Column(name = "create_timestamp")
103
    private LocalDateTime createTimestamp = LocalDateTime.now();
26213 amit.gupta 104
 
33115 shampa 105
    @Convert(converter = LocalDateTimeAttributeConverter.class)
106
    @Column(name = "update_timestamp")
107
    @UpdateTimestamp
108
    private LocalDateTime updateTimestamp = LocalDateTime.now();
26213 amit.gupta 109
 
33115 shampa 110
    @OneToOne(fetch = FetchType.LAZY)
111
    @JoinColumn(name = "item_id", insertable = false, updatable = false, nullable = false, referencedColumnName = "id")
112
    private Item item;
26213 amit.gupta 113
 
33115 shampa 114
    @OneToOne(fetch = FetchType.LAZY)
115
    @JoinColumn(name = "purchase_id", insertable = false, updatable = false, nullable = false, referencedColumnName = "id")
116
    private Purchase purchase;
26213 amit.gupta 117
 
33115 shampa 118
    public void setUnitPrice(float unitPrice) {
119
        this.unitPrice = unitPrice;
120
    }
26213 amit.gupta 121
 
33115 shampa 122
    @Transient
123
    private String itemDescription;
21552 ashik.ali 124
 
33115 shampa 125
    @Transient
126
    private LocalDateTime activatedTimestamp;
30523 amit.gupta 127
 
33115 shampa 128
    @Transient
129
    private boolean priceDropValidated = true;
30523 amit.gupta 130
 
33115 shampa 131
    @Transient
132
    private String pdValidationFailedReason = null;
30523 amit.gupta 133
 
33115 shampa 134
    @Override
135
    public boolean equals(Object o) {
136
        if (this == o) return true;
137
        if (o == null || getClass() != o.getClass()) return false;
138
        InventoryItem that = (InventoryItem) o;
139
        return id == that.id && itemId == that.itemId && fofoId == that.fofoId && initialQuantity == that.initialQuantity && goodQuantity == that.goodQuantity && badQuantity == that.badQuantity && purchaseId == that.purchaseId && Float.compare(that.unitPrice, unitPrice) == 0 && Float.compare(that.priceDropAmount, priceDropAmount) == 0 && buyBack == that.buyBack && Float.compare(that.igstRate, igstRate) == 0 && Float.compare(that.cgstRate, cgstRate) == 0 && Float.compare(that.sgstRate, sgstRate) == 0 && priceDropValidated == that.priceDropValidated && pdValidationFailedReason == that.pdValidationFailedReason && Objects.equals(serialNumber, that.serialNumber) && Objects.equals(activationTimestamp, that.activationTimestamp) && lastScanType == that.lastScanType && Objects.equals(hsnCode, that.hsnCode) && Objects.equals(createTimestamp, that.createTimestamp) && Objects.equals(updateTimestamp, that.updateTimestamp) && Objects.equals(item, that.item) && Objects.equals(purchase, that.purchase) && Objects.equals(itemDescription, that.itemDescription) && Objects.equals(activatedTimestamp, that.activatedTimestamp);
140
    }
30523 amit.gupta 141
 
33115 shampa 142
    @Override
143
    public int hashCode() {
144
        return Objects.hash(id, itemId, fofoId, serialNumber, initialQuantity, goodQuantity, badQuantity, activationTimestamp, lastScanType, purchaseId, unitPrice, priceDropAmount, buyBack, igstRate, cgstRate, sgstRate, hsnCode, createTimestamp, updateTimestamp, item, purchase, itemDescription, activatedTimestamp, priceDropValidated, pdValidationFailedReason);
145
    }
30523 amit.gupta 146
 
33115 shampa 147
    public String getPdValidationFailedReason() {
148
        return pdValidationFailedReason;
149
    }
30523 amit.gupta 150
 
33115 shampa 151
    public void setPdValidationFailedReason(String pdValidationFailedReason) {
152
        this.pdValidationFailedReason = pdValidationFailedReason;
153
    }
30523 amit.gupta 154
 
33115 shampa 155
    @Override
156
    public String toString() {
157
        return "InventoryItem{" +
158
                "id=" + id +
159
                ", itemId=" + itemId +
160
                ", fofoId=" + fofoId +
161
                ", serialNumber='" + serialNumber + '\'' +
162
                ", initialQuantity=" + initialQuantity +
163
                ", goodQuantity=" + goodQuantity +
164
                ", badQuantity=" + badQuantity +
165
                ", activationTimestamp=" + activationTimestamp +
166
                ", lastScanType=" + lastScanType +
167
                ", purchaseId=" + purchaseId +
168
                ", unitPrice=" + unitPrice +
169
                ", priceDropAmount=" + priceDropAmount +
170
                ", buyBack=" + buyBack +
171
                ", igstRate=" + igstRate +
172
                ", cgstRate=" + cgstRate +
173
                ", sgstRate=" + sgstRate +
174
                ", hsnCode='" + hsnCode + '\'' +
175
                ", createTimestamp=" + createTimestamp +
176
                ", updateTimestamp=" + updateTimestamp +
177
                ", item=" + item +
178
                ", purchase=" + purchase +
179
                ", itemDescription='" + itemDescription + '\'' +
180
                ", activatedTimestamp=" + activatedTimestamp +
181
                ", priceDropValidated=" + priceDropValidated +
182
                ", pdValidationFailedReason='" + pdValidationFailedReason + '\'' +
183
                '}';
184
    }
30523 amit.gupta 185
 
33115 shampa 186
    public LocalDateTime getActivatedTimestamp() {
187
        return activatedTimestamp;
188
    }
26304 amit.gupta 189
 
33115 shampa 190
    public void setActivatedTimestamp(LocalDateTime activatedTimestamp) {
191
        this.activatedTimestamp = activatedTimestamp;
192
    }
26304 amit.gupta 193
 
33115 shampa 194
    public int getId() {
195
        return id;
196
    }
21552 ashik.ali 197
 
33115 shampa 198
    public void setId(int id) {
199
        this.id = id;
200
    }
21552 ashik.ali 201
 
33115 shampa 202
    public int getItemId() {
203
        return itemId;
204
    }
21552 ashik.ali 205
 
33115 shampa 206
    public void setItemId(int itemId) {
207
        this.itemId = itemId;
208
    }
26213 amit.gupta 209
 
33115 shampa 210
    public void setFofoId(int fofoId) {
211
        this.fofoId = fofoId;
212
    }
21552 ashik.ali 213
 
33115 shampa 214
    public int getFofoId() {
215
        return fofoId;
216
    }
21552 ashik.ali 217
 
33115 shampa 218
    public String getSerialNumber() {
219
        return serialNumber == null ? serialNumber : serialNumber.toLowerCase();
220
    }
26213 amit.gupta 221
 
33115 shampa 222
    public void setSerialNumber(String serialNumber) {
223
        this.serialNumber = serialNumber == null ? serialNumber : serialNumber.toLowerCase();
224
    }
26213 amit.gupta 225
 
33115 shampa 226
    public int getInitialQuantity() {
227
        return initialQuantity;
228
    }
21552 ashik.ali 229
 
33115 shampa 230
    public float getUnitPrice() {
231
        return unitPrice;
232
    }
21984 kshitij.so 233
 
33115 shampa 234
    public void setUnitPrice(Float unitPrice) {
235
        this.unitPrice = unitPrice;
236
    }
21984 kshitij.so 237
 
33115 shampa 238
    public void setInitialQuantity(int initialQuantity) {
239
        this.initialQuantity = initialQuantity;
240
    }
26213 amit.gupta 241
 
33115 shampa 242
    public float getNetPrice() {
243
        return unitPrice - priceDropAmount;
244
    }
21552 ashik.ali 245
 
33115 shampa 246
    public int getGoodQuantity() {
247
        return goodQuantity;
248
    }
21552 ashik.ali 249
 
33115 shampa 250
    public void setGoodQuantity(int goodQuantity) {
251
        this.goodQuantity = goodQuantity;
252
    }
21552 ashik.ali 253
 
33115 shampa 254
    public int getBadQuantity() {
255
        return badQuantity;
256
    }
21552 ashik.ali 257
 
33115 shampa 258
    public void setBadQuantity(int badQuantity) {
259
        this.badQuantity = badQuantity;
260
    }
21552 ashik.ali 261
 
33115 shampa 262
    public ScanType getLastScanType() {
263
        return lastScanType;
264
    }
21552 ashik.ali 265
 
33115 shampa 266
    public void setLastScanType(ScanType lastScanType) {
267
        this.lastScanType = lastScanType;
268
    }
26213 amit.gupta 269
 
33115 shampa 270
    public int getPurchaseId() {
271
        return purchaseId;
272
    }
26213 amit.gupta 273
 
33115 shampa 274
    public void setPurchaseId(int purchaseId) {
275
        this.purchaseId = purchaseId;
276
    }
26213 amit.gupta 277
 
33115 shampa 278
    public float getPriceDropAmount() {
279
        return priceDropAmount;
280
    }
26213 amit.gupta 281
 
33115 shampa 282
    public void setPriceDropAmount(float priceDropAmount) {
283
        this.priceDropAmount = priceDropAmount;
284
    }
26213 amit.gupta 285
 
33115 shampa 286
    public float getIgstRate() {
287
        return igstRate;
288
    }
26213 amit.gupta 289
 
33115 shampa 290
    public void setIgstRate(float igstRate) {
291
        this.igstRate = igstRate;
292
    }
26213 amit.gupta 293
 
33115 shampa 294
    public float getCgstRate() {
295
        return cgstRate;
296
    }
26213 amit.gupta 297
 
33115 shampa 298
    public void setCgstRate(float cgstRate) {
299
        this.cgstRate = cgstRate;
300
    }
26213 amit.gupta 301
 
33115 shampa 302
    public float getSgstRate() {
303
        return sgstRate;
304
    }
26213 amit.gupta 305
 
33115 shampa 306
    public void setSgstRate(float sgstRate) {
307
        this.sgstRate = sgstRate;
308
    }
26213 amit.gupta 309
 
33115 shampa 310
    public String getHsnCode() {
311
        return hsnCode;
312
    }
26213 amit.gupta 313
 
33115 shampa 314
    public void setHsnCode(String hsnCode) {
315
        this.hsnCode = hsnCode;
316
    }
21552 ashik.ali 317
 
33115 shampa 318
    public LocalDateTime getCreateTimestamp() {
319
        return createTimestamp;
320
    }
21552 ashik.ali 321
 
33115 shampa 322
    public void setCreateTimestamp(LocalDateTime createTimestamp) {
323
        this.createTimestamp = createTimestamp;
324
    }
26213 amit.gupta 325
 
33115 shampa 326
    public LocalDateTime getUpdateTimestamp() {
327
        return updateTimestamp;
328
    }
26213 amit.gupta 329
 
33115 shampa 330
    public void setUpdateTimestamp(LocalDateTime updateTimestamp) {
331
        this.updateTimestamp = updateTimestamp;
332
    }
26213 amit.gupta 333
 
33115 shampa 334
    public Item getItem() {
335
        return item;
336
    }
26213 amit.gupta 337
 
33115 shampa 338
    public void setItem(Item item) {
339
        this.item = item;
340
    }
21602 ashik.ali 341
 
33115 shampa 342
    public boolean isBuyBack() {
343
        return buyBack;
344
    }
26213 amit.gupta 345
 
33115 shampa 346
    public void setBuyBack(boolean buyBack) {
347
        this.buyBack = buyBack;
348
    }
26213 amit.gupta 349
 
33115 shampa 350
    public Purchase getPurchase() {
351
        return purchase;
352
    }
26213 amit.gupta 353
 
33115 shampa 354
    public double getMarginPercentage(double amount) {
355
        return amount / this.getNetPrice() * (100 + this.getCgstRate() + this.getIgstRate() + this.getSgstRate());
356
    }
30652 amit.gupta 357
 
33115 shampa 358
    public void setPurchase(Purchase purchase) {
359
        this.purchase = purchase;
360
    }
26213 amit.gupta 361
 
33115 shampa 362
    public String getFormattedCreateTimestamp() {
363
        if (createTimestamp == null) {
364
            return null;
365
        }
366
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd-MM-yyyy HH:mm");
367
        return createTimestamp.format(formatter);
368
    }
26213 amit.gupta 369
 
33115 shampa 370
    public String getItemDescription() {
371
        return itemDescription;
372
    }
26213 amit.gupta 373
 
33115 shampa 374
    public void setItemDescription(String itemDescription) {
375
        this.itemDescription = itemDescription;
376
    }
26213 amit.gupta 377
 
33115 shampa 378
    public LocalDateTime getActivationTimestamp() {
379
        return activationTimestamp;
380
    }
29093 amit.gupta 381
 
33115 shampa 382
    public void setActivationTimestamp(LocalDateTime activationTimestamp) {
383
        this.activationTimestamp = activationTimestamp;
384
    }
29093 amit.gupta 385
 
33115 shampa 386
    public boolean isPriceDropValidated() {
387
        return priceDropValidated;
388
    }
29093 amit.gupta 389
 
33115 shampa 390
    public void setPriceDropValidated(boolean priceDropValidated) {
391
        this.priceDropValidated = priceDropValidated;
392
    }
29093 amit.gupta 393
 
33115 shampa 394
    @Override
395
    public int compareTo(Object o) {
396
        return o.hashCode() - this.hashCode();
397
    }
26213 amit.gupta 398
 
21552 ashik.ali 399
}