spree_cm_commissioner 2.8.7 → 2.8.9.pre.pre1
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/.gitignore +6 -0
- data/Gemfile.lock +1 -1
- data/app/controllers/concerns/spree_cm_commissioner/content_cachable.rb +2 -0
- data/app/controllers/spree/admin/homepage_section_controller.rb +4 -1
- data/app/controllers/spree/admin/inventory_holds_controller.rb +20 -1
- data/app/controllers/spree/admin/taxons_controller_decorator.rb +19 -0
- data/app/controllers/spree/api/v2/storefront/homepage_sections_controller.rb +1 -0
- data/app/controllers/spree/api/v2/storefront/order_histories_controller.rb +7 -2
- data/app/controllers/spree/api/v2/storefront/preview_products_controller.rb +48 -0
- data/app/controllers/spree/api/v2/storefront/preview_sections_controller.rb +27 -0
- data/app/controllers/spree/api/v2/storefront/preview_taxons_controller.rb +18 -0
- data/app/controllers/spree/api/v2/storefront/products_controller_decorator.rb +15 -0
- data/app/controllers/spree/api/v2/storefront/taxons_controller_decorator.rb +15 -0
- data/app/controllers/spree/api/v2/tenant/ad_campaigns_controller.rb +25 -0
- data/app/controllers/spree/api/v2/tenant/base_controller.rb +4 -0
- data/app/controllers/spree/api/v2/tenant/episodes_controller.rb +38 -0
- data/app/controllers/spree/api/v2/tenant/free_vote_claims_controller.rb +37 -0
- data/app/controllers/spree/api/v2/tenant/homepage_sections_controller.rb +1 -0
- data/app/controllers/spree/api/v2/tenant/order_histories_controller.rb +7 -2
- data/app/controllers/spree/api/v2/tenant/preview_products_controller.rb +47 -0
- data/app/controllers/spree/api/v2/tenant/preview_sections_controller.rb +26 -0
- data/app/controllers/spree/api/v2/tenant/preview_shows_controller.rb +19 -0
- data/app/controllers/spree/api/v2/tenant/preview_taxons_controller.rb +19 -0
- data/app/controllers/spree/api/v2/tenant/products_controller.rb +1 -1
- data/app/controllers/spree/api/v2/tenant/show_contestants_controller.rb +52 -0
- data/app/controllers/spree/api/v2/tenant/show_elimination_sessions_controller.rb +57 -0
- data/app/controllers/spree/api/v2/tenant/show_people_controller.rb +49 -0
- data/app/controllers/spree/api/v2/tenant/show_person_assignments_controller.rb +36 -0
- data/app/controllers/spree/api/v2/tenant/shows_controller.rb +36 -0
- data/app/controllers/spree/api/v2/tenant/taxons_controller.rb +1 -1
- data/app/controllers/spree/api/v2/tenant/votes_controller.rb +94 -0
- data/app/controllers/spree/api/v2/tenant/voting_contestants_controller.rb +43 -0
- data/app/controllers/spree/api/v2/tenant/voting_credit_transactions_controller.rb +41 -0
- data/app/controllers/spree/api/v2/tenant/voting_credits_controller.rb +31 -0
- data/app/controllers/spree_cm_commissioner/admin/products_controller_decorator.rb +19 -0
- data/app/finders/spree_cm_commissioner/events/find_matches.rb +1 -0
- data/app/helpers/spree_cm_commissioner/admin/homepage_segment_helper.rb +2 -0
- data/app/interactors/spree_cm_commissioner/waiting_guests_caller.rb +39 -10
- data/app/jobs/spree_cm_commissioner/show_contestants/import_job.rb +9 -0
- data/app/jobs/spree_cm_commissioner/vote_fraud_event_job.rb +9 -0
- data/app/jobs/spree_cm_commissioner/voting_credit_allocation_job.rb +10 -0
- data/app/jobs/spree_cm_commissioner/voting_credit_de_allocation_job.rb +10 -0
- data/app/mailers/spree/order_mailer_decorator.rb +2 -0
- data/app/models/concerns/spree_cm_commissioner/homepage_section_bitwise.rb +2 -1
- data/app/models/concerns/spree_cm_commissioner/option_type_attr_type.rb +2 -1
- data/app/models/concerns/spree_cm_commissioner/order_state_machine.rb +33 -1
- data/app/models/concerns/spree_cm_commissioner/product_delegation.rb +2 -0
- data/app/models/concerns/spree_cm_commissioner/product_type.rb +1 -1
- data/app/models/concerns/spree_cm_commissioner/taxon_kind.rb +3 -1
- data/app/models/concerns/spree_cm_commissioner/voting_session_live_stream_concern.rb +41 -0
- data/app/models/spree_cm_commissioner/import.rb +2 -1
- data/app/models/spree_cm_commissioner/imports/import_contestant.rb +7 -0
- data/app/models/spree_cm_commissioner/maintenance_tasks/voting_session.rb +36 -0
- data/app/models/spree_cm_commissioner/preview_role.rb +8 -0
- data/app/models/spree_cm_commissioner/product_decorator.rb +53 -0
- data/app/models/spree_cm_commissioner/role_decorator.rb +4 -1
- data/app/models/spree_cm_commissioner/role_user_decorator.rb +8 -0
- data/app/models/spree_cm_commissioner/show.rb +163 -0
- data/app/models/spree_cm_commissioner/show_contestant.rb +39 -0
- data/app/models/spree_cm_commissioner/show_contestant_image.rb +11 -0
- data/app/models/spree_cm_commissioner/show_contestant_video.rb +15 -0
- data/app/models/spree_cm_commissioner/show_episode.rb +108 -0
- data/app/models/spree_cm_commissioner/show_person.rb +15 -0
- data/app/models/spree_cm_commissioner/show_person_assignment.rb +21 -0
- data/app/models/spree_cm_commissioner/show_person_image.rb +11 -0
- data/app/models/spree_cm_commissioner/taxon_decorator.rb +23 -0
- data/app/models/spree_cm_commissioner/taxonomy_decorator.rb +19 -1
- data/app/models/spree_cm_commissioner/tenant.rb +9 -0
- data/app/models/spree_cm_commissioner/user_decorator.rb +5 -0
- data/app/models/spree_cm_commissioner/variant_decorator.rb +4 -0
- data/app/models/spree_cm_commissioner/variant_options.rb +4 -0
- data/app/models/spree_cm_commissioner/vendor_decorator.rb +4 -0
- data/app/models/spree_cm_commissioner/vote.rb +16 -0
- data/app/models/spree_cm_commissioner/vote_fraud_event.rb +20 -0
- data/app/models/spree_cm_commissioner/voting_contestant.rb +100 -0
- data/app/models/spree_cm_commissioner/voting_credit.rb +72 -0
- data/app/models/spree_cm_commissioner/voting_credit_transaction.rb +55 -0
- data/app/models/spree_cm_commissioner/voting_session.rb +216 -0
- data/app/models/spree_cm_commissioner/voting_session_stat.rb +8 -0
- data/app/overrides/spree/admin/orders/_search/payment_number_search_field.html.erb.deface +8 -0
- data/app/overrides/spree/admin/products/_form/enable_telegram_alert.html.erb.deface +14 -0
- data/app/overrides/spree/admin/products/_form/preview_checkbox.html.erb.deface +9 -0
- data/app/overrides/spree/admin/taxons/_form/preview_checkbox.html.erb.deface +7 -0
- data/app/serializers/spree/v2/storefront/homepage_section_serializer.rb +1 -1
- data/app/serializers/spree/v2/storefront/product_serializer_decorator.rb +2 -1
- data/app/serializers/spree/v2/storefront/role_serializer.rb +1 -1
- data/app/serializers/spree/v2/storefront/taxon_serializer_decorator.rb +2 -1
- data/app/serializers/spree/v2/tenant/ad_campaign_serializer.rb +13 -0
- data/app/serializers/spree/v2/tenant/advertisement_serializer.rb +11 -0
- data/app/serializers/spree/v2/tenant/homepage_section_serializer.rb +1 -1
- data/app/serializers/spree/v2/tenant/role_serializer.rb +1 -1
- data/app/serializers/spree/v2/tenant/show_contestant_serializer.rb +21 -0
- data/app/serializers/spree/v2/tenant/show_episode_serializer.rb +20 -0
- data/app/serializers/spree/v2/tenant/show_parent_serializer.rb +13 -0
- data/app/serializers/spree/v2/tenant/show_person_assignment_serializer.rb +16 -0
- data/app/serializers/spree/v2/tenant/show_person_serializer.rb +13 -0
- data/app/serializers/spree/v2/tenant/show_serializer.rb +23 -0
- data/app/serializers/spree/v2/tenant/video_serializer.rb +9 -0
- data/app/serializers/spree/v2/tenant/vote_package_serializer.rb +9 -0
- data/app/serializers/spree/v2/tenant/vote_serializer.rb +14 -0
- data/app/serializers/spree/v2/tenant/voting_contestant_serializer.rb +23 -0
- data/app/serializers/spree/v2/tenant/voting_credit_serializer.rb +10 -0
- data/app/serializers/spree/v2/tenant/voting_credit_transaction_serializer.rb +14 -0
- data/app/serializers/spree/v2/tenant/voting_session_serializer.rb +21 -0
- data/app/services/spree_cm_commissioner/api_caches/invalidate.rb +12 -0
- data/app/services/spree_cm_commissioner/cart/add_guest.rb +16 -2
- data/app/services/spree_cm_commissioner/fraud_check.rb +299 -0
- data/app/services/spree_cm_commissioner/imports/contestants/create.rb +153 -0
- data/app/services/spree_cm_commissioner/show_contestants/normalize_video_highlights.rb +57 -0
- data/app/services/spree_cm_commissioner/show_persons/contestant_assigner.rb +51 -0
- data/app/services/spree_cm_commissioner/url_embed/youtube_embed.rb +44 -0
- data/app/services/spree_cm_commissioner/vote_counters/audit_counters.rb +43 -0
- data/app/services/spree_cm_commissioner/vote_counters/base.rb +31 -0
- data/app/services/spree_cm_commissioner/vote_counters/increment.rb +44 -0
- data/app/services/spree_cm_commissioner/vote_counters/per_contestant_counter.rb +68 -0
- data/app/services/spree_cm_commissioner/vote_counters/rebuild_from_db.rb +70 -0
- data/app/services/spree_cm_commissioner/vote_counters/snapshot_to_db.rb +113 -0
- data/app/services/spree_cm_commissioner/vote_credit_deductor.rb +68 -0
- data/app/services/spree_cm_commissioner/vote_package/create.rb +145 -0
- data/app/services/spree_cm_commissioner/vote_package/update.rb +91 -0
- data/app/services/spree_cm_commissioner/vote_processor.rb +144 -0
- data/app/services/spree_cm_commissioner/voting_contestants/advancer.rb +335 -0
- data/app/services/spree_cm_commissioner/voting_contestants/assigner.rb +40 -0
- data/app/services/spree_cm_commissioner/voting_contestants/bulk_updater.rb +106 -0
- data/app/services/spree_cm_commissioner/voting_credits/allocate.rb +77 -0
- data/app/services/spree_cm_commissioner/voting_credits/claim_free_votes.rb +119 -0
- data/app/services/spree_cm_commissioner/voting_credits/credit_calculator.rb +35 -0
- data/app/services/spree_cm_commissioner/voting_credits/de_allocate.rb +87 -0
- data/app/services/spree_cm_commissioner/voting_leaderboards/calculate_score.rb +67 -0
- data/app/services/spree_cm_commissioner/voting_leaderboards/combined_result.rb +190 -0
- data/app/services/spree_cm_commissioner/voting_sessions/finalize.rb +105 -0
- data/app/services/spree_cm_commissioner/waiting_room/publish_lobby_path.rb +11 -2
- data/app/services/spree_cm_commissioner/waiting_room/stamp_queue_positions.rb +37 -8
- data/app/views/spree/admin/homepage_section/_form.html.erb +5 -0
- data/app/views/spree_cm_commissioner/order_mailer/purchased_items/_items.html.erb +12 -9
- data/config/initializers/spree_permitted_attributes.rb +11 -0
- data/config/locales/en.yml +50 -4
- data/config/locales/km.yml +34 -2
- data/config/routes.rb +28 -0
- data/db/migrate/20260309230148_create_cm_show_people.rb +14 -0
- data/db/migrate/20260309230149_create_cm_show_people_assignments.rb +16 -0
- data/db/migrate/20260310082711_create_cm_show_contestants.rb +28 -0
- data/db/migrate/20260310082720_create_cm_voting_sessions.rb +21 -0
- data/db/migrate/20260310082721_create_cm_voting_contestants.rb +23 -0
- data/db/migrate/20260310082734_add_voting_fields_to_spree_taxons.rb +9 -0
- data/db/migrate/20260310082735_add_type_to_spree_products.rb +6 -0
- data/db/migrate/20260310082749_create_cm_voting_credits.rb +27 -0
- data/db/migrate/20260326080200_create_cm_voting_credit_transactions.rb +27 -0
- data/db/migrate/20260330160000_create_cm_votes.rb +25 -0
- data/db/migrate/20260401072500_add_advanced_from_to_cm_voting_contestants.rb +7 -0
- data/db/migrate/20260402000001_add_voting_credit_scope_to_spree_taxons.rb +6 -0
- data/db/migrate/20260402000002_rename_scopeable_to_votable_in_cm_voting_credits.rb +12 -0
- data/db/migrate/20260403070000_add_name_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260406000001_add_vendor_id_to_voting_tables.rb +6 -0
- data/db/migrate/20260406000001_rename_votes_remaining_to_amount_in_cm_voting_credits.rb +11 -0
- data/db/migrate/20260408085255_add_show_id_and_vendor_id_to_cm_voting_sessions.rb +9 -0
- data/db/migrate/20260420000001_rename_type_to_credit_type_in_cm_voting_credits.rb +25 -0
- data/db/migrate/20260422000001_create_cm_vote_fraud_events.rb +23 -0
- data/db/migrate/20260423000001_add_preview_to_taxons_products_and_sections.rb +11 -0
- data/db/migrate/20260423000002_create_preview_roles.rb +24 -0
- data/db/migrate/20260515120000_add_public_metadata_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260518090920_add_unique_voter_count_to_voting_contestants.rb +5 -0
- data/db/migrate/20260518094322_create_cm_voting_session_stats.rb +17 -0
- data/db/migrate/20260520000001_add_scoring_model_to_cm_voting_sessions.rb +5 -0
- data/db/migrate/20260520000001_optimize_cm_votes_indexes.rb +22 -0
- data/db/migrate/20260525042257_add_vote_number_to_cm_voting_contestants.rb +18 -0
- data/db/migrate/20260527035430_add_confirmed_rank_to_cm_voting_contestants.rb +5 -0
- data/db/migrate/20260527062005_add_eliminated_at_to_cm_show_contestants.rb +5 -0
- data/db/migrate/20260603063652_add_parent_to_voting_sessions.rb +9 -0
- data/db/migrate/20260603090000_add_session_type_to_cm_voting_sessions.rb +6 -0
- data/db/migrate/20260608000000_add_display_to_cm_voting_sessions.rb +5 -0
- data/docs/sql/jsonb_query_guide.md +57 -0
- data/lib/spree_cm_commissioner/test_helper/factories/show_episode_factory.rb +12 -0
- data/lib/spree_cm_commissioner/test_helper/factories/show_factory.rb +120 -0
- data/lib/spree_cm_commissioner/test_helper/factories/vote_credit_factory.rb +37 -0
- data/lib/spree_cm_commissioner/test_helper/factories/vote_factory.rb +28 -0
- data/lib/spree_cm_commissioner/test_helper/factories/voting_credit_transaction_factory.rb +11 -0
- data/lib/spree_cm_commissioner/test_helper/factories/voting_session_factory.rb +11 -0
- data/lib/spree_cm_commissioner/version.rb +1 -1
- data/lib/spree_cm_commissioner.rb +7 -1
- data/spree_cm_commissioner.gemspec +1 -1
- metadata +133 -4
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 21353bffad01d109c6d6cecd34a9a99fff871cd505adc678c725f94ed4e733ef
|
|
4
|
+
data.tar.gz: 55641da3ba827c4533e6362aa376abcbd33d8f454543fc289d45df56da772cce
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 266f2dc7d634dcb279f1b84631ea17b07bb511c54b5212f58c0354fe32ea54ffb82cf37e2b349b60768f82fbb83959df4d5da4b6b41a6cf5bd1522b8efc91027
|
|
7
|
+
data.tar.gz: 1009f16a54fdb769f5885d00555500c4e30920622258d3ce0c5e06fe72be2da462e8e1d256dd79dfbd755f2221329f41fce398223cb9ad54a9c54524882e61f0
|
data/.gitignore
CHANGED
data/Gemfile.lock
CHANGED
|
@@ -16,6 +16,7 @@ module SpreeCmCommissioner
|
|
|
16
16
|
GuestCardClassesController
|
|
17
17
|
SeatLayoutController
|
|
18
18
|
CmsPagesController
|
|
19
|
+
AdvertisementsController
|
|
19
20
|
].freeze
|
|
20
21
|
|
|
21
22
|
# Priority 2: Semi-Static (1 hour)
|
|
@@ -25,6 +26,7 @@ module SpreeCmCommissioner
|
|
|
25
26
|
HomepageDataController
|
|
26
27
|
PopularRoutesController
|
|
27
28
|
RoutePlacesController
|
|
29
|
+
ShowsController
|
|
28
30
|
].freeze
|
|
29
31
|
|
|
30
32
|
# Priority 3: Moderate Freshness (30 minutes)
|
|
@@ -51,7 +51,10 @@ module Spree
|
|
|
51
51
|
def permitted_resource_params
|
|
52
52
|
segment_value = helpers.calculate_segment_value(params[:spree_cm_commissioner_homepage_section])
|
|
53
53
|
|
|
54
|
-
params
|
|
54
|
+
params
|
|
55
|
+
.require(:spree_cm_commissioner_homepage_section)
|
|
56
|
+
.permit(:title, :description, :active, :tenant_id, :preview)
|
|
57
|
+
.merge(segment: segment_value)
|
|
55
58
|
end
|
|
56
59
|
|
|
57
60
|
def load_tenants
|
|
@@ -9,6 +9,7 @@ module Spree
|
|
|
9
9
|
q['s'] ||= 'created_at desc'
|
|
10
10
|
q['created_at_gt'] = parse_time_or_nil(q['created_at_gt'], :beginning_of_day) if q['created_at_gt'].present?
|
|
11
11
|
q['created_at_lt'] = parse_time_or_nil(q['created_at_lt'], :end_of_day) if q['created_at_lt'].present?
|
|
12
|
+
normalize_enum_filters!(q)
|
|
12
13
|
|
|
13
14
|
@search = scope.ransack(q)
|
|
14
15
|
result_scope = @search.result(distinct: true)
|
|
@@ -18,7 +19,11 @@ module Spree
|
|
|
18
19
|
.page(params[:page])
|
|
19
20
|
.per(params[:per_page] || Spree::Backend::Config[:admin_orders_per_page])
|
|
20
21
|
|
|
21
|
-
|
|
22
|
+
# Status tab counts must reflect every other filter but NOT the status filter, so
|
|
23
|
+
# each tab shows how many holds it would return (otherwise selecting one status
|
|
24
|
+
# zeroes out all the other tabs).
|
|
25
|
+
@status_counts = scope.ransack(q.except('status_eq')).result(distinct: true)
|
|
26
|
+
.reorder(nil).group(:status).count
|
|
22
27
|
end
|
|
23
28
|
|
|
24
29
|
def release
|
|
@@ -44,6 +49,20 @@ module Spree
|
|
|
44
49
|
|
|
45
50
|
private
|
|
46
51
|
|
|
52
|
+
# `status` and `release_reason` are integer-backed enums. Ransack casts a string
|
|
53
|
+
# value for an integer column with String#to_i, so "payment_locked" becomes 0
|
|
54
|
+
# (== :pending) and every label silently filters to the wrong status. Translate
|
|
55
|
+
# enum labels to their stored integer before searching.
|
|
56
|
+
def normalize_enum_filters!(query)
|
|
57
|
+
{
|
|
58
|
+
'status_eq' => SpreeCmCommissioner::InventoryHold.statuses,
|
|
59
|
+
'release_reason_eq' => SpreeCmCommissioner::InventoryHold.release_reasons
|
|
60
|
+
}.each do |key, mapping|
|
|
61
|
+
value = query[key]
|
|
62
|
+
query[key] = mapping[value.to_s] if value.present? && mapping.key?(value.to_s)
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
|
|
47
66
|
def back_params
|
|
48
67
|
raw_params = params[:back_params].presence || params
|
|
49
68
|
ActionController::Parameters.new(raw_params).permit(:page, :per_page, q: {})
|
|
@@ -3,6 +3,7 @@ module Spree
|
|
|
3
3
|
module TaxonsControllerDecorator
|
|
4
4
|
def self.prepended(base)
|
|
5
5
|
base.before_action :build_assets, only: %i[create update]
|
|
6
|
+
base.before_action :normalize_sti_taxon_params, only: %i[create update]
|
|
6
7
|
end
|
|
7
8
|
|
|
8
9
|
# override
|
|
@@ -55,6 +56,24 @@ module Spree
|
|
|
55
56
|
@taxon.build_ad_banner(attachment: permitted_resource_params.delete(:ad_banner)) if permitted_resource_params[:ad_banner]
|
|
56
57
|
@taxon.build_video_banner(attachment: permitted_resource_params.delete(:video_banner)) if permitted_resource_params[:video_banner]
|
|
57
58
|
end
|
|
59
|
+
|
|
60
|
+
# Some admin forms submit STI records under their class key
|
|
61
|
+
# (e.g. :spree_cm_commissioner_show) while Spree update reads :taxon.
|
|
62
|
+
# Merge both into :taxon so all edited fields are persisted.
|
|
63
|
+
def normalize_sti_taxon_params
|
|
64
|
+
return unless @taxon
|
|
65
|
+
|
|
66
|
+
sti_key = @taxon.class.model_name.param_key.to_sym
|
|
67
|
+
sti_params = params[sti_key]
|
|
68
|
+
return unless sti_params.is_a?(::ActionController::Parameters)
|
|
69
|
+
|
|
70
|
+
base_params = params[:taxon]
|
|
71
|
+
base_hash = base_params.is_a?(::ActionController::Parameters) ? base_params.to_unsafe_h : {}
|
|
72
|
+
sti_hash = sti_params.to_unsafe_h
|
|
73
|
+
merged_params = ::ActionController::Parameters.new(base_hash.merge(sti_hash))
|
|
74
|
+
|
|
75
|
+
params[:taxon] = merged_params
|
|
76
|
+
end
|
|
58
77
|
end
|
|
59
78
|
end
|
|
60
79
|
end
|
|
@@ -30,13 +30,18 @@ module Spree
|
|
|
30
30
|
private
|
|
31
31
|
|
|
32
32
|
def collection
|
|
33
|
+
# WARNING: Do NOT remove .order(id: :desc).
|
|
34
|
+
# Mobile relies on this ordering for paginated order_histories.
|
|
35
|
+
# Removing it will cause mobile to paginate by oldest records first (last 10 oldest),
|
|
36
|
+
# breaking the "most recent orders" display on the order history screen.
|
|
37
|
+
# It related to user cancel or complete order flow, which relies on the most recent orders being returned first.
|
|
33
38
|
if spree_current_user.present?
|
|
34
|
-
spree_current_user.orders.not_archived
|
|
39
|
+
spree_current_user.orders.not_archived.order(id: :desc)
|
|
35
40
|
else
|
|
36
41
|
order_tokens = Array(params[:order_tokens])
|
|
37
42
|
return Spree::Order.none if order_tokens.empty?
|
|
38
43
|
|
|
39
|
-
Spree::Order.not_archived.without_user.where(token: order_tokens)
|
|
44
|
+
Spree::Order.not_archived.without_user.where(token: order_tokens).order(id: :desc)
|
|
40
45
|
end
|
|
41
46
|
end
|
|
42
47
|
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewProductsController < ::Spree::Api::V2::Storefront::ProductsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
private
|
|
9
|
+
|
|
10
|
+
def scope(**args)
|
|
11
|
+
taxon_type = model_class.reflect_on_association(:taxons).klass.polymorphic_name
|
|
12
|
+
|
|
13
|
+
# IDs of products that have been explicitly assigned their own PreviewRole.
|
|
14
|
+
products_with_own_roles = SpreeCmCommissioner::PreviewRole
|
|
15
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
16
|
+
.select(:previewable_id)
|
|
17
|
+
|
|
18
|
+
# Base: all active preview products from the parent scope.
|
|
19
|
+
base = super(**args).rewhere(preview: true).where(status: :active)
|
|
20
|
+
|
|
21
|
+
# Path A: product has its own PreviewRole → user must hold that role directly.
|
|
22
|
+
# Taxon membership is irrelevant for these products.
|
|
23
|
+
via_product_role = base
|
|
24
|
+
.where(id: products_with_own_roles)
|
|
25
|
+
.where(id: spree_current_user.preview_roles
|
|
26
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
27
|
+
.select(:previewable_id)
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
# Path B: product has no own PreviewRole → inherit access from its taxons.
|
|
31
|
+
# Accessible if the user holds a preview role for any taxon the product belongs to.
|
|
32
|
+
via_taxon = base
|
|
33
|
+
.where.not(id: products_with_own_roles)
|
|
34
|
+
.joins(:taxons)
|
|
35
|
+
.where(spree_taxons: { id: spree_current_user.preview_roles
|
|
36
|
+
.where(previewable_type: taxon_type)
|
|
37
|
+
.select(:previewable_id)
|
|
38
|
+
}
|
|
39
|
+
)
|
|
40
|
+
|
|
41
|
+
# via_taxon uses joins(:taxons) which is incompatible with or — wrap as subquery.
|
|
42
|
+
via_product_role.or(base.where(id: via_taxon.select(:id)))
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewSectionsController < HomepageSectionsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def collection
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: Spree::Taxon.polymorphic_name).pluck(:previewable_id)
|
|
11
|
+
|
|
12
|
+
section_ids = SpreeCmCommissioner::HomepageSectionRelatable
|
|
13
|
+
.where(relatable_type: 'Spree::Taxon', relatable_id: allowed_ids.presence || [])
|
|
14
|
+
.select(:homepage_section_id)
|
|
15
|
+
|
|
16
|
+
@collection ||= model_class.filter_by_segment(params[:homepage_id] || :general)
|
|
17
|
+
.active
|
|
18
|
+
.where(tenant_id: nil)
|
|
19
|
+
.where(preview: true)
|
|
20
|
+
.where(id: section_ids)
|
|
21
|
+
.order(position: :asc)
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
class PreviewTaxonsController < ::Spree::Api::V2::Storefront::TaxonsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
private
|
|
9
|
+
|
|
10
|
+
def scope(**args)
|
|
11
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: model_class.polymorphic_name).select(:previewable_id)
|
|
12
|
+
super(**args).rewhere(preview: true).where(id: allowed_ids)
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
module ProductsControllerDecorator
|
|
6
|
+
def scope
|
|
7
|
+
super.where(preview: false)
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
Spree::Api::V2::Storefront::ProductsController.prepend(Spree::Api::V2::Storefront::ProductsControllerDecorator)
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Storefront
|
|
5
|
+
module TaxonsControllerDecorator
|
|
6
|
+
def scope
|
|
7
|
+
super.where(preview: false)
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
end
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
Spree::Api::V2::Storefront::TaxonsController.prepend(Spree::Api::V2::Storefront::TaxonsControllerDecorator)
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class AdCampaignsController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
def scope
|
|
9
|
+
Spree::Taxon.ad_campaigns
|
|
10
|
+
.joins(:vendor)
|
|
11
|
+
.includes(:advertisements)
|
|
12
|
+
.where(spree_vendors: { tenant_id: @tenant.id })
|
|
13
|
+
.where('spree_taxons.from_date <= ? OR spree_taxons.from_date IS NULL', Time.current)
|
|
14
|
+
.where('spree_taxons.to_date >= ? OR spree_taxons.to_date IS NULL', Time.current)
|
|
15
|
+
.order(created_at: :asc)
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
def collection_serializer
|
|
19
|
+
Spree::V2::Tenant::AdCampaignSerializer
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class EpisodesController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
def model_class
|
|
9
|
+
SpreeCmCommissioner::ShowEpisode
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
def resource
|
|
13
|
+
@resource ||= scope.find(params[:id])
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def scope
|
|
17
|
+
current_season.episodes.where(product_type: :show_episode).includes(:voting_sessions, :vote_packages)
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def current_season
|
|
21
|
+
@current_season ||= SpreeCmCommissioner::Show
|
|
22
|
+
.where(vendor_id: @tenant.vendors.select(:id))
|
|
23
|
+
.where.not(parent_id: nil)
|
|
24
|
+
.find_by!(slug: params[:show_id])
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def resource_serializer
|
|
28
|
+
Spree::V2::Tenant::ShowEpisodeSerializer
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def collection_serializer
|
|
32
|
+
Spree::V2::Tenant::ShowEpisodeSerializer
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
end
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class FreeVoteClaimsController < BaseController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
def create
|
|
9
|
+
show = current_vendor.shows.find(params[:show_id])
|
|
10
|
+
|
|
11
|
+
result = SpreeCmCommissioner::VotingCredits::ClaimFreeVotes.new(
|
|
12
|
+
show: show,
|
|
13
|
+
user: spree_current_user,
|
|
14
|
+
tenant_id: MultiTenant.current_tenant_id,
|
|
15
|
+
votable_type: params[:votable_type],
|
|
16
|
+
votable_id: params[:votable_id]
|
|
17
|
+
).call
|
|
18
|
+
|
|
19
|
+
if result.failure?
|
|
20
|
+
render_error_payload(result.error.to_s)
|
|
21
|
+
elsif result.value.nil?
|
|
22
|
+
head :no_content
|
|
23
|
+
else
|
|
24
|
+
render_serialized_payload { serialize_resource(result.value) }
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
private
|
|
29
|
+
|
|
30
|
+
def resource_serializer
|
|
31
|
+
Spree::V2::Tenant::VotingCreditSerializer
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
@@ -37,13 +37,18 @@ module Spree
|
|
|
37
37
|
end
|
|
38
38
|
|
|
39
39
|
def collection
|
|
40
|
+
# WARNING: Do NOT remove .order(id: :desc).
|
|
41
|
+
# Mobile relies on this ordering for paginated order_histories.
|
|
42
|
+
# Removing it will cause mobile to paginate by oldest records first (last 10 oldest),
|
|
43
|
+
# breaking the "most recent orders" display on the order history screen.
|
|
44
|
+
# It related to user cancel or complete order flow, which relies on the most recent orders being returned first.
|
|
40
45
|
if spree_current_user.present?
|
|
41
|
-
spree_current_user.orders.not_archived
|
|
46
|
+
spree_current_user.orders.not_archived.order(id: :desc)
|
|
42
47
|
else
|
|
43
48
|
order_tokens = Array(params[:order_tokens])
|
|
44
49
|
return Spree::Order.none if order_tokens.empty?
|
|
45
50
|
|
|
46
|
-
Spree::Order.not_archived.without_user.where(token: order_tokens)
|
|
51
|
+
Spree::Order.not_archived.without_user.where(token: order_tokens).order(id: :desc)
|
|
47
52
|
end
|
|
48
53
|
end
|
|
49
54
|
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewProductsController < ProductsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
taxon_type = model_class.reflect_on_association(:taxons).klass.polymorphic_name
|
|
11
|
+
|
|
12
|
+
# IDs of products that have been explicitly assigned their own PreviewRole.
|
|
13
|
+
products_with_own_roles = SpreeCmCommissioner::PreviewRole
|
|
14
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
15
|
+
.select(:previewable_id)
|
|
16
|
+
|
|
17
|
+
# Base: all active preview products from the parent scope.
|
|
18
|
+
base = super.where(status: :active, preview: true)
|
|
19
|
+
|
|
20
|
+
# Path A: product has its own PreviewRole → user must hold that role directly.
|
|
21
|
+
# Taxon membership is irrelevant for these products.
|
|
22
|
+
via_product_role = base
|
|
23
|
+
.where(id: products_with_own_roles)
|
|
24
|
+
.where(id: spree_current_user.preview_roles
|
|
25
|
+
.where(previewable_type: model_class.polymorphic_name)
|
|
26
|
+
.select(:previewable_id)
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Path B: product has no own PreviewRole → inherit access from its taxons.
|
|
30
|
+
# Accessible if the user holds a preview role for any taxon the product belongs to.
|
|
31
|
+
via_taxon = base
|
|
32
|
+
.where.not(id: products_with_own_roles)
|
|
33
|
+
.joins(:taxons)
|
|
34
|
+
.where(spree_taxons: { id: spree_current_user.preview_roles
|
|
35
|
+
.where(previewable_type: taxon_type)
|
|
36
|
+
.select(:previewable_id)
|
|
37
|
+
}
|
|
38
|
+
)
|
|
39
|
+
|
|
40
|
+
# via_taxon uses joins(:taxons) which is incompatible with or — wrap as subquery.
|
|
41
|
+
via_product_role.or(base.where(id: via_taxon.select(:id)))
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewSectionsController < HomepageSectionsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def collection
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: Spree::Taxon.polymorphic_name).pluck(:previewable_id)
|
|
11
|
+
|
|
12
|
+
section_ids = SpreeCmCommissioner::HomepageSectionRelatable
|
|
13
|
+
.where(relatable_type: 'Spree::Taxon', relatable_id: allowed_ids.presence || [])
|
|
14
|
+
.select(:homepage_section_id)
|
|
15
|
+
|
|
16
|
+
@collection ||= scope.filter_by_segment(params[:homepage_id] || :general)
|
|
17
|
+
.active
|
|
18
|
+
.where(preview: true)
|
|
19
|
+
.where(id: section_ids)
|
|
20
|
+
.order(position: :asc)
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewShowsController < ShowsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles
|
|
11
|
+
.where(previewable_type: SpreeCmCommissioner::Show.polymorphic_name)
|
|
12
|
+
.select(:previewable_id)
|
|
13
|
+
super.rewhere(preview: true).where(id: allowed_ids)
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class PreviewTaxonsController < TaxonsController
|
|
6
|
+
before_action :require_spree_current_user
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def scope
|
|
10
|
+
allowed_ids = spree_current_user.preview_roles.where(previewable_type: model_class.polymorphic_name).select(:previewable_id)
|
|
11
|
+
MultiTenant.with(@tenant) do
|
|
12
|
+
model_class.where(preview: true, id: allowed_ids)
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
module Spree
|
|
2
|
+
module Api
|
|
3
|
+
module V2
|
|
4
|
+
module Tenant
|
|
5
|
+
class ShowContestantsController < BaseController
|
|
6
|
+
private
|
|
7
|
+
|
|
8
|
+
# override
|
|
9
|
+
def model_class
|
|
10
|
+
SpreeCmCommissioner::ShowContestant
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
# override
|
|
14
|
+
def scope
|
|
15
|
+
return model_class.none unless current_show
|
|
16
|
+
|
|
17
|
+
model_class
|
|
18
|
+
.where(show_id: current_show.id)
|
|
19
|
+
.includes(
|
|
20
|
+
:show_contestant_images,
|
|
21
|
+
:show_contestant_videos,
|
|
22
|
+
:current_voting_session,
|
|
23
|
+
:voting_contestants,
|
|
24
|
+
assigned_show_person: :show_person_images,
|
|
25
|
+
show: [
|
|
26
|
+
:parent,
|
|
27
|
+
{ episodes: :voting_sessions },
|
|
28
|
+
{ seasons: { episodes: :voting_sessions } }
|
|
29
|
+
]
|
|
30
|
+
)
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
def current_show
|
|
34
|
+
@current_show ||= show_scope.find_by!(slug: params[:show_id])
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def show_scope
|
|
38
|
+
vendor_ids = @tenant.vendors.select(:id)
|
|
39
|
+
return SpreeCmCommissioner::Show.none if vendor_ids.blank?
|
|
40
|
+
|
|
41
|
+
SpreeCmCommissioner::Show.where(vendor_id: vendor_ids)
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
# override
|
|
45
|
+
def resource_serializer
|
|
46
|
+
Spree::V2::Tenant::ShowContestantSerializer
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|