spree_cm_commissioner 2.7.1.pre.pre8 → 2.8.0

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: aead7dbe0a1723c8c08996fe74ba64198a19134aeac915fb77f45b96979ce9a8
4
- data.tar.gz: c591f41addd0555cd853de9cd10a3326a72a23e1069429f20f4564582b5a4b6f
3
+ metadata.gz: 6a112e266f3450b307b12ea0ac4a28a4d5ee9a3eff8e2650d6de5c93c1b73df3
4
+ data.tar.gz: 3285f85273a6c1d19e2eb4b23f087eccca371af1f6cd48282c22042b97d4d8d8
5
5
  SHA512:
6
- metadata.gz: 608c9766931ce6858cacd8118d1c9c384f3a013724136226ef24d3b796b0bfd7890c72541c8716d500814226daedbe762bac6d2e20ca8c158b4e53c112fb9346
7
- data.tar.gz: 3ca15cc172c6c7219eb56309fc7665fd8775692770e37dfec4325fdfe3c605fa7e2eca80dd5f6e8efcb6bb7ec2dcd02396a3ba629b776a38aafd7240267769c6
6
+ metadata.gz: 81c02501bd52647acbc65cc34e6ebcfa309b349a1215a0eadde56101b8d508877cb96e08c044612863ea458be0e70ff018311dc5be59806bc67f97a7cff99061
7
+ data.tar.gz: feb4e3ef254c32769245dd1053ab3ec987f73250db800bd36373bf40e5d9e9ea981586b92a57fbe8bbcfc22ab09bf5cf7343b1a9b8d35bf672e1057510be11ad
data/Gemfile.lock CHANGED
@@ -34,7 +34,7 @@ GIT
34
34
  PATH
35
35
  remote: .
36
36
  specs:
37
- spree_cm_commissioner (2.7.1.pre.pre8)
37
+ spree_cm_commissioner (2.8.0)
38
38
  activerecord-multi-tenant
39
39
  activerecord_json_validator (~> 2.1, >= 2.1.3)
40
40
  aws-sdk-cloudfront
@@ -38,8 +38,12 @@ module Spree
38
38
  render_error_payload(e.message, 422)
39
39
  end
40
40
 
41
- private
41
+ # override
42
+ def default_resource_includes
43
+ ['pricing_adjustments']
44
+ end
42
45
 
46
+ # override
43
47
  def resource_serializer
44
48
  SpreeCmCommissioner::V2::Storefront::PricingPreviewSerializer
45
49
  end
@@ -19,6 +19,7 @@ module Spree
19
19
 
20
20
  cached_result = Rails.cache.fetch(cache_key, expires_in: 60.seconds) do
21
21
  result = SpreeCmCommissioner::PricingModels::Preview.call(order_context: order_context)
22
+
22
23
  if result.success?
