spree_cm_commissioner 1.21.0 → 2.0.0.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/.env.example +0 -3
- data/.github/workflows/test_and_build_gem.yml +16 -2
- data/.gitignore +2 -1
- data/Gemfile.lock +28 -1
- data/Rakefile +33 -4
- data/app/assets/javascripts/spree_cm_commissioner/backend.js +0 -1
- data/app/assets/stylesheets/spree_cm_commissioner/backend/calendar.scss +8 -11
- data/app/assets/stylesheets/spree_cm_commissioner/backend/commissioner_admin.css.scss +0 -1
- data/app/controllers/concerns/spree_cm_commissioner/content_cachable.rb +1 -2
- data/app/controllers/spree/admin/event_blazer_queries_controller.rb +4 -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/admin/tenants_controller.rb +0 -8
- 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/dynamic_field_options_controller.rb +1 -5
- data/app/controllers/spree/api/v2/storefront/guests_controller.rb +5 -31
- data/app/controllers/spree/api/v2/storefront/queue_cart/line_items_controller.rb +2 -2
- data/app/controllers/spree/api/v2/tenant/checkout_controller.rb +0 -2
- data/app/controllers/spree_cm_commissioner/admin/variants_controller_decorator.rb +1 -1
- data/app/controllers/spree_cm_commissioner/api/v2/storefront/checkout_controller_decorator.rb +0 -11
- data/app/controllers/spree_cm_commissioner/well_known_controller.rb +17 -31
- data/app/factory/spree_cm_commissioner/invite_guest_claimed_telegram_message_factory.rb +84 -37
- 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/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/interactors/spree_cm_commissioner/vattanac_bank_initiator.rb +1 -5
- 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/models/concerns/spree_cm_commissioner/line_item_durationable.rb +9 -15
- data/app/models/concerns/spree_cm_commissioner/option_type_attr_type.rb +1 -13
- 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 -4
- data/app/models/spree_cm_commissioner/block.rb +23 -0
- data/app/models/spree_cm_commissioner/dynamic_field.rb +3 -17
- data/app/models/spree_cm_commissioner/dynamic_field_option.rb +1 -7
- data/app/models/spree_cm_commissioner/guest.rb +19 -1
- data/app/models/spree_cm_commissioner/guest_dynamic_field.rb +3 -21
- 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/invite.rb +6 -4
- data/app/models/spree_cm_commissioner/invite_team.rb +1 -3
- 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/pin_code.rb +2 -3
- data/app/models/spree_cm_commissioner/place.rb +1 -3
- data/app/models/spree_cm_commissioner/price_decorator.rb +9 -0
- data/app/models/spree_cm_commissioner/product_decorator.rb +10 -4
- 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_blazer_query.rb +8 -0
- data/app/models/spree_cm_commissioner/taxon_decorator.rb +2 -6
- data/app/models/spree_cm_commissioner/taxonomy_decorator.rb +0 -6
- data/app/models/spree_cm_commissioner/trip.rb +12 -10
- data/app/models/spree_cm_commissioner/trip_connection.rb +5 -5
- data/app/models/spree_cm_commissioner/trip_stop.rb +2 -3
- data/app/models/spree_cm_commissioner/user_identity_provider.rb +4 -26
- data/app/models/spree_cm_commissioner/user_taxon.rb +0 -1
- data/app/models/spree_cm_commissioner/variant_block.rb +9 -0
- data/app/models/spree_cm_commissioner/variant_decorator.rb +36 -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 +7 -10
- data/app/models/spree_cm_commissioner/vendor_place.rb +6 -5
- data/app/models/spree_cm_commissioner/vendor_stop.rb +1 -2
- data/app/overrides/spree/admin/variants/_form/kyc_field.html.erb.deface +2 -2
- data/app/queries/spree_cm_commissioner/guest_searcher_query.rb +3 -45
- data/app/queries/spree_cm_commissioner/trip_query.rb +23 -26
- 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/operator/dashboard_crew_event_serializer.rb +1 -4
- data/app/serializers/spree_cm_commissioner/v2/storefront/dynamic_field_option_serializer.rb +3 -1
- data/app/serializers/spree_cm_commissioner/v2/storefront/dynamic_field_serializer.rb +3 -1
- data/app/serializers/spree_cm_commissioner/v2/storefront/guest_dynamic_field_serializer.rb +1 -2
- data/app/services/spree_cm_commissioner/organizer/export_guest_csv_service.rb +15 -23
- data/app/services/spree_cm_commissioner/user_authenticator.rb +1 -1
- data/app/views/blazer/queries/_content.html.erb +0 -8
- 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/tenants/_form.html.erb +42 -109
- data/config/initializers/paper_trail.rb +1 -0
- data/config/initializers/spree_permitted_attributes.rb +5 -2
- data/config/locales/en.yml +0 -5
- data/config/routes.rb +22 -6
- 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/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 +9 -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 +8 -0
- data/lib/spree_cm_commissioner/test_helper/factories/seat_section_factory.rb +8 -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 +10 -3
- 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 +1 -1
- 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 +135 -57
- data/app/assets/images/cm-hangmeas-checkout_image.svg +0 -63
- data/app/assets/images/cm-hangmeas-failed.svg +0 -56
- data/app/assets/images/cm-hangmeas-loader.svg +0 -50
- data/app/assets/images/cm-hangmeas-success.svg +0 -51
- data/app/assets/javascripts/spree_cm_commissioner/tenant_payment_icon_fields.js +0 -65
- data/app/assets/stylesheets/spree_cm_commissioner/backend/tenant_payment_icon_fields.scss +0 -60
- data/app/controllers/concerns/spree_cm_commissioner/transit/taxon_bitwise.rb +0 -44
- data/app/controllers/spree/admin/trip_blazer_queries_controller.rb +0 -35
- data/app/controllers/spree/api/v2/organizer/invite_crews_controller.rb +0 -33
- data/app/finders/spree_cm_commissioner/line_items/find_by_variant_decorator.rb +0 -20
- data/app/interactors/spree_cm_commissioner/apple_app_site_association_fetcher.rb +0 -27
- data/app/interactors/spree_cm_commissioner/asset_links_fetcher.rb +0 -27
- data/app/interactors/spree_cm_commissioner/crew_invite_link_handler.rb +0 -48
- data/app/interactors/spree_cm_commissioner/telegram_chats_auto_finder.rb +0 -144
- data/app/models/concerns/spree_cm_commissioner/event_check_in_flowable.rb +0 -30
- data/app/models/spree_cm_commissioner/blazer_queryable.rb +0 -8
- data/app/models/spree_cm_commissioner/branch.rb +0 -12
- data/app/models/spree_cm_commissioner/crew_invite_link.rb +0 -4
- 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/pin_code_telegram.rb +0 -28
- data/app/models/spree_cm_commissioner/promotion_category_decorator.rb +0 -11
- data/app/models/spree_cm_commissioner/stop.rb +0 -23
- data/app/models/spree_cm_commissioner/telegram_chat.rb +0 -6
- data/app/models/spree_cm_commissioner/vehicle_seat.rb +0 -11
- data/app/models/spree_cm_commissioner/vehicle_type.rb +0 -76
- data/app/overrides/spree/admin/taxons/_form/check_in_flows.html.erb.deface +0 -18
- 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/serializers/spree/v2/organizer/invite_crews_serializer.rb +0 -11
- data/app/services/spree_cm_commissioner/vehicle_option_value_creator.rb +0 -11
- data/db/migrate/20250616084219_add_description_to_cm_vendor_place.rb +0 -5
- data/db/migrate/20250630103536_create_cm_telegram_chats.rb +0 -13
- data/db/migrate/20250701093203_add_configurations_to_cm_dynamic_field.rb +0 -6
- data/db/migrate/20250702091305_add_dynamic_field_option_to_guest_dynamic_field.rb +0 -5
- data/db/migrate/20250702091935_add_status_to_dynamic_field_option.rb +0 -5
- data/db/migrate/20250707032008_add_vendor_id_to_spree_category.rb +0 -7
- data/db/migrate/20250711092937_add_position_to_cm_dynamic_fields.rb +0 -11
- data/db/migrate/20250711093045_add_position_to_cm_dynamic_field_options.rb +0 -11
- data/db/migrate/20250714121508_rename_cm_taxon_blazer_query_to_blazer_queryables.rb +0 -7
- data/db/migrate/20250714124323_make_cm_blazer_queryables_polymorphic.rb +0 -19
- data/db/migrate/20250715103333_remove_indexes_from_cm_user_identity_providers.rb +0 -13
- 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
@@ -3,17 +3,15 @@ module SpreeCmCommissioner
|
|
3
3
|
enum identity_type: { :google => 0, :apple => 1, :facebook => 2, :telegram => 3, :vattanac_bank => 4 }
|
4
4
|
|
5
5
|
belongs_to :user, class_name: Spree.user_class.to_s, optional: false
|
6
|
-
has_one :tenant, through: :user
|
7
|
-
|
8
|
-
has_many :user_identity_provider_telegram_bots
|
9
|
-
has_many :telegram_bots, through: :user_identity_provider_telegram_bots
|
10
6
|
|
11
7
|
validates :sub, presence: true
|
8
|
+
validates :sub, uniqueness: { scope: :identity_type }
|
9
|
+
|
12
10
|
validates :identity_type, presence: true
|
13
11
|
validates :identity_type, uniqueness: { scope: :user_id }
|
14
12
|
|
15
|
-
|
16
|
-
|
13
|
+
has_many :user_identity_provider_telegram_bots
|
14
|
+
has_many :telegram_bots, through: :user_identity_provider_telegram_bots
|
17
15
|
|
18
16
|
# sub is a telegram uid, which telegram considered a chatID if
|
19
17
|
# user have /started with bot.
|
@@ -22,25 +20,5 @@ module SpreeCmCommissioner
|
|
22
20
|
|
23
21
|
nil
|
24
22
|
end
|
25
|
-
|
26
|
-
private
|
27
|
-
|
28
|
-
def unique_sub_per_identity_type_and_tenant
|
29
|
-
return if user.nil? || sub.blank? || identity_type.blank?
|
30
|
-
|
31
|
-
tenant_id = user.tenant_id
|
32
|
-
|
33
|
-
# Check for duplicates in the same tenant
|
34
|
-
scope = self.class
|
35
|
-
.joins(:user)
|
36
|
-
.where(sub: sub, identity_type: identity_type)
|
37
|
-
.where(spree_users: { tenant_id: tenant_id })
|
38
|
-
|
39
|
-
scope = scope.where.not(id: id) if persisted?
|
40
|
-
|
41
|
-
return unless scope.exists?
|
42
|
-
|
43
|
-
errors.add(:sub, 'must be unique per identity_type and tenant')
|
44
|
-
end
|
45
23
|
end
|
46
24
|
end
|
@@ -2,6 +2,5 @@ module SpreeCmCommissioner
|
|
2
2
|
class UserTaxon < Base
|
3
3
|
belongs_to :user, class_name: Spree.user_class.to_s, optional: false
|
4
4
|
belongs_to :taxon, class_name: 'Spree::Taxon', optional: false
|
5
|
-
has_many :invite_user_taxons, class_name: 'SpreeCmCommissioner::InviteUserTaxon', dependent: :destroy
|
6
5
|
end
|
7
6
|
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
module SpreeCmCommissioner
|
2
|
+
class VariantBlock < Base
|
3
|
+
belongs_to :variant, class_name: 'Spree::Variant', optional: false
|
4
|
+
belongs_to :trip, class_name: 'SpreeCmCommissioner::Trip', optional: false
|
5
|
+
belongs_to :block, class_name: 'SpreeCmCommissioner::Block', optional: false
|
6
|
+
|
7
|
+
validates :block_id, uniqueness: { scope: %i[variant_id trip_id] }
|
8
|
+
end
|
9
|
+
end
|
@@ -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,25 @@ 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
|
99
104
|
|
100
105
|
vendor.update(min_price: price) if vendor.min_price.nil? || price < vendor.min_price
|
101
106
|
vendor.update(max_price: price) if vendor.max_price.nil? || price > vendor.max_price
|
@@ -119,22 +124,6 @@ module SpreeCmCommissioner
|
|
119
124
|
end
|
120
125
|
end
|
121
126
|
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
127
|
end
|
139
128
|
end
|
140
129
|
|
@@ -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,12 +36,13 @@ 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, -> { branches }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
40
|
+
base.has_many :stops, -> { stops }, class_name: 'SpreeCmCommissioner::VendorPlace'
|
41
|
+
base.has_many :locations, -> { locations }, 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'
|
@@ -78,16 +79,12 @@ module SpreeCmCommissioner
|
|
78
79
|
base.has_many :invoices, class_name: 'SpreeCmCommissioner::Invoice', dependent: :destroy
|
79
80
|
base.has_many :subscriptions, through: :customers, class_name: 'SpreeCmCommissioner::Subscription'
|
80
81
|
base.has_many :subscription_orders, through: :subscriptions, class_name: 'Spree::Order', source: :orders
|
81
|
-
base.has_many :promotion_categories, class_name: 'Spree::PromotionCategory', foreign_key: :vendor_id, dependent: :destroy
|
82
82
|
|
83
83
|
base.has_many :homepage_section_relatables,
|
84
84
|
class_name: 'SpreeCmCommissioner::HomepageSectionRelatable',
|
85
85
|
dependent: :destroy, inverse_of: :relatable
|
86
86
|
|
87
|
-
base.has_many :vehicle_types, class_name: 'SpreeCmCommissioner::VehicleType', dependent: :destroy
|
88
87
|
base.has_many :vehicles, class_name: 'SpreeCmCommissioner::Vehicle', dependent: :destroy
|
89
|
-
# base.has_many :vehicles, through: :vehicle_types, class_name: 'SpreeCmCommissioner::Vehicle', dependent: :destroy
|
90
|
-
|
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
|
}
|
@@ -7,13 +7,14 @@ module SpreeCmCommissioner
|
|
7
7
|
belongs_to :place, class_name: 'SpreeCmCommissioner::Place', optional: false
|
8
8
|
|
9
9
|
validates :place_type, presence: true
|
10
|
-
validates :
|
10
|
+
validates :position, presence: true, numericality: { only_integer: true, greater_than: 0 }
|
11
11
|
|
12
|
-
|
12
|
+
# include place when using these delegate to avoid N+1
|
13
|
+
def display_name
|
14
|
+
place&.name
|
15
|
+
end
|
13
16
|
|
14
|
-
|
15
|
-
scope :stops, -> { where(place_type: :stop) }
|
16
|
-
scope :locations, -> { where(place_type: :location) }
|
17
|
+
accepts_nested_attributes_for :place, allow_destroy: true
|
17
18
|
|
18
19
|
def selected
|
19
20
|
vendor.selected_place_references.include?(place&.reference)
|
@@ -2,13 +2,13 @@
|
|
2
2
|
|
3
3
|
<p>Guest Information Fields</p>
|
4
4
|
<div class="form-check mb-3">
|
5
|
-
<%= f.check_box :use_product_kyc, id: "toggleGuestInfo", class: 'form-check-input mr-2', checked: @variant.kyc.
|
5
|
+
<%= f.check_box :use_product_kyc, id: "toggleGuestInfo", class: 'form-check-input mr-2', checked: (@variant.kyc == @product.kyc) %>
|
6
6
|
<label for="toggleGuestInfo" class="form-check-label">
|
7
7
|
Use Product Guest Information
|
8
8
|
</label>
|
9
9
|
</div>
|
10
10
|
|
11
|
-
<div id="guestInfoForm" <% if @variant.kyc.
|
11
|
+
<div id="guestInfoForm" <% if @variant.kyc == @product.kyc %>style="display: none;"<% end %>">
|
12
12
|
<small class="form-text text-muted mb-4">
|
13
13
|
<%= raw I18n.t('kyc.variant_note') %>
|
14
14
|
</small>
|
@@ -8,36 +8,20 @@ module SpreeCmCommissioner
|
|
8
8
|
|
9
9
|
def event_id = params[:event_id]
|
10
10
|
|
11
|
-
def call
|
11
|
+
def call
|
12
12
|
return SpreeCmCommissioner::Guest.none if event_id.blank?
|
13
13
|
|
14
|
-
if params[:qr_data].present?
|
15
|
-
search_by_order_qr
|
16
|
-
elsif params[:qr_data].present? && line_item_qr_data?
|
17
|
-
search_by_line_item_qr
|
18
|
-
elsif params[:qr_data].present? && guest_qr_data?
|
14
|
+
if params[:qr_data].present?
|
19
15
|
search_by_guest_qr
|
20
16
|
elsif params[:term].present?
|
21
17
|
search_by_term
|
22
|
-
elsif params[:ids].present?
|
23
|
-
SpreeCmCommissioner::Guest.complete_or_canceled.where(event_id: event_id, id: params[:ids])
|
24
18
|
else
|
25
|
-
SpreeCmCommissioner::Guest.
|
19
|
+
SpreeCmCommissioner::Guest.none
|
26
20
|
end
|
27
21
|
end
|
28
22
|
|
29
23
|
private
|
30
24
|
|
31
|
-
def search_by_order_qr
|
32
|
-
order = Spree::Order.complete_or_canceled.search_by_qr_data!(params[:qr_data])
|
33
|
-
order.guests.where(event_id: event_id)
|
34
|
-
end
|
35
|
-
|
36
|
-
def search_by_line_item_qr
|
37
|
-
line_item = Spree::LineItem.complete_or_canceled.search_by_qr_data!(params[:qr_data])
|
38
|
-
line_item.guests.where(event_id: event_id)
|
39
|
-
end
|
40
|
-
|
41
25
|
def search_by_guest_qr
|
42
26
|
SpreeCmCommissioner::Guest.complete_or_canceled.where(
|
43
27
|
token: params[:qr_data],
|
@@ -45,32 +29,6 @@ module SpreeCmCommissioner
|
|
45
29
|
)
|
46
30
|
end
|
47
31
|
|
48
|
-
def order_qr_data?
|
49
|
-
matches = construct_matches
|
50
|
-
matches&.size == 2
|
51
|
-
end
|
52
|
-
|
53
|
-
def line_item_qr_data?
|
54
|
-
matches = construct_matches
|
55
|
-
matches&.size == 3
|
56
|
-
end
|
57
|
-
|
58
|
-
def guest_qr_data?
|
59
|
-
matches = construct_matches
|
60
|
-
matches.nil?
|
61
|
-
end
|
62
|
-
|
63
|
-
def construct_matches
|
64
|
-
qr_data = params[:qr_data]
|
65
|
-
return nil unless qr_data
|
66
|
-
|
67
|
-
if qr_data =~ /-L\d+$/
|
68
|
-
qr_data.match(/(R\d+)-([A-Za-z0-9_\-]+)-(L\d+)/)&.captures
|
69
|
-
else
|
70
|
-
qr_data.match(/(R\d+)-([A-Za-z0-9_\-]+)/)&.captures
|
71
|
-
end
|
72
|
-
end
|
73
|
-
|
74
32
|
def search_by_term
|
75
33
|
terms = params[:term].split.map { |term| "%#{term.downcase}%" }
|
76
34
|
|
@@ -2,18 +2,18 @@ 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
|
-
@
|
10
|
+
@date = date
|
11
|
+
@date = Time.zone.now if date.to_date == Time.zone.now.to_date
|
12
12
|
@params = params
|
13
13
|
end
|
14
14
|
|
15
15
|
def call
|
16
|
-
return [] if
|
16
|
+
return [] if date.to_date < Date.current
|
17
17
|
|
18
18
|
direct_results = direct_trips.map { |trip| SpreeCmCommissioner::TripQueryResult.new([trip]) }
|
19
19
|
connected_results = connected_trips || []
|
@@ -35,18 +35,18 @@ module SpreeCmCommissioner
|
|
35
35
|
trips.duration AS duration,
|
36
36
|
trips.vehicle_id AS vehicle_id'
|
37
37
|
)
|
38
|
-
.joins('INNER JOIN
|
38
|
+
.joins('INNER JOIN spree_products AS routes ON routes.id = spree_variants.product_id')
|
39
|
+
.joins('INNER JOIN cm_trips AS trips ON trips.product_id = routes.id')
|
39
40
|
.joins('INNER JOIN cm_trip_stops AS boarding ON boarding.trip_id = spree_variants.id AND boarding.stop_type = 0')
|
40
41
|
.joins('INNER JOIN cm_trip_stops AS drop_off ON drop_off.trip_id = spree_variants.id AND drop_off.stop_type = 1')
|
41
42
|
.joins('INNER JOIN spree_vendors AS vendors ON vendors.id = spree_variants.vendor_id')
|
42
|
-
|
43
|
+
|
43
44
|
result = result.where(vendors: { id: params[:vendor_id] }) if params[:vendor_id].present?
|
44
45
|
result = result.where('boarding.stop_id = ? AND drop_off.stop_id = ?', origin_id, destination_id)
|
45
46
|
.where('trips.departure_time > ? AND trips.departure_time <= ?',
|
46
|
-
|
47
|
-
|
47
|
+
date.strftime('%H:%M:%S'),
|
48
|
+
date.end_of_day.strftime('%H:%M:%S')
|
48
49
|
)
|
49
|
-
|
50
50
|
result.map do |trip|
|
51
51
|
trip_result_options = {
|
52
52
|
trip_id: trip[:variant_id],
|
@@ -70,20 +70,18 @@ module SpreeCmCommissioner
|
|
70
70
|
def connected_trips # rubocop:disable Metrics/MethodLength
|
71
71
|
result = SpreeCmCommissioner::TripConnection
|
72
72
|
.joins('
|
73
|
-
INNER JOIN
|
74
|
-
INNER JOIN
|
75
|
-
INNER JOIN spree_products AS routes1 ON routes1.id =
|
76
|
-
INNER JOIN spree_products AS routes2 ON routes2.id =
|
77
|
-
INNER JOIN
|
78
|
-
INNER JOIN
|
79
|
-
INNER JOIN cm_trip_stops
|
80
|
-
INNER JOIN
|
81
|
-
INNER JOIN
|
82
|
-
INNER JOIN spree_vendors AS vendor1 ON vendor1.id = variant1.vendor_id
|
83
|
-
INNER JOIN spree_vendors AS vendor2 ON vendor2.id = variant2.vendor_id'
|
73
|
+
INNER JOIN cm_trips trip1 ON trip1.id = cm_trip_connections.from_trip_id
|
74
|
+
INNER JOIN cm_trips trip2 ON trip2.id = cm_trip_connections.to_trip_id
|
75
|
+
INNER JOIN spree_products AS routes1 ON routes1.id = trip1.product_id
|
76
|
+
INNER JOIN spree_products AS routes2 ON routes2.id = trip2.product_id
|
77
|
+
INNER JOIN cm_trip_stops trip1_origin ON trip1_origin.trip_id = trip1.id AND trip1_origin.stop_type = 0
|
78
|
+
INNER JOIN cm_trip_stops trip2_origin ON trip2_origin.trip_id = trip2.id AND trip2_origin.stop_type = 0
|
79
|
+
INNER JOIN cm_trip_stops trip2_destination ON trip2_destination.trip_id = trip2.id AND trip2_destination.stop_type = 1
|
80
|
+
INNER JOIN spree_vendors AS vendor1 ON vendor1.id = routes1.vendor_id
|
81
|
+
INNER JOIN spree_vendors AS vendor2 ON vendor2.id = routes2.vendor_id'
|
84
82
|
)
|
85
83
|
.select('cm_trip_connections.id AS id,
|
86
|
-
trip1.
|
84
|
+
trip1.id AS trip1_id,
|
87
85
|
trip1.origin_id AS trip1_origin_id,
|
88
86
|
trip1.destination_id AS trip1_destination_id,
|
89
87
|
trip1.departure_time AS trip1_departure_time,
|
@@ -92,7 +90,7 @@ module SpreeCmCommissioner
|
|
92
90
|
routes1.name AS route1_name,
|
93
91
|
trip1.vehicle_id AS trip1_vehicle,
|
94
92
|
vendor1.name AS trip1_vendor_name,
|
95
|
-
trip2.
|
93
|
+
trip2.id AS trip2_id,
|
96
94
|
trip2.origin_id AS trip2_origin_id,
|
97
95
|
trip2.destination_id AS trip2_destination_id,
|
98
96
|
trip2.departure_time AS trip2_departure_time,
|
@@ -106,10 +104,9 @@ module SpreeCmCommissioner
|
|
106
104
|
vendor2.name AS trip2_vendor_name'
|
107
105
|
).where('trip1_origin.stop_id = ? AND trip2_destination.stop_id = ?', origin_id, destination_id)
|
108
106
|
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
|
-
|
107
|
+
result = result.where('trip1.departure_time > ? AND trip1.departure_time <= ?', date.strftime('%H:%M:%S'),
|
108
|
+
date.end_of_day.strftime('%H:%M:%S')
|
111
109
|
).uniq
|
112
|
-
|
113
110
|
return [] if result.blank?
|
114
111
|
|
115
112
|
build_trip_query_result(result)
|
@@ -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,10 +2,7 @@ module SpreeCmCommissioner
|
|
2
2
|
module V2
|
3
3
|
module Operator
|
4
4
|
class DashboardCrewEventSerializer < BaseSerializer
|
5
|
-
attributes :id, :name, :permalink,
|
6
|
-
:from_date, :to_date,
|
7
|
-
:check_in_flows,
|
8
|
-
:updated_at
|
5
|
+
attributes :id, :name, :permalink, :from_date, :to_date, :updated_at
|
9
6
|
|
10
7
|
has_many :children_classifications, serializer: :classification
|
11
8
|
has_one :category_icon, serializer: SpreeCmCommissioner::V2::Storefront::AssetSerializer
|
@@ -2,7 +2,9 @@ module SpreeCmCommissioner
|
|
2
2
|
module V2
|
3
3
|
module Storefront
|
4
4
|
class DynamicFieldOptionSerializer < BaseSerializer
|
5
|
-
|
5
|
+
set_type :dynamic_field_option
|
6
|
+
|
7
|
+
attributes :id, :value, :dynamic_field_id, :created_at, :updated_at
|
6
8
|
end
|
7
9
|
end
|
8
10
|
end
|
@@ -2,7 +2,9 @@ module SpreeCmCommissioner
|
|
2
2
|
module V2
|
3
3
|
module Storefront
|
4
4
|
class DynamicFieldSerializer < BaseSerializer
|
5
|
-
|
5
|
+
set_type :dynamic_field
|
6
|
+
|
7
|
+
attributes :id, :label, :data_type, :vendor_id, :created_at, :updated_at
|
6
8
|
|
7
9
|
has_many :dynamic_field_options, serializer: SpreeCmCommissioner::V2::Storefront::DynamicFieldOptionSerializer
|
8
10
|
end
|
@@ -4,10 +4,9 @@ module SpreeCmCommissioner
|
|
4
4
|
class GuestDynamicFieldSerializer < BaseSerializer
|
5
5
|
set_type :guest_dynamic_field
|
6
6
|
|
7
|
-
attributes :id, :value, :guest_id, :dynamic_field_id, :
|
7
|
+
attributes :id, :value, :guest_id, :dynamic_field_id, :created_at, :updated_at
|
8
8
|
|
9
9
|
belongs_to :dynamic_field, serializer: SpreeCmCommissioner::V2::Storefront::DynamicFieldSerializer
|
10
|
-
belongs_to :dynamic_field_option, serializer: SpreeCmCommissioner::V2::Storefront::DynamicFieldOptionSerializer
|
11
10
|
end
|
12
11
|
end
|
13
12
|
end
|