item_builder 0.1.20 → 0.1.25
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/item_builder.rb +21 -4
- data/lib/item_builder/get_quantity_service.rb +5 -4
- data/lib/item_builder/modes.rb +4 -0
- data/lib/item_builder/modes/quantity/base.rb +3 -19
- data/lib/item_builder/modes/quantity_service.rb +17 -3
- data/lib/item_builder/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f7fe5aee9e5ad53c176f35a5f67d68dedcc66bb5475861c432865a1fe762252f
|
4
|
+
data.tar.gz: d1c4b8a261c1a9839d273b3a9c2fb4aad7a4a5ac62cfec359e9c7b5f1cbc38ed
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4293e1f028ae58b3a9b1925adad9f24a3e9aeb1262254691c6bda8138cce5dbddcba15011259bdfaadc473ef92b1cd9fa7bc5373f9de2608ee63f60401151bdd
|
7
|
+
data.tar.gz: b6a48cb493ad29427f51a8d85dc6abf529b2ad09ad8e6498aa606c8d940146f21a3c05d4c63e8d9d732f50171d9f08ed578aab8990ce43bf3243ba241eb7343c
|
data/lib/item_builder.rb
CHANGED
@@ -41,10 +41,11 @@ class ItemBuilder
|
|
41
41
|
|
42
42
|
def qty_params(listing)
|
43
43
|
{
|
44
|
-
listing: listing, wh_spaces: wh_spaces,
|
45
|
-
|
44
|
+
listing: listing, wh_spaces: wh_spaces, variants: variants,
|
45
|
+
stock_allocs: stock_allocs, variant_listings: variant_listings,
|
46
46
|
bundles: bundles, item_bundle_variants: item_bundle_variants,
|
47
|
-
existing_alloc_stocks: existing_alloc_stocks
|
47
|
+
existing_alloc_stocks: existing_alloc_stocks,
|
48
|
+
reserved_stocks: reserved_stocks
|
48
49
|
}
|
49
50
|
end
|
50
51
|
|
@@ -85,7 +86,7 @@ class ItemBuilder
|
|
85
86
|
|
86
87
|
def stock_allocs
|
87
88
|
@stock_allocs ||= VariantListingStockAllocation.where(
|
88
|
-
variant_association_id:
|
89
|
+
variant_association_id: vl_ids
|
89
90
|
)
|
90
91
|
end
|
91
92
|
|
@@ -114,4 +115,20 @@ class ItemBuilder
|
|
114
115
|
update: ItemBuilder::Modes::UpdateService
|
115
116
|
}
|
116
117
|
end
|
118
|
+
|
119
|
+
def order_host
|
120
|
+
url = ENV['ORDERS_URL'] || 'orders.forstok.com'
|
121
|
+
url + '/api/v3/item_line/reserved_stock'
|
122
|
+
end
|
123
|
+
|
124
|
+
def reserved_params
|
125
|
+
"account_id=#{listings[0].profile_channel_association_id}
|
126
|
+
&item_variant_ids=#{variant_ids.join(',')}"
|
127
|
+
end
|
128
|
+
|
129
|
+
def reserved_stocks
|
130
|
+
@reserved_stocks ||= JSON.parse(RestClient.get(
|
131
|
+
"#{order_host}?#{reserved_params}"
|
132
|
+
).body) if [3,13].include?(listings[0].channel_id)
|
133
|
+
end
|
117
134
|
end
|
@@ -78,7 +78,8 @@ class ItemBuilder
|
|
78
78
|
if @bundle_variants.present?
|
79
79
|
qty_list = []
|
80
80
|
@bundle_variants.each do |bvr|
|
81
|
-
|
81
|
+
warehouse_space = wh_space.select {|ws| ws.item_variant_id == bvr.variant_id }.first
|
82
|
+
qty = warehouse_space.quantity if warehouse_space.present?
|
82
83
|
qty ||= 0
|
83
84
|
qty = qty / bvr.unit
|
84
85
|
qty_list.push(qty)
|
@@ -89,8 +90,8 @@ class ItemBuilder
|
|
89
90
|
end
|
90
91
|
end
|
91
92
|
|
92
|
-
def
|
93
|
-
@
|
93
|
+
def wh_space
|
94
|
+
@wh_space ||= WarehouseSpace.where(item_variant_id: variant_ids)
|
94
95
|
end
|
95
96
|
|
96
97
|
def variant_ids
|
@@ -104,7 +105,7 @@ class ItemBuilder
|
|
104
105
|
def count_existing_alloc_stock
|
105
106
|
return 0 if @existing_allocated_stock.blank?
|
106
107
|
|
107
|
-
@existing_allocated_stock.sum(
|
108
|
+
@existing_allocated_stock.sum(&:quantity)
|
108
109
|
end
|
109
110
|
|
110
111
|
def count_alloc_rsvd_stock
|
data/lib/item_builder/modes.rb
CHANGED
@@ -15,6 +15,8 @@ class ItemBuilder
|
|
15
15
|
attr_reader :bundles
|
16
16
|
attr_reader :item_bundle_variants
|
17
17
|
attr_reader :existing_alloc_stocks
|
18
|
+
attr_reader :variant_listings
|
19
|
+
attr_reader :reserved_stocks
|
18
20
|
def initialize(args)
|
19
21
|
@listing = args.fetch(:listing)
|
20
22
|
@wh_spaces = args.fetch(:wh_spaces, [])
|
@@ -23,6 +25,8 @@ class ItemBuilder
|
|
23
25
|
@bundles = args.fetch(:bundles, [])
|
24
26
|
@item_bundle_variants = args.fetch(:item_bundle_variants, [])
|
25
27
|
@existing_alloc_stocks = args.fetch(:existing_alloc_stocks, [])
|
28
|
+
@variant_listings = args.fetch(:variant_listings, [])
|
29
|
+
@reserved_stocks = args.fetch(:reserved_stocks, [])
|
26
30
|
end
|
27
31
|
|
28
32
|
def base
|
@@ -6,30 +6,14 @@ class ItemBuilder
|
|
6
6
|
class Base
|
7
7
|
attr_reader :listing
|
8
8
|
attr_reader :available_quantity
|
9
|
+
attr_reader :reserved_stock
|
9
10
|
|
10
|
-
def initialize(listing, available_quantity)
|
11
|
+
def initialize(listing, available_quantity, reserved_stock)
|
11
12
|
raise 'listing is not set' if listing.nil?
|
12
13
|
|
13
14
|
@listing = listing
|
14
15
|
@available_quantity = available_quantity
|
15
|
-
|
16
|
-
|
17
|
-
def order_host
|
18
|
-
url = ENV['ORDERS_URL'] || 'orders.forstok.com'
|
19
|
-
url + '/api/v2/item_line/reserved_stock'
|
20
|
-
end
|
21
|
-
|
22
|
-
def reserved_params
|
23
|
-
"account_id=#{listing.profile_channel_association_id}
|
24
|
-
&item_variant_id=#{listing.variant_id}"
|
25
|
-
end
|
26
|
-
|
27
|
-
def reserved_stock
|
28
|
-
RestClient.get("#{order_host}?#{reserved_params}")
|
29
|
-
end
|
30
|
-
|
31
|
-
def apigateway_get
|
32
|
-
RestClient.get("#{host}?#{params}")
|
16
|
+
@reserved_stock = reserved_stock
|
33
17
|
end
|
34
18
|
end
|
35
19
|
end
|
@@ -37,13 +37,17 @@ class ItemBuilder
|
|
37
37
|
def qty_channel
|
38
38
|
class_name = "ItemBuilder::Modes::Quantity::#{channel_name}Service"
|
39
39
|
qty_channel_service = class_name.constantize
|
40
|
-
qty_channel_service.new(listing, available_quantity).perform
|
40
|
+
qty_channel_service.new(listing, available_quantity, reserved_stock).perform
|
41
41
|
end
|
42
42
|
|
43
43
|
def channel_name
|
44
44
|
QUANTITY_CHANNEL[listing.channel_id].to_s
|
45
45
|
end
|
46
46
|
|
47
|
+
def reserved_stock
|
48
|
+
reserved_stocks.find {|rs| rs['variant_id'] == listing.variant_id }['reserved_quantity']
|
49
|
+
end
|
50
|
+
|
47
51
|
def available_quantity
|
48
52
|
ItemBuilder::GetQuantityService.new(
|
49
53
|
listing: listing, variant: variant,
|
@@ -54,11 +58,21 @@ class ItemBuilder
|
|
54
58
|
end
|
55
59
|
|
56
60
|
def existing_allocated_stock
|
57
|
-
existing_alloc_stocks.
|
61
|
+
existing_alloc_stocks.map do |els|
|
62
|
+
if listings.pluck(:id).include?(els.variant_association_id)
|
63
|
+
els
|
64
|
+
end
|
65
|
+
end.compact
|
66
|
+
end
|
67
|
+
|
68
|
+
def listings
|
69
|
+
variant_listings.select {|vl| vl.variant_id == listing.variant_id}
|
58
70
|
end
|
59
71
|
|
60
72
|
def bundle_variants
|
61
|
-
|
73
|
+
if bundle.present?
|
74
|
+
item_bundle_variants.select {|ibv| ibv.bundle_id == bundle.id }
|
75
|
+
end
|
62
76
|
end
|
63
77
|
|
64
78
|
def bundle
|
data/lib/item_builder/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: item_builder
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.25
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- okaaryanata
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-01-
|
11
|
+
date: 2021-01-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|