23
24
  {
24
25
  success: true,
@@ -43,6 +44,12 @@ module Spree
43
44
 
44
45
  private
45
46
 
47
+ # override
48
+ def default_resource_includes
49
+ ['pricing_adjustments']
50
+ end
51
+
52
+ # override
46
53
  def resource_serializer
47
54
  Spree::V2::Tenant::PricingPreviewSerializer
48
55
  end
@@ -10,6 +10,7 @@
10
10
  # Supported types:
11
11
  # - boolean
12
12
  # - string
13
+ # - text
13
14
  # - integer
14
15
  # - array
15
16
  # - datetime
@@ -105,7 +106,7 @@ module SpreeCmCommissioner
105
106
  ActiveModel::Type::Boolean.new.cast(raw_value)
106
107
  when :integer
107
108
  raw_value.to_i
108
- when :string
109
+ when :string, :text
109
110
  raw_value.to_s
110
111
  when :array
111
112
  Array(raw_value)
@@ -136,6 +137,14 @@ module SpreeCmCommissioner
136
137
  end
137
138
  when :string
138
139
  validates key, length: { maximum: 255 }, allow_nil: true
140
+ when :text
141
+ validate do
142
+ metadata = send(column_name) || {}
143
+ raw_value = metadata[key.to_s]
144
+ next if raw_value.nil?
145
+
146
+ errors.add(key, 'must be a string') unless raw_value.is_a?(String)
147
+ end
139
148
  when :array
140
149
  validate do
141
150
  metadata = send(column_name) || {}
@@ -1,6 +1,7 @@
1
1
  module SpreeCmCommissioner
2
2
  class Route < Base
3
3
  include SpreeCmCommissioner::RouteType
4
+ include SpreeCmCommissioner::StoreMetadata
4
5
 
5
6
  belongs_to :vendor, class_name: 'Spree::Vendor', optional: false
6
7
  belongs_to :tenant, class_name: 'SpreeCmCommissioner::Tenant', optional: true
@@ -29,6 +30,8 @@ module SpreeCmCommissioner
29
30
 
30
31
  delegate :multi_leg?, to: :route_stops
31
32
 
33
+ store_public_metadata :terms_and_conditions, :text
34
+
32
35
  def prices_for(currency)
33
36
  route_prices.for_currency(currency)
34
37
  end
@@ -0,0 +1,10 @@
1
+ module Spree
2
+ module V2
3
+ module Tenant
4
+ class PreviewAdjustmentSerializer < BaseSerializer
5
+ attributes :label, :amount, :action_type, :pricing_action,
6
+ :adjustable_type, :adjustable_id, :line_item_id, :guest_ids
7
+ end
8
+ end
9
+ end
10
+ end
@@ -6,9 +6,7 @@ module Spree
6
6
 
7
7
  attributes :item_total, :total, :pricing_adjustment_total
8
8
 
9
- attribute :pricing_adjustments do |object|
10
- object.pricing_adjustments.map(&:to_h)
11
- end
9
+ has_many :pricing_adjustments, serializer: Spree::V2::Tenant::PreviewAdjustmentSerializer
12
10
  end
13
11
  end
14
12
  end
@@ -0,0 +1,10 @@
1
+ module SpreeCmCommissioner
2
+ module V2
3
+ module Storefront
4
+ class PreviewAdjustmentSerializer < BaseSerializer
5
+ attributes :label, :amount, :action_type, :pricing_action,
6
+ :adjustable_type, :adjustable_id, :line_item_id, :guest_ids
7
+ end
8
+ end
9
+ end
10
+ end
@@ -6,9 +6,7 @@ module SpreeCmCommissioner
6
6
 
7
7
  attributes :item_total, :total, :pricing_adjustment_total
8
8
 
9
- attribute :pricing_adjustments do |object|
10
- object.pricing_adjustments.map(&:to_h)
11
- end
9
+ has_many :pricing_adjustments, serializer: SpreeCmCommissioner::V2::Storefront::PreviewAdjustmentSerializer
12
10
  end
13
11
  end
14
12
  end
@@ -4,9 +4,6 @@ module SpreeCmCommissioner
4
4
  prepend ::Spree::ServiceModule::Base
5
5
 
6
6
  def call(order:)
7
- return failure(:order_is_not_persisted) unless order.persisted?
8
- return failure(:order_not_completed) unless order.completed?
9
-
10
7
  order_context = OrderContext.build_from_context(fallback_order: order)
11
8
 
12
9
  preview_result = Preview.call(order_context: order_context)
@@ -100,6 +100,7 @@ module Spree
100
100
  vendor_id
101
101
  route_type
102
102
  route_stops
103
+ terms_and_conditions
103
104
  ]
104
105
  end
105
106
  end
@@ -0,0 +1,6 @@
1
+ class AddPublicAndPrivateMetadataToCmRoutes < ActiveRecord::Migration[7.0]
2
+ def change
3
+ add_column :cm_routes, :public_metadata, :jsonb, default: {}, if_not_exists: true
4
+ add_column :cm_routes, :private_metadata, :jsonb, default: {}, if_not_exists: true
5
+ end
6
+ end
@@ -20,8 +20,6 @@ module SpreeCmCommissioner
20
20
  end
21
21
 
22
22
  def self.load!(params)
23
- raise ArgumentError, 'order_context is required' if params.nil?
24
-
25
23
  params = params.to_h.deep_symbolize_keys
26
24
  number = params[:number].presence
27
25
  token = params[:token].presence
@@ -1,10 +1,11 @@
1
1
  module SpreeCmCommissioner
2
2
  module PricingModels
3
3
  class PreviewAdjustment
4
- attr_reader :label, :amount, :action_type, :pricing_action,
4
+ attr_reader :id, :label, :amount, :action_type, :pricing_action,
5
5
  :adjustable_type, :adjustable_id, :line_item_id, :guest_ids
6
6
 
7
7
  def initialize(options = {})
8
+ @id = SecureRandom.uuid
8
9
  @label = options[:label]
9
10
  @amount = options[:amount]
10
11
  @action_type = options[:action_type]
@@ -14,17 +15,6 @@ module SpreeCmCommissioner
14
15
  @line_item_id = options[:line_item_id]
