workarea-haven_theme 1.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.editorconfig +16 -0
- data/.eslintignore +1 -0
- data/.eslintrc +25 -0
- data/.github/ISSUE_TEMPLATE/bug_report.md +37 -0
- data/.github/ISSUE_TEMPLATE/documentation-request.md +17 -0
- data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
- data/.github/workflows/ci.yml +60 -0
- data/.gitignore +23 -0
- data/.rubocop.yml +3 -0
- data/.scss-lint.yml +192 -0
- data/.stylelintrc.json +8 -0
- data/CHANGELOG.md +1847 -0
- data/Gemfile +24 -0
- data/README.md +199 -0
- data/Rakefile +60 -0
- data/app/assets/fonts/workarea/storefront/hind/hind_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/hind/hind_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/hind/hind_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/hind/hind_regular_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_bolditalic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_bolditalic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_italic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_italic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/lora/lora_regular_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_bolditalic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_bolditalic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_italic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_italic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/muli/muli_regular_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_bolditalic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_bolditalic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_italic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_italic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/playfair_display/playfairdisplay_regular_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_300.woff +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_300.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_500.woff +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_500.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_700.woff +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_700.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_regular.woff +0 -0
- data/app/assets/fonts/workarea/storefront/poppins/poppins_regular.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/pt_serif/pt_serif_700.woff +0 -0
- data/app/assets/fonts/workarea/storefront/pt_serif/pt_serif_700.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/pt_serif/pt_serif_regular.woff +0 -0
- data/app/assets/fonts/workarea/storefront/pt_serif/pt_serif_regular.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_italic_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_italic_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/roboto/roboto_regular_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/source_serif_pro/source_serif_pro_bold_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/source_serif_pro/source_serif_pro_bold_webfont.woff2 +0 -0
- data/app/assets/fonts/workarea/storefront/source_serif_pro/source_serif_pro_regular_webfont.woff +0 -0
- data/app/assets/fonts/workarea/storefront/source_serif_pro/source_serif_pro_regular_webfont.woff2 +0 -0
- data/app/assets/images/workarea/core/product_placeholder.jpg +0 -0
- data/app/assets/images/workarea/storefront/dialog_close.svg +1 -0
- data/app/assets/images/workarea/storefront/favicon.ico +0 -0
- data/app/assets/images/workarea/storefront/icons/account.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/arrow_down.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/arrow_left.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/arrow_right.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/arrow_up.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/cart.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/checkmark.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/email.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/empty_star.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/eye.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/facebook.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/half_star.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/lock.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/long_arrow.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/menu.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/minus.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/plus.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/search.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/share.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/twitter.svg +1 -0
- data/app/assets/images/workarea/storefront/icons/x.svg +1 -0
- data/app/assets/images/workarea/storefront/logo.png +0 -0
- data/app/assets/images/workarea/storefront/style_guide_product.jpg +0 -0
- data/app/assets/images/workarea/storefront/style_guide_product_retina.jpg +0 -0
- data/app/assets/javascripts/workarea/storefront/haven_theme/config.js +44 -0
- data/app/assets/javascripts/workarea/storefront/modules/address_region_fields.js +93 -0
- data/app/assets/javascripts/workarea/storefront/modules/checkout_primary_payments.js +130 -0
- data/app/assets/javascripts/workarea/storefront/modules/expandable_filters.js +50 -0
- data/app/assets/javascripts/workarea/storefront/modules/mobile_filter_buttons.js +89 -0
- data/app/assets/javascripts/workarea/storefront/modules/mobile_nav_button.js +104 -0
- data/app/assets/javascripts/workarea/storefront/modules/product_detail_tabs.js +59 -0
- data/app/assets/javascripts/workarea/storefront/modules/quantity_control.js +56 -0
- data/app/assets/javascripts/workarea/storefront/modules/search_buttons.js +56 -0
- data/app/assets/javascripts/workarea/storefront/modules/toggle_class_button.js +43 -0
- data/app/assets/javascripts/workarea/storefront/modules/user_welcome_placeholder.js +38 -0
- data/app/assets/javascripts/workarea/storefront/reviews/modules/product_reviews_sort_menus.js +82 -0
- data/app/assets/javascripts/workarea/storefront/reviews/templates/sort_by_property.jst.ejs +13 -0
- data/app/assets/javascripts/workarea/storefront/templates/back_to_top_button.jst.ejs +3 -0
- data/app/assets/javascripts/workarea/storefront/templates/log_out_link.jst.ejs +1 -0
- data/app/assets/javascripts/workarea/storefront/templates/mobile_filters_nav_close_button.jst.ejs +3 -0
- data/app/assets/javascripts/workarea/storefront/templates/optional_field_prompt.jst.ejs +8 -0
- data/app/assets/javascripts/workarea/storefront/templates/saved_addresses_property.jst.ejs +23 -0
- data/app/assets/javascripts/workarea/storefront/templates/ui_menu_item.jst.ejs +9 -0
- data/app/assets/javascripts/workarea/storefront/templates/user_welcome.jst.ejs +7 -0
- data/app/assets/stylesheets/haven_theme/.keep +0 -0
- data/app/assets/stylesheets/jquery_ui/storefront/_ui_autocomplete.scss +13 -0
- data/app/assets/stylesheets/jquery_ui/storefront/_ui_dialog.scss +168 -0
- data/app/assets/stylesheets/jquery_ui/storefront/_ui_menu.scss +133 -0
- data/app/assets/stylesheets/jquery_ui/storefront/_ui_state_focus.scss +7 -0
- data/app/assets/stylesheets/jquery_ui/storefront/_ui_widget_overlay.scss +15 -0
- data/app/assets/stylesheets/workarea/product_badges/components/_badges.scss +83 -0
- data/app/assets/stylesheets/workarea/product_grid_content/components/_product_grid_cell_content_block.scss +32 -0
- data/app/assets/stylesheets/workarea/storefront/base/_forms.scss +224 -0
- data/app/assets/stylesheets/workarea/storefront/blog/components/_blog_entry.scss +127 -0
- data/app/assets/stylesheets/workarea/storefront/blog/components/_blog_entry_summary.scss +166 -0
- data/app/assets/stylesheets/workarea/storefront/blog/components/_blog_index.scss +25 -0
- data/app/assets/stylesheets/workarea/storefront/blog/components/_featured_entry_content_block.scss +9 -0
- data/app/assets/stylesheets/workarea/storefront/components/_account_menu.scss +50 -0
- data/app/assets/stylesheets/workarea/storefront/components/_add_to_cart.scss +51 -0
- data/app/assets/stylesheets/workarea/storefront/components/_back_to_top_button.scss +30 -0
- data/app/assets/stylesheets/workarea/storefront/components/_box.scss +44 -0
- data/app/assets/stylesheets/workarea/storefront/components/_breadcrumbs.scss +53 -0
- data/app/assets/stylesheets/workarea/storefront/components/_button.scss +153 -0
- data/app/assets/stylesheets/workarea/storefront/components/_button_property.scss +46 -0
- data/app/assets/stylesheets/workarea/storefront/components/_cart.scss +85 -0
- data/app/assets/stylesheets/workarea/storefront/components/_category_summary_content_block.scss +27 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_addresses.scss +21 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_confirmation.scss +57 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_payment.scss +80 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_progress.scss +149 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_shipping.scss +15 -0
- data/app/assets/stylesheets/workarea/storefront/components/_checkout_step_summary.scss +81 -0
- data/app/assets/stylesheets/workarea/storefront/components/_color_box.scss +83 -0
- data/app/assets/stylesheets/workarea/storefront/components/_content_block.scss +56 -0
- data/app/assets/stylesheets/workarea/storefront/components/_data_card.scss +70 -0
- data/app/assets/stylesheets/workarea/storefront/components/_divider_content_block.scss +39 -0
- data/app/assets/stylesheets/workarea/storefront/components/_email_signup.scss +61 -0
- data/app/assets/stylesheets/workarea/storefront/components/_email_signup_view.scss +18 -0
- data/app/assets/stylesheets/workarea/storefront/components/_hero_content_block.scss +77 -0
- data/app/assets/stylesheets/workarea/storefront/components/_image_and_text_content_block.scss +29 -0
- data/app/assets/stylesheets/workarea/storefront/components/_image_content_block.scss +16 -0
- data/app/assets/stylesheets/workarea/storefront/components/_image_group_content_block.scss +9 -0
- data/app/assets/stylesheets/workarea/storefront/components/_loading.scss +92 -0
- data/app/assets/stylesheets/workarea/storefront/components/_login.scss +47 -0
- data/app/assets/stylesheets/workarea/storefront/components/_mobile_filters.scss +51 -0
- data/app/assets/stylesheets/workarea/storefront/components/_mobile_filters_nav.scss +42 -0
- data/app/assets/stylesheets/workarea/storefront/components/_mobile_nav.scss +120 -0
- data/app/assets/stylesheets/workarea/storefront/components/_option_button.scss +48 -0
- data/app/assets/stylesheets/workarea/storefront/components/_order_details.scss +55 -0
- data/app/assets/stylesheets/workarea/storefront/components/_order_summary.scss +34 -0
- data/app/assets/stylesheets/workarea/storefront/components/_overlay.scss +20 -0
- data/app/assets/stylesheets/workarea/storefront/components/_page_content.scss +96 -0
- data/app/assets/stylesheets/workarea/storefront/components/_page_footer.scss +53 -0
- data/app/assets/stylesheets/workarea/storefront/components/_page_header.scss +208 -0
- data/app/assets/stylesheets/workarea/storefront/components/_pagination.scss +12 -0
- data/app/assets/stylesheets/workarea/storefront/components/_payment_icon.scss +37 -0
- data/app/assets/stylesheets/workarea/storefront/components/_personalized_recommendations_content_block.scss +19 -0
- data/app/assets/stylesheets/workarea/storefront/components/_primary_nav.scss +75 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_detail_container.scss +177 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_details.scss +105 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_insights_content_block.scss +22 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_list.scss +186 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_list_content_block.scss +22 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_media.scss +70 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_prices.scss +82 -0
- data/app/assets/stylesheets/workarea/storefront/components/_product_summary.scss +104 -0
- data/app/assets/stylesheets/workarea/storefront/components/_property.scss +71 -0
- data/app/assets/stylesheets/workarea/storefront/components/_quantity_control.scss +101 -0
- data/app/assets/stylesheets/workarea/storefront/components/_quote_content_block.scss +42 -0
- data/app/assets/stylesheets/workarea/storefront/components/_recent_views.scss +46 -0
- data/app/assets/stylesheets/workarea/storefront/components/_recommendations.scss +31 -0
- data/app/assets/stylesheets/workarea/storefront/components/_result_filters.scss.erb +203 -0
- data/app/assets/stylesheets/workarea/storefront/components/_search.scss +64 -0
- data/app/assets/stylesheets/workarea/storefront/components/_search_no_results.scss +34 -0
- data/app/assets/stylesheets/workarea/storefront/components/_secondary_nav.scss +58 -0
- data/app/assets/stylesheets/workarea/storefront/components/_social_networks_content_block.scss +46 -0
- data/app/assets/stylesheets/workarea/storefront/components/_svg_icon.scss +80 -0
- data/app/assets/stylesheets/workarea/storefront/components/_table.scss +57 -0
- data/app/assets/stylesheets/workarea/storefront/components/_taxonomy_content_block.scss +138 -0
- data/app/assets/stylesheets/workarea/storefront/components/_text_box.scss +82 -0
- data/app/assets/stylesheets/workarea/storefront/components/_text_content_block.scss +5 -0
- data/app/assets/stylesheets/workarea/storefront/components/_value.scss +85 -0
- data/app/assets/stylesheets/workarea/storefront/components/_video_and_text_content_block.scss +42 -0
- data/app/assets/stylesheets/workarea/storefront/content_search/components/_search_autocomplete.scss +20 -0
- data/app/assets/stylesheets/workarea/storefront/email/_settings.scss +23 -0
- data/app/assets/stylesheets/workarea/storefront/generic/_fonts.scss.erb +11 -0
- data/app/assets/stylesheets/workarea/storefront/objects/_content_wrapper.scss +19 -0
- data/app/assets/stylesheets/workarea/storefront/package_products/components/_product_detail_packaged_products.scss +29 -0
- data/app/assets/stylesheets/workarea/storefront/product_quickview/components/_quickview_button.scss +22 -0
- data/app/assets/stylesheets/workarea/storefront/reviews/components/_rating.scss +41 -0
- data/app/assets/stylesheets/workarea/storefront/reviews/components/_reviews.scss +93 -0
- data/app/assets/stylesheets/workarea/storefront/reviews/components/_reviews_aggregate.scss +54 -0
- data/app/assets/stylesheets/workarea/storefront/reviews/components/_write_review.scss +65 -0
- data/app/assets/stylesheets/workarea/storefront/search_autocomplete/components/_search_autocomplete.scss +56 -0
- data/app/assets/stylesheets/workarea/storefront/settings/_colors.scss.erb +17 -0
- data/app/assets/stylesheets/workarea/storefront/settings/_font_families.scss.erb +6 -0
- data/app/assets/stylesheets/workarea/storefront/settings/_global.scss +36 -0
- data/app/assets/stylesheets/workarea/storefront/settings/_typography.scss +19 -0
- data/app/assets/stylesheets/workarea/storefront/settings/_z_indexes.scss +39 -0
- data/app/assets/stylesheets/workarea/storefront/share/components/_share_buttons.scss +139 -0
- data/app/assets/stylesheets/workarea/storefront/slick_slider/components/_slick_slider.scss +140 -0
- data/app/assets/stylesheets/workarea/storefront/swatches/components/_swatch_facet.scss +37 -0
- data/app/assets/stylesheets/workarea/storefront/swatches/components/_swatch_options.scss +79 -0
- data/app/assets/stylesheets/workarea/storefront/theme/_style_guide.scss +9 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/color_schemes/_haven_color_scheme.scss +276 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/color_schemes/_lagoon_color_scheme.scss +279 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_hind.scss +21 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_lora.scss +37 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_muli.scss +37 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_playfair_display.scss +37 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_poppins.scss +40 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_pt_serif.scss +22 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_roboto.scss +29 -0
- data/app/assets/stylesheets/workarea/storefront/theme_config/fonts/_source_serif_pro.scss +21 -0
- data/app/assets/stylesheets/workarea/storefront/tools/_focus_ring.scss +22 -0
- data/app/assets/stylesheets/workarea/storefront/tools/_full_bleed_container.scss +15 -0
- data/app/assets/stylesheets/workarea/storefront/typography/_headings.scss +144 -0
- data/app/assets/stylesheets/workarea/storefront/typography/_links.scss +47 -0
- data/app/assets/stylesheets/workarea/storefront/typography/_text.scss +45 -0
- data/app/assets/stylesheets/workarea/styled_selects/components/_styled_select.scss +64 -0
- data/app/helpers/workarea/storefront/applied_facets_helper.rb +30 -0
- data/app/helpers/workarea/storefront/haven_blog_helper.rb +12 -0
- data/app/helpers/workarea/storefront/haven_swatches_helper.rb +24 -0
- data/app/helpers/workarea/storefront/product_media_slider_helper.rb +37 -0
- data/app/helpers/workarea/storefront/product_retina_image_srcset_helper.rb +9 -0
- data/app/seeds/workarea/haven_categories_seeds.rb +42 -0
- data/app/seeds/workarea/haven_demo_product_seeds.rb +94 -0
- data/app/seeds/workarea/theme_layout_content_seeds.rb +59 -0
- data/app/view_models/workarea/storefront/blog_entry_view_model.decorator +11 -0
- data/app/view_models/workarea/storefront/cart_content.rb +19 -0
- data/app/view_models/workarea/storefront/cart_view_model.decorator +7 -0
- data/app/view_models/workarea/storefront/content_blocks/hero_view_model.decorator +19 -0
- data/app/view_models/workarea/storefront/content_blocks/product_grid_cell_view_model.decorator +11 -0
- data/app/view_models/workarea/storefront/product_view_model.decorator +19 -0
- data/app/views/layouts/workarea/storefront/application.html.haml +194 -0
- data/app/views/layouts/workarea/storefront/checkout.html.haml +82 -0
- data/app/views/workarea/storefront/blog_comments/index.html.haml +29 -0
- data/app/views/workarea/storefront/blog_entries/_summary.html.haml +32 -0
- data/app/views/workarea/storefront/blog_entries/show.html.haml +84 -0
- data/app/views/workarea/storefront/blogs/_blog_navigation.html.haml +9 -0
- data/app/views/workarea/storefront/blogs/index.html.haml +25 -0
- data/app/views/workarea/storefront/blogs/show.html.haml +31 -0
- data/app/views/workarea/storefront/cart_items/create.html.haml +76 -0
- data/app/views/workarea/storefront/cart_items/package.html.haml +64 -0
- data/app/views/workarea/storefront/carts/_pricing.html.haml +12 -0
- data/app/views/workarea/storefront/carts/show.html.haml +172 -0
- data/app/views/workarea/storefront/categories/show.html.haml +131 -0
- data/app/views/workarea/storefront/checkouts/_checkout_progress.html.haml +26 -0
- data/app/views/workarea/storefront/checkouts/_gift_card_payment.html.haml +34 -0
- data/app/views/workarea/storefront/checkouts/_summary.html.haml +175 -0
- data/app/views/workarea/storefront/checkouts/addresses.html.haml +56 -0
- data/app/views/workarea/storefront/checkouts/confirmation.html.haml +56 -0
- data/app/views/workarea/storefront/checkouts/payment.html.haml +110 -0
- data/app/views/workarea/storefront/content_blocks/_blog_entry.html.haml +5 -0
- data/app/views/workarea/storefront/content_blocks/_category_summary.html.haml +16 -0
- data/app/views/workarea/storefront/content_blocks/_hero.html.haml +3 -0
- data/app/views/workarea/storefront/content_blocks/_product_grid_cell.html.haml +25 -0
- data/app/views/workarea/storefront/content_blocks/_product_insights.html.haml +12 -0
- data/app/views/workarea/storefront/content_blocks/_product_list.html.haml +12 -0
- data/app/views/workarea/storefront/content_blocks/_social_networks.html.haml +17 -0
- data/app/views/workarea/storefront/content_blocks/_taxonomy.html.haml +27 -0
- data/app/views/workarea/storefront/content_blocks/_three_column_taxonomy.html.haml +28 -0
- data/app/views/workarea/storefront/content_blocks/_two_column_taxonomy.html.haml +28 -0
- data/app/views/workarea/storefront/email_signups/_form.html.haml +9 -0
- data/app/views/workarea/storefront/email_signups/show.html.haml +8 -0
- data/app/views/workarea/storefront/facets/_applied.html.haml +13 -0
- data/app/views/workarea/storefront/facets/_range.html.haml +15 -0
- data/app/views/workarea/storefront/facets/_swatches.html.haml +16 -0
- data/app/views/workarea/storefront/facets/_terms.html.haml +15 -0
- data/app/views/workarea/storefront/menus/show.html.haml +10 -0
- data/app/views/workarea/storefront/orders/_details.haml +143 -0
- data/app/views/workarea/storefront/orders/_summary.html.haml +75 -0
- data/app/views/workarea/storefront/orders/index.html.haml +47 -0
- data/app/views/workarea/storefront/orders/show.html.haml +19 -0
- data/app/views/workarea/storefront/products/_media.html.haml +42 -0
- data/app/views/workarea/storefront/products/_pricing.html.haml +34 -0
- data/app/views/workarea/storefront/products/_rating.html.haml +9 -0
- data/app/views/workarea/storefront/products/_reviews.html.haml +34 -0
- data/app/views/workarea/storefront/products/_reviews_aggregate.html.haml +13 -0
- data/app/views/workarea/storefront/products/_summary.html.haml +16 -0
- data/app/views/workarea/storefront/products/_swatch_summary.html.haml +20 -0
- data/app/views/workarea/storefront/products/_video_thumbnail.html.haml +11 -0
- data/app/views/workarea/storefront/products/package_show.html.haml +50 -0
- data/app/views/workarea/storefront/products/show.html.haml +95 -0
- data/app/views/workarea/storefront/products/templates/_family.html.haml +28 -0
- data/app/views/workarea/storefront/products/templates/_generic.html.haml +57 -0
- data/app/views/workarea/storefront/products/templates/_gift_card.html.haml +68 -0
- data/app/views/workarea/storefront/products/templates/_option_selects.html.haml +59 -0
- data/app/views/workarea/storefront/products/templates/_option_thumbnails.html.haml +66 -0
- data/app/views/workarea/storefront/products/templates/_package.html.haml +22 -0
- data/app/views/workarea/storefront/products/templates/_swatches.html.haml +72 -0
- data/app/views/workarea/storefront/recent_views/show.html.haml +21 -0
- data/app/views/workarea/storefront/recommendations/show.html.haml +13 -0
- data/app/views/workarea/storefront/reviews/new.html.haml +71 -0
- data/app/views/workarea/storefront/searches/autocomplete.html.haml +35 -0
- data/app/views/workarea/storefront/searches/content.html.haml +72 -0
- data/app/views/workarea/storefront/searches/no_results.html.haml +33 -0
- data/app/views/workarea/storefront/searches/show.html.haml +118 -0
- data/app/views/workarea/storefront/shared/_address_fields.html.haml +99 -0
- data/app/views/workarea/storefront/shared/_left_navigation.html.haml +26 -0
- data/app/views/workarea/storefront/shares/_share_buttons.html.haml +19 -0
- data/app/views/workarea/storefront/shares/new.html.haml +53 -0
- data/app/views/workarea/storefront/style_guides/components/_button.html.haml +100 -0
- data/app/views/workarea/storefront/style_guides/components/_data_card.html.haml +218 -0
- data/app/views/workarea/storefront/style_guides/components/_mobile_filters.html.haml +146 -0
- data/app/views/workarea/storefront/style_guides/components/_personalized_recommendations_content_block.html.haml +34 -0
- data/app/views/workarea/storefront/style_guides/components/_product_insights_content_block.html.haml +34 -0
- data/app/views/workarea/storefront/style_guides/components/_product_list.html.haml +222 -0
- data/app/views/workarea/storefront/style_guides/components/_product_list_content_block.html.haml +34 -0
- data/app/views/workarea/storefront/style_guides/components/_product_summary.html.haml +47 -0
- data/app/views/workarea/storefront/style_guides/components/_property.html.haml +93 -0
- data/app/views/workarea/storefront/style_guides/components/_recommendations.html.haml +43 -0
- data/app/views/workarea/storefront/style_guides/components/_social_networks_content_block.html.haml +20 -0
- data/app/views/workarea/storefront/style_guides/components/_svg_icon.html.haml +76 -0
- data/app/views/workarea/storefront/style_guides/components/_value.html.haml +90 -0
- data/app/views/workarea/storefront/style_guides/settings/_color_variables.html.haml +90 -0
- data/app/views/workarea/storefront/style_guides/settings/color_schemes/_haven_color_scheme.html.haml +8 -0
- data/app/views/workarea/storefront/style_guides/settings/color_schemes/_lagoon_color_scheme.html.haml +8 -0
- data/app/views/workarea/storefront/style_guides/typography/_fonts.html.haml +13 -0
- data/app/views/workarea/storefront/style_guides/typography/_headings.html.haml +53 -0
- data/app/views/workarea/storefront/style_guides/typography/_links.html.haml +27 -0
- data/app/views/workarea/storefront/style_guides/typography/_text.html.haml +27 -0
- data/app/views/workarea/storefront/users/_haven_current_user.json.jbuilder +1 -0
- data/app/views/workarea/storefront/users/accounts/edit.html.haml +48 -0
- data/app/views/workarea/storefront/users/accounts/show.html.haml +119 -0
- data/app/views/workarea/storefront/users/addresses/edit.html.haml +24 -0
- data/app/views/workarea/storefront/users/addresses/new.html.haml +24 -0
- data/app/views/workarea/storefront/users/credit_cards/edit.html.haml +71 -0
- data/app/views/workarea/storefront/users/credit_cards/new.html.haml +66 -0
- data/app/views/workarea/storefront/users/logins/new.html.haml +60 -0
- data/app/views/workarea/storefront/users/orders/_summary.html.haml +25 -0
- data/app/views/workarea/storefront/users/orders/index.html.haml +23 -0
- data/app/views/workarea/storefront/users/orders/show.html.haml +22 -0
- data/app/views/workarea/storefront/users/passwords/change.html.haml +25 -0
- data/app/views/workarea/storefront/users/passwords/edit.html.haml +16 -0
- data/app/views/workarea/storefront/users/passwords/new.html.haml +27 -0
- data/bin/rails +20 -0
- data/browserslist +3 -0
- data/config/initializers/appends.rb +94 -0
- data/config/initializers/assets.rb +1 -0
- data/config/initializers/content_block_types.rb +95 -0
- data/config/initializers/dragonfly.rb +74 -0
- data/config/initializers/seeds.rb +3 -0
- data/config/initializers/theme.rb +68 -0
- data/config/initializers/workarea.rb +3 -0
- data/config/locales/en.yml +63 -0
- data/data/content_assets/product_grid_content_2_cell_background.jpg +0 -0
- data/data/content_assets/product_grid_content_background.jpg +0 -0
- data/data/content_assets/taxonomy_content_image.jpg +0 -0
- data/data/workarea/images/products/Clock.jpg +0 -0
- data/data/workarea/images/products/Headphones.jpg +0 -0
- data/data/workarea/images/products/Scissors.jpg +0 -0
- data/data/workarea/images/products/bookends.jpg +0 -0
- data/data/workarea/images/products/camera.jpg +0 -0
- data/data/workarea/images/products/coffee.jpg +0 -0
- data/data/workarea/images/products/lamp1.jpg +0 -0
- data/data/workarea/images/products/lamp2.png +0 -0
- data/data/workarea/images/products/lamp3.jpg +0 -0
- data/data/workarea/images/products/pen.jpg +0 -0
- data/data/workarea/images/products/plant.jpg +0 -0
- data/data/workarea/images/products/plant2.jpg +0 -0
- data/data/workarea/images/products/table.jpg +0 -0
- data/data/workarea/images/products/table2.jpg +0 -0
- data/data/workarea/images/products/table3.jpg +0 -0
- data/lib/tasks/haven_theme_tasks.rake +20 -0
- data/lib/workarea/haven_theme.rb +30 -0
- data/lib/workarea/haven_theme/engine.rb +17 -0
- data/lib/workarea/haven_theme/version.rb +5 -0
- data/package.json +9 -0
- data/public/screenshots/account.png +0 -0
- data/public/screenshots/blog.png +0 -0
- data/public/screenshots/blog_entry.png +0 -0
- data/public/screenshots/cart.png +0 -0
- data/public/screenshots/category_page.png +0 -0
- data/public/screenshots/checkout.png +0 -0
- data/public/screenshots/full_screen_search.png +0 -0
- data/public/screenshots/product_detail_page.png +0 -0
- data/script/admin_ci +9 -0
- data/script/ci +11 -0
- data/script/core_ci +9 -0
- data/script/plugins_ci +9 -0
- data/script/storefront_ci +9 -0
- data/test/dummy/Rakefile +6 -0
- data/test/dummy/app/assets/config/manifest.js +4 -0
- data/test/dummy/app/assets/images/.keep +0 -0
- data/test/dummy/app/assets/javascripts/application.js +13 -0
- data/test/dummy/app/assets/stylesheets/application.css +15 -0
- data/test/dummy/app/controllers/application_controller.rb +3 -0
- data/test/dummy/app/controllers/concerns/.keep +0 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/jobs/application_job.rb +2 -0
- data/test/dummy/app/mailers/application_mailer.rb +4 -0
- data/test/dummy/app/models/concerns/.keep +0 -0
- data/test/dummy/app/views/layouts/application.html.erb +14 -0
- data/test/dummy/app/views/layouts/mailer.html.erb +13 -0
- data/test/dummy/app/views/layouts/mailer.text.erb +1 -0
- data/test/dummy/bin/bundle +3 -0
- data/test/dummy/bin/rails +4 -0
- data/test/dummy/bin/rake +4 -0
- data/test/dummy/bin/setup +38 -0
- data/test/dummy/bin/update +29 -0
- data/test/dummy/bin/yarn +11 -0
- data/test/dummy/config.ru +5 -0
- data/test/dummy/config/application.rb +28 -0
- data/test/dummy/config/boot.rb +5 -0
- data/test/dummy/config/cable.yml +10 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +54 -0
- data/test/dummy/config/environments/production.rb +91 -0
- data/test/dummy/config/environments/test.rb +44 -0
- data/test/dummy/config/initializers/application_controller_renderer.rb +8 -0
- data/test/dummy/config/initializers/assets.rb +14 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +5 -0
- data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/test/dummy/config/initializers/inflections.rb +16 -0
- data/test/dummy/config/initializers/mime_types.rb +4 -0
- data/test/dummy/config/initializers/workarea.rb +5 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/test/dummy/config/locales/en.yml +33 -0
- data/test/dummy/config/puma.rb +56 -0
- data/test/dummy/config/routes.rb +5 -0
- data/test/dummy/config/secrets.yml +32 -0
- data/test/dummy/config/spring.rb +6 -0
- data/test/dummy/db/seeds.rb +2 -0
- data/test/dummy/lib/assets/.keep +0 -0
- data/test/dummy/log/.keep +0 -0
- data/test/dummy/package.json +5 -0
- data/test/integration/workarea/storefront/swatches_integration_test.decorator +28 -0
- data/test/system/workarea/admin/guest_browsing_system_test.decorator +38 -0
- data/test/system/workarea/storefront/analytics_system_test.decorator +71 -0
- data/test/system/workarea/storefront/blog_system_test.decorator +26 -0
- data/test/system/workarea/storefront/cart_content_system_test.rb +60 -0
- data/test/system/workarea/storefront/categories_system_test.decorator +188 -0
- data/test/system/workarea/storefront/categories_with_packages_system_test.decorator +94 -0
- data/test/system/workarea/storefront/content_system_test.decorator +21 -0
- data/test/system/workarea/storefront/digital_products_system_test.decorator +58 -0
- data/test/system/workarea/storefront/discounting_system_test.decorator +141 -0
- data/test/system/workarea/storefront/gift_cards_system_test.decorator +224 -0
- data/test/system/workarea/storefront/guest_checkout_system_test.decorator +100 -0
- data/test/system/workarea/storefront/hover_zoom_test.decorator +12 -0
- data/test/system/workarea/storefront/logged_in_checkout_system_test.decorator +90 -0
- data/test/system/workarea/storefront/login_system_test.decorator +94 -0
- data/test/system/workarea/storefront/navigation_system_test.decorator +28 -0
- data/test/system/workarea/storefront/no_js_system_test.decorator +76 -0
- data/test/system/workarea/storefront/passwords_system_test.decorator +59 -0
- data/test/system/workarea/storefront/product_videos_system_test.decorator +28 -0
- data/test/system/workarea/storefront/products_system_test.decorator +14 -0
- data/test/system/workarea/storefront/review_system_test.decorator +34 -0
- data/test/system/workarea/storefront/search_autocomplete_system_test.decorator +46 -0
- data/test/system/workarea/storefront/search_system_test.decorator +105 -0
- data/test/system/workarea/storefront/sharing_system_test.decorator +50 -0
- data/test/system/workarea/storefront/store_credit_system_test.decorator +125 -0
- data/test/teaspoon_env.rb +6 -0
- data/test/test_helper.rb +10 -0
- data/test/view_models/workarea/storefront/content_blocks/product_insights_view_model_test.decorator +41 -0
- data/vendor/assets/javascripts/polyfills/stickyfill.js +520 -0
- data/workarea-haven_theme.gemspec +39 -0
- metadata +789 -0
@@ -0,0 +1,59 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.productDetailTabs
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('productDetailTabs', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var scrollToElement = function ($element) {
|
8
|
+
$('html, body').animate({
|
9
|
+
scrollTop: $element.offset().top - WORKAREA.config.productDetailTabs.topOffset
|
10
|
+
}, WORKAREA.config.productDetailTabs.animationSpeed);
|
11
|
+
},
|
12
|
+
|
13
|
+
closeOverlay = function ($overlay) {
|
14
|
+
$overlay.removeClass('product-detail-container__section--open-overlay');
|
15
|
+
},
|
16
|
+
|
17
|
+
openOverlay = function ($eventTarget) {
|
18
|
+
$eventTarget.addClass('product-detail-container__section--open-overlay');
|
19
|
+
},
|
20
|
+
|
21
|
+
isMobile = function() {
|
22
|
+
return WORKAREA.breakPoints.currentlyLessThan('medium');
|
23
|
+
},
|
24
|
+
|
25
|
+
handleCloseOverlayClick = function(event) {
|
26
|
+
var $button = $(event.target),
|
27
|
+
$overlay = $button.closest('.product-detail-container__section--open-overlay');
|
28
|
+
|
29
|
+
closeOverlay($overlay);
|
30
|
+
},
|
31
|
+
|
32
|
+
handleClick = function(event) {
|
33
|
+
var $targetElement = $(event.target.hash);
|
34
|
+
|
35
|
+
if (_.isEmpty($targetElement)) { return; }
|
36
|
+
|
37
|
+
event.preventDefault();
|
38
|
+
|
39
|
+
if (isMobile()) {
|
40
|
+
openOverlay($targetElement);
|
41
|
+
} else {
|
42
|
+
scrollToElement($targetElement);
|
43
|
+
}
|
44
|
+
},
|
45
|
+
|
46
|
+
/**
|
47
|
+
* @method
|
48
|
+
* @name init
|
49
|
+
* @memberof WORKAREA.productDetailTabs
|
50
|
+
*/
|
51
|
+
init = function ($scope) {
|
52
|
+
$('[data-product-detail-tabs]', $scope).on('click', handleClick);
|
53
|
+
$('[data-product-detail-tabs-close-overlay]', $scope).on('click', handleCloseOverlayClick);
|
54
|
+
};
|
55
|
+
|
56
|
+
return {
|
57
|
+
init: init
|
58
|
+
};
|
59
|
+
}()));
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.quantityControl
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('quantityControl', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var handleQtyEvent = function (event) {
|
8
|
+
var $button = $(event.currentTarget),
|
9
|
+
data = $button.data('quantityControl'),
|
10
|
+
$qtyInput = $button.closest('form').find('.quantity-control__input'),
|
11
|
+
currentQty = parseInt($qtyInput.val()),
|
12
|
+
changeDirection = data.direction,
|
13
|
+
autoSubmit = data.autosubmit || false;
|
14
|
+
|
15
|
+
event.preventDefault();
|
16
|
+
|
17
|
+
updateQty($qtyInput, calculateQty(currentQty, changeDirection));
|
18
|
+
|
19
|
+
if(autoSubmit) {
|
20
|
+
_.delay(submitForm, WORKAREA.config.havenTheme.quantityControl.autoSubmitDelay, $qtyInput);
|
21
|
+
}
|
22
|
+
},
|
23
|
+
|
24
|
+
calculateQty = function(currentQty, changeDirection) {
|
25
|
+
if (changeDirection === 'inc') {
|
26
|
+
return currentQty + 1;
|
27
|
+
} else {
|
28
|
+
return currentQty > 0 ? currentQty - 1 : currentQty;
|
29
|
+
}
|
30
|
+
},
|
31
|
+
|
32
|
+
updateQty = function ($qtyInput, newQty) {
|
33
|
+
$qtyInput.val(newQty);
|
34
|
+
},
|
35
|
+
|
36
|
+
submitForm = function($qtyInput) {
|
37
|
+
var $form = $qtyInput.closest('form');
|
38
|
+
|
39
|
+
if($form.valid()) {
|
40
|
+
$form.submit();
|
41
|
+
}
|
42
|
+
},
|
43
|
+
|
44
|
+
/**
|
45
|
+
* @method
|
46
|
+
* @name init
|
47
|
+
* @memberof WORKAREA.quantityControl
|
48
|
+
*/
|
49
|
+
init = function ($scope) {
|
50
|
+
$('[data-quantity-control]', $scope).on('click', handleQtyEvent);
|
51
|
+
};
|
52
|
+
|
53
|
+
return {
|
54
|
+
init: init
|
55
|
+
};
|
56
|
+
}()));
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.searchButtons
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('searchButtons', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var searchOpen = function ($search) {
|
8
|
+
return $search.hasClass('search--open');
|
9
|
+
},
|
10
|
+
|
11
|
+
closeSearch = function($search) {
|
12
|
+
$search.removeClass('search--open');
|
13
|
+
},
|
14
|
+
|
15
|
+
openSearch = function ($search) {
|
16
|
+
$search.addClass('search--open');
|
17
|
+
},
|
18
|
+
|
19
|
+
focusOnSearchInput = function ($search) {
|
20
|
+
var $searchInput = $search.find('.text-box');
|
21
|
+
$searchInput.trigger('focus');
|
22
|
+
},
|
23
|
+
|
24
|
+
closeSearchIfOpen = function () {
|
25
|
+
var $search = $('#search');
|
26
|
+
|
27
|
+
if (searchOpen($search)) {
|
28
|
+
closeSearch($search);
|
29
|
+
}
|
30
|
+
},
|
31
|
+
|
32
|
+
searchButtonClicked = function() {
|
33
|
+
var $search = $('#search');
|
34
|
+
|
35
|
+
if (searchOpen($search)) {
|
36
|
+
closeSearch($search);
|
37
|
+
} else {
|
38
|
+
openSearch($search);
|
39
|
+
focusOnSearchInput($search);
|
40
|
+
}
|
41
|
+
},
|
42
|
+
|
43
|
+
init = function ($scope) {
|
44
|
+
$('[data-search-button]', $scope).on('click', searchButtonClicked);
|
45
|
+
};
|
46
|
+
|
47
|
+
$(document).keyup(function (e) {
|
48
|
+
if (e.keyCode === 27) { // escape key maps to keycode `27`
|
49
|
+
closeSearchIfOpen();
|
50
|
+
}
|
51
|
+
});
|
52
|
+
|
53
|
+
return {
|
54
|
+
init: init
|
55
|
+
};
|
56
|
+
}()));
|
@@ -0,0 +1,43 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.toggleClassButton
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('toggleClassButton', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var handleToggleEvent = function (event) {
|
8
|
+
var $button = $(event.currentTarget),
|
9
|
+
data = $button.data('toggleClassButton');
|
10
|
+
|
11
|
+
if (data.closest === true) {
|
12
|
+
updateClosest(data.target, data.class, $button);
|
13
|
+
return;
|
14
|
+
}
|
15
|
+
|
16
|
+
event.preventDefault();
|
17
|
+
|
18
|
+
updateClass(data.target, data.class);
|
19
|
+
},
|
20
|
+
|
21
|
+
updateClass = function (toggleTarget, className) {
|
22
|
+
$(toggleTarget).toggleClass(className);
|
23
|
+
},
|
24
|
+
|
25
|
+
updateClosest = function (toggleTarget, className, $button) {
|
26
|
+
$button.closest(toggleTarget).toggleClass(className);
|
27
|
+
},
|
28
|
+
|
29
|
+
/**
|
30
|
+
* Module Init
|
31
|
+
* Add a class to anoter element on click
|
32
|
+
* Accepts: data{'target': 'x', class: 'y', closest: boolean}
|
33
|
+
*/
|
34
|
+
|
35
|
+
init = function ($scope) {
|
36
|
+
$('[data-toggle-class-button]', $scope)
|
37
|
+
.on('click', handleToggleEvent);
|
38
|
+
};
|
39
|
+
|
40
|
+
return {
|
41
|
+
init: init
|
42
|
+
};
|
43
|
+
}()));
|
@@ -0,0 +1,38 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.userWelcomePlaceholders
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('userWelcomePlaceholders', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var userWelcomeTemplate = JST['workarea/storefront/templates/user_welcome'],
|
8
|
+
|
9
|
+
injectUserWelcomeMessage = function (currentUser, index, element) {
|
10
|
+
$(element).replaceWith(userWelcomeTemplate({
|
11
|
+
username: currentUser.first_name
|
12
|
+
}));
|
13
|
+
},
|
14
|
+
|
15
|
+
testPlaceholders = function ($scope, currentUser) {
|
16
|
+
$('[data-user-welcome-placeholder]', $scope).each(_.partial(injectUserWelcomeMessage, currentUser));
|
17
|
+
},
|
18
|
+
|
19
|
+
testCurrentUser = function ($scope, currentUser) {
|
20
|
+
if (!currentUser.logged_in) { return; }
|
21
|
+
|
22
|
+
testPlaceholders($scope, currentUser);
|
23
|
+
},
|
24
|
+
|
25
|
+
/**
|
26
|
+
* @method
|
27
|
+
* @name init
|
28
|
+
* @memberof WORKAREA.userWelcomePlaceholders
|
29
|
+
*/
|
30
|
+
init = function ($scope) {
|
31
|
+
WORKAREA.currentUser.gettingUserData
|
32
|
+
.done(_.partial(testCurrentUser, $scope));
|
33
|
+
};
|
34
|
+
|
35
|
+
return {
|
36
|
+
init: init
|
37
|
+
};
|
38
|
+
}()));
|
@@ -0,0 +1,82 @@
|
|
1
|
+
/**
|
2
|
+
* @namespace WORKAREA.productReviewsSortMenus
|
3
|
+
*/
|
4
|
+
WORKAREA.registerModule('productReviewsSortMenus', (function () {
|
5
|
+
'use strict';
|
6
|
+
|
7
|
+
var insertSortSelectBox = function (index, section) {
|
8
|
+
$('.reviews__sort', section).append(
|
9
|
+
JST['workarea/storefront/reviews/templates/sort_by_property']()
|
10
|
+
);
|
11
|
+
},
|
12
|
+
|
13
|
+
sortNewToOld = function ($reviews) {
|
14
|
+
return _.sortBy($reviews, function (review) {
|
15
|
+
return -($(review).data('productReviewSectionEntry').createdAt);
|
16
|
+
});
|
17
|
+
},
|
18
|
+
|
19
|
+
sortOldToNew = function ($reviews) {
|
20
|
+
return _.sortBy($reviews, function (review) {
|
21
|
+
return $(review).data('productReviewSectionEntry').createdAt;
|
22
|
+
});
|
23
|
+
},
|
24
|
+
|
25
|
+
|
26
|
+
sortHighToLow = function ($reviews) {
|
27
|
+
return _.sortBy($reviews, function (review) {
|
28
|
+
return -($(review).data('productReviewSectionEntry').rating);
|
29
|
+
});
|
30
|
+
},
|
31
|
+
|
32
|
+
sortLowToHigh = function ($reviews) {
|
33
|
+
return _.sortBy($reviews, function (review) {
|
34
|
+
return $(review).data('productReviewSectionEntry').rating;
|
35
|
+
});
|
36
|
+
},
|
37
|
+
|
38
|
+
handleSortSelectChange = function (event) {
|
39
|
+
var $reviews = $(
|
40
|
+
'[data-product-review-section-entry]', event.delegateTarget
|
41
|
+
),
|
42
|
+
|
43
|
+
action = $(event.currentTarget).val(),
|
44
|
+
|
45
|
+
actions = {
|
46
|
+
oldest: function () {
|
47
|
+
return sortOldToNew($reviews);
|
48
|
+
},
|
49
|
+
newest: function () {
|
50
|
+
return sortNewToOld($reviews);
|
51
|
+
},
|
52
|
+
lowest: function () {
|
53
|
+
return sortLowToHigh($reviews);
|
54
|
+
},
|
55
|
+
highest: function () {
|
56
|
+
return sortHighToLow($reviews);
|
57
|
+
}
|
58
|
+
};
|
59
|
+
|
60
|
+
$('.reviews__review-group', event.delegateTarget)
|
61
|
+
.html(actions[action]());
|
62
|
+
},
|
63
|
+
|
64
|
+
/**
|
65
|
+
* @method
|
66
|
+
* @name init
|
67
|
+
* @memberof WORKAREA.productReviewsSortMenus
|
68
|
+
*/
|
69
|
+
init = function ($scope) {
|
70
|
+
$('.reviews', $scope)
|
71
|
+
.each(insertSortSelectBox)
|
72
|
+
.on(
|
73
|
+
'change',
|
74
|
+
'[data-product-reviews-sort-menu]',
|
75
|
+
handleSortSelectChange
|
76
|
+
);
|
77
|
+
};
|
78
|
+
|
79
|
+
return {
|
80
|
+
init: init
|
81
|
+
};
|
82
|
+
}()));
|
@@ -0,0 +1,13 @@
|
|
1
|
+
<div class="property">
|
2
|
+
<label class="property__name"><span class="property__text">Sort By</span></label>
|
3
|
+
<div class="value value--block">
|
4
|
+
<div class="styled-select">
|
5
|
+
<select data-product-reviews-sort-menu="">
|
6
|
+
<option value="newest" selected>Most Recent</option>
|
7
|
+
<option value="oldest">Oldest First</option>
|
8
|
+
<option value="highest">Rating: High to Low</option>
|
9
|
+
<option value="lowest">Rating: Low to High</option>
|
10
|
+
</select>
|
11
|
+
</div>
|
12
|
+
</div>
|
13
|
+
</div>
|
@@ -0,0 +1 @@
|
|
1
|
+
<li class="account-menu__item"><a href="<%= WORKAREA.routes.storefront.logoutPath() %>" data-analytics="{'event':'logout', 'domEvent':'click'}" data-method="delete" class="account-menu__logout-link"><%= I18n.t('workarea.storefront.users.logout') %></a></li>
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<p><button type='button' class='button button--secondary button--small'>
|
2
|
+
<%= text %>
|
3
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" class="button__icon">
|
4
|
+
<title>plus</title>
|
5
|
+
<polygon points="1 6.63 1 9.13 6.75 9.13 6.75 14.88 9.25 14.88 9.25 9.13 15 9.13 15 6.63 9.25 6.63 9.25 0.88 6.75 0.88 6.75 6.63 1 6.63"
|
6
|
+
/>
|
7
|
+
</svg>
|
8
|
+
</button></p>
|
@@ -0,0 +1,23 @@
|
|
1
|
+
<div class="property">
|
2
|
+
<label for="saved_addresses_<%= counter %>" class="property__name">
|
3
|
+
<span><%= I18n.t('workarea.storefront.checkouts.saved_addresses') %></span>
|
4
|
+
</label>
|
5
|
+
<div class="value value--block">
|
6
|
+
<div class="styled-select">
|
7
|
+
<select id="saved_addresses_<%= counter %>" name="saved_addresses_<%= counter %>">
|
8
|
+
<option value="" selected><%= I18n.t('workarea.storefront.checkouts.select_an_address') %></option>
|
9
|
+
<% _.forEach(addresses, function(address) { %>
|
10
|
+
<option value="<%= address._id %>">
|
11
|
+
<%= address.first_name %>
|
12
|
+
<%= address.last_name %>
|
13
|
+
<%= address.street %>
|
14
|
+
<%= address.street_2 %>
|
15
|
+
<%= address.city %>
|
16
|
+
<%= address.region %>
|
17
|
+
<%= address.postal_code %>
|
18
|
+
</option>
|
19
|
+
<% }); %>
|
20
|
+
</select>
|
21
|
+
</div>
|
22
|
+
</div>
|
23
|
+
</div>
|
@@ -0,0 +1,9 @@
|
|
1
|
+
<!-- TODO: Move this to storefront once v3.3 is released -->
|
2
|
+
<li class="ui-menu-item ui-menu-item--<%= type %>">
|
3
|
+
<span class="ui-menu-item-wrapper">
|
4
|
+
<% if (image) { %>
|
5
|
+
<img class="ui-menu-item__image" src="<%= image %>" alt="">
|
6
|
+
<% } %>
|
7
|
+
<span class="ui-menu-item__text"><%= label %></span>
|
8
|
+
</span>
|
9
|
+
</li>
|
File without changes
|
@@ -0,0 +1,13 @@
|
|
1
|
+
/*------------------------------------*\
|
2
|
+
#UI-AUTOCOMPLETE
|
3
|
+
\*------------------------------------*/
|
4
|
+
|
5
|
+
$ui-autocomplete-bg-color: $transparent !default;
|
6
|
+
|
7
|
+
|
8
|
+
.ui-autocomplete {
|
9
|
+
@extend %list-reset;
|
10
|
+
z-index: index($components, ui-autocomplete);
|
11
|
+
padding: $spacing-unit;
|
12
|
+
background: $ui-autocomplete-bg-color;
|
13
|
+
}
|
@@ -0,0 +1,168 @@
|
|
1
|
+
/*------------------------------------*\
|
2
|
+
#UI-DIALOG
|
3
|
+
\*------------------------------------*/
|
4
|
+
|
5
|
+
$ui-dialog-bg-color: $background-color !default;
|
6
|
+
$ui-dialog-loading-background-color: $transparent !default;
|
7
|
+
$ui-dialog-titlebar-bg-color: $ui-dialog-titlebar-bg-color !default;
|
8
|
+
$ui-dialog-shadow: 0 6px 8px 0 $black-alpha-50 !default;
|
9
|
+
$ui-dialog-content-height: 90vh !default;
|
10
|
+
$ui-dialog-close-button-offset: $spacing-unit * -4 !default;
|
11
|
+
|
12
|
+
|
13
|
+
.ui-dialog {
|
14
|
+
position: absolute;
|
15
|
+
z-index: index($components, ui-dialog);
|
16
|
+
max-height: 100vh;
|
17
|
+
background: $ui-dialog-bg-color;
|
18
|
+
box-shadow: $ui-dialog-shadow;
|
19
|
+
outline: 0;
|
20
|
+
|
21
|
+
&:focus {
|
22
|
+
outline: none;
|
23
|
+
}
|
24
|
+
|
25
|
+
.ui-draggable-handle {
|
26
|
+
cursor: move;
|
27
|
+
touch-action: none;
|
28
|
+
}
|
29
|
+
|
30
|
+
.ui-resizable-handle {
|
31
|
+
display: block;
|
32
|
+
position: absolute;
|
33
|
+
font-size: 0.1px;
|
34
|
+
touch-action: none;
|
35
|
+
}
|
36
|
+
|
37
|
+
.ui-resizable-n {
|
38
|
+
top: -5px;
|
39
|
+
left: 0;
|
40
|
+
width: 100%;
|
41
|
+
height: 7px;
|
42
|
+
cursor: n-resize;
|
43
|
+
}
|
44
|
+
|
45
|
+
.ui-resizable-s {
|
46
|
+
bottom: -5px;
|
47
|
+
left: 0;
|
48
|
+
width: 100%;
|
49
|
+
height: 7px;
|
50
|
+
cursor: s-resize;
|
51
|
+
}
|
52
|
+
|
53
|
+
.ui-resizable-e {
|
54
|
+
top: 0;
|
55
|
+
right: -5px;
|
56
|
+
width: 7px;
|
57
|
+
height: 100%;
|
58
|
+
cursor: e-resize;
|
59
|
+
}
|
60
|
+
|
61
|
+
.ui-resizable-w {
|
62
|
+
top: 0;
|
63
|
+
left: -5px;
|
64
|
+
width: 7px;
|
65
|
+
height: 100%;
|
66
|
+
cursor: w-resize;
|
67
|
+
}
|
68
|
+
|
69
|
+
.ui-resizable-se {
|
70
|
+
right: -5px;
|
71
|
+
bottom: -5px;
|
72
|
+
width: 12px;
|
73
|
+
height: 12px;
|
74
|
+
cursor: se-resize;
|
75
|
+
}
|
76
|
+
|
77
|
+
.ui-resizable-sw {
|
78
|
+
bottom: -5px;
|
79
|
+
left: -5px;
|
80
|
+
width: 9px;
|
81
|
+
height: 9px;
|
82
|
+
cursor: sw-resize;
|
83
|
+
}
|
84
|
+
|
85
|
+
.ui-resizable-nw {
|
86
|
+
top: -5px;
|
87
|
+
left: -5px;
|
88
|
+
width: 9px;
|
89
|
+
height: 9px;
|
90
|
+
cursor: nw-resize;
|
91
|
+
}
|
92
|
+
|
93
|
+
.ui-resizable-ne {
|
94
|
+
top: -5px;
|
95
|
+
right: -5px;
|
96
|
+
width: 9px;
|
97
|
+
height: 9px;
|
98
|
+
cursor: ne-resize;
|
99
|
+
}
|
100
|
+
}
|
101
|
+
|
102
|
+
.ui-dialog-titlebar {
|
103
|
+
line-height: 1;
|
104
|
+
text-align: right;
|
105
|
+
background: $ui-dialog-titlebar-bg-color;
|
106
|
+
|
107
|
+
.ui-dialog-image & {
|
108
|
+
position: absolute;
|
109
|
+
top: 0;
|
110
|
+
right: 0;
|
111
|
+
}
|
112
|
+
|
113
|
+
.ui-dialog-loading & {
|
114
|
+
display: none;
|
115
|
+
}
|
116
|
+
}
|
117
|
+
|
118
|
+
.ui-dialog-title {
|
119
|
+
display: none;
|
120
|
+
}
|
121
|
+
|
122
|
+
.ui-dialog-titlebar-close {
|
123
|
+
position: absolute;
|
124
|
+
top: $ui-dialog-close-button-offset;
|
125
|
+
padding: 0;
|
126
|
+
font-size: 0;
|
127
|
+
line-height: 1;
|
128
|
+
background: none;
|
129
|
+
border: 0;
|
130
|
+
cursor: pointer;
|
131
|
+
|
132
|
+
.ui-button-icon {
|
133
|
+
@include svg('dialog_close.svg', 32px);
|
134
|
+
padding: $spacing-unit;
|
135
|
+
cursor: pointer;
|
136
|
+
}
|
137
|
+
}
|
138
|
+
|
139
|
+
.ui-dialog-content {
|
140
|
+
padding: $spacing-unit * 2;
|
141
|
+
// NOTE: Because jQuery UI generates the .ui-dialog-content HTML with
|
142
|
+
// an inline style that sets `max-height: none`, we need the
|
143
|
+
// `!important` designation here to properly override.
|
144
|
+
// scss-lint:disable ImportantRule
|
145
|
+
max-height: $ui-dialog-content-height !important;
|
146
|
+
overflow: auto;
|
147
|
+
|
148
|
+
.ui-dialog-add-to-cart &,
|
149
|
+
.ui-dialog-image & {
|
150
|
+
padding: 0;
|
151
|
+
}
|
152
|
+
|
153
|
+
.ui-dialog-loading & {
|
154
|
+
padding: 50px 0;
|
155
|
+
}
|
156
|
+
}
|
157
|
+
|
158
|
+
|
159
|
+
.ui-dialog-image img {
|
160
|
+
display: block;
|
161
|
+
}
|
162
|
+
|
163
|
+
.ui-dialog-loading {
|
164
|
+
width: 100vw;
|
165
|
+
height: 100vh;
|
166
|
+
background-color: $ui-dialog-loading-background-color;
|
167
|
+
box-shadow: none;
|
168
|
+
}
|