rerobe-js-orm 2.4.79 → 2.4.84
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/factories/Product/ProductFromFormState.js +1 -0
- package/lib/form-states/Product/ProductFormState.d.ts +1 -0
- package/lib/form-states/Product/ProductFormState.js +24 -1
- package/lib/helpers/OrderHelpers.js +9 -0
- package/lib/helpers/ReRobeProductHelpers.js +14 -3
- package/lib/models/Order.js +1 -1
- package/lib/models/Product.js +1 -0
- package/lib/types/rerobe-product-types.d.ts +8 -0
- package/package.json +1 -1
|
@@ -76,6 +76,7 @@ class ProductFromFormState extends ProductFactory_1.default {
|
|
|
76
76
|
discountValue: props.fields.discountValue.inputValue || '',
|
|
77
77
|
selectedForClearance: ((_r = props.props) === null || _r === void 0 ? void 0 : _r.selectedForClearance) || '',
|
|
78
78
|
locationIds: props.fields.locationIds.selectedValues || [],
|
|
79
|
+
inventoryLocations: props.fields.inventoryLocations.selectedValues || [],
|
|
79
80
|
};
|
|
80
81
|
const timestampAttributes = {
|
|
81
82
|
sellRequestReviewTimestamp: (_s = props.props) === null || _s === void 0 ? void 0 : _s.sellRequestReviewTimestamp,
|
|
@@ -71,6 +71,7 @@ class ProductFormState extends FormState_1.default {
|
|
|
71
71
|
this.fields.vendorName = this.fieldFactory('singleSelect', 'vendorName');
|
|
72
72
|
this.fields.rfidTag = this.fieldFactory('textInput', 'rfidTag');
|
|
73
73
|
this.fields.locationIds = this.fieldFactory('multiSelect', 'locationIds');
|
|
74
|
+
this.fields.inventoryLocations = this.fieldFactory('multiSelect', 'inventoryLocations');
|
|
74
75
|
this.fields.featuredCollections = this.fieldFactory('multiSelect', 'featuredCollections');
|
|
75
76
|
this.fields.tags = this.fieldFactory('multiSelect', 'tags');
|
|
76
77
|
}
|
|
@@ -413,6 +414,24 @@ class ProductFormState extends FormState_1.default {
|
|
|
413
414
|
}
|
|
414
415
|
return '';
|
|
415
416
|
}
|
|
417
|
+
inventoryLocationsChangeHandler(val) {
|
|
418
|
+
const { id, incomingAmount, availableAmount } = val;
|
|
419
|
+
const existingIds = this.fields.inventoryLocations.selectedValues.map((i) => i.id);
|
|
420
|
+
if (existingIds.includes(id)) {
|
|
421
|
+
const foundInd = this.fields.inventoryLocations.selectedValues.findIndex((i) => i.id === id);
|
|
422
|
+
const foundI = this.fields.inventoryLocations.selectedValues[foundInd];
|
|
423
|
+
// Delete case: val is exact same object
|
|
424
|
+
if (incomingAmount === foundI.incomingAmount && availableAmount === foundI.availableAmount) {
|
|
425
|
+
this.fields.inventoryLocations.selectedValues.splice(foundInd, 1);
|
|
426
|
+
}
|
|
427
|
+
else {
|
|
428
|
+
this.fields.inventoryLocations.selectedValues.splice(foundInd, 1, val);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
else {
|
|
432
|
+
this.multiSelectChangeHandler('inventoryLocations', val);
|
|
433
|
+
}
|
|
434
|
+
}
|
|
416
435
|
fieldFactory(fieldType, fieldKey, fieldOptions) {
|
|
417
436
|
let options = fieldOptions || [];
|
|
418
437
|
let hidden = false;
|
|
@@ -499,6 +518,7 @@ class ProductFormState extends FormState_1.default {
|
|
|
499
518
|
};
|
|
500
519
|
}
|
|
501
520
|
if (fieldType === 'multiSelect') {
|
|
521
|
+
let onChangeHandler = (val) => this.multiSelectChangeHandler(fieldKey, val);
|
|
502
522
|
if (fieldKey === 'productStyle') {
|
|
503
523
|
options = this.setProductStylesFromCategoryAndType(this.props.productCategory, this.props.productType);
|
|
504
524
|
if (this.props.productStyle && this.props.productStyle.length > 0) {
|
|
@@ -608,12 +628,15 @@ class ProductFormState extends FormState_1.default {
|
|
|
608
628
|
}
|
|
609
629
|
hidden = this.props.productCategory !== 'Clothing' || this.props.productType === 'Jeans';
|
|
610
630
|
}
|
|
631
|
+
if (fieldKey === 'inventoryLocations') {
|
|
632
|
+
onChangeHandler = (val) => this.inventoryLocationsChangeHandler(val);
|
|
633
|
+
}
|
|
611
634
|
return {
|
|
612
635
|
options,
|
|
613
636
|
hidden,
|
|
614
637
|
selectedValues: this.props[fieldKey] || [],
|
|
615
638
|
valid: this.props[fieldKey].length > 0,
|
|
616
|
-
onChangeHandler
|
|
639
|
+
onChangeHandler,
|
|
617
640
|
};
|
|
618
641
|
}
|
|
619
642
|
if (fieldType === 'textInput') {
|
|
@@ -16,6 +16,15 @@ class OrderHelpers {
|
|
|
16
16
|
}
|
|
17
17
|
getShippingTypeFromShopifyObj(shippingLines) {
|
|
18
18
|
if (shippingLines && shippingLines[0]) {
|
|
19
|
+
if (shippingLines[0].title === 'Local pickup') {
|
|
20
|
+
return Order_1.default.SHIPPING_TYPES.localPickUp;
|
|
21
|
+
}
|
|
22
|
+
if (shippingLines[0].title === 'Shipping fee') {
|
|
23
|
+
return Order_1.default.SHIPPING_TYPES.shipping;
|
|
24
|
+
}
|
|
25
|
+
if (shippingLines[0].title === 'Localy delivery') {
|
|
26
|
+
return Order_1.default.SHIPPING_TYPES.localDelivery;
|
|
27
|
+
}
|
|
19
28
|
return shippingLines[0].price_set.shop_money.amount > 0
|
|
20
29
|
? Order_1.default.SHIPPING_TYPES.localDelivery
|
|
21
30
|
: Order_1.default.SHIPPING_TYPES.localPickUp;
|
|
@@ -226,7 +226,7 @@ class ReRobeProductHelpers {
|
|
|
226
226
|
static createTimestampsForStates(productObj) {
|
|
227
227
|
const docFieldsToUpdate = {};
|
|
228
228
|
if (productObj) {
|
|
229
|
-
const { status, sellRequestReviewDraftTimestamp, sellRequestReviewTimestamp, rejectedTimestamp, holdTimestamp, acceptedTimestamp, sellerToDropOffTimestamp, sellerToShipTimestamp, sellerToGetPickUpTimestamp, qualityControlTimestamp, pendingPublicationTimestamp, listedTimestamp, clearanceTimestamp, reservedTimestamp, soldTimestamp, soldSellerToBePaidTimestamp, soldSellerPaidTimestamp, returnedTimestamp, sellerSelfRejectTimestamp, liquidationRequestedTimestamp, sellerLiquidatedTimestamp, } = productObj;
|
|
229
|
+
const { dateSold, status, sellRequestReviewDraftTimestamp, sellRequestReviewTimestamp, rejectedTimestamp, holdTimestamp, acceptedTimestamp, sellerToDropOffTimestamp, sellerToShipTimestamp, sellerToGetPickUpTimestamp, qualityControlTimestamp, pendingPublicationTimestamp, listedTimestamp, clearanceTimestamp, reservedTimestamp, soldTimestamp, soldSellerToBePaidTimestamp, soldSellerPaidTimestamp, returnedTimestamp, sellerSelfRejectTimestamp, liquidationRequestedTimestamp, sellerLiquidatedTimestamp, } = productObj;
|
|
230
230
|
if (status === ProductStateManager_1.default.PRODUCT_STATES.sellRequestReviewDraft && !sellRequestReviewDraftTimestamp) {
|
|
231
231
|
docFieldsToUpdate.sellRequestReviewDraftTimestamp = new Date().getTime();
|
|
232
232
|
}
|
|
@@ -270,10 +270,21 @@ class ReRobeProductHelpers {
|
|
|
270
270
|
docFieldsToUpdate.soldTimestamp = new Date().getTime();
|
|
271
271
|
}
|
|
272
272
|
if (status === ProductStateManager_1.default.PRODUCT_STATES.soldSellerToBePaid && !soldSellerToBePaidTimestamp) {
|
|
273
|
-
|
|
273
|
+
const timeNow = new Date().getTime();
|
|
274
|
+
docFieldsToUpdate.soldSellerToBePaidTimestamp = timeNow;
|
|
275
|
+
if (!soldTimestamp) {
|
|
276
|
+
docFieldsToUpdate.soldTimestamp = timeNow;
|
|
277
|
+
}
|
|
274
278
|
}
|
|
275
279
|
if (status === ProductStateManager_1.default.PRODUCT_STATES.soldSellerPaid && !soldSellerPaidTimestamp) {
|
|
276
|
-
|
|
280
|
+
const timeNow = new Date().getTime();
|
|
281
|
+
docFieldsToUpdate.soldSellerPaidTimestamp = timeNow;
|
|
282
|
+
if (!soldSellerToBePaidTimestamp) {
|
|
283
|
+
docFieldsToUpdate.soldSellerToBePaidTimestamp = timeNow;
|
|
284
|
+
}
|
|
285
|
+
if (!soldTimestamp) {
|
|
286
|
+
docFieldsToUpdate.soldTimestamp = timeNow;
|
|
287
|
+
}
|
|
277
288
|
}
|
|
278
289
|
if (status === ProductStateManager_1.default.PRODUCT_STATES.returned && !returnedTimestamp) {
|
|
279
290
|
docFieldsToUpdate.returnedTimestamp = new Date().getTime();
|
package/lib/models/Order.js
CHANGED
package/lib/models/Product.js
CHANGED
|
@@ -80,6 +80,7 @@ class Product extends Base_1.default {
|
|
|
80
80
|
discountValue: (props === null || props === void 0 ? void 0 : props.discountValue) || '',
|
|
81
81
|
selectedForClearance: (props === null || props === void 0 ? void 0 : props.selectedForClearance) || '',
|
|
82
82
|
locationIds: (props === null || props === void 0 ? void 0 : props.locationIds) || [],
|
|
83
|
+
inventoryLocations: (props === null || props === void 0 ? void 0 : props.inventoryLocations) || [],
|
|
83
84
|
};
|
|
84
85
|
this.timestampAttributes = {
|
|
85
86
|
sellRequestReviewDraftTimestamp: (props === null || props === void 0 ? void 0 : props.sellRequestReviewDraftTimestamp)
|
|
@@ -69,6 +69,7 @@ declare type ProductConsignmentAttributes = {
|
|
|
69
69
|
discountValue: string;
|
|
70
70
|
selectedForClearance: string;
|
|
71
71
|
locationIds?: string[];
|
|
72
|
+
inventoryLocations: InventoryLocation[];
|
|
72
73
|
};
|
|
73
74
|
declare type ProductTimestampAttributes = {
|
|
74
75
|
sellRequestReviewTimestamp: number | null;
|
|
@@ -188,6 +189,7 @@ declare type ProductConsignmentAttributesFormFields = {
|
|
|
188
189
|
discountType: SingleSelectFormField<string>;
|
|
189
190
|
discountValue: TextInputFormField<string>;
|
|
190
191
|
locationIds: MultiSelectFormField<string>;
|
|
192
|
+
inventoryLocations: MultiSelectFormField<InventoryLocation>;
|
|
191
193
|
};
|
|
192
194
|
declare type ProductFormFields = ProductAttributesFormFields & ProductFilterAttributesFormFields & ProductConsignmentAttributesFormFields;
|
|
193
195
|
interface ParamsForBuildProductInputObjForShopify {
|
|
@@ -221,3 +223,9 @@ declare type ProductLineItem = {
|
|
|
221
223
|
image: string;
|
|
222
224
|
quantity: number;
|
|
223
225
|
};
|
|
226
|
+
declare type InventoryLocation = {
|
|
227
|
+
id: string;
|
|
228
|
+
name: string;
|
|
229
|
+
incomingAmount: number;
|
|
230
|
+
availableAmount: number;
|
|
231
|
+
};
|