spree_storefront 5.0.0.rc1
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 +7 -0
- data/LICENSE.md +13 -0
- data/Rakefile +15 -0
- data/app/assets/config/spree_storefront_manifest.js +6 -0
- data/app/assets/stylesheets/storefront_page_builder.css +51 -0
- data/app/controllers/concerns/spree/cart_methods.rb +40 -0
- data/app/controllers/concerns/spree/locale_urls.rb +23 -0
- data/app/controllers/concerns/spree/password_protected.rb +17 -0
- data/app/controllers/concerns/spree/theme_concern.rb +29 -0
- data/app/controllers/spree/account/addresses_controller.rb +16 -0
- data/app/controllers/spree/account/base_controller.rb +20 -0
- data/app/controllers/spree/account/newsletter_controller.rb +34 -0
- data/app/controllers/spree/account/orders_controller.rb +34 -0
- data/app/controllers/spree/account/profile_controller.rb +23 -0
- data/app/controllers/spree/account/store_credits_controller.rb +23 -0
- data/app/controllers/spree/account/wished_items_controller.rb +45 -0
- data/app/controllers/spree/addresses_controller.rb +101 -0
- data/app/controllers/spree/checkout_controller.rb +365 -0
- data/app/controllers/spree/contacts_controller.rb +46 -0
- data/app/controllers/spree/digital_links_controller.rb +48 -0
- data/app/controllers/spree/home_controller.rb +5 -0
- data/app/controllers/spree/line_items_controller.rb +96 -0
- data/app/controllers/spree/newsletter_subscribers_controller.rb +43 -0
- data/app/controllers/spree/order_status_controller.rb +32 -0
- data/app/controllers/spree/orders_controller.rb +104 -0
- data/app/controllers/spree/page_sections_controller.rb +17 -0
- data/app/controllers/spree/pages_controller.rb +13 -0
- data/app/controllers/spree/password_controller.rb +21 -0
- data/app/controllers/spree/policies_controller.rb +17 -0
- data/app/controllers/spree/posts_controller.rb +76 -0
- data/app/controllers/spree/products_controller.rb +99 -0
- data/app/controllers/spree/search_controller.rb +39 -0
- data/app/controllers/spree/seo_controller.rb +25 -0
- data/app/controllers/spree/settings_controller.rb +68 -0
- data/app/controllers/spree/store_controller.rb +247 -0
- data/app/controllers/spree/taxonomies_controller.rb +30 -0
- data/app/controllers/spree/taxons_controller.rb +46 -0
- data/app/controllers/spree/wishlists_controller.rb +19 -0
- data/app/finders/spree/storefront/variant_finder.rb +80 -0
- data/app/helpers/spree/analytics_helper.rb +28 -0
- data/app/helpers/spree/cart_helper.rb +48 -0
- data/app/helpers/spree/checkout_analytics_helper.rb +77 -0
- data/app/helpers/spree/checkout_helper.rb +58 -0
- data/app/helpers/spree/filters_helper.rb +180 -0
- data/app/helpers/spree/fonts_helper.rb +58 -0
- data/app/helpers/spree/orders_helper.rb +7 -0
- data/app/helpers/spree/page_helper.rb +67 -0
- data/app/helpers/spree/posts_helper.rb +42 -0
- data/app/helpers/spree/products_helper.rb +205 -0
- data/app/helpers/spree/storefront_helper.rb +86 -0
- data/app/helpers/spree/storefront_locale_helper.rb +42 -0
- data/app/helpers/spree/theme_helper.rb +244 -0
- data/app/helpers/spree/turbo_helper.rb +13 -0
- data/app/helpers/spree/turbo_stream_actions_helper.rb +13 -0
- data/app/helpers/spree/wishlist_helper.rb +7 -0
- data/app/javascript/spree/storefront/application.js +156 -0
- data/app/javascript/spree/storefront/controllers/accordion_controller.js +25 -0
- data/app/javascript/spree/storefront/controllers/account_nav_controller.js +10 -0
- data/app/javascript/spree/storefront/controllers/card_validation_controller.js +103 -0
- data/app/javascript/spree/storefront/controllers/carousel_controller.js +44 -0
- data/app/javascript/spree/storefront/controllers/cart_controller.js +10 -0
- data/app/javascript/spree/storefront/controllers/checkout_address_book_controller.js +28 -0
- data/app/javascript/spree/storefront/controllers/checkout_delivery_controller.js +39 -0
- data/app/javascript/spree/storefront/controllers/checkout_promotions_controller.js +28 -0
- data/app/javascript/spree/storefront/controllers/checkout_summary_controller.js +46 -0
- data/app/javascript/spree/storefront/controllers/clear_input_controller.js +23 -0
- data/app/javascript/spree/storefront/controllers/copy_input_controller.js +19 -0
- data/app/javascript/spree/storefront/controllers/dropdown_controller.js +14 -0
- data/app/javascript/spree/storefront/controllers/header_controller.js +33 -0
- data/app/javascript/spree/storefront/controllers/infinite_scroll_controller.js +31 -0
- data/app/javascript/spree/storefront/controllers/lightbox_controller.js +138 -0
- data/app/javascript/spree/storefront/controllers/mobile_nav_controller.js +17 -0
- data/app/javascript/spree/storefront/controllers/modal_controller.js +15 -0
- data/app/javascript/spree/storefront/controllers/no_ui_slider_controller.js +55 -0
- data/app/javascript/spree/storefront/controllers/pdp_desktop_gallery_controller.js +28 -0
- data/app/javascript/spree/storefront/controllers/plp_variant_picker_controller.js +151 -0
- data/app/javascript/spree/storefront/controllers/product_form_controller.js +136 -0
- data/app/javascript/spree/storefront/controllers/quantity_picker_controller.js +43 -0
- data/app/javascript/spree/storefront/controllers/search_suggestions_controller.js +61 -0
- data/app/javascript/spree/storefront/controllers/searchable_list_controller.js +25 -0
- data/app/javascript/spree/storefront/controllers/slideover_controller.js +40 -0
- data/app/javascript/spree/storefront/controllers/sticky_button_controller.js +32 -0
- data/app/javascript/spree/storefront/controllers/toggle_menu_controller.js +32 -0
- data/app/javascript/spree/storefront/controllers/turbo_stream_form_controller.js +51 -0
- data/app/javascript/spree/storefront/controllers/wished_item_controller.js +69 -0
- data/app/javascript/spree/storefront/helpers/lazy_load_controllers_with_manifest.js +78 -0
- data/app/javascript/spree/storefront/helpers/show_flash_message.js +25 -0
- data/app/models/spree/color_names.rb +35 -0
- data/app/models/spree/contact.rb +24 -0
- data/app/presenters/spree/colors_preview_styles_presenter.rb +84 -0
- data/app/presenters/spree/featured_product_presenter.rb +42 -0
- data/app/presenters/spree/mega_nav_presenter.rb +55 -0
- data/app/views/devise/passwords/edit.html.erb +22 -0
- data/app/views/devise/passwords/new.html.erb +16 -0
- data/app/views/devise/registrations/_form.html.erb +21 -0
- data/app/views/devise/registrations/edit.html.erb +24 -0
- data/app/views/devise/registrations/new.html.erb +27 -0
- data/app/views/devise/sessions/new.html.erb +25 -0
- data/app/views/devise/shared/_links.html.erb +22 -0
- data/app/views/layouts/spree/checkout.html.erb +58 -0
- data/app/views/layouts/spree/password.html.erb +34 -0
- data/app/views/layouts/spree/storefront.html.erb +38 -0
- data/app/views/spree/account/wished_items/create.turbo_stream.erb +8 -0
- data/app/views/spree/account/wished_items/destroy.turbo_stream.erb +20 -0
- data/app/views/spree/addresses/destroy.turbo_stream.erb +1 -0
- data/app/views/spree/addresses/edit.html.erb +57 -0
- data/app/views/spree/addresses/new.html.erb +71 -0
- data/app/views/spree/checkout/_address.html.erb +153 -0
- data/app/views/spree/checkout/_button_processing.html.erb +7 -0
- data/app/views/spree/checkout/_coupon_code.html.erb +55 -0
- data/app/views/spree/checkout/_credit_card.html.erb +12 -0
- data/app/views/spree/checkout/_delivery.html.erb +70 -0
- data/app/views/spree/checkout/_line_item.html.erb +26 -0
- data/app/views/spree/checkout/_line_items.html.erb +7 -0
- data/app/views/spree/checkout/_missing_all_line_items.html.erb +17 -0
- data/app/views/spree/checkout/_missing_line_items.html.erb +28 -0
- data/app/views/spree/checkout/_payment.html.erb +35 -0
- data/app/views/spree/checkout/_payment_methods.html.erb +72 -0
- data/app/views/spree/checkout/_payment_sources.html.erb +24 -0
- data/app/views/spree/checkout/_quick_checkout.html.erb +1 -0
- data/app/views/spree/checkout/_sidebar.html.erb +34 -0
- data/app/views/spree/checkout/_store_credit.html.erb +21 -0
- data/app/views/spree/checkout/_summary.html.erb +116 -0
- data/app/views/spree/checkout/_user_account.html.erb +9 -0
- data/app/views/spree/checkout/apply_coupon_code.turbo_stream.erb +45 -0
- data/app/views/spree/checkout/apply_store_credit.turbo_stream.erb +19 -0
- data/app/views/spree/checkout/edit.html.erb +98 -0
- data/app/views/spree/checkout/payment/_check.html.erb +0 -0
- data/app/views/spree/checkout/payment/_gateway.html.erb +74 -0
- data/app/views/spree/checkout/payment/_store_credit.html.erb +13 -0
- data/app/views/spree/checkout/remove_coupon_code.turbo_stream.erb +34 -0
- data/app/views/spree/checkout/remove_store_credit.turbo_stream.erb +19 -0
- data/app/views/spree/checkout/update.turbo_stream.erb +25 -0
- data/app/views/spree/home/index.html.erb +1 -0
- data/app/views/spree/line_items/create.turbo_stream.erb +13 -0
- data/app/views/spree/line_items/destroy.turbo_stream.erb +11 -0
- data/app/views/spree/line_items/update.turbo_stream.erb +10 -0
- data/app/views/spree/newsletter_subscribers/create.turbo_stream.erb +7 -0
- data/app/views/spree/order_status/new.html.erb +16 -0
- data/app/views/spree/page_sections/show.html.erb +3 -0
- data/app/views/spree/pages/show.html.erb +1 -0
- data/app/views/spree/password/show.html.erb +1 -0
- data/app/views/spree/posts/index.html.erb +1 -0
- data/app/views/spree/posts/related_products.html.erb +7 -0
- data/app/views/spree/posts/show.html.erb +1 -0
- data/app/views/spree/products/index.html.erb +1 -0
- data/app/views/spree/products/index.turbo_stream.erb +1 -0
- data/app/views/spree/products/related.html.erb +3 -0
- data/app/views/spree/products/show.html.erb +1 -0
- data/app/views/spree/search/show.html.erb +6 -0
- data/app/views/spree/search/show.turbo_stream.erb +1 -0
- data/app/views/spree/search/suggestions.turbo_stream.erb +8 -0
- data/app/views/spree/seo/robots.text.erb +31 -0
- data/app/views/spree/seo/sitemap.xml.erb +25 -0
- data/app/views/spree/shared/_fonts.html.erb +14 -0
- data/app/views/spree/shared/_head.html.erb +36 -0
- data/app/views/spree/shared/_load_more_products.turbo_stream.erb +7 -0
- data/app/views/spree/shared/_product_listing_page.html.erb +11 -0
- data/app/views/spree/shared/_products.html.erb +1 -0
- data/app/views/spree/taxonomies/show.html.erb +1 -0
- data/app/views/spree/taxons/show.html.erb +1 -0
- data/app/views/spree/taxons/show.turbo_stream.erb +1 -0
- data/app/views/spree/waitlists/create.turbo_stream.erb +9 -0
- data/app/views/themes/default/kaminari/storefront/_first_page.html.erb +8 -0
- data/app/views/themes/default/kaminari/storefront/_gap.html.erb +8 -0
- data/app/views/themes/default/kaminari/storefront/_last_page.html.erb +8 -0
- data/app/views/themes/default/kaminari/storefront/_next_page.html.erb +13 -0
- data/app/views/themes/default/kaminari/storefront/_page.html.erb +10 -0
- data/app/views/themes/default/kaminari/storefront/_paginator.html.erb +27 -0
- data/app/views/themes/default/kaminari/storefront/_prev_page.html.erb +13 -0
- data/app/views/themes/default/spree/account/_account_nav.html.erb +46 -0
- data/app/views/themes/default/spree/account/_order.html.erb +39 -0
- data/app/views/themes/default/spree/account/_orders.html.erb +16 -0
- data/app/views/themes/default/spree/account/addresses/_address.html.erb +42 -0
- data/app/views/themes/default/spree/account/addresses/index.html.erb +28 -0
- data/app/views/themes/default/spree/account/newsletter/_newsletter_settings.html.erb +13 -0
- data/app/views/themes/default/spree/account/newsletter/edit.html.erb +16 -0
- data/app/views/themes/default/spree/account/newsletter/update.html.erb +1 -0
- data/app/views/themes/default/spree/account/orders/index.html.erb +24 -0
- data/app/views/themes/default/spree/account/orders/show.html.erb +22 -0
- data/app/views/themes/default/spree/account/profile/edit.html.erb +36 -0
- data/app/views/themes/default/spree/account/store_credits/_store_credit_event.html.erb +29 -0
- data/app/views/themes/default/spree/account/store_credits/index.html.erb +31 -0
- data/app/views/themes/default/spree/checkout/_footer.html.erb +10 -0
- data/app/views/themes/default/spree/checkout/complete.html.erb +84 -0
- data/app/views/themes/default/spree/contacts/new.html.erb +23 -0
- data/app/views/themes/default/spree/orders/_cart.html.erb +14 -0
- data/app/views/themes/default/spree/orders/_empty.html.erb +11 -0
- data/app/views/themes/default/spree/orders/_line_item.html.erb +47 -0
- data/app/views/themes/default/spree/orders/_line_item_quantity.html.erb +11 -0
- data/app/views/themes/default/spree/orders/_summary.html.erb +41 -0
- data/app/views/themes/default/spree/orders/edit.html.erb +18 -0
- data/app/views/themes/default/spree/orders/show.html.erb +6 -0
- data/app/views/themes/default/spree/page_sections/_announcement_bar.html.erb +10 -0
- data/app/views/themes/default/spree/page_sections/_custom_code.html.erb +5 -0
- data/app/views/themes/default/spree/page_sections/_featured_product.html.erb +136 -0
- data/app/views/themes/default/spree/page_sections/_featured_taxon.html.erb +116 -0
- data/app/views/themes/default/spree/page_sections/_featured_taxons.html.erb +71 -0
- data/app/views/themes/default/spree/page_sections/_footer.html.erb +62 -0
- data/app/views/themes/default/spree/page_sections/_header.html.erb +166 -0
- data/app/views/themes/default/spree/page_sections/_image_banner.html.erb +57 -0
- data/app/views/themes/default/spree/page_sections/_image_with_text.html.erb +66 -0
- data/app/views/themes/default/spree/page_sections/_main_password_footer.html.erb +64 -0
- data/app/views/themes/default/spree/page_sections/_main_password_header.html.erb +54 -0
- data/app/views/themes/default/spree/page_sections/_newsletter.html.erb +47 -0
- data/app/views/themes/default/spree/page_sections/_page_title.html.erb +7 -0
- data/app/views/themes/default/spree/page_sections/_post_details.html.erb +19 -0
- data/app/views/themes/default/spree/page_sections/_post_grid.html.erb +11 -0
- data/app/views/themes/default/spree/page_sections/_product_details.html.erb +102 -0
- data/app/views/themes/default/spree/page_sections/_product_grid.html.erb +52 -0
- data/app/views/themes/default/spree/page_sections/_related_products.html.erb +15 -0
- data/app/views/themes/default/spree/page_sections/_rich_text.html.erb +18 -0
- data/app/views/themes/default/spree/page_sections/_taxon_banner.html.erb +37 -0
- data/app/views/themes/default/spree/page_sections/_taxon_grid.html.erb +103 -0
- data/app/views/themes/default/spree/page_sections/_video.html.erb +27 -0
- data/app/views/themes/default/spree/page_sections/nav/_desktop.html.erb +49 -0
- data/app/views/themes/default/spree/page_sections/nav/_mobile.html.erb +136 -0
- data/app/views/themes/default/spree/policies/show.html.erb +11 -0
- data/app/views/themes/default/spree/posts/_json_ld.html.erb +20 -0
- data/app/views/themes/default/spree/posts/_pagination.html.erb +1 -0
- data/app/views/themes/default/spree/posts/_post.html.erb +13 -0
- data/app/views/themes/default/spree/products/_add_to_cart_button.html.erb +58 -0
- data/app/views/themes/default/spree/products/_add_to_waitlist.html.erb +36 -0
- data/app/views/themes/default/spree/products/_add_to_wishlist.html.erb +33 -0
- data/app/views/themes/default/spree/products/_breadcrumbs.html.erb +23 -0
- data/app/views/themes/default/spree/products/_color_picker.html.erb +19 -0
- data/app/views/themes/default/spree/products/_color_swatches.html.erb +61 -0
- data/app/views/themes/default/spree/products/_details.html.erb +55 -0
- data/app/views/themes/default/spree/products/_featured_image.html.erb +37 -0
- data/app/views/themes/default/spree/products/_filters.html.erb +45 -0
- data/app/views/themes/default/spree/products/_json_ld.html.erb +38 -0
- data/app/views/themes/default/spree/products/_json_ld_list.html.erb +9 -0
- data/app/views/themes/default/spree/products/_json_ld_variant.html.erb +10 -0
- data/app/views/themes/default/spree/products/_label.html.erb +26 -0
- data/app/views/themes/default/spree/products/_media_gallery.html.erb +94 -0
- data/app/views/themes/default/spree/products/_price.html.erb +59 -0
- data/app/views/themes/default/spree/products/_product.html.erb +62 -0
- data/app/views/themes/default/spree/products/_quantity_selector.html.erb +32 -0
- data/app/views/themes/default/spree/products/_returns_policy_modal.html.erb +22 -0
- data/app/views/themes/default/spree/products/_show_more_button.html.erb +8 -0
- data/app/views/themes/default/spree/products/_sort.html.erb +45 -0
- data/app/views/themes/default/spree/products/_swiper.html.erb +85 -0
- data/app/views/themes/default/spree/products/_tags.html.erb +0 -0
- data/app/views/themes/default/spree/products/_variant_options.html.erb +71 -0
- data/app/views/themes/default/spree/products/_variant_picker.html.erb +50 -0
- data/app/views/themes/default/spree/products/filters/_availability.html.erb +32 -0
- data/app/views/themes/default/spree/products/filters/_colors.html.erb +23 -0
- data/app/views/themes/default/spree/products/filters/_generic.html.erb +75 -0
- data/app/views/themes/default/spree/products/filters/_price.html.erb +35 -0
- data/app/views/themes/default/spree/products/filters/_taxons.erb +78 -0
- data/app/views/themes/default/spree/search/_suggestions.html.erb +92 -0
- data/app/views/themes/default/spree/settings/show.html.erb +32 -0
- data/app/views/themes/default/spree/shared/_account_pane.html.erb +28 -0
- data/app/views/themes/default/spree/shared/_address.html.erb +35 -0
- data/app/views/themes/default/spree/shared/_cart_icon.html.erb +13 -0
- data/app/views/themes/default/spree/shared/_cart_pane.html.erb +38 -0
- data/app/views/themes/default/spree/shared/_css_variables.html.erb +54 -0
- data/app/views/themes/default/spree/shared/_custom_head.html.erb +0 -0
- data/app/views/themes/default/spree/shared/_error_messages.html.erb +9 -0
- data/app/views/themes/default/spree/shared/_error_messages_without_base_attribute.html.erb +15 -0
- data/app/views/themes/default/spree/shared/_flash.html.erb +16 -0
- data/app/views/themes/default/spree/shared/_flashes.html.erb +10 -0
- data/app/views/themes/default/spree/shared/_json_ld.html.erb +32 -0
- data/app/views/themes/default/spree/shared/_line_item_options.html.erb +18 -0
- data/app/views/themes/default/spree/shared/_logo.html.erb +42 -0
- data/app/views/themes/default/spree/shared/_meta_tags.html.erb +45 -0
- data/app/views/themes/default/spree/shared/_order_details.html.erb +106 -0
- data/app/views/themes/default/spree/shared/_order_line_item.html.erb +65 -0
- data/app/views/themes/default/spree/shared/_order_shipment.html.erb +71 -0
- data/app/views/themes/default/spree/shared/_search.html.erb +32 -0
- data/app/views/themes/default/spree/shared/_title.html.erb +3 -0
- data/app/views/themes/default/spree/shared/_wishlist_icon.html.erb +13 -0
- data/app/views/themes/default/spree/shared/icons/_account.html.erb +17 -0
- data/app/views/themes/default/spree/shared/icons/_arrow-left.html.erb +8 -0
- data/app/views/themes/default/spree/shared/icons/_arrow-right.html.erb +3 -0
- data/app/views/themes/default/spree/shared/icons/_bell.html.erb +9 -0
- data/app/views/themes/default/spree/shared/icons/_cart.html.erb +10 -0
- data/app/views/themes/default/spree/shared/icons/_cart_48.html.erb +6 -0
- data/app/views/themes/default/spree/shared/icons/_check.html.erb +4 -0
- data/app/views/themes/default/spree/shared/icons/_chevron.html.erb +15 -0
- data/app/views/themes/default/spree/shared/icons/_chevron_down.html.erb +5 -0
- data/app/views/themes/default/spree/shared/icons/_chevron_right.html.erb +15 -0
- data/app/views/themes/default/spree/shared/icons/_chevron_up.html.erb +3 -0
- data/app/views/themes/default/spree/shared/icons/_close.html.erb +9 -0
- data/app/views/themes/default/spree/shared/icons/_cross.html.erb +16 -0
- data/app/views/themes/default/spree/shared/icons/_delete.html.erb +3 -0
- data/app/views/themes/default/spree/shared/icons/_delivery.html.erb +5 -0
- data/app/views/themes/default/spree/shared/icons/_disabled.html.erb +13 -0
- data/app/views/themes/default/spree/shared/icons/_edit.html.erb +3 -0
- data/app/views/themes/default/spree/shared/icons/_facebook.html.erb +16 -0
- data/app/views/themes/default/spree/shared/icons/_filter.html.erb +8 -0
- data/app/views/themes/default/spree/shared/icons/_heart.html.erb +12 -0
- data/app/views/themes/default/spree/shared/icons/_info.html.erb +7 -0
- data/app/views/themes/default/spree/shared/icons/_instagram.html.erb +18 -0
- data/app/views/themes/default/spree/shared/icons/_lock.html.erb +13 -0
- data/app/views/themes/default/spree/shared/icons/_menu.html.erb +10 -0
- data/app/views/themes/default/spree/shared/icons/_minus.html.erb +5 -0
- data/app/views/themes/default/spree/shared/icons/_pinch.html.erb +6 -0
- data/app/views/themes/default/spree/shared/icons/_pinterest.html.erb +8 -0
- data/app/views/themes/default/spree/shared/icons/_plus.html.erb +17 -0
- data/app/views/themes/default/spree/shared/icons/_return.html.erb +11 -0
- data/app/views/themes/default/spree/shared/icons/_search.html.erb +17 -0
- data/app/views/themes/default/spree/shared/icons/_spinner.html.erb +1 -0
- data/app/views/themes/default/spree/shared/icons/_spotify.html.erb +8 -0
- data/app/views/themes/default/spree/shared/icons/_tiktok.html.erb +9 -0
- data/app/views/themes/default/spree/shared/icons/_twitter.html.erb +16 -0
- data/app/views/themes/default/spree/shared/icons/_youtube.html.erb +9 -0
- data/app/views/themes/default/spree/shared/icons/_zoom.html.erb +10 -0
- data/app/views/themes/default/spree/wishlists/_no_wished_items.html.erb +10 -0
- data/app/views/themes/default/spree/wishlists/_wished_item.html.erb +38 -0
- data/app/views/themes/default/spree/wishlists/show.html.erb +17 -0
- data/config/i18n-tasks.yml +176 -0
- data/config/importmap.rb +22 -0
- data/config/initializers/assets.rb +1 -0
- data/config/initializers/heroicon.rb +10 -0
- data/config/locales/en.yml +76 -0
- data/config/routes.rb +88 -0
- data/lib/generators/spree/storefront/install/install_generator.rb +45 -0
- data/lib/generators/spree/storefront/install/templates/application.tailwind.css +1760 -0
- data/lib/generators/spree/storefront/install/templates/dev +16 -0
- data/lib/generators/spree/storefront/install/templates/tailwind.config.js +128 -0
- data/lib/generators/spree/storefront/theme/templates/model.rb.tt +12 -0
- data/lib/generators/spree/storefront/theme/theme_generator.rb +41 -0
- data/lib/spree/storefront/configuration.rb +11 -0
- data/lib/spree/storefront/engine.rb +51 -0
- data/lib/spree/storefront/testing_support/capybara_utils.rb +13 -0
- data/lib/spree/storefront.rb +16 -0
- data/lib/spree_storefront.rb +1 -0
- data/vendor/colornames.json +1 -0
- data/vendor/javascript/@kanety--stimulus-accordion.js +4 -0
- data/vendor/javascript/@stimulus-components--carousel.js +4 -0
- data/vendor/javascript/card-validator.js +4 -0
- data/vendor/javascript/credit-card-type.js +4 -0
- data/vendor/javascript/headroom.js.js +19 -0
- data/vendor/javascript/nouislider.js +4 -0
- data/vendor/javascript/photoswipe--dist--photoswipe-lightbox.esm.js.js +667 -0
- data/vendor/javascript/photoswipe.js +1675 -0
- data/vendor/javascript/stimulus-read-more.js +4 -0
- data/vendor/javascript/stimulus-scroll-to.js +4 -0
- data/vendor/javascript/swiper--bundle.js +4 -0
- metadata +567 -0
@@ -0,0 +1,153 @@
|
|
1
|
+
<%= render 'spree/checkout/quick_checkout' %>
|
2
|
+
|
3
|
+
<% address_type = 'shipping' %>
|
4
|
+
<% address_name = "#{address_type[0...4]}_address" %>
|
5
|
+
|
6
|
+
<% if user_available_addresses.present? %>
|
7
|
+
<div data-controller="checkout-address-book">
|
8
|
+
<%= turbo_frame_tag :checkout_address_book do %>
|
9
|
+
<div class="mb-4" data-checkout-address-book-target="list">
|
10
|
+
<div id="<%= address_type %>">
|
11
|
+
<h5 class="font-body">
|
12
|
+
<%= Spree.t(address_type + '_address') %>
|
13
|
+
</h5>
|
14
|
+
<ul class="select_address list-group mb-5 border mt-3 rounded-md border-default">
|
15
|
+
<% user_available_addresses.each_with_index do |address, idx| %>
|
16
|
+
<li class="p-0 m-0 border-b border-default" id="<%= [address_type, dom_id(address)].join('_') %>">
|
17
|
+
<% checked = (address.id == @order.ship_address_id || (!@order.ship_address_id && idx == 0)) %>
|
18
|
+
<div class="custom-control custom-radio px-5 py-4 flex items-center">
|
19
|
+
<%= radio_button_tag "order_#{address_name}_id", address.id, checked, class: 'custom-control-input radio-input mt-1 mr-5', data: { action: 'checkout-address-book#select' } %>
|
20
|
+
<label class="custom-control-label d-block select-none cursor-pointer max-w-[calc(100%-58px)]" for="<%= "order_#{address_name}_id_#{address.id}" %>">
|
21
|
+
<%= turbo_frame_tag dom_id(address) do %>
|
22
|
+
<%= render 'spree/shared/address', address: address %>
|
23
|
+
<div class="address-book-actions mt-3 <% unless checked %>hidden<% end %>">
|
24
|
+
<%= link_to Spree.t(:edit), spree.edit_address_path(address, checkout: @order.token), class: 'text-dark' %>
|
25
|
+
</div>
|
26
|
+
<% end %>
|
27
|
+
</label>
|
28
|
+
</div>
|
29
|
+
</li>
|
30
|
+
<% end %>
|
31
|
+
<li class="list-group-item p-0 m-0">
|
32
|
+
<div class="custom-control custom-radio px-5 py-4 flex items-center">
|
33
|
+
<%= radio_button_tag "order_#{address_name}_id", 0, false, class: 'custom-control-input radio-input mr-5', data: { action: 'checkout-address-book#select' } %>
|
34
|
+
<label class="custom-control-label d-block select-none cursor-pointer w-full max-w-[calc(100%-58px)]" for="<%= "order_#{address_name}_id_0" %>">
|
35
|
+
<%= Spree.t(:new_address) %>
|
36
|
+
<div class="mt-4 hidden" data-checkout-address-book-target="newAddressForm">
|
37
|
+
<%= turbo_frame_tag :new_address do %>
|
38
|
+
<%= form_for try_spree_current_user.addresses.build(country: current_store.default_country), html: { id: 'checkout_form_address' } do |f| %>
|
39
|
+
<%= render 'spree/addresses/form',
|
40
|
+
address_name: 'address',
|
41
|
+
address_form: f,
|
42
|
+
address_type: 'shipping',
|
43
|
+
address: @address %>
|
44
|
+
<%= hidden_field_tag :order_token, @order.token %>
|
45
|
+
<%= hidden_field_tag "default_shipping", true %>
|
46
|
+
<%= hidden_field_tag "default_billing", true %>
|
47
|
+
<%= f.submit Spree.t('actions.save'), class: 'btn btn-primary btn-block spree-btn mb-5' %>
|
48
|
+
<% end %>
|
49
|
+
<% end %>
|
50
|
+
</div>
|
51
|
+
</label>
|
52
|
+
</label>
|
53
|
+
</li>
|
54
|
+
</ul>
|
55
|
+
</div>
|
56
|
+
</div>
|
57
|
+
<% end %>
|
58
|
+
|
59
|
+
<%= form_for @order, url: spree.update_checkout_path(@order.token, @order.state), html: { id: "checkout_form_#{@order.state}" } do |form| %>
|
60
|
+
<div>
|
61
|
+
<%= form.hidden_field :state_lock_version %>
|
62
|
+
<%= form.hidden_field :ship_address_id, data: { 'checkout-address-book-target': 'addressId' } %>
|
63
|
+
</div>
|
64
|
+
<div>
|
65
|
+
<%= button_tag Spree.t(:save_and_continue),
|
66
|
+
data: {
|
67
|
+
'checkout-address-book-target': 'submit',
|
68
|
+
'turbo-submits-with': (render 'spree/checkout/button_processing', is_hidden: false)
|
69
|
+
},
|
70
|
+
class: 'btn btn-primary font-weight-bold w-full lg:w-48 float-right checkout-content-save-continue-button',
|
71
|
+
disabled: @order.ship_address_id.nil? %>
|
72
|
+
</div>
|
73
|
+
<% end %>
|
74
|
+
</div>
|
75
|
+
<% else %>
|
76
|
+
<%= form_for @order, url: spree.update_checkout_path(@order.token, @order.state), html: { id: "checkout_form_#{@order.state}" } do |form| %>
|
77
|
+
<div class="mb-5">
|
78
|
+
<%= form.hidden_field :state_lock_version %>
|
79
|
+
|
80
|
+
<% if !try_spree_current_user || try_spree_current_user.email.blank? %>
|
81
|
+
<div class="grid grid-cols-1 lg:grid-cols-2 mb-3 font-body">
|
82
|
+
<h5 class="font-body">
|
83
|
+
<%= Spree.t(:contact_information) %>
|
84
|
+
</h5>
|
85
|
+
<% if !already_have_an_account? && defined?(spree_login_path) %>
|
86
|
+
<div class="lg:text-right">
|
87
|
+
<span class="text-gray-600 text-sm">
|
88
|
+
<%= Spree.t('storefront.checkout.already_have_an_account') %> <span class="text-primary"><%= link_to Spree.t(:login), spree_login_path, data: { turbo_frame: '_top' } %></span>
|
89
|
+
</span>
|
90
|
+
</div>
|
91
|
+
<% end %>
|
92
|
+
</div>
|
93
|
+
<div class="form-group has-float-label mb-3">
|
94
|
+
<%= form.email_field :email, class: 'w-full text-input', required: true, placeholder: Spree.t(:email), id: 'order_ship_address_attributes_email' %>
|
95
|
+
<label for="order_ship_address_attributes_email"><%= Spree.t(:email) %></label>
|
96
|
+
</div>
|
97
|
+
<% end %>
|
98
|
+
<div class="py-2">
|
99
|
+
<div class="flex items-center gap-2">
|
100
|
+
<%= form.check_box :accept_marketing, class: 'checkbox-input' %>
|
101
|
+
<%= form.label :accept_marketing, class: 'cursor-pointer text-sm select-none' do %>
|
102
|
+
<%= Spree.t('storefront.newsletter_subscription.join') %>
|
103
|
+
<% end %>
|
104
|
+
</div>
|
105
|
+
|
106
|
+
<% if !try_spree_current_user && !already_have_an_account? %>
|
107
|
+
<div class="flex items-center gap-2 mt-2">
|
108
|
+
<%= form.check_box :signup_for_an_account, class: 'checkbox-input' %>
|
109
|
+
<%= form.label :signup_for_an_account, class: 'cursor-pointer text-sm select-none' do %>
|
110
|
+
<%= Spree.t('storefront.checkout.signup_for_an_account') %>
|
111
|
+
<% end %>
|
112
|
+
</div>
|
113
|
+
<% end %>
|
114
|
+
</div>
|
115
|
+
<% unless try_spree_current_user %>
|
116
|
+
<% if already_have_an_account? %>
|
117
|
+
<div class="py-2 text-sm">
|
118
|
+
It seems you already have an account with us. Please
|
119
|
+
<%= link_to Spree.t(:login), spree_login_path, class: 'text-primary font-semibold' %> to continue.
|
120
|
+
</div>
|
121
|
+
<% end %>
|
122
|
+
<% end %>
|
123
|
+
|
124
|
+
<div class="mb-4" data-controller="checkout-address-book" data-checkout-address-book-target="list">
|
125
|
+
<div id="<%= address_type %>">
|
126
|
+
<h5 class="mt-5 mb-4 font-body">
|
127
|
+
<%= Spree.t(address_type + '_address') %>
|
128
|
+
</h5>
|
129
|
+
<%= form.fields_for address_name do |address_form| %>
|
130
|
+
<div class="inner checkout-content-inner" data-hook='<%= "#{address_type}_inner" %>'>
|
131
|
+
<%= render partial: 'spree/addresses/form', locals: {
|
132
|
+
address_name: address_name,
|
133
|
+
address_form: address_form,
|
134
|
+
address_type: address_type,
|
135
|
+
address: Spree::Address.new(country: current_store.default_country, user: try_spree_current_user),
|
136
|
+
form: form
|
137
|
+
} %>
|
138
|
+
</div>
|
139
|
+
<% end %>
|
140
|
+
</div>
|
141
|
+
</div>
|
142
|
+
|
143
|
+
<%= hidden_field_tag 'save_user_address', true, data: { hook: "save_user_address" } %>
|
144
|
+
</div>
|
145
|
+
<div class="flex justify-end w-full">
|
146
|
+
<%= button_tag Spree.t(:save_and_continue),
|
147
|
+
class: 'btn-primary w-full lg:w-2/5 font-semibold checkout-content-save-continue-button my-5 !py-4',
|
148
|
+
data: {
|
149
|
+
'turbo-submits-with': (render 'spree/checkout/button_processing', is_hidden: false)
|
150
|
+
} %>
|
151
|
+
</div>
|
152
|
+
<% end %>
|
153
|
+
<% end %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<div class="<%= 'hidden' if is_hidden %> spinner flex justify-center">
|
2
|
+
<svg class="animate-spin h-5 w-5 mr-4 text-white" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24">
|
3
|
+
<circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
|
4
|
+
<path class="opacity-75" fill="currentColor" d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path>
|
5
|
+
</svg>
|
6
|
+
<%= Spree.t(:processing) %>...
|
7
|
+
</div>
|
@@ -0,0 +1,55 @@
|
|
1
|
+
<%= turbo_frame_tag :checkout_coupon_code, class: "shopping-cart-coupon-code #{local_assigns[:classes]} flex flex-col gap-3" do %>
|
2
|
+
<% if promotion.nil? %>
|
3
|
+
<%= form_tag spree.checkout_apply_coupon_code_path(@order.token), method: :patch, data: {controller: "checkout-promotions"} do %>
|
4
|
+
<div class="flex" data-controller="enable-button">
|
5
|
+
<%= hidden_field_tag :promotion_email, @order.email, data: {checkout_promotions_target: 'promotionEmailField'} %>
|
6
|
+
<%= text_field_tag :coupon_code, params[:coupon_code], class: 'w-full text-input',
|
7
|
+
placeholder: Spree.t('cart_page.add_promo_code').capitalize,
|
8
|
+
aria: { label: Spree.t('cart_page.add_promo_code') },
|
9
|
+
data: { 'enable-button-target': 'input' },
|
10
|
+
required: true %>
|
11
|
+
<%= button_tag 'Apply', class: 'min-h-full ml-3 btn-primary !px-4 !py-3', data: { 'enable-button-target': 'button' }, disabled: true %>
|
12
|
+
</div>
|
13
|
+
<% end %>
|
14
|
+
<% elsif promotion.present? %>
|
15
|
+
<%= form_tag spree.checkout_remove_coupon_code_path(@order.token), method: :delete do %>
|
16
|
+
<%= hidden_field_tag :coupon_code, promotion.code_for_order(@order) %>
|
17
|
+
<div class="m-0">
|
18
|
+
<div class="flex items-center justify-between text-sm">
|
19
|
+
<span class="max-w-[250px] truncate flex items-center p-2 rounded bg-gray-200">
|
20
|
+
<%= heroicon('tag', options: { class: 'h-4 w-4 mr-2' }) %>
|
21
|
+
<%= promotion.name_for_order(@order) %>
|
22
|
+
</span>
|
23
|
+
<%= button_tag(class: 'btn btn-sm p-1 ml-2', id: 'remove-promotion') do %>
|
24
|
+
<%= heroicon('x-mark', options: { variant: :solid, class: 'h-5 w-5' }) %>
|
25
|
+
<% end %>
|
26
|
+
</div>
|
27
|
+
</div>
|
28
|
+
<% end %>
|
29
|
+
<% elsif @order.respond_to?(:gift_card) && @order.gift_card %>
|
30
|
+
<%= form_tag spree.checkout_remove_coupon_code_path(@order.token), method: :delete do %>
|
31
|
+
<%= hidden_field_tag :gift_card, @order.gift_card.code %>
|
32
|
+
<div class="m-0">
|
33
|
+
<div class="flex items-center justify-between text-sm">
|
34
|
+
<span class="max-w-[250px] truncate flex items-center p-2 rounded bg-gray-200">
|
35
|
+
<%= heroicon('gift', options: { class: 'h-4 w-4 mr-2' }) %>
|
36
|
+
<%= @order.gift_card.code.upcase %>
|
37
|
+
</span>
|
38
|
+
<%= button_tag(class: 'btn btn-sm p-1 ml-2', id: 'remove-promotion') do %>
|
39
|
+
<%= heroicon('x-mark', options: { variant: :solid, class: 'h-5 w-5' }) %>
|
40
|
+
<% end %>
|
41
|
+
</div>
|
42
|
+
</div>
|
43
|
+
<% end %>
|
44
|
+
<% end %>
|
45
|
+
|
46
|
+
<% if local_assigns[:result] && action_name == 'apply_coupon_code' %>
|
47
|
+
<% if result.error.blank? %>
|
48
|
+
<div class="alert-success p-2 text-xs rounded"><%= result.success %></div>
|
49
|
+
<% else %>
|
50
|
+
<div class="text-red-500 !text-md text-xs ">
|
51
|
+
<span><%= result.error %></span>
|
52
|
+
</div>
|
53
|
+
<% end %>
|
54
|
+
<% end %>
|
55
|
+
<% end %>
|
@@ -0,0 +1,12 @@
|
|
1
|
+
<li class="p-0 m-0 border-b" id="<%= spree_dom_id(card) %>">
|
2
|
+
<div class="custom-control custom-radio px-5 py-4 flex items-center">
|
3
|
+
<label class="flex flex-row items-center cursor-pointer">
|
4
|
+
<%= radio_button_tag "order[existing_card]", card.gateway_payment_profile_id, index == 0, { data: {action: "checkout-credit-card-book#select" }, class: "mr-5" } %>
|
5
|
+
<div class="flex space-x-4 items-center">
|
6
|
+
<%= payment_method_icon_tag(card.cc_type) %>
|
7
|
+
<span>****<%= card.last_digits %></span>
|
8
|
+
<span><%= card.month.to_s.rjust(2, '0') %>/<%= card.year %></span>
|
9
|
+
</div>
|
10
|
+
</label>
|
11
|
+
</div>
|
12
|
+
</li>
|
@@ -0,0 +1,70 @@
|
|
1
|
+
<%= form_for @order, url: spree.update_checkout_path(@order.token, @order.state), data: { controller: 'checkout-delivery' } do |form| %>
|
2
|
+
<div class="mb-5">
|
3
|
+
<%= turbo_frame_tag :checkout_lock_version do %>
|
4
|
+
<%= hidden_field_tag 'order[state_lock_version]', @order.state_lock_version %>
|
5
|
+
<% end %>
|
6
|
+
<div id="shipping-method">
|
7
|
+
<% if @order.backordered_variants.any? %>
|
8
|
+
<div class="alert rounded border border-default text-sm p-5 mb-6">
|
9
|
+
Some products in your cart will be dispatched a bit later than the rest of your order:
|
10
|
+
<ul class="list-disc list-inside flex-col flex space-y-1 mt-2">
|
11
|
+
<% @order.backordered_variants.each do |variant| %>
|
12
|
+
<li><%= variant.name %></li>
|
13
|
+
<% end %>
|
14
|
+
</ul>
|
15
|
+
</div>
|
16
|
+
<% end %>
|
17
|
+
|
18
|
+
<div id="methods">
|
19
|
+
<%= form.fields_for :shipments do |ship_form| %>
|
20
|
+
<div class="shipment">
|
21
|
+
<h5 class="checkout-content-header mb-3 font-body">
|
22
|
+
<%= Spree.t('storefront.checkout.delivery_method').capitalize %>
|
23
|
+
<% if ship_form.object.stock_location.present? %>
|
24
|
+
<%= Spree.t(:from).downcase %>
|
25
|
+
<strong><%= ship_form.object.stock_location.name %></strong>
|
26
|
+
<% end %>
|
27
|
+
</h5>
|
28
|
+
<ul class="rounded-md list-group mb-4 border border-default border-b-0 text-sm border-default" data-checkout-delivery-target="shippingList">
|
29
|
+
<% ship_form.object.shipping_rates.includes(:shipping_method, :tax_rate).each do |rate| %>
|
30
|
+
<li class="list-group-item p-0 m-0 border-b delivery-list-item border-default" data-checkout-delivery-target="shippingRate">
|
31
|
+
<div class="custom-control custom-radio flex items-center px-5 py-4">
|
32
|
+
<%= ship_form.radio_button :selected_shipping_rate_id,
|
33
|
+
rate.id,
|
34
|
+
class: 'custom-control-input radio-input',
|
35
|
+
id: "shipping-rate-#{rate.id}",
|
36
|
+
data: {
|
37
|
+
action: 'click->checkout-delivery#update',
|
38
|
+
cost: rate.display_cost,
|
39
|
+
tax: rate.display_tax_amount
|
40
|
+
} %>
|
41
|
+
<label class="select-none cursor-pointer px-2 word-break w-full" for="<%= "shipping-rate-#{rate.id}" %>">
|
42
|
+
<%= rate.name %>
|
43
|
+
<% if rate.delivery_range %>
|
44
|
+
<span class="text-gray-600 text-xs ml-3"><%= rate.display_delivery_range %></span>
|
45
|
+
<% end %>
|
46
|
+
</label>
|
47
|
+
<span class="text-right">
|
48
|
+
<%= rate.cost <= 0 ? Spree.t(:free) : rate.display_cost %>
|
49
|
+
</span>
|
50
|
+
</div>
|
51
|
+
</li>
|
52
|
+
<% end %>
|
53
|
+
</ul>
|
54
|
+
</div>
|
55
|
+
<% end %>
|
56
|
+
</div>
|
57
|
+
</div>
|
58
|
+
</div>
|
59
|
+
<div class="flex justify-end w-full mt-5">
|
60
|
+
<div class="flex justify-end w-full">
|
61
|
+
<%= button_tag Spree.t(:save_and_continue),
|
62
|
+
class: 'btn-primary w-full lg:w-2/5 font-semibold checkout-content-save-continue-button my-5 !py-4',
|
63
|
+
data: { action: 'click->checkout-delivery#disableShippingRates',
|
64
|
+
'checkout-delivery-target': 'submit',
|
65
|
+
'turbo-submits-with': (render 'button_processing', is_hidden: false)
|
66
|
+
} %>
|
67
|
+
</div>
|
68
|
+
</div>
|
69
|
+
<% end %>
|
70
|
+
|
@@ -0,0 +1,26 @@
|
|
1
|
+
<div class="flex justify-between items-center">
|
2
|
+
<div class="flex items-center">
|
3
|
+
<div class="mr-5 w-[64px] h-[64px] relative rounded bg-accent-100">
|
4
|
+
<span class="rounded-full text-xs text-center font-bold pl-[0.5px] py-1 w-6 text-sidebar-text bg-background absolute -right-2 -top-3">
|
5
|
+
<%= line_item.quantity %>
|
6
|
+
</span>
|
7
|
+
<% image = line_item.variant.default_image %>
|
8
|
+
<% if image.present? && image.attached? && image.variable? %>
|
9
|
+
<%= image_tag main_app.cdn_image_url(image.variant(spree_image_variant_options(resize_to_fill: [128, 128]))), class: 'rounded border border-default bg-transparent object-cover object-center', loading: :lazy, width: 64, height: 64 %>
|
10
|
+
<% end %>
|
11
|
+
</div>
|
12
|
+
<div class="col-6 col-md-8 pr-3 text-sm">
|
13
|
+
<p class="font-bold word-break"><%= line_item.name %></p>
|
14
|
+
<p class="text-xs"><%= line_item.options_text %></p>
|
15
|
+
</div>
|
16
|
+
</div>
|
17
|
+
<div class="font-semibold text-sm text-right">
|
18
|
+
<% if should_display_compare_at_price?(line_item.variant) %>
|
19
|
+
<span class="line-through text-red-500">
|
20
|
+
<%= Spree::Money.new(line_item.variant.compare_at_amount_in(line_item.currency) * line_item.quantity, currency: line_item.currency) %>
|
21
|
+
</span>
|
22
|
+
<br />
|
23
|
+
<% end %>
|
24
|
+
<%= line_item.display_pre_tax_amount %>
|
25
|
+
</div>
|
26
|
+
</div>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<%= turbo_frame_tag :checkout_line_items, id: 'line_items', target: '_top' do %>
|
2
|
+
<% cache spree_base_cache_scope.call(order.line_items.cache_key_with_version) do %>
|
3
|
+
<div class="overflow-y-auto line-items flex flex-col gap-5 pt-5 md:pt-0" data-checkout-summary-target="line_items">
|
4
|
+
<%= render collection: order.line_items, partial: 'spree/checkout/line_item', cached: spree_base_cache_scope %>
|
5
|
+
</div>
|
6
|
+
<% end %>
|
7
|
+
<% end %>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<div data-controller="modal" data-modal-opened-value="true" data-modal-allow-background-close="false">
|
2
|
+
<div data-modal-target="container" data-action="click->modal#closeBackground keyup@window->modal#closeWithKeyboard" class="hidden animated fadeIn fixed inset-0 overflow-y-auto flex items-center justify-center" style="z-index: 9999;">
|
3
|
+
<div class="max-h-screen w-full max-w-lg relative">
|
4
|
+
<div class="m-1 bg-white rounded shadow">
|
5
|
+
<div class="p-8">
|
6
|
+
<h2 class="text-xl mb-4"><%= Spree.t(:shipping_not_available) %></h2>
|
7
|
+
<p class="mb-4"><%= Spree.t('errors.messages.no_shipping_methods_available') %> </p>
|
8
|
+
|
9
|
+
<div class="flex justify-end items-center flex-wrap mt-6">
|
10
|
+
<%= link_to 'Return to cart', spree.cart_path, class: 'mx-4 py-4', target: :_top %>
|
11
|
+
<%= link_to 'Close', checkout_state_path(@order.token, @order.state), class: 'btn-primary font-semibold checkout-content-save-continue-button my-5 ml-4 !py-4', target: :_top %>
|
12
|
+
</div>
|
13
|
+
</div>
|
14
|
+
</div>
|
15
|
+
</div>
|
16
|
+
</div>
|
17
|
+
</div>
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<div data-controller="modal" data-modal-opened-value="true" data-modal-allow-background-close="false">
|
2
|
+
<div data-modal-target="container" data-action="click->modal#closeBackground keyup@window->modal#closeWithKeyboard" class="hidden animated fadeIn fixed inset-0 overflow-y-auto flex items-center justify-center" style="z-index: 9999;">
|
3
|
+
<div class="max-h-screen w-full max-w-lg relative">
|
4
|
+
<div class="m-1 bg-white rounded shadow">
|
5
|
+
<div class="p-8">
|
6
|
+
<h2 class="text-xl mb-4"><%= Spree.t('storefront.checkout.shipping_not_available') %></h2>
|
7
|
+
<p class="mb-4">
|
8
|
+
<%= Spree.t('storefront.checkout.errors.invalid_line_items', count: @order.line_items_without_shipping_rates.size) %>
|
9
|
+
</p>
|
10
|
+
|
11
|
+
<div class="mb-5 overflow-y-auto pt-3 mx-3 lg:mx-8 lg:mt-4 lg:pt-6 line-items" data-checkout-summary-target="line_items">
|
12
|
+
<%= render collection: @order.line_items_without_shipping_rates, partial: 'spree/checkout/line_item', cached: spree_base_cache_scope %>
|
13
|
+
</div>
|
14
|
+
|
15
|
+
<div class="flex justify-end items-center flex-wrap mt-6">
|
16
|
+
<%= link_to Spree.t('storefront.checkout.continue_to_cart'), spree.cart_path, class: 'mx-4 py-4', target: :_top %>
|
17
|
+
<%= button_to Spree.t('storefront.checkout.continue_to_checkout'),
|
18
|
+
spree.checkout_remove_missing_items_path(@order.token, line_item_ids: @order.line_items_without_shipping_rates.map(&:id)),
|
19
|
+
class: 'btn-primary font-semibold checkout-content-save-continue-button my-5 ml-4 !py-4',
|
20
|
+
method: :delete,
|
21
|
+
data: { turbo: false, 'turbo-submits-with': (render 'spree/checkout/button_processing', is_hidden: false) }
|
22
|
+
%>
|
23
|
+
</div>
|
24
|
+
</div>
|
25
|
+
</div>
|
26
|
+
</div>
|
27
|
+
</div>
|
28
|
+
</div>
|
@@ -0,0 +1,35 @@
|
|
1
|
+
<%= form_for @order, url: spree.update_checkout_path(@order.token, @order.state), html: { id: "checkout_form_#{@order.state}" } do |form| %>
|
2
|
+
<%= form.hidden_field :state_lock_version %>
|
3
|
+
|
4
|
+
<% if @order.respond_to?(:gift_card) %>
|
5
|
+
<%= turbo_frame_tag :gift_card_code_field do %>
|
6
|
+
<%= hidden_field_tag 'order[gift_card_code]', @order.gift_card&.code %>
|
7
|
+
<%= hidden_field_tag 'order[gift_card_amount]', @order.gift_card_total %>
|
8
|
+
<% end %>
|
9
|
+
<% end %>
|
10
|
+
|
11
|
+
<% use_shipping = @order.shipping_eq_billing_address? || @order.bill_address.nil? || @order.bill_address.new_record? %>
|
12
|
+
|
13
|
+
<div id="billing-address" class="mb-8 max-w-full" data-controller="toggle">
|
14
|
+
<h5 class="mb-3 font-body font-semibold">
|
15
|
+
<%= Spree.t(:billing_address) %>
|
16
|
+
</h5>
|
17
|
+
<div class="flex items-center">
|
18
|
+
<%= form.check_box :use_shipping, { checked: use_shipping, class: 'checkbox-input', data: { action: 'change->toggle#toggle' } } %>
|
19
|
+
<%= form.label :use_shipping, Spree.t(:use_shipping_address), class: 'ml-1 cursor-pointer select-none' %>
|
20
|
+
</div>
|
21
|
+
<%= form.fields_for :bill_address do |address_form| %>
|
22
|
+
<div class="mt-4 <%= 'hidden' if use_shipping %>" data-toggle-target='toggleable'>
|
23
|
+
<%= render partial: 'spree/addresses/form', locals: {
|
24
|
+
address_name: 'bill_address',
|
25
|
+
address_form: address_form,
|
26
|
+
address_type: 'billing',
|
27
|
+
address: @order.bill_address,
|
28
|
+
form: form
|
29
|
+
} %>
|
30
|
+
</div>
|
31
|
+
<% end %>
|
32
|
+
</div>
|
33
|
+
|
34
|
+
<%= render 'spree/checkout/payment_methods', form: form %>
|
35
|
+
<% end %>
|
@@ -0,0 +1,72 @@
|
|
1
|
+
<%= turbo_frame_tag :checkout_payment_methods do %>
|
2
|
+
<% if !@order.payment_required? && @order.using_store_credit? %>
|
3
|
+
<div class="d-flex flex-column mb-5">
|
4
|
+
<p>
|
5
|
+
<% if @order.respond_to?(:gift_card) && @order.gift_card.present? %>
|
6
|
+
<%= Spree.t('storefront.checkout.gift_card_amount_applied', amount: @order.display_gift_card_total, code: @order.gift_card.code) %>
|
7
|
+
<% else %>
|
8
|
+
<%= Spree.t('storefront.checkout.store_credits_amount_applied', amount: @order.display_total_applicable_store_credit.abs) %>
|
9
|
+
<% end %>
|
10
|
+
|
11
|
+
<%= Spree.t('storefront.checkout.order_already_paid') %>
|
12
|
+
</p>
|
13
|
+
</div>
|
14
|
+
<div class="flex justify-end w-full">
|
15
|
+
<%= button_tag Spree.t(:place_now),
|
16
|
+
class: 'btn-primary w-full lg:w-2/5 font-semibold checkout-content-save-continue-button my-5 !py-4',
|
17
|
+
data: { 'turbo-submits-with': (render 'spree/checkout/button_processing', is_hidden: false) } %>
|
18
|
+
</div>
|
19
|
+
<% else %>
|
20
|
+
<h5 class="mb-3 font-body font-semibold">
|
21
|
+
<%= Spree.t(:payment) %>
|
22
|
+
</h5>
|
23
|
+
<p class="text-muted mb-3 text-neutral-600">
|
24
|
+
<%= Spree.t('storefront.checkout.all_transactions_are_secure_and_encrypted') %>
|
25
|
+
</p>
|
26
|
+
|
27
|
+
<%= render partial: 'spree/checkout/payment/store_credit' %>
|
28
|
+
|
29
|
+
<% if checkout_available_payment_methods.size > 1 %>
|
30
|
+
<ul id="payment-method-fields" class="rounded-md list-group mb-4 border border-default border-b-0 text-sm border-default">
|
31
|
+
<% selected_method = params[:payment_method_id].present? ? checkout_available_payment_methods.find { |method| method.id.to_s == params[:payment_method_id].to_s } : checkout_available_payment_methods.first %>
|
32
|
+
|
33
|
+
<% checkout_available_payment_methods.each do |method| %>
|
34
|
+
<li class="list-group-item p-0 m-0 border-b delivery-list-item border-default">
|
35
|
+
<%= link_to spree.checkout_state_path(token: @order.token, state: 'payment', payment_method_id: method.id), class: 'custom-control custom-radio flex items-center px-5 py-4 cursor-pointer w-full' do %>
|
36
|
+
<%= radio_button_tag "order[payments_attributes][][payment_method_id]",
|
37
|
+
method.id,
|
38
|
+
selected_method == method,
|
39
|
+
class: 'mr-3' %>
|
40
|
+
<%= Spree.t(method.name, scope: :payment_methods, default: method.name) %>
|
41
|
+
<% end %>
|
42
|
+
|
43
|
+
<% if selected_method == method %>
|
44
|
+
<div class="px-5 py-4">
|
45
|
+
<%= render partial: "spree/checkout/payment/#{method.method_type}", locals: { payment_method: method } %>
|
46
|
+
</div>
|
47
|
+
<% end %>
|
48
|
+
</li>
|
49
|
+
<% end %>
|
50
|
+
</ul>
|
51
|
+
<% elsif checkout_available_payment_methods.any? %>
|
52
|
+
<%= hidden_field_tag "order[payments_attributes][][payment_method_id]", checkout_available_payment_methods.first&.id %>
|
53
|
+
<%= render partial: "spree/checkout/payment/#{checkout_available_payment_methods.first.method_type}", locals: { payment_method: checkout_available_payment_methods.first } %>
|
54
|
+
<% end %>
|
55
|
+
<% end %>
|
56
|
+
|
57
|
+
<p class="text-xs mt-2 mb-4">
|
58
|
+
<%= Spree.t('storefront.checkout.by_placing_this_order_you_agree_to') %>
|
59
|
+
<%= link_to Spree.t(:terms_of_service), policy_path('terms_of_service'), target: :_blank, class: 'text-primary' %><%= I18n.t('support.array.two_words_connector') %>
|
60
|
+
<%= link_to Spree.t(:privacy_policy), policy_path('privacy_policy'), target: :_blank, class: 'text-primary' %>.
|
61
|
+
</p>
|
62
|
+
|
63
|
+
<div class="flex justify-end w-full">
|
64
|
+
<button type="submit"
|
65
|
+
id="checkout-payment-submit"
|
66
|
+
class="btn-primary w-full lg:w-2/5 font-semibold checkout-content-save-continue-button my-5 !py-4"
|
67
|
+
>
|
68
|
+
<%= render 'button_processing', is_hidden: true %>
|
69
|
+
<%= Spree.t(:pay).titleize %>
|
70
|
+
</button>
|
71
|
+
</div>
|
72
|
+
<% end %>
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<div id="existing_cards" data-controller="checkout-credit-card-book">
|
2
|
+
<div class="form-group">
|
3
|
+
<ul class="list-group mb-5 border mt-3 rounded-md">
|
4
|
+
<% checkout_payment_sources.each_with_index do |card, i| %>
|
5
|
+
<%= render partial: 'credit_card', locals: { card: card, index: i } %>
|
6
|
+
<% end %>
|
7
|
+
<li>
|
8
|
+
<div class="custom-control custom-radio px-5 py-4 flex items-center w-full">
|
9
|
+
<label class="flex flex-row items-center w-full pr-8">
|
10
|
+
<%= radio_button_tag "order[existing_card]", nil, false, { data: {action: "checkout-credit-card-book#select checkout-stripe#initializeStripe"}, class: "mr-5" } %>
|
11
|
+
<div class="w-full flex flex-col items-start space-y-4 justify-center">
|
12
|
+
<span class="cursor-pointer">
|
13
|
+
<%= Spree.t(:add_new_credit_card) %>
|
14
|
+
</span>
|
15
|
+
<div class="w-full hidden" data-checkout-credit-card-book-target="newCreditCardForm">
|
16
|
+
|
17
|
+
</div>
|
18
|
+
</div>
|
19
|
+
</label>
|
20
|
+
</div>
|
21
|
+
</li>
|
22
|
+
</ul>
|
23
|
+
</div>
|
24
|
+
</div>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render_storefront_partials(:quick_checkout_partials) %>
|
@@ -0,0 +1,34 @@
|
|
1
|
+
<div data-controller="checkout-summary" class="w-full">
|
2
|
+
<div data-controller='toggle' data-toggle-class="summary-folded" class="w-full summary-wrapper flex flex-col leading-none" data-toggle-target="toggleable" data-checkout-summary-target="wrapper">
|
3
|
+
<button data-action='click->toggle#toggle touch->toggle#toggle' class="w-full lg:hidden relative z-[999] bg-accent", id="toggle-order-summary">
|
4
|
+
<div class="h-full flex justify-between text-sm items-center">
|
5
|
+
<p class="flex gap-1 chevron-summary items-center">
|
6
|
+
<%= heroicon("shopping-bag", variant: :outline) %>
|
7
|
+
<span class="show-summary hidden">
|
8
|
+
<%= Spree.t(:show) %>
|
9
|
+
</span>
|
10
|
+
<span class="hide-summary">
|
11
|
+
<%= Spree.t(:hide) %>
|
12
|
+
</span>
|
13
|
+
<span class="lowercase"><%= Spree.t(:order_summary) %></span>
|
14
|
+
</p>
|
15
|
+
<span class="font-bold" id='summary-order-total'>
|
16
|
+
<%= @order.display_total.to_html %>
|
17
|
+
</span>
|
18
|
+
</div>
|
19
|
+
</button>
|
20
|
+
<div class="summary overflow-hidden transition-[height] h-0 p-0" data-checkout-summary-target="container">
|
21
|
+
<div class="summary-content flex flex-col gap-5" data-checkout-summary-target="content">
|
22
|
+
<%= render 'line_items', order: @order %>
|
23
|
+
|
24
|
+
<div data-checkout-summary-target="coupon_area" class="flex flex-col gap-5">
|
25
|
+
<% unless action_name == 'complete' %>
|
26
|
+
<%= render 'coupon_code', promotion: @order.valid_coupon_promotions.first %>
|
27
|
+
<%= render 'store_credit' %>
|
28
|
+
<% end %>
|
29
|
+
<%= render 'summary', order: @order %>
|
30
|
+
</div>
|
31
|
+
</div>
|
32
|
+
</div>
|
33
|
+
</div>
|
34
|
+
</div>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<%= turbo_frame_tag :checkout_store_credit do %>
|
2
|
+
<% if can_use_store_credit_on_checkout?(@order) %>
|
3
|
+
<%= form_tag(
|
4
|
+
@order.using_store_credit? ? spree.checkout_remove_store_credit_path(@order.token) : spree.checkout_apply_store_credit_path(@order.token),
|
5
|
+
method: @order.using_store_credit? ? :delete : :patch,
|
6
|
+
class: 'aria-busy:opacity-25',
|
7
|
+
data: { controller: 'auto-submit' }
|
8
|
+
) do %>
|
9
|
+
<div class="flex items-center justify-between border text-sm px-5 py-4 rounded-md border-neutral-200 cursor-pointer">
|
10
|
+
<%= label_tag :store_credit, class: 'flex items-center gap-3 text-sm cursor-pointer' do %>
|
11
|
+
<%= check_box_tag :store_credit, '1', @order.using_store_credit?,
|
12
|
+
class: 'input-checkbox !border-neutral-200 rounded-md',
|
13
|
+
data: { action: 'auto-submit#submit' } %>
|
14
|
+
<%= Spree.t("store_credit.apply") %>
|
15
|
+
<% end %>
|
16
|
+
|
17
|
+
<div><%= @order.display_total_available_store_credit %></div>
|
18
|
+
</div>
|
19
|
+
<% end %>
|
20
|
+
<% end %>
|
21
|
+
<% end %>
|