spree_cm_commissioner 2.0.0 → 2.0.1.pre.pre
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 +4 -4
- data/.github/workflows/test_and_build_gem.yml +16 -2
- data/.gitignore +2 -1
- data/Gemfile.lock +32 -1
- data/Rakefile +33 -4
- data/app/assets/stylesheets/spree_cm_commissioner/backend/calendar.scss +8 -11
- data/app/controllers/spree/admin/inventory_items_controller.rb +83 -0
- data/app/controllers/spree/admin/stock_managements_controller.rb +63 -1
- data/app/controllers/spree/api/v2/organizer/invite_guests_controller.rb +1 -1
- data/app/controllers/spree/api/v2/storefront/accommodations/variants_controller.rb +42 -0
- data/app/controllers/spree/api/v2/storefront/accommodations_controller.rb +14 -31
- data/app/controllers/spree/api/v2/storefront/guests_controller.rb +13 -13
- data/app/controllers/spree/api/v2/storefront/queue_cart/line_items_controller.rb +2 -2
- data/app/factory/spree_cm_commissioner/invite_guest_claimed_telegram_message_factory.rb +81 -23
- data/app/finders/spree_cm_commissioner/accommodations/find.rb +37 -0
- data/app/finders/spree_cm_commissioner/accommodations/find_variant.rb +32 -0
- data/app/interactors/spree_cm_commissioner/create_ticket.rb +5 -6
- data/app/interactors/spree_cm_commissioner/ensure_correct_product_type.rb +40 -0
- data/app/interactors/spree_cm_commissioner/inventory_item_syncer.rb +25 -0
- data/app/interactors/spree_cm_commissioner/pin_code_sender.rb +1 -0
- data/app/interactors/spree_cm_commissioner/sms.rb +1 -1
- data/app/interactors/spree_cm_commissioner/stock/inventory_item_resetter.rb +44 -0
- data/app/interactors/spree_cm_commissioner/stock/inventory_items_adjuster.rb +13 -0
- data/app/interactors/spree_cm_commissioner/stock/inventory_items_generator.rb +15 -0
- data/app/interactors/spree_cm_commissioner/stock/permanent_inventory_items_generator.rb +75 -0
- data/app/interactors/spree_cm_commissioner/stock/stock_movement_creator.rb +32 -0
- data/app/interactors/spree_cm_commissioner/user_id_token_authenticator.rb +3 -7
- data/app/interactors/spree_cm_commissioner/user_id_token_checker.rb +3 -11
- data/app/interactors/spree_cm_commissioner/user_identity_checker.rb +6 -12
- data/app/interactors/spree_cm_commissioner/user_registration_with_id_token.rb +1 -7
- data/app/jobs/spree_cm_commissioner/application_job.rb +20 -0
- data/app/jobs/spree_cm_commissioner/application_unique_job.rb +20 -0
- data/app/jobs/spree_cm_commissioner/ensure_correct_product_type_job.rb +7 -0
- data/app/jobs/spree_cm_commissioner/inventory_item_syncer_job.rb +7 -0
- data/app/jobs/spree_cm_commissioner/sms_pin_code_job.rb +1 -1
- data/app/jobs/spree_cm_commissioner/stock/inventory_items_adjuster_job.rb +11 -0
- data/app/jobs/spree_cm_commissioner/stock/inventory_items_generator_job.rb +11 -0
- data/app/jobs/spree_cm_commissioner/stock/permanent_inventory_items_generator_job.rb +9 -0
- data/app/mailers/spree/order_mailer_decorator.rb +3 -18
- data/app/models/concerns/spree_cm_commissioner/line_item_durationable.rb +9 -15
- data/app/models/concerns/spree_cm_commissioner/option_type_attr_type.rb +1 -12
- data/app/models/concerns/spree_cm_commissioner/order_seatable.rb +44 -0
- data/app/models/concerns/spree_cm_commissioner/order_state_machine.rb +39 -0
- data/app/models/concerns/spree_cm_commissioner/product_delegation.rb +1 -3
- data/app/models/concerns/spree_cm_commissioner/product_type.rb +10 -0
- data/app/models/concerns/spree_cm_commissioner/taxon_kind.rb +1 -1
- data/app/models/concerns/spree_cm_commissioner/tenant_preference.rb +0 -1
- data/app/models/spree_cm_commissioner/block.rb +23 -0
- data/app/models/spree_cm_commissioner/dynamic_field.rb +0 -20
- data/app/models/spree_cm_commissioner/guest.rb +18 -56
- data/app/models/spree_cm_commissioner/guest_dynamic_field.rb +1 -41
- data/app/models/spree_cm_commissioner/inventory.rb +11 -0
- data/app/models/spree_cm_commissioner/inventory_item.rb +69 -0
- data/app/models/spree_cm_commissioner/line_item_decorator.rb +46 -78
- data/app/models/spree_cm_commissioner/notification_taxon.rb +1 -1
- data/app/models/spree_cm_commissioner/option_type_decorator.rb +1 -11
- data/app/models/spree_cm_commissioner/order_decorator.rb +30 -1
- data/app/models/spree_cm_commissioner/place.rb +1 -4
- data/app/models/spree_cm_commissioner/price_decorator.rb +9 -0
- data/app/models/spree_cm_commissioner/product_decorator.rb +10 -28
- data/app/models/spree_cm_commissioner/redis_stock/cached_inventory_items_builder.rb +41 -0
- data/app/models/spree_cm_commissioner/redis_stock/inventory_updater.rb +126 -0
- data/app/models/spree_cm_commissioner/redis_stock/line_items_cached_inventory_items_builder.rb +36 -0
- data/app/models/spree_cm_commissioner/redis_stock/variant_cached_inventory_items_builder.rb +25 -0
- data/app/models/spree_cm_commissioner/reserved_block.rb +30 -0
- data/app/models/spree_cm_commissioner/seat_layout.rb +20 -0
- data/app/models/spree_cm_commissioner/seat_section.rb +16 -0
- data/app/models/spree_cm_commissioner/seats/blocks_canceler.rb +30 -0
- data/app/models/spree_cm_commissioner/seats/blocks_holder.rb +53 -0
- data/app/models/spree_cm_commissioner/seats/blocks_reserver.rb +49 -0
- data/app/models/spree_cm_commissioner/seats/errors/blocks_are_on_hold_by_other_guest.rb +4 -0
- data/app/models/spree_cm_commissioner/seats/errors/blocks_are_reserved_by_other_guest.rb +4 -0
- data/app/models/spree_cm_commissioner/seats/errors/blocks_are_reserved_by_same_guest.rb +4 -0
- data/app/models/spree_cm_commissioner/seats/errors/unable_to_save_reserved_block_record.rb +4 -0
- data/app/models/spree_cm_commissioner/service_calendar.rb +0 -2
- data/app/models/spree_cm_commissioner/state_decorator.rb +0 -1
- data/app/models/spree_cm_commissioner/stock/availability_checker.rb +26 -25
- data/app/models/spree_cm_commissioner/stock/availability_validator_decorator.rb +2 -1
- data/app/models/spree_cm_commissioner/stock/line_item_availability_checker.rb +3 -3
- data/app/models/spree_cm_commissioner/stock/order_availability_checker.rb +44 -0
- data/app/models/spree_cm_commissioner/stock_item_decorator.rb +17 -0
- data/app/models/spree_cm_commissioner/taxon_decorator.rb +0 -1
- data/app/models/spree_cm_commissioner/taxonomy_decorator.rb +0 -6
- data/app/models/spree_cm_commissioner/trip.rb +8 -10
- data/app/models/spree_cm_commissioner/trip_connection.rb +5 -5
- data/app/models/spree_cm_commissioner/trip_stop.rb +6 -25
- data/app/models/spree_cm_commissioner/user_identity_provider.rb +4 -26
- data/app/models/spree_cm_commissioner/variant_block.rb +9 -0
- data/app/models/spree_cm_commissioner/variant_decorator.rb +37 -47
- data/app/models/spree_cm_commissioner/variant_options.rb +0 -23
- data/app/models/spree_cm_commissioner/vehicle.rb +9 -14
- data/app/models/spree_cm_commissioner/vendor_decorator.rb +11 -17
- data/app/models/spree_cm_commissioner/vendor_place.rb +9 -3
- data/app/queries/spree_cm_commissioner/trip_query.rb +70 -44
- data/app/request_schemas/spree_cm_commissioner/accommodation_request_schema.rb +3 -0
- data/app/request_schemas/spree_cm_commissioner/application_request_schema.rb +1 -1
- data/app/request_schemas/spree_cm_commissioner/variant_request_schema.rb +19 -0
- data/app/serializers/spree/v2/storefront/accommodation_serializer.rb +2 -0
- data/app/serializers/spree/v2/storefront/line_item_serializer_decorator.rb +1 -0
- data/app/serializers/spree/v2/tenant/user_serializer.rb +0 -1
- data/app/serializers/spree_cm_commissioner/v2/storefront/dynamic_field_serializer.rb +1 -1
- data/app/services/spree_cm_commissioner/user_authenticator.rb +1 -1
- data/app/views/spree/admin/inventory_items/show.html.erb +72 -0
- data/app/views/spree/admin/stock_managements/_variant_stock_items.html.erb +7 -2
- data/app/views/spree/admin/stock_managements/calendar.html.erb +56 -0
- data/app/views/spree/admin/stock_managements/index.html.erb +55 -6
- data/app/views/spree/admin/tenant_vendors/index.html.erb +2 -9
- data/app/views/spree/admin/tenants/_form.html.erb +0 -9
- data/app/views/spree/admin/tenants/edit.html.erb +1 -2
- data/app/views/spree/admin/tenants/index.html.erb +1 -7
- data/app/views/spree/admin/vendors/_form.html.erb +0 -14
- data/app/views/spree/order_mailer/confirm_email.html.erb +16 -27
- data/app/views/spree_cm_commissioner/layouts/order_mailer.html.erb +1 -5
- data/app/views/spree_cm_commissioner/order_mailer/_mailer_stylesheets.html.erb +4 -41
- data/config/initializers/paper_trail.rb +1 -0
- data/config/initializers/spree_permitted_attributes.rb +5 -0
- data/config/locales/en.yml +1 -5
- data/config/routes.rb +21 -2
- data/db/migrate/20240202080634_update_counter_cache_of_vehicle_type.rb +3 -1
- data/db/migrate/20250304293518_create_cm_inventory_items.rb +21 -0
- data/db/migrate/20250429094228_add_lock_version_to_cm_inventory_items.rb +5 -0
- data/db/migrate/20250502025848_add_index_to_spree_products.rb +5 -0
- data/db/migrate/20250502030001_add_product_type_to_spree_variants.rb +5 -0
- data/db/migrate/20250502030002_add_product_type_to_spree_line_items.rb +5 -0
- data/db/migrate/20250603035256_add_inventory_item_to_spree_prices.rb +7 -0
- data/db/migrate/20250619073724_drop_table_cm_line_item_seats.rb +5 -0
- data/db/migrate/20250619073812_drop_table_cm_vehicle_seats.rb +5 -0
- data/db/migrate/20250619073844_drop_table_cm_vehicle_types.rb +9 -0
- data/db/migrate/20250619073957_drop_table_cm_option_value_vehicle_types.rb +5 -0
- data/db/migrate/20250619082354_remove_unnecessary_fields_from_cm_places.rb +9 -0
- data/db/migrate/20250619082736_remove_route_type_from_spree_products.rb +5 -0
- data/db/migrate/20250619083055_remove_unnecessary_fields_from_spree_taxons.rb +5 -0
- data/db/migrate/20250620083055_remove_variant_id_from_cm_trips.rb +5 -0
- data/db/migrate/20250620090000_update_cm_trip_connections_to_use_cm_trips.rb +6 -0
- data/db/migrate/20250620090001_create_cm_seat_layouts.rb +17 -0
- data/db/migrate/20250620090002_create_cm_seat_sections.rb +18 -0
- data/db/migrate/20250620090003_create_cm_blocks.rb +18 -0
- data/db/migrate/20250624091005_create_cm_reserved_blocks.rb +29 -0
- data/db/migrate/20250626083642_create_cm_variant_blocks.rb +24 -0
- data/db/migrate/20250627023314_add_block_id_to_cm_guests.rb +13 -0
- data/db/migrate/20250716022821_add_location_reference_to_cm_vendor_places.rb +5 -0
- data/db/migrate/20250716031743_drop_table_cm_vendor_stops.rb +5 -0
- data/db/migrate/20250717023824_add_vendor_reference_to_cm_trips.rb +5 -0
- data/db/migrate/20250717041414_add_location_place_reference_to_cm_trip_stops.rb +5 -0
- data/db/migrate/20250717042539_rename_cm_trip_stops_stop_id_column_to_stop_place_id.rb +7 -0
- data/db/migrate/20250717042707_rename_cm_trips_origin_and_destination_to_origin_place_and_destination_place.rb +11 -0
- data/docker-compose.yml +1 -1
- data/lib/cm_app_logger.rb +11 -4
- data/lib/generators/spree_cm_commissioner/install/install_generator.rb +14 -11
- data/lib/generators/spree_cm_commissioner/install/templates/app/javascript/{spree_cm_commissioner → spree_dashboard/spree_cm_commissioner}/utilities.js +4 -0
- data/lib/spree_cm_commissioner/cached_inventory_item.rb +23 -0
- data/lib/spree_cm_commissioner/calendar_event.rb +11 -1
- data/lib/spree_cm_commissioner/test_helper/factories/block_factory.rb +15 -0
- data/lib/spree_cm_commissioner/test_helper/factories/guest_factory.rb +10 -0
- data/lib/spree_cm_commissioner/test_helper/factories/homepage_section_relatable_factory.rb +1 -1
- data/lib/spree_cm_commissioner/test_helper/factories/inventory_item_factory.rb +9 -0
- data/lib/spree_cm_commissioner/test_helper/factories/line_item_factory.rb +1 -1
- data/lib/spree_cm_commissioner/test_helper/factories/option_type_factory.rb +6 -30
- data/lib/spree_cm_commissioner/test_helper/factories/order_factory.rb +0 -36
- data/lib/spree_cm_commissioner/test_helper/factories/product_factory.rb +18 -34
- data/lib/spree_cm_commissioner/test_helper/factories/reserved_block_factory.rb +27 -0
- data/lib/spree_cm_commissioner/test_helper/factories/seat_layout_factory.rb +11 -0
- data/lib/spree_cm_commissioner/test_helper/factories/seat_section_factory.rb +16 -0
- data/lib/spree_cm_commissioner/test_helper/factories/stock_location_factory.rb +2 -2
- data/lib/spree_cm_commissioner/test_helper/factories/trip_connection_factory.rb +6 -0
- data/lib/spree_cm_commissioner/test_helper/factories/trip_factory.rb +11 -3
- data/lib/spree_cm_commissioner/test_helper/factories/trip_stop_factory.rb +10 -0
- data/lib/spree_cm_commissioner/test_helper/factories/user_identity_provider_factory.rb +1 -1
- data/lib/spree_cm_commissioner/test_helper/factories/variant_block_factory.rb +7 -0
- data/lib/spree_cm_commissioner/test_helper/factories/variant_factory.rb +41 -19
- data/lib/spree_cm_commissioner/test_helper/factories/vehicle_factory.rb +1 -1
- data/lib/spree_cm_commissioner/test_helper/factories/vendor_factory.rb +6 -1
- data/lib/spree_cm_commissioner/test_helper/factories/vendor_place_factory.rb +13 -1
- data/lib/spree_cm_commissioner/trip_query_result.rb +8 -0
- data/lib/spree_cm_commissioner/trip_result.rb +5 -3
- data/lib/spree_cm_commissioner/version.rb +1 -1
- data/lib/spree_cm_commissioner.rb +35 -1
- data/lib/tasks/create_default_non_permanent_inventory_items.rake +16 -0
- data/lib/tasks/ensure_correct_product_type.rake +7 -0
- data/lib/tasks/generate_inventory_items.rake +7 -0
- data/spree_cm_commissioner.gemspec +7 -0
- metadata +141 -38
- data/app/assets/images/mailer/mail.png +0 -0
- data/app/assets/images/mailer/tenant_phone.png +0 -0
- data/app/assets/images/mailer/tenant_user.png +0 -0
- data/app/controllers/concerns/spree_cm_commissioner/transit/taxon_bitwise.rb +0 -44
- data/app/finders/spree_cm_commissioner/line_items/find_by_variant_decorator.rb +0 -20
- data/app/models/spree_cm_commissioner/branch.rb +0 -12
- data/app/models/spree_cm_commissioner/line_item_seat.rb +0 -10
- data/app/models/spree_cm_commissioner/option_value_vehicle_type.rb +0 -8
- data/app/models/spree_cm_commissioner/stop.rb +0 -23
- data/app/models/spree_cm_commissioner/vehicle_seat.rb +0 -11
- data/app/models/spree_cm_commissioner/vehicle_type.rb +0 -76
- data/app/models/spree_cm_commissioner/vendor_stop.rb +0 -10
- data/app/queries/spree_cm_commissioner/trip_search_query.rb +0 -76
- data/app/queries/spree_cm_commissioner/variant_availability/non_permanent_stock_query.rb +0 -45
- data/app/queries/spree_cm_commissioner/variant_availability/permanent_stock_query.rb +0 -55
- data/app/queries/spree_cm_commissioner/vendor_stop_place_query.rb +0 -54
- data/app/services/spree_cm_commissioner/vehicle_option_value_creator.rb +0 -11
- data/app/views/spree_cm_commissioner/order_mailer/tenant/_customer_info.html.erb +0 -42
- data/app/views/spree_cm_commissioner/order_mailer/tenant/_footer.html.erb +0 -25
- data/app/views/spree_cm_commissioner/order_mailer/tenant/_greeting.html.erb +0 -19
- data/app/views/spree_cm_commissioner/order_mailer/tenant/_support_contact.html.erb +0 -33
- data/db/migrate/20250709073455_add_email_fields_to_spree_vendors.rb +0 -6
- data/db/migrate/20250715103333_remove_indexes_from_cm_user_identity_providers.rb +0 -13
- data/db/migrate/20250718071620_add_data_fill_stage_to_dynamic_fields.rb +0 -5
- data/lib/spree_cm_commissioner/test_helper/factories/branch_factory.rb +0 -12
- data/lib/spree_cm_commissioner/test_helper/factories/departure_time_option_type_factory.rb +0 -8
- data/lib/spree_cm_commissioner/test_helper/factories/duration_option_type_factory.rb +0 -8
- data/lib/spree_cm_commissioner/test_helper/factories/line_item_seat_factory.rb +0 -7
- data/lib/spree_cm_commissioner/test_helper/factories/stop_factory.rb +0 -14
- data/lib/spree_cm_commissioner/test_helper/factories/transit_place_factory.rb +0 -8
- data/lib/spree_cm_commissioner/test_helper/factories/vehicle_option_type_factory.rb +0 -8
- data/lib/spree_cm_commissioner/test_helper/factories/vehicle_type_factory.rb +0 -96
- data/lib/spree_cm_commissioner/trip_seat_layout_result.rb +0 -11
@@ -1,6 +1,7 @@
|
|
1
1
|
module SpreeCmCommissioner
|
2
2
|
module VariantDecorator
|
3
|
-
def self.prepended(base)
|
3
|
+
def self.prepended(base) # rubocop:disable Metrics/AbcSize
|
4
|
+
base.include SpreeCmCommissioner::ProductType
|
4
5
|
base.include SpreeCmCommissioner::ProductDelegation
|
5
6
|
base.include SpreeCmCommissioner::VariantOptionsConcern
|
6
7
|
base.include SpreeCmCommissioner::KycBitwise
|
@@ -20,24 +21,21 @@ module SpreeCmCommissioner
|
|
20
21
|
base.has_many :video_on_demands, class_name: 'SpreeCmCommissioner::VideoOnDemand', dependent: :destroy
|
21
22
|
base.has_many :complete_line_items, -> { complete }, class_name: 'Spree::LineItem'
|
22
23
|
|
24
|
+
base.has_many :variant_blocks, class_name: 'SpreeCmCommissioner::VariantBlock', dependent: :destroy
|
25
|
+
base.has_many :blocks, class_name: 'SpreeCmCommissioner::Block', through: :variant_blocks
|
26
|
+
|
23
27
|
base.has_many :variant_guest_card_class, class_name: 'SpreeCmCommissioner::VariantGuestCardClass'
|
24
28
|
base.has_many :guest_card_classes, class_name: 'SpreeCmCommissioner::GuestCardClass', through: :variant_guest_card_class
|
25
29
|
|
30
|
+
base.has_many :inventory_items, class_name: 'SpreeCmCommissioner::InventoryItem'
|
31
|
+
|
26
32
|
base.scope :subscribable, -> { active.joins(:product).where(product: { subscribable: true, status: :active }) }
|
27
|
-
base.
|
28
|
-
|
29
|
-
base.has_many :trip_stops, class_name: 'SpreeCmCommissioner::TripStop', dependent: :destroy, foreign_key: :trip_id
|
30
|
-
base.accepts_nested_attributes_for :option_values
|
31
|
-
base.after_commit :sync_trip, if: :transit?
|
32
|
-
base.accepts_nested_attributes_for :trip_stops, allow_destroy: true
|
33
|
-
base.after_commit :create_trip_stops, if: :transit?
|
34
|
-
end
|
33
|
+
base.scope :with_permanent_stock, -> { where(product_type: base::PERMANENT_STOCK_PRODUCT_TYPES) }
|
34
|
+
base.scope :with_non_permanent_stock, -> { where.not(product_type: base::PERMANENT_STOCK_PRODUCT_TYPES) }
|
35
35
|
|
36
|
-
|
37
|
-
return if is_master?
|
36
|
+
base.accepts_nested_attributes_for :option_values
|
38
37
|
|
39
|
-
|
40
|
-
trip_stops.find_or_create_by(stop_type: :drop_off, stop_id: options.destination)
|
38
|
+
base.before_save -> { self.product_type = product.product_type }, if: -> { product_type.nil? }
|
41
39
|
end
|
42
40
|
|
43
41
|
def delivery_required?
|
@@ -53,8 +51,20 @@ module SpreeCmCommissioner
|
|
53
51
|
super || product.discontinued?
|
54
52
|
end
|
55
53
|
|
56
|
-
def
|
57
|
-
|
54
|
+
def default_inventory_item_exist?
|
55
|
+
inventory_items.exists?(inventory_date: nil)
|
56
|
+
end
|
57
|
+
|
58
|
+
def create_default_non_permanent_inventory_item!(quantity_available: nil, max_capacity: nil)
|
59
|
+
return if product_type.blank? # handle in case product not exist for variant.
|
60
|
+
return unless should_track_inventory?
|
61
|
+
return if default_inventory_item_exist?
|
62
|
+
|
63
|
+
inventory_items.create!(
|
64
|
+
product_type: product_type,
|
65
|
+
quantity_available: [0, quantity_available || total_on_hand].max,
|
66
|
+
max_capacity: [0, max_capacity || total_on_hand].max
|
67
|
+
)
|
58
68
|
end
|
59
69
|
|
60
70
|
# override
|
@@ -72,30 +82,26 @@ module SpreeCmCommissioner
|
|
72
82
|
"#{display_sku} - #{display_price}"
|
73
83
|
end
|
74
84
|
|
75
|
-
def transit?
|
76
|
-
product.product_type == 'transit'
|
77
|
-
end
|
78
|
-
|
79
85
|
# override
|
80
|
-
def in_stock?
|
81
|
-
|
86
|
+
def in_stock?(options = {})
|
87
|
+
SpreeCmCommissioner::Stock::AvailabilityChecker.new(self, options).can_supply?
|
82
88
|
end
|
83
89
|
|
84
|
-
|
90
|
+
def price_for_date(currency:, date:)
|
91
|
+
currency = currency.upcase
|
85
92
|
|
86
|
-
|
87
|
-
|
93
|
+
prices.joins(:inventory_item)
|
94
|
+
.find_by(
|
95
|
+
currency: currency,
|
96
|
+
inventory_item: { inventory_date: date }
|
97
|
+
)
|
88
98
|
end
|
89
99
|
|
90
|
-
|
91
|
-
stock_count = stock_items.sum(&:count_on_hand)
|
92
|
-
return stock_count if delivery_required?
|
93
|
-
|
94
|
-
stock_count - total_purchases
|
95
|
-
end
|
100
|
+
private
|
96
101
|
|
97
102
|
def update_vendor_price
|
98
|
-
return unless vendor.present? &&
|
103
|
+
return unless vendor.present? && product_type == vendor&.primary_product_type
|
104
|
+
return if price.blank?
|
99
105
|
|
100
106
|
vendor.update(min_price: price) if vendor.min_price.nil? || price < vendor.min_price
|
101
107
|
vendor.update(max_price: price) if vendor.max_price.nil? || price > vendor.max_price
|
@@ -119,22 +125,6 @@ module SpreeCmCommissioner
|
|
119
125
|
end
|
120
126
|
end
|
121
127
|
end
|
122
|
-
|
123
|
-
def sync_trip
|
124
|
-
return unless product.product_type == 'transit'
|
125
|
-
|
126
|
-
trip = SpreeCmCommissioner::Trip.find_or_initialize_by(variant_id: id)
|
127
|
-
|
128
|
-
trip.assign_attributes(
|
129
|
-
product_id: product_id,
|
130
|
-
origin_id: options.origin,
|
131
|
-
destination_id: options.destination,
|
132
|
-
departure_time: options.departure_time,
|
133
|
-
duration: options.total_duration_in_seconds,
|
134
|
-
vehicle_id: options.vehicle
|
135
|
-
)
|
136
|
-
trip.save
|
137
|
-
end
|
138
128
|
end
|
139
129
|
end
|
140
130
|
|
@@ -143,28 +143,5 @@ module SpreeCmCommissioner
|
|
143
143
|
def number_of_guests
|
144
144
|
number_of_adults + number_of_kids
|
145
145
|
end
|
146
|
-
|
147
|
-
def origin
|
148
|
-
@origin ||= option_value_name_for(option_type_name: 'origin')&.to_i
|
149
|
-
end
|
150
|
-
|
151
|
-
def destination
|
152
|
-
@destination ||= option_value_name_for(option_type_name: 'destination')&.to_i
|
153
|
-
end
|
154
|
-
|
155
|
-
def vehicle
|
156
|
-
@vehicle ||= option_value_name_for(option_type_name: 'vehicle')&.to_i
|
157
|
-
end
|
158
|
-
|
159
|
-
def allow_seat_selection
|
160
|
-
@allow_seat_selection ||= option_value_name_for(option_type_name: 'allow-seat-selection')&.to_i
|
161
|
-
end
|
162
|
-
|
163
|
-
def departure_time
|
164
|
-
@departure_time ||= begin
|
165
|
-
time = option_value_name_for(option_type_name: 'departure-time')
|
166
|
-
Time.zone.parse(time) if time.present?
|
167
|
-
end
|
168
|
-
end
|
169
146
|
end
|
170
147
|
end
|
@@ -1,29 +1,24 @@
|
|
1
|
-
require_dependency 'spree_cm_commissioner'
|
2
|
-
|
3
1
|
module SpreeCmCommissioner
|
4
|
-
class Vehicle <
|
2
|
+
class Vehicle < Base
|
5
3
|
include SpreeCmCommissioner::RouteType
|
6
4
|
|
7
|
-
belongs_to :vehicle_type, class_name: 'SpreeCmCommissioner::VehicleType'
|
8
|
-
has_one :primary_photo, -> { order(position: :asc) }, class_name: 'SpreeCmCommissioner::VehiclePhoto', as: :viewable, dependent: :destroy
|
9
5
|
belongs_to :vendor, class_name: 'Spree::Vendor'
|
10
6
|
|
11
|
-
|
7
|
+
has_one :primary_photo, -> { order(position: :asc) }, class_name: 'SpreeCmCommissioner::VehiclePhoto', as: :viewable, dependent: :destroy
|
8
|
+
has_one :seat_layout, as: :layoutable, class_name: 'SpreeCmCommissioner::SeatLayout'
|
12
9
|
|
13
|
-
has_many :
|
14
|
-
has_many :vehicle_seats, class_name: 'SpreeCmCommissioner::VehicleSeat', through: :vehicle_type
|
10
|
+
has_many :vehicle_photos, class_name: 'SpreeCmCommissioner::VehiclePhoto', as: :viewable, dependent: :destroy
|
15
11
|
|
16
12
|
has_many :vehicle_option_types, class_name: 'SpreeCmCommissioner::VehicleOptionType', dependent: :destroy
|
17
13
|
has_many :option_value_vehicles, class_name: 'SpreeCmCommissioner::OptionValueVehicle', dependent: :destroy
|
18
14
|
|
19
15
|
validates :code, uniqueness: { scope: :vendor_id }, presence: true
|
20
|
-
validates :license_plate, uniqueness:
|
21
|
-
|
22
|
-
def create_vehicle_option_value
|
23
|
-
SpreeCmCommissioner::VehicleOptionValueCreator.call(self)
|
24
|
-
end
|
16
|
+
validates :license_plate, uniqueness: true, allow_blank: true
|
25
17
|
|
26
18
|
self.whitelisted_ransackable_attributes = %w[license_plate code]
|
27
|
-
|
19
|
+
|
20
|
+
def display_name
|
21
|
+
"#{code} (#{license_plate})"
|
22
|
+
end
|
28
23
|
end
|
29
24
|
end
|
@@ -36,21 +36,17 @@ module SpreeCmCommissioner
|
|
36
36
|
base.has_many :vendor_kind_option_values,
|
37
37
|
through: :option_value_vendors, source: :option_value
|
38
38
|
|
39
|
-
base.has_many :branches,
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
base.has_many :
|
44
|
-
|
39
|
+
base.has_many :branches, -> { branch }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
40
|
+
base.has_many :stops, -> { stop }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
41
|
+
base.has_many :locations, -> { location }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
42
|
+
|
43
|
+
base.has_many :branch_places, through: :branches, class_name: 'SpreeCmCommissioner::Place', source: :place
|
44
|
+
base.has_many :stop_places, through: :stops, class_name: 'SpreeCmCommissioner::Place', source: :place
|
45
|
+
base.has_many :location_places, through: :locations, class_name: 'SpreeCmCommissioner::Place', source: :place
|
45
46
|
|
46
47
|
base.has_many :places,
|
47
48
|
through: :nearby_places, source: :place, class_name: 'SpreeCmCommissioner::Place'
|
48
49
|
|
49
|
-
base.has_many :vendor_stops, class_name: 'SpreeCmCommissioner::VendorStop', dependent: :destroy
|
50
|
-
base.has_many :boarding_points, -> { where(cm_vendor_stops: { stop_type: 0 }) },
|
51
|
-
through: :vendor_stops, source: :stop, class_name: 'SpreeCmCommissioner::Place'
|
52
|
-
base.has_many :drop_off_points, -> { where(cm_vendor_stops: { stop_type: 1 }) },
|
53
|
-
through: :vendor_stops, source: :stop, class_name: 'SpreeCmCommissioner::Place'
|
54
50
|
base.has_many :dynamic_fields, class_name: 'SpreeCmCommissioner::DynamicField', foreign_key: :vendor_id, dependent: :destroy
|
55
51
|
|
56
52
|
base.has_one :logo, as: :viewable, dependent: :destroy, class_name: 'SpreeCmCommissioner::VendorLogo'
|
@@ -81,19 +77,19 @@ module SpreeCmCommissioner
|
|
81
77
|
base.has_many :promotion_categories, class_name: 'Spree::PromotionCategory', foreign_key: :vendor_id, dependent: :destroy
|
82
78
|
|
83
79
|
base.has_many :homepage_section_relatables,
|
80
|
+
as: :relatable,
|
84
81
|
class_name: 'SpreeCmCommissioner::HomepageSectionRelatable',
|
85
|
-
dependent: :destroy,
|
82
|
+
dependent: :destroy,
|
83
|
+
inverse_of: :relatable
|
86
84
|
|
87
|
-
base.has_many :vehicle_types, class_name: 'SpreeCmCommissioner::VehicleType', dependent: :destroy
|
88
85
|
base.has_many :vehicles, class_name: 'SpreeCmCommissioner::Vehicle', dependent: :destroy
|
89
|
-
|
86
|
+
base.has_many :trips, class_name: 'SpreeCmCommissioner::Trip', dependent: :destroy
|
90
87
|
|
91
88
|
base.validates :account_name, :account_number, presence: true, if: lambda {
|
92
89
|
payment_qrcode.present? && Spree::Store.default.code.include?('billing')
|
93
90
|
}
|
94
91
|
|
95
92
|
base.validates :commission_rate, presence: true, numericality: { greater_than_or_equal_to: 0, less_than_or_equal_to: 100 }
|
96
|
-
base.validates :from_email, presence: true, if: :tenant_present?
|
97
93
|
|
98
94
|
def base.by_vendor_id!(vendor_id)
|
99
95
|
if vendor_id.to_s =~ /^\d+$/
|
@@ -196,8 +192,6 @@ module SpreeCmCommissioner
|
|
196
192
|
|
197
193
|
vendor_kind_option_values.where(option_type_id: rules_option_type.id)
|
198
194
|
end
|
199
|
-
|
200
|
-
delegate :present?, to: :tenant, prefix: true
|
201
195
|
end
|
202
196
|
end
|
203
197
|
|
@@ -5,15 +5,21 @@ module SpreeCmCommissioner
|
|
5
5
|
|
6
6
|
belongs_to :vendor, class_name: 'Spree::Vendor', optional: false
|
7
7
|
belongs_to :place, class_name: 'SpreeCmCommissioner::Place', optional: false
|
8
|
+
belongs_to :location, class_name: 'SpreeCmCommissioner::VendorPlace', optional: true
|
9
|
+
|
10
|
+
has_many :branches, -> { branch }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
11
|
+
has_many :stops, -> { stop }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
8
12
|
|
9
13
|
validates :place_type, presence: true
|
10
14
|
validates :place_id, uniqueness: { scope: %i[vendor_id place_type] }
|
15
|
+
validates :location, presence: true, if: -> { branch? || stop? }
|
11
16
|
|
12
17
|
accepts_nested_attributes_for :place, allow_destroy: true
|
13
18
|
|
14
|
-
|
15
|
-
|
16
|
-
|
19
|
+
# include place when using these delegate to avoid N+1
|
20
|
+
def display_name
|
21
|
+
place&.name
|
22
|
+
end
|
17
23
|
|
18
24
|
def selected
|
19
25
|
vendor.selected_place_references.include?(place&.reference)
|
@@ -2,54 +2,57 @@ module SpreeCmCommissioner
|
|
2
2
|
class TripQuery
|
3
3
|
include SpreeCmCommissioner::Transit::TripHelper
|
4
4
|
|
5
|
-
attr_reader :origin_id, :destination_id, :
|
5
|
+
attr_reader :origin_id, :destination_id, :date, :params
|
6
6
|
|
7
|
-
def initialize(origin_id:, destination_id:,
|
7
|
+
def initialize(origin_id:, destination_id:, date:, params: {})
|
8
8
|
@origin_id = origin_id
|
9
9
|
@destination_id = destination_id
|
10
|
-
@
|
11
|
-
@travel_date = Time.zone.now if travel_date.to_date == Time.zone.now.to_date
|
10
|
+
@date = date.to_date == Time.zone.now.to_date ? Time.zone.now : Time.zone.parse(date.to_s)
|
12
11
|
@params = params
|
13
12
|
end
|
14
13
|
|
15
14
|
def call
|
16
|
-
return [] if
|
15
|
+
return [] if date.to_date < Date.current
|
17
16
|
|
18
17
|
direct_results = direct_trips.map { |trip| SpreeCmCommissioner::TripQueryResult.new([trip]) }
|
19
18
|
connected_results = connected_trips || []
|
20
19
|
direct_results + connected_results
|
21
20
|
end
|
22
21
|
|
23
|
-
def direct_trips
|
24
|
-
result = Spree::
|
25
|
-
.select('
|
22
|
+
def direct_trips # rubocop:disable Metrics/MethodLength
|
23
|
+
result = Spree::Product
|
24
|
+
.select('
|
26
25
|
vendors.id AS vendor_id,
|
27
26
|
vendors.name AS vendor_name,
|
28
|
-
|
29
|
-
|
27
|
+
spree_products.name AS route_name,
|
28
|
+
spree_products.short_name AS short_name,
|
30
29
|
boarding.stop_id AS origin_id,
|
31
30
|
drop_off.stop_id AS destination_id,
|
32
31
|
boarding.stop_name AS origin,
|
33
32
|
drop_off.stop_name AS destination,
|
33
|
+
spree_products.id AS trip_id,
|
34
34
|
trips.departure_time AS departure_time,
|
35
35
|
trips.duration AS duration,
|
36
|
-
trips.vehicle_id AS vehicle_id
|
36
|
+
trips.vehicle_id AS vehicle_id,
|
37
|
+
COALESCE(iv.quantity_available, 0) AS quantity_available,
|
38
|
+
COALESCE(iv.max_capacity, 0) AS max_capacity'
|
37
39
|
)
|
38
|
-
.joins('INNER JOIN cm_trips AS trips ON trips.
|
39
|
-
.joins('INNER JOIN cm_trip_stops AS boarding ON boarding.trip_id =
|
40
|
-
.joins('INNER JOIN cm_trip_stops AS drop_off ON drop_off.trip_id =
|
41
|
-
.joins('INNER JOIN spree_vendors AS vendors ON vendors.id =
|
42
|
-
.joins(
|
40
|
+
.joins('INNER JOIN cm_trips AS trips ON trips.product_id = spree_products.id')
|
41
|
+
.joins('INNER JOIN cm_trip_stops AS boarding ON boarding.trip_id = trips.id AND boarding.stop_type = 0')
|
42
|
+
.joins('INNER JOIN cm_trip_stops AS drop_off ON drop_off.trip_id = trips.id AND drop_off.stop_type = 1')
|
43
|
+
.joins('INNER JOIN spree_vendors AS vendors ON vendors.id = spree_products.vendor_id')
|
44
|
+
.joins("LEFT JOIN (#{product_inventory_totals.to_sql}) iv ON spree_products.id = iv.product_id")
|
45
|
+
|
43
46
|
result = result.where(vendors: { id: params[:vendor_id] }) if params[:vendor_id].present?
|
44
47
|
result = result.where('boarding.stop_id = ? AND drop_off.stop_id = ?', origin_id, destination_id)
|
45
48
|
.where('trips.departure_time > ? AND trips.departure_time <= ?',
|
46
|
-
|
47
|
-
|
49
|
+
date.strftime('%H:%M:%S'),
|
50
|
+
date.end_of_day.strftime('%H:%M:%S')
|
48
51
|
)
|
49
52
|
|
50
53
|
result.map do |trip|
|
51
54
|
trip_result_options = {
|
52
|
-
trip_id: trip[:
|
55
|
+
trip_id: trip[:trip_id],
|
53
56
|
vendor_id: trip[:vendor_id],
|
54
57
|
vendor_name: trip[:vendor_name],
|
55
58
|
route_name: trip[:route_name],
|
@@ -61,7 +64,9 @@ module SpreeCmCommissioner
|
|
61
64
|
destination: trip[:destination],
|
62
65
|
vehicle_id: trip[:vehicle_id],
|
63
66
|
departure_time: parse_time(trip[:departure_time]),
|
64
|
-
duration: trip[:duration]
|
67
|
+
duration: trip[:duration],
|
68
|
+
quantity_available: trip[:quantity_available].to_i,
|
69
|
+
max_capacity: trip[:max_capacity].to_i
|
65
70
|
}
|
66
71
|
SpreeCmCommissioner::TripResult.new(trip_result_options)
|
67
72
|
end
|
@@ -69,52 +74,69 @@ module SpreeCmCommissioner
|
|
69
74
|
|
70
75
|
def connected_trips # rubocop:disable Metrics/MethodLength
|
71
76
|
result = SpreeCmCommissioner::TripConnection
|
72
|
-
.joins(
|
73
|
-
INNER JOIN
|
74
|
-
INNER JOIN
|
75
|
-
INNER JOIN spree_products AS
|
76
|
-
INNER JOIN spree_products AS
|
77
|
-
INNER JOIN
|
78
|
-
INNER JOIN
|
79
|
-
INNER JOIN cm_trip_stops
|
80
|
-
INNER JOIN
|
81
|
-
INNER JOIN
|
82
|
-
|
83
|
-
|
77
|
+
.joins("
|
78
|
+
INNER JOIN cm_trips trip1 ON trip1.id = cm_trip_connections.from_trip_id
|
79
|
+
INNER JOIN cm_trips trip2 ON trip2.id = cm_trip_connections.to_trip_id
|
80
|
+
INNER JOIN spree_products AS product1 ON product1.id = trip1.product_id
|
81
|
+
INNER JOIN spree_products AS product2 ON product2.id = trip2.product_id
|
82
|
+
INNER JOIN cm_trip_stops trip1_origin ON trip1_origin.trip_id = trip1.id AND trip1_origin.stop_type = 0
|
83
|
+
INNER JOIN cm_trip_stops trip2_origin ON trip2_origin.trip_id = trip2.id AND trip2_origin.stop_type = 0
|
84
|
+
INNER JOIN cm_trip_stops trip2_destination ON trip2_destination.trip_id = trip2.id AND trip2_destination.stop_type = 1
|
85
|
+
INNER JOIN spree_vendors AS vendor1 ON vendor1.id = product1.vendor_id
|
86
|
+
INNER JOIN spree_vendors AS vendor2 ON vendor2.id = product2.vendor_id
|
87
|
+
LEFT JOIN (#{product_inventory_totals.to_sql}) AS iv1 ON iv1.product_id = product1.id
|
88
|
+
LEFT JOIN (#{product_inventory_totals.to_sql}) AS iv2 ON iv2.product_id = product2.id"
|
84
89
|
)
|
85
90
|
.select('cm_trip_connections.id AS id,
|
86
|
-
trip1.
|
91
|
+
trip1.id AS trip1_id,
|
87
92
|
trip1.origin_id AS trip1_origin_id,
|
88
93
|
trip1.destination_id AS trip1_destination_id,
|
89
94
|
trip1.departure_time AS trip1_departure_time,
|
90
95
|
trip1.duration AS trip1_duration,
|
91
|
-
|
92
|
-
|
96
|
+
product1.id AS trip1_id,
|
97
|
+
product1.short_name AS route1_short_name,
|
98
|
+
product1.name AS route1_name,
|
93
99
|
trip1.vehicle_id AS trip1_vehicle,
|
94
100
|
vendor1.name AS trip1_vendor_name,
|
95
|
-
trip2.
|
101
|
+
trip2.id AS trip2_id,
|
96
102
|
trip2.origin_id AS trip2_origin_id,
|
97
103
|
trip2.destination_id AS trip2_destination_id,
|
98
104
|
trip2.departure_time AS trip2_departure_time,
|
99
105
|
trip2.duration AS trip2_duration,
|
100
106
|
trip2.vehicle_id AS trip2_vehicle,
|
101
|
-
|
102
|
-
|
107
|
+
product2.id AS trip2_id,
|
108
|
+
product2.short_name AS route2_short_name,
|
109
|
+
product2.name AS route2_name,
|
103
110
|
trip1_origin.stop_name AS trip1_origin,
|
104
111
|
trip2_origin.stop_name AS trip2_origin,
|
105
112
|
trip2_destination.stop_name AS trip2_destination,
|
106
|
-
vendor2.name AS trip2_vendor_name
|
113
|
+
vendor2.name AS trip2_vendor_name,
|
114
|
+
COALESCE(iv1.quantity_available, 0) as trip1_quantity_available,
|
115
|
+
COALESCE(iv2.quantity_available, 0) as trip2_quantity_available,
|
116
|
+
COALESCE(iv1.max_capacity, 0) as trip1_max_capacity,
|
117
|
+
COALESCE(iv2.max_capacity, 0) as trip2_max_capacity'
|
107
118
|
).where('trip1_origin.stop_id = ? AND trip2_destination.stop_id = ?', origin_id, destination_id)
|
108
119
|
result = result.where('vendor1.id = ? OR vendor2.id = ?', params[:vendor_id], params[:vendor_id]) if params[:vendor_id].present?
|
109
|
-
result = result.where('trip1.departure_time > ? AND trip1.departure_time <= ?',
|
110
|
-
|
120
|
+
result = result.where('trip1.departure_time > ? AND trip1.departure_time <= ?', date.strftime('%H:%M:%S'),
|
121
|
+
date.end_of_day.strftime('%H:%M:%S')
|
111
122
|
).uniq
|
112
|
-
|
113
123
|
return [] if result.blank?
|
114
124
|
|
115
125
|
build_trip_query_result(result)
|
116
126
|
end
|
117
127
|
|
128
|
+
def product_inventory_totals
|
129
|
+
Spree::Product
|
130
|
+
.select(
|
131
|
+
'spree_products.id AS product_id,
|
132
|
+
SUM(cm_inventory_items.max_capacity) AS max_capacity,
|
133
|
+
SUM(cm_inventory_items.quantity_available) AS quantity_available'
|
134
|
+
)
|
135
|
+
.joins(variants: :inventory_items)
|
136
|
+
.where(cm_inventory_items: { inventory_date: date.to_date })
|
137
|
+
.group('spree_products.id')
|
138
|
+
end
|
139
|
+
|
118
140
|
private
|
119
141
|
|
120
142
|
def build_trip_query_result(connections)
|
@@ -130,7 +152,9 @@ module SpreeCmCommissioner
|
|
130
152
|
short_name: trip[:route1_short_name],
|
131
153
|
vehicle_id: trip[:trip1_vehicle],
|
132
154
|
origin: trip[:trip1_origin],
|
133
|
-
destination: trip[:trip2_origin]
|
155
|
+
destination: trip[:trip2_origin],
|
156
|
+
quantity_available: trip[:trip1_quantity_available].to_i,
|
157
|
+
max_capacity: trip[:trip1_max_capacity].to_i
|
134
158
|
}
|
135
159
|
to_trip = {
|
136
160
|
trip_id: trip[:trip2_id],
|
@@ -143,7 +167,9 @@ module SpreeCmCommissioner
|
|
143
167
|
short_name: trip[:route2_short_name],
|
144
168
|
vehicle_id: trip[:trip2_vehicle],
|
145
169
|
origin: trip[:trip2_origin],
|
146
|
-
destination: trip[:trip2_destination]
|
170
|
+
destination: trip[:trip2_destination],
|
171
|
+
quantity_available: trip[:trip2_quantity_available].to_i,
|
172
|
+
max_capacity: trip[:trip2_max_capacity].to_i
|
147
173
|
}
|
148
174
|
data = [SpreeCmCommissioner::TripResult.new(from_trip),
|
149
175
|
SpreeCmCommissioner::TripResult.new(to_trip)
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module SpreeCmCommissioner
|
2
|
+
class VariantRequestSchema < ApplicationRequestSchema
|
3
|
+
params do
|
4
|
+
required(:from_date).value(:date)
|
5
|
+
required(:to_date).value(:date)
|
6
|
+
required(:adult).value(:integer)
|
7
|
+
required(:children).value(:integer)
|
8
|
+
end
|
9
|
+
|
10
|
+
rule(:from_date, :to_date) do
|
11
|
+
from_date = values[:from_date]
|
12
|
+
to_date = values[:to_date]
|
13
|
+
|
14
|
+
key.failure(:must_be_in_future) if from_date < Time.zone.today
|
15
|
+
key.failure(:must_be_later_than_start_date) if from_date > to_date
|
16
|
+
key.failure(:stay_is_too_long) if (to_date - from_date).to_i > ENV.fetch('ACCOMMODATION_MAX_STAY_DAYS', 10).to_i
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -9,10 +9,12 @@ module Spree
|
|
9
9
|
|
10
10
|
attributes :total_inventory, :service_availabilities
|
11
11
|
|
12
|
+
# Deprecated
|
12
13
|
attribute :total_booking do |vendor|
|
13
14
|
vendor.respond_to?(:total_booking) ? vendor.total_booking : 0
|
14
15
|
end
|
15
16
|
|
17
|
+
# Deprecated
|
16
18
|
attribute :remaining do |vendor|
|
17
19
|
vendor.respond_to?(:remaining) ? vendor.remaining : vendor.total_inventory
|
18
20
|
end
|
@@ -4,6 +4,7 @@ module Spree
|
|
4
4
|
module LineItemSerializerDecorator
|
5
5
|
def self.prepended(base)
|
6
6
|
base.attributes :from_date, :to_date, :need_confirmation, :product_type, :event_status, :amount, :display_amount,
|
7
|
+
:checkin_date, :checkout_date,
|
7
8
|
:number, :qr_data,
|
8
9
|
:kyc, :kyc_fields, :remaining_total_guests, :number_of_guests,
|
9
10
|
:completion_steps, :available_social_contact_platforms, :allow_anonymous_booking, :discontinue_on,
|
@@ -11,7 +11,6 @@ module Spree
|
|
11
11
|
has_one :profile, serializer: Spree::V2::Tenant::AssetSerializer
|
12
12
|
has_many :device_tokens, serializer: Spree::V2::Tenant::UserDeviceTokenSerializer
|
13
13
|
has_many :spree_roles, serializer: Spree::V2::Tenant::RoleSerializer
|
14
|
-
has_many :user_identity_providers, serializer: Spree::V2::Tenant::UserIdentityProviderSerializer
|
15
14
|
|
16
15
|
attribute :store_credits, &:total_available_store_credit
|
17
16
|
|
@@ -2,7 +2,7 @@ module SpreeCmCommissioner
|
|
2
2
|
module V2
|
3
3
|
module Storefront
|
4
4
|
class DynamicFieldSerializer < BaseSerializer
|
5
|
-
attributes :id, :label, :data_type, :vendor_id, :multiple_select, :created_at, :updated_at, :position
|
5
|
+
attributes :id, :label, :data_type, :vendor_id, :multiple_select, :created_at, :updated_at, :position
|
6
6
|
|
7
7
|
has_many :dynamic_field_options, serializer: SpreeCmCommissioner::V2::Storefront::DynamicFieldOptionSerializer
|
8
8
|
end
|
@@ -32,7 +32,7 @@ module SpreeCmCommissioner
|
|
32
32
|
options = { login: params[:username], password: params[:password], tenant_id: tenant_id }
|
33
33
|
SpreeCmCommissioner::UserPasswordAuthenticator.call(options)
|
34
34
|
when 'social_auth'
|
35
|
-
options = { id_token: params[:id_token]
|
35
|
+
options = { id_token: params[:id_token] }
|
36
36
|
SpreeCmCommissioner::UserIdTokenAuthenticator.call(options)
|
37
37
|
when 'telegram_web_app_auth'
|
38
38
|
options = { telegram_init_data: params[:telegram_init_data], telegram_bot_username: params[:tg_bot] }
|