15
16
  @guest_ids = Array(options[:guest_ids])
16
17
  end
17
-
18
- def to_h
19
- {
20
- label: label,
21
- amount: amount,
22
- action_type: action_type,
23
- pricing_action_id: pricing_action&.id,
24
- line_item_id: line_item_id,
25
- guest_ids: guest_ids.presence
26
- }.compact
27
- end
28
18
  end
29
19
  end
30
20
  end
@@ -1,7 +1,7 @@
1
1
  module SpreeCmCommissioner
2
2
  module PricingModels
3
3
  class PricingPreview
4
- attr_reader :id, :item_total, :total, :pricing_adjustment_total, :pricing_adjustments
4
+ attr_reader :id, :item_total, :total, :pricing_adjustment_total, :pricing_adjustments, :pricing_adjustment_ids
5
5
 
6
6
  def initialize(id:, item_total:, total:, pricing_adjustment_total:, pricing_adjustments:)
7
7
  @id = id
@@ -9,6 +9,7 @@ module SpreeCmCommissioner
9
9
  @total = total
10
10
  @pricing_adjustment_total = pricing_adjustment_total
11
11
  @pricing_adjustments = pricing_adjustments
12
+ @pricing_adjustment_ids = pricing_adjustments.map(&:id)
12
13
  end
13
14
  end
14
15
  end
@@ -1,5 +1,5 @@
1
1
  module SpreeCmCommissioner
2
- VERSION = '2.7.1-pre8'.freeze
2
+ VERSION = '2.8.0'.freeze
3
3
 
4
4
  module_function
5
5
 
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: spree_cm_commissioner
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.7.1.pre.pre8
4
+ version: 2.8.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - You
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2026-05-06 00:00:00.000000000 Z
11
+ date: 2026-05-07 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: spree
@@ -1923,6 +1923,7 @@ files:
1923
1923
  - app/serializers/spree/v2/tenant/order_serializer.rb
1924
1924
  - app/serializers/spree/v2/tenant/payment_method_group_serializer.rb
1925
1925
  - app/serializers/spree/v2/tenant/payment_method_serializer.rb
1926
+ - app/serializers/spree/v2/tenant/preview_adjustment_serializer.rb
1926
1927
  - app/serializers/spree/v2/tenant/pricing_preview_serializer.rb
1927
1928
  - app/serializers/spree/v2/tenant/product_dynamic_field_serializer.rb
1928
1929
  - app/serializers/spree/v2/tenant/product_serializer.rb
@@ -2001,6 +2002,7 @@ files:
2001
2002
  - app/serializers/spree_cm_commissioner/v2/storefront/menu_serializer_decorator.rb
2002
2003
  - app/serializers/spree_cm_commissioner/v2/storefront/payment_method_group_serializer.rb
2003
2004
  - app/serializers/spree_cm_commissioner/v2/storefront/pin_code_serializer.rb
2005
+ - app/serializers/spree_cm_commissioner/v2/storefront/preview_adjustment_serializer.rb
2004
2006
  - app/serializers/spree_cm_commissioner/v2/storefront/price_serializer.rb
2005
2007
  - app/serializers/spree_cm_commissioner/v2/storefront/pricing_preview_serializer.rb
2006
2008
  - app/serializers/spree_cm_commissioner/v2/storefront/product_dynamic_field_serializer.rb
@@ -3157,6 +3159,7 @@ files:
3157
3159
  - db/migrate/20260330032108_add_vendor_id_to_spree_taxonomies.rb
3158
3160
  - db/migrate/20260401080000_create_cm_route_prices.rb
3159
3161
  - db/migrate/20260410080000_add_payment_locked_at_to_cm_reserved_blocks.rb
3162
+ - db/migrate/20260504100000_add_public_and_private_metadata_to_cm_routes.rb
3160
3163
  - db/migrate/20260506090000_remove_default_from_cm_guests_nationality_group.rb
3161
3164
  - docker-compose.yml
3162
3165
  - docs/api/scoped-access-token-endpoints.md
@@ -3357,9 +3360,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
3357
3360
  version: '2.7'
3358
3361
  required_rubygems_version: !ruby/object:Gem::Requirement
3359
3362
  requirements:
3360
- - - ">"
3363
+ - - ">="
3361
3364
  - !ruby/object:Gem::Version
3362
- version: 1.3.1
3365
+ version: '0'
3363
3366
  requirements:
3364
3367
  - none
3365
3368
  rubygems_version: 3.4.1