workarea-storefront 3.4.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (686) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +52 -0
  3. data/README.md +19 -0
  4. data/Rakefile +23 -0
  5. data/app/assets/fonts/.keep +0 -0
  6. data/app/assets/images/workarea/core/test.jpg +0 -0
  7. data/app/assets/images/workarea/storefront/default_card.svg +1 -0
  8. data/app/assets/images/workarea/storefront/dialog_close.svg +1 -0
  9. data/app/assets/images/workarea/storefront/email/banner.png +0 -0
  10. data/app/assets/images/workarea/storefront/icons/facebook.svg +1 -0
  11. data/app/assets/images/workarea/storefront/icons/google_plus.svg +1 -0
  12. data/app/assets/images/workarea/storefront/icons/menu.svg +1 -0
  13. data/app/assets/images/workarea/storefront/icons/pinterest.svg +1 -0
  14. data/app/assets/images/workarea/storefront/icons/twitter.svg +1 -0
  15. data/app/assets/images/workarea/storefront/logo.png +0 -0
  16. data/app/assets/images/workarea/storefront/message_dismiss.svg +1 -0
  17. data/app/assets/images/workarea/storefront/message_error.svg +1 -0
  18. data/app/assets/images/workarea/storefront/message_info.svg +1 -0
  19. data/app/assets/images/workarea/storefront/message_success.svg +1 -0
  20. data/app/assets/images/workarea/storefront/message_warning.svg +1 -0
  21. data/app/assets/images/workarea/storefront/payment_icons/american_express.svg +1 -0
  22. data/app/assets/images/workarea/storefront/payment_icons/diner_s_club.svg +1 -0
  23. data/app/assets/images/workarea/storefront/payment_icons/discover.svg +1 -0
  24. data/app/assets/images/workarea/storefront/payment_icons/mastercard.svg +1 -0
  25. data/app/assets/images/workarea/storefront/payment_icons/visa.svg +1 -0
  26. data/app/assets/images/workarea/storefront/payment_method_icons.png +0 -0
  27. data/app/assets/images/workarea/storefront/style_guide_light_banner.png +0 -0
  28. data/app/assets/images/workarea/storefront/style_guide_product.jpg +0 -0
  29. data/app/assets/javascripts/jquery_ui/storefront/categorized_autocomplete.js +53 -0
  30. data/app/assets/javascripts/workarea/storefront/application.js.erb +162 -0
  31. data/app/assets/javascripts/workarea/storefront/config.js.erb +153 -0
  32. data/app/assets/javascripts/workarea/storefront/head.js.erb +18 -0
  33. data/app/assets/javascripts/workarea/storefront/modules/address_region_fields.js +91 -0
  34. data/app/assets/javascripts/workarea/storefront/modules/admin_toolbar.js +105 -0
  35. data/app/assets/javascripts/workarea/storefront/modules/alternate_image_buttons.js +78 -0
  36. data/app/assets/javascripts/workarea/storefront/modules/analytics.js +285 -0
  37. data/app/assets/javascripts/workarea/storefront/modules/authenticity_token.js +27 -0
  38. data/app/assets/javascripts/workarea/storefront/modules/back_to_top_button.js +47 -0
  39. data/app/assets/javascripts/workarea/storefront/modules/break_points.js +67 -0
  40. data/app/assets/javascripts/workarea/storefront/modules/cart_count.js +51 -0
  41. data/app/assets/javascripts/workarea/storefront/modules/checkout_addresses_forms.js +222 -0
  42. data/app/assets/javascripts/workarea/storefront/modules/checkout_primary_payments.js +66 -0
  43. data/app/assets/javascripts/workarea/storefront/modules/checkout_shipping_services.js +53 -0
  44. data/app/assets/javascripts/workarea/storefront/modules/current_user.js +28 -0
  45. data/app/assets/javascripts/workarea/storefront/modules/dialog.js +284 -0
  46. data/app/assets/javascripts/workarea/storefront/modules/dialog_buttons.js +78 -0
  47. data/app/assets/javascripts/workarea/storefront/modules/dialog_close_buttons.js +29 -0
  48. data/app/assets/javascripts/workarea/storefront/modules/dialog_forms.js +47 -0
  49. data/app/assets/javascripts/workarea/storefront/modules/forms.js +94 -0
  50. data/app/assets/javascripts/workarea/storefront/modules/loading.js +81 -0
  51. data/app/assets/javascripts/workarea/storefront/modules/log_out_link_placeholders.js +36 -0
  52. data/app/assets/javascripts/workarea/storefront/modules/messages.js +179 -0
  53. data/app/assets/javascripts/workarea/storefront/modules/mobile_filter_buttons.js +87 -0
  54. data/app/assets/javascripts/workarea/storefront/modules/mobile_nav_button.js +100 -0
  55. data/app/assets/javascripts/workarea/storefront/modules/option_buttons.js +40 -0
  56. data/app/assets/javascripts/workarea/storefront/modules/optional_fields.js +49 -0
  57. data/app/assets/javascripts/workarea/storefront/modules/pagination.js +284 -0
  58. data/app/assets/javascripts/workarea/storefront/modules/popup_buttons.js +42 -0
  59. data/app/assets/javascripts/workarea/storefront/modules/primary_nav_content.js +77 -0
  60. data/app/assets/javascripts/workarea/storefront/modules/product_details_sku_selects.js +94 -0
  61. data/app/assets/javascripts/workarea/storefront/modules/recent_views.js +25 -0
  62. data/app/assets/javascripts/workarea/storefront/modules/recommendations_placeholders.js +33 -0
  63. data/app/assets/javascripts/workarea/storefront/modules/scroll_to_buttons.js +37 -0
  64. data/app/assets/javascripts/workarea/storefront/modules/search_fields.js +59 -0
  65. data/app/assets/javascripts/workarea/storefront/modules/single_submit_forms.js +35 -0
  66. data/app/assets/javascripts/workarea/storefront/modules/traffic_referrer.js +33 -0
  67. data/app/assets/javascripts/workarea/storefront/modules/workarea_analytics.js +54 -0
  68. data/app/assets/javascripts/workarea/storefront/routes.js.erb +16 -0
  69. data/app/assets/javascripts/workarea/storefront/serviceworkers/pwa_cache.js.erb +31 -0
  70. data/app/assets/javascripts/workarea/storefront/serviceworkers/register_pwa_cache.js +5 -0
  71. data/app/assets/javascripts/workarea/storefront/templates/authenticity_token.jst.ejs +1 -0
  72. data/app/assets/javascripts/workarea/storefront/templates/back_to_top_button.jst.ejs +3 -0
  73. data/app/assets/javascripts/workarea/storefront/templates/button.jst.ejs +3 -0
  74. data/app/assets/javascripts/workarea/storefront/templates/loading.jst.ejs +1 -0
  75. data/app/assets/javascripts/workarea/storefront/templates/log_out_link.jst.ejs +1 -0
  76. data/app/assets/javascripts/workarea/storefront/templates/message.jst.ejs +10 -0
  77. data/app/assets/javascripts/workarea/storefront/templates/message_dismiss_action.jst.ejs +5 -0
  78. data/app/assets/javascripts/workarea/storefront/templates/mobile_filters_nav_close_button.jst.ejs +3 -0
  79. data/app/assets/javascripts/workarea/storefront/templates/optional_field_prompt.jst.ejs +1 -0
  80. data/app/assets/javascripts/workarea/storefront/templates/page_header_cart_count.jst.ejs +1 -0
  81. data/app/assets/javascripts/workarea/storefront/templates/pagination_button.jst.ejs +11 -0
  82. data/app/assets/javascripts/workarea/storefront/templates/same_as_shipping_button_property.jst.ejs +8 -0
  83. data/app/assets/javascripts/workarea/storefront/templates/saved_addresses_property.jst.ejs +21 -0
  84. data/app/assets/javascripts/workarea/storefront/templates/ui_menu_heading.jst.ejs +1 -0
  85. data/app/assets/javascripts/workarea/storefront/templates/ui_menu_item.jst.ejs +8 -0
  86. data/app/assets/stylesheets/jquery_ui/storefront/_ui_autocomplete.scss +17 -0
  87. data/app/assets/stylesheets/jquery_ui/storefront/_ui_dialog.scss +158 -0
  88. data/app/assets/stylesheets/jquery_ui/storefront/_ui_helper_hidden_accessible.scss +7 -0
  89. data/app/assets/stylesheets/jquery_ui/storefront/_ui_menu.scss +40 -0
  90. data/app/assets/stylesheets/jquery_ui/storefront/_ui_state_focus.scss +10 -0
  91. data/app/assets/stylesheets/jquery_ui/storefront/_ui_widget_overlay.scss +11 -0
  92. data/app/assets/stylesheets/workarea/storefront/application.scss.erb +138 -0
  93. data/app/assets/stylesheets/workarea/storefront/base/_forms.scss +113 -0
  94. data/app/assets/stylesheets/workarea/storefront/base/_images.scss +29 -0
  95. data/app/assets/stylesheets/workarea/storefront/base/_lists.scss +8 -0
  96. data/app/assets/stylesheets/workarea/storefront/base/_page.scss +27 -0
  97. data/app/assets/stylesheets/workarea/storefront/base/_tables.scss +15 -0
  98. data/app/assets/stylesheets/workarea/storefront/components/_admin_toolbar.scss +34 -0
  99. data/app/assets/stylesheets/workarea/storefront/components/_back_to_top_button.scss +23 -0
  100. data/app/assets/stylesheets/workarea/storefront/components/_box.scss +37 -0
  101. data/app/assets/stylesheets/workarea/storefront/components/_breadcrumbs.scss +27 -0
  102. data/app/assets/stylesheets/workarea/storefront/components/_button.scss +47 -0
  103. data/app/assets/stylesheets/workarea/storefront/components/_button_content_block.scss +9 -0
  104. data/app/assets/stylesheets/workarea/storefront/components/_button_property.scss +40 -0
  105. data/app/assets/stylesheets/workarea/storefront/components/_cart.scss +21 -0
  106. data/app/assets/stylesheets/workarea/storefront/components/_category_summary_content_block.scss +14 -0
  107. data/app/assets/stylesheets/workarea/storefront/components/_checkout_addresses.scss +17 -0
  108. data/app/assets/stylesheets/workarea/storefront/components/_checkout_payment.scss +48 -0
  109. data/app/assets/stylesheets/workarea/storefront/components/_checkout_progress.scss +42 -0
  110. data/app/assets/stylesheets/workarea/storefront/components/_checkout_shipping.scss +11 -0
  111. data/app/assets/stylesheets/workarea/storefront/components/_checkout_step_summary.scss +19 -0
  112. data/app/assets/stylesheets/workarea/storefront/components/_content_block.scss +39 -0
  113. data/app/assets/stylesheets/workarea/storefront/components/_data_card.scss +68 -0
  114. data/app/assets/stylesheets/workarea/storefront/components/_divider_content_block.scss +38 -0
  115. data/app/assets/stylesheets/workarea/storefront/components/_email_signup.scss +9 -0
  116. data/app/assets/stylesheets/workarea/storefront/components/_hero_content_block.scss +77 -0
  117. data/app/assets/stylesheets/workarea/storefront/components/_html_content_block.scss +5 -0
  118. data/app/assets/stylesheets/workarea/storefront/components/_image_and_text_content_block.scss +30 -0
  119. data/app/assets/stylesheets/workarea/storefront/components/_image_content_block.scss +16 -0
  120. data/app/assets/stylesheets/workarea/storefront/components/_image_group_content_block.scss +9 -0
  121. data/app/assets/stylesheets/workarea/storefront/components/_inline_form.scss +11 -0
  122. data/app/assets/stylesheets/workarea/storefront/components/_loading.scss +92 -0
  123. data/app/assets/stylesheets/workarea/storefront/components/_message.scss +120 -0
  124. data/app/assets/stylesheets/workarea/storefront/components/_mobile_filters.scss +25 -0
  125. data/app/assets/stylesheets/workarea/storefront/components/_mobile_filters_nav.scss +31 -0
  126. data/app/assets/stylesheets/workarea/storefront/components/_mobile_nav.scss +67 -0
  127. data/app/assets/stylesheets/workarea/storefront/components/_option_button.scss +27 -0
  128. data/app/assets/stylesheets/workarea/storefront/components/_order_help_menu.scss +31 -0
  129. data/app/assets/stylesheets/workarea/storefront/components/_order_summary.scss +14 -0
  130. data/app/assets/stylesheets/workarea/storefront/components/_page_container.scss +26 -0
  131. data/app/assets/stylesheets/workarea/storefront/components/_page_content.scss +14 -0
  132. data/app/assets/stylesheets/workarea/storefront/components/_page_footer.scss +57 -0
  133. data/app/assets/stylesheets/workarea/storefront/components/_page_header.scss +79 -0
  134. data/app/assets/stylesheets/workarea/storefront/components/_page_messages.scss +36 -0
  135. data/app/assets/stylesheets/workarea/storefront/components/_pagination.scss +9 -0
  136. data/app/assets/stylesheets/workarea/storefront/components/_payment_icon.scss +19 -0
  137. data/app/assets/stylesheets/workarea/storefront/components/_personalized_recommendations_content_block.scss +10 -0
  138. data/app/assets/stylesheets/workarea/storefront/components/_primary_nav.scss +54 -0
  139. data/app/assets/stylesheets/workarea/storefront/components/_product_detail_container.scss +13 -0
  140. data/app/assets/stylesheets/workarea/storefront/components/_product_details.scss +84 -0
  141. data/app/assets/stylesheets/workarea/storefront/components/_product_insights_content_block.scss +10 -0
  142. data/app/assets/stylesheets/workarea/storefront/components/_product_list.scss +160 -0
  143. data/app/assets/stylesheets/workarea/storefront/components/_product_list_content_block.scss +10 -0
  144. data/app/assets/stylesheets/workarea/storefront/components/_product_prices.scss +32 -0
  145. data/app/assets/stylesheets/workarea/storefront/components/_product_summary.scss +53 -0
  146. data/app/assets/stylesheets/workarea/storefront/components/_property.scss +67 -0
  147. data/app/assets/stylesheets/workarea/storefront/components/_quote_content_block.scss +38 -0
  148. data/app/assets/stylesheets/workarea/storefront/components/_recent_views.scss +28 -0
  149. data/app/assets/stylesheets/workarea/storefront/components/_recommendations.scss +9 -0
  150. data/app/assets/stylesheets/workarea/storefront/components/_result_filters.scss +33 -0
  151. data/app/assets/stylesheets/workarea/storefront/components/_search_no_results.scss +21 -0
  152. data/app/assets/stylesheets/workarea/storefront/components/_search_results.scss +22 -0
  153. data/app/assets/stylesheets/workarea/storefront/components/_secondary_nav.scss +23 -0
  154. data/app/assets/stylesheets/workarea/storefront/components/_sitemap.scss +9 -0
  155. data/app/assets/stylesheets/workarea/storefront/components/_sitemap_pagination.scss +26 -0
  156. data/app/assets/stylesheets/workarea/storefront/components/_social_networks_content_block.scss +14 -0
  157. data/app/assets/stylesheets/workarea/storefront/components/_style_guide.scss +140 -0
  158. data/app/assets/stylesheets/workarea/storefront/components/_svg_icon.scss +57 -0
  159. data/app/assets/stylesheets/workarea/storefront/components/_table.scss +50 -0
  160. data/app/assets/stylesheets/workarea/storefront/components/_taxonomy_content_block.scss +87 -0
  161. data/app/assets/stylesheets/workarea/storefront/components/_text_box.scss +36 -0
  162. data/app/assets/stylesheets/workarea/storefront/components/_text_button.scss +17 -0
  163. data/app/assets/stylesheets/workarea/storefront/components/_text_content_block.scss +5 -0
  164. data/app/assets/stylesheets/workarea/storefront/components/_value.scss +46 -0
  165. data/app/assets/stylesheets/workarea/storefront/components/_video_and_text_content_block.scss +44 -0
  166. data/app/assets/stylesheets/workarea/storefront/components/_video_content_block.scss +21 -0
  167. data/app/assets/stylesheets/workarea/storefront/components/_view.scss +12 -0
  168. data/app/assets/stylesheets/workarea/storefront/email.scss +4 -0
  169. data/app/assets/stylesheets/workarea/storefront/email/_base.scss +52 -0
  170. data/app/assets/stylesheets/workarea/storefront/email/_components.scss +91 -0
  171. data/app/assets/stylesheets/workarea/storefront/email/_helpers.scss +69 -0
  172. data/app/assets/stylesheets/workarea/storefront/email/_settings.scss +22 -0
  173. data/app/assets/stylesheets/workarea/storefront/generic/_box_sizing.scss +20 -0
  174. data/app/assets/stylesheets/workarea/storefront/generic/_fonts.scss +24 -0
  175. data/app/assets/stylesheets/workarea/storefront/generic/_reset.scss +37 -0
  176. data/app/assets/stylesheets/workarea/storefront/objects/_button_reset.scss +17 -0
  177. data/app/assets/stylesheets/workarea/storefront/objects/_content_preview_visibility.scss +93 -0
  178. data/app/assets/stylesheets/workarea/storefront/objects/_content_wrapper.scss +18 -0
  179. data/app/assets/stylesheets/workarea/storefront/objects/_inline_list.scss +14 -0
  180. data/app/assets/stylesheets/workarea/storefront/objects/_list_reset.scss +10 -0
  181. data/app/assets/stylesheets/workarea/storefront/objects/_text_field_reset.scss +10 -0
  182. data/app/assets/stylesheets/workarea/storefront/settings/_breakpoints.scss.erb +8 -0
  183. data/app/assets/stylesheets/workarea/storefront/settings/_colors.scss +45 -0
  184. data/app/assets/stylesheets/workarea/storefront/settings/_global.scss +25 -0
  185. data/app/assets/stylesheets/workarea/storefront/settings/_grid.scss +36 -0
  186. data/app/assets/stylesheets/workarea/storefront/settings/_typography.scss +18 -0
  187. data/app/assets/stylesheets/workarea/storefront/settings/_z_indexes.scss +29 -0
  188. data/app/assets/stylesheets/workarea/storefront/tools/_center.scss +34 -0
  189. data/app/assets/stylesheets/workarea/storefront/tools/_focus_ring.scss +23 -0
  190. data/app/assets/stylesheets/workarea/storefront/tools/_respond_to.scss +31 -0
  191. data/app/assets/stylesheets/workarea/storefront/tools/_svg.scss +29 -0
  192. data/app/assets/stylesheets/workarea/storefront/trumps/_break_word.scss +9 -0
  193. data/app/assets/stylesheets/workarea/storefront/trumps/_clearfix.scss +13 -0
  194. data/app/assets/stylesheets/workarea/storefront/trumps/_hidden.scss +71 -0
  195. data/app/assets/stylesheets/workarea/storefront/trumps/_hidden_if_js_enabled.scss +10 -0
  196. data/app/assets/stylesheets/workarea/storefront/trumps/_image_replacement.scss +11 -0
  197. data/app/assets/stylesheets/workarea/storefront/trumps/_truncate.scss +10 -0
  198. data/app/assets/stylesheets/workarea/storefront/trumps/_visible.scss +70 -0
  199. data/app/assets/stylesheets/workarea/storefront/trumps/_visually_hidden.scss +14 -0
  200. data/app/assets/stylesheets/workarea/storefront/typography/_align.scss +15 -0
  201. data/app/assets/stylesheets/workarea/storefront/typography/_headings.scss +62 -0
  202. data/app/assets/stylesheets/workarea/storefront/typography/_links.scss +15 -0
  203. data/app/assets/stylesheets/workarea/storefront/typography/_text.scss +26 -0
  204. data/app/controllers/workarea/storefront/analytics_controller.rb +45 -0
  205. data/app/controllers/workarea/storefront/application_controller.rb +50 -0
  206. data/app/controllers/workarea/storefront/cart_items_controller.rb +99 -0
  207. data/app/controllers/workarea/storefront/carts_controller.rb +61 -0
  208. data/app/controllers/workarea/storefront/categories_controller.rb +11 -0
  209. data/app/controllers/workarea/storefront/check_inventory.rb +10 -0
  210. data/app/controllers/workarea/storefront/check_pricing_override.rb +17 -0
  211. data/app/controllers/workarea/storefront/checkout/addresses_controller.rb +58 -0
  212. data/app/controllers/workarea/storefront/checkout/payment_controller.rb +21 -0
  213. data/app/controllers/workarea/storefront/checkout/place_order_controller.rb +65 -0
  214. data/app/controllers/workarea/storefront/checkout/shipping_controller.rb +53 -0
  215. data/app/controllers/workarea/storefront/checkouts_controller.rb +102 -0
  216. data/app/controllers/workarea/storefront/contacts_controller.rb +28 -0
  217. data/app/controllers/workarea/storefront/content_areas_controller.rb +15 -0
  218. data/app/controllers/workarea/storefront/content_blocks_controller.rb +51 -0
  219. data/app/controllers/workarea/storefront/current_checkout.rb +114 -0
  220. data/app/controllers/workarea/storefront/email_signups_controller.rb +19 -0
  221. data/app/controllers/workarea/storefront/errors_controller.rb +58 -0
  222. data/app/controllers/workarea/storefront/http_caching.rb +33 -0
  223. data/app/controllers/workarea/storefront/menus_controller.rb +25 -0
  224. data/app/controllers/workarea/storefront/order_lookup.rb +20 -0
  225. data/app/controllers/workarea/storefront/orders_controller.rb +29 -0
  226. data/app/controllers/workarea/storefront/pages_controller.rb +23 -0
  227. data/app/controllers/workarea/storefront/products_controller.rb +25 -0
  228. data/app/controllers/workarea/storefront/recent_views_controller.rb +51 -0
  229. data/app/controllers/workarea/storefront/recommendations_controller.rb +11 -0
  230. data/app/controllers/workarea/storefront/searches_controller.rb +47 -0
  231. data/app/controllers/workarea/storefront/sitemaps_controller.rb +11 -0
  232. data/app/controllers/workarea/storefront/style_guides_controller.rb +6 -0
  233. data/app/controllers/workarea/storefront/user_activity.rb +17 -0
  234. data/app/controllers/workarea/storefront/users/accounts_controller.rb +91 -0
  235. data/app/controllers/workarea/storefront/users/addresses_controller.rb +49 -0
  236. data/app/controllers/workarea/storefront/users/credit_cards_controller.rb +75 -0
  237. data/app/controllers/workarea/storefront/users/logins_controller.rb +47 -0
  238. data/app/controllers/workarea/storefront/users/orders_controller.rb +30 -0
  239. data/app/controllers/workarea/storefront/users/passwords_controller.rb +65 -0
  240. data/app/helpers/workarea/storefront/admin_helper.rb +13 -0
  241. data/app/helpers/workarea/storefront/analytics_helper.rb +230 -0
  242. data/app/helpers/workarea/storefront/application_helper.rb +79 -0
  243. data/app/helpers/workarea/storefront/content_helper.rb +71 -0
  244. data/app/helpers/workarea/storefront/credit_cards_helper.rb +38 -0
  245. data/app/helpers/workarea/storefront/favicons_helper.rb +25 -0
  246. data/app/helpers/workarea/storefront/locales_helper.rb +27 -0
  247. data/app/helpers/workarea/storefront/navigation_helper.rb +97 -0
  248. data/app/helpers/workarea/storefront/pagination_helper.rb +22 -0
  249. data/app/helpers/workarea/storefront/products_helper.rb +43 -0
  250. data/app/helpers/workarea/storefront/recent_views_helper.rb +9 -0
  251. data/app/helpers/workarea/storefront/users_helper.rb +9 -0
  252. data/app/mailers/workarea/storefront/account_mailer.rb +21 -0
  253. data/app/mailers/workarea/storefront/application_mailer.rb +23 -0
  254. data/app/mailers/workarea/storefront/fulfillment_mailer.rb +47 -0
  255. data/app/mailers/workarea/storefront/inquiry_mailer.rb +10 -0
  256. data/app/mailers/workarea/storefront/order_mailer.rb +31 -0
  257. data/app/mailers/workarea/storefront/payment_mailer.rb +23 -0
  258. data/app/mailers/workarea/storefront/transactional_mailer.rb +17 -0
  259. data/app/view_models/workarea/storefront/cart_item_view_model.rb +11 -0
  260. data/app/view_models/workarea/storefront/cart_recommendations_view_model.rb +13 -0
  261. data/app/view_models/workarea/storefront/cart_view_model.rb +95 -0
  262. data/app/view_models/workarea/storefront/category_view_model.rb +119 -0
  263. data/app/view_models/workarea/storefront/checkout/addresses_view_model.rb +73 -0
  264. data/app/view_models/workarea/storefront/checkout/confirmation_view_model.rb +14 -0
  265. data/app/view_models/workarea/storefront/checkout/payment_view_model.rb +103 -0
  266. data/app/view_models/workarea/storefront/checkout/shipping_view_model.rb +13 -0
  267. data/app/view_models/workarea/storefront/checkout/summary_view_model.rb +89 -0
  268. data/app/view_models/workarea/storefront/checkout_content.rb +11 -0
  269. data/app/view_models/workarea/storefront/content_block_view_model.rb +62 -0
  270. data/app/view_models/workarea/storefront/content_blocks/category_summary_view_model.rb +52 -0
  271. data/app/view_models/workarea/storefront/content_blocks/hero_view_model.rb +23 -0
  272. data/app/view_models/workarea/storefront/content_blocks/image_group_view_model.rb +24 -0
  273. data/app/view_models/workarea/storefront/content_blocks/navigation_view_model.rb +32 -0
  274. data/app/view_models/workarea/storefront/content_blocks/product_insights_view_model.rb +46 -0
  275. data/app/view_models/workarea/storefront/content_blocks/product_list_view_model.rb +20 -0
  276. data/app/view_models/workarea/storefront/content_blocks/taxonomy_view_model.rb +17 -0
  277. data/app/view_models/workarea/storefront/content_blocks/video_view_model.rb +58 -0
  278. data/app/view_models/workarea/storefront/content_view_model.rb +11 -0
  279. data/app/view_models/workarea/storefront/credit_card_view_model.rb +7 -0
  280. data/app/view_models/workarea/storefront/detail_page_recommendations_view_model.rb +13 -0
  281. data/app/view_models/workarea/storefront/display_content.rb +56 -0
  282. data/app/view_models/workarea/storefront/email_recommendations_view_model.rb +13 -0
  283. data/app/view_models/workarea/storefront/email_signups_view_model.rb +18 -0
  284. data/app/view_models/workarea/storefront/fulfillment_item_view_model.rb +13 -0
  285. data/app/view_models/workarea/storefront/inquiry_view_model.rb +22 -0
  286. data/app/view_models/workarea/storefront/inventory_status_view_model.rb +27 -0
  287. data/app/view_models/workarea/storefront/menu_view_model.rb +7 -0
  288. data/app/view_models/workarea/storefront/option_set_view_model.rb +59 -0
  289. data/app/view_models/workarea/storefront/order_item_view_model.rb +83 -0
  290. data/app/view_models/workarea/storefront/order_pricing.rb +37 -0
  291. data/app/view_models/workarea/storefront/order_view_model.rb +144 -0
  292. data/app/view_models/workarea/storefront/package_view_model.rb +20 -0
  293. data/app/view_models/workarea/storefront/page_view_model.rb +11 -0
  294. data/app/view_models/workarea/storefront/pagination.rb +42 -0
  295. data/app/view_models/workarea/storefront/personalized_recommendations_view_model.rb +13 -0
  296. data/app/view_models/workarea/storefront/product_browsing.rb +33 -0
  297. data/app/view_models/workarea/storefront/product_templates/option_selects_view_model.rb +7 -0
  298. data/app/view_models/workarea/storefront/product_templates/option_thumbnails_view_model.rb +15 -0
  299. data/app/view_models/workarea/storefront/product_view_model.rb +183 -0
  300. data/app/view_models/workarea/storefront/product_view_model/cache_key.rb +44 -0
  301. data/app/view_models/workarea/storefront/product_view_model/image_collection.rb +58 -0
  302. data/app/view_models/workarea/storefront/product_view_model/option.rb +24 -0
  303. data/app/view_models/workarea/storefront/product_view_model/option_set.rb +97 -0
  304. data/app/view_models/workarea/storefront/product_view_model/sku_options.rb +53 -0
  305. data/app/view_models/workarea/storefront/recommendations_view_model.rb +39 -0
  306. data/app/view_models/workarea/storefront/refund_view_model.rb +16 -0
  307. data/app/view_models/workarea/storefront/search_content.rb +19 -0
  308. data/app/view_models/workarea/storefront/search_customization_content.rb +15 -0
  309. data/app/view_models/workarea/storefront/search_customization_view_model.rb +7 -0
  310. data/app/view_models/workarea/storefront/search_suggestion_view_model.rb +87 -0
  311. data/app/view_models/workarea/storefront/search_view_model.rb +50 -0
  312. data/app/view_models/workarea/storefront/shipping_view_model.rb +27 -0
  313. data/app/view_models/workarea/storefront/taxon_lookup.rb +37 -0
  314. data/app/view_models/workarea/storefront/user_activity_view_model.rb +41 -0
  315. data/app/view_models/workarea/storefront/user_view_model.rb +55 -0
  316. data/app/views/layouts/workarea/storefront/application.html.haml +175 -0
  317. data/app/views/layouts/workarea/storefront/checkout.html.haml +89 -0
  318. data/app/views/layouts/workarea/storefront/content_preview.html.haml +46 -0
  319. data/app/views/layouts/workarea/storefront/email.html.haml +193 -0
  320. data/app/views/layouts/workarea/storefront/empty.html.haml +48 -0
  321. data/app/views/layouts/workarea/storefront/navigation.html.haml +48 -0
  322. data/app/views/workarea/storefront/account_mailer/creation.html.haml +15 -0
  323. data/app/views/workarea/storefront/account_mailer/password_reset.html.haml +12 -0
  324. data/app/views/workarea/storefront/cart_items/create.html.haml +71 -0
  325. data/app/views/workarea/storefront/carts/_pricing.html.haml +14 -0
  326. data/app/views/workarea/storefront/carts/show.html.haml +183 -0
  327. data/app/views/workarea/storefront/categories/show.html.haml +103 -0
  328. data/app/views/workarea/storefront/checkouts/_checkout_progress.html.haml +6 -0
  329. data/app/views/workarea/storefront/checkouts/_summary.html.haml +102 -0
  330. data/app/views/workarea/storefront/checkouts/addresses.html.haml +56 -0
  331. data/app/views/workarea/storefront/checkouts/confirmation.html.haml +37 -0
  332. data/app/views/workarea/storefront/checkouts/payment.html.haml +184 -0
  333. data/app/views/workarea/storefront/checkouts/shipping.html.haml +39 -0
  334. data/app/views/workarea/storefront/checkouts/summary.html.haml +1 -0
  335. data/app/views/workarea/storefront/contacts/show.html.haml +41 -0
  336. data/app/views/workarea/storefront/content_areas/show.html.haml +6 -0
  337. data/app/views/workarea/storefront/content_blocks/_button.html.haml +5 -0
  338. data/app/views/workarea/storefront/content_blocks/_category_summary.html.haml +15 -0
  339. data/app/views/workarea/storefront/content_blocks/_divider.html.haml +2 -0
  340. data/app/views/workarea/storefront/content_blocks/_hero.html.haml +3 -0
  341. data/app/views/workarea/storefront/content_blocks/_html.html.haml +1 -0
  342. data/app/views/workarea/storefront/content_blocks/_image.html.haml +2 -0
  343. data/app/views/workarea/storefront/content_blocks/_image_and_text.html.haml +4 -0
  344. data/app/views/workarea/storefront/content_blocks/_image_group.html.haml +10 -0
  345. data/app/views/workarea/storefront/content_blocks/_product_insights.html.haml +10 -0
  346. data/app/views/workarea/storefront/content_blocks/_product_list.html.haml +10 -0
  347. data/app/views/workarea/storefront/content_blocks/_quote.html.haml +4 -0
  348. data/app/views/workarea/storefront/content_blocks/_recommendations.html.haml +1 -0
  349. data/app/views/workarea/storefront/content_blocks/_social_networks.html.haml +17 -0
  350. data/app/views/workarea/storefront/content_blocks/_taxonomy.html.haml +27 -0
  351. data/app/views/workarea/storefront/content_blocks/_text.html.haml +1 -0
  352. data/app/views/workarea/storefront/content_blocks/_three_column_taxonomy.html.haml +28 -0
  353. data/app/views/workarea/storefront/content_blocks/_two_column_taxonomy.html.haml +28 -0
  354. data/app/views/workarea/storefront/content_blocks/_video.html.haml +2 -0
  355. data/app/views/workarea/storefront/content_blocks/_video_and_text.html.haml +4 -0
  356. data/app/views/workarea/storefront/content_blocks/show.html.haml +1 -0
  357. data/app/views/workarea/storefront/email_signups/show.html.haml +12 -0
  358. data/app/views/workarea/storefront/errors/show.html.haml +12 -0
  359. data/app/views/workarea/storefront/facets/_range.html.haml +11 -0
  360. data/app/views/workarea/storefront/facets/_terms.html.haml +11 -0
  361. data/app/views/workarea/storefront/favicons/_tags.html.haml +8 -0
  362. data/app/views/workarea/storefront/fulfillment_mailer/canceled.html.haml +34 -0
  363. data/app/views/workarea/storefront/fulfillment_mailer/shipped.html.haml +92 -0
  364. data/app/views/workarea/storefront/inquiry_mailer/created.html.haml +27 -0
  365. data/app/views/workarea/storefront/mailers/_recommendations.html.haml +22 -0
  366. data/app/views/workarea/storefront/menus/index.html.haml +12 -0
  367. data/app/views/workarea/storefront/menus/show.html.haml +6 -0
  368. data/app/views/workarea/storefront/order_mailer/_summary.html.haml +209 -0
  369. data/app/views/workarea/storefront/order_mailer/confirmation.html.haml +15 -0
  370. data/app/views/workarea/storefront/order_mailer/reminder.html.haml +34 -0
  371. data/app/views/workarea/storefront/order_mailer/tenders/_credit_card.html.haml +4 -0
  372. data/app/views/workarea/storefront/order_mailer/tenders/_store_credit.html.haml +2 -0
  373. data/app/views/workarea/storefront/orders/_summary.html.haml +274 -0
  374. data/app/views/workarea/storefront/orders/index.html.haml +40 -0
  375. data/app/views/workarea/storefront/orders/show.html.haml +16 -0
  376. data/app/views/workarea/storefront/orders/tenders/_credit_card.html.haml +9 -0
  377. data/app/views/workarea/storefront/orders/tenders/_store_credit.html.haml +6 -0
  378. data/app/views/workarea/storefront/pages/accessibility.html.haml +53 -0
  379. data/app/views/workarea/storefront/pages/browser_config.xml.builder +9 -0
  380. data/app/views/workarea/storefront/pages/home_page.html.haml +20 -0
  381. data/app/views/workarea/storefront/pages/robots.text.erb +17 -0
  382. data/app/views/workarea/storefront/pages/show.html.haml +28 -0
  383. data/app/views/workarea/storefront/pages/templates/_generic.html.haml +1 -0
  384. data/app/views/workarea/storefront/pages/templates/_test.html.haml +1 -0
  385. data/app/views/workarea/storefront/pages/web_manifest.json.jbuilder +11 -0
  386. data/app/views/workarea/storefront/payment_mailer/refunded.html.haml +13 -0
  387. data/app/views/workarea/storefront/products/_price.html.haml +4 -0
  388. data/app/views/workarea/storefront/products/_pricing.html.haml +34 -0
  389. data/app/views/workarea/storefront/products/_summary.html.haml +12 -0
  390. data/app/views/workarea/storefront/products/details.html.haml +2 -0
  391. data/app/views/workarea/storefront/products/show.html.haml +48 -0
  392. data/app/views/workarea/storefront/products/templates/_generic.html.haml +69 -0
  393. data/app/views/workarea/storefront/products/templates/_option_selects.html.haml +70 -0
  394. data/app/views/workarea/storefront/products/templates/_option_thumbnails.html.haml +76 -0
  395. data/app/views/workarea/storefront/products/templates/_test.html.haml +1 -0
  396. data/app/views/workarea/storefront/recent_views/aside.html.haml +25 -0
  397. data/app/views/workarea/storefront/recent_views/narrow.html.haml +25 -0
  398. data/app/views/workarea/storefront/recent_views/show.html.haml +27 -0
  399. data/app/views/workarea/storefront/recommendations/show.html.haml +12 -0
  400. data/app/views/workarea/storefront/searches/index.json.jbuilder +1 -0
  401. data/app/views/workarea/storefront/searches/no_results.html.haml +31 -0
  402. data/app/views/workarea/storefront/searches/show.html.haml +99 -0
  403. data/app/views/workarea/storefront/shared/_address_fields.html.haml +105 -0
  404. data/app/views/workarea/storefront/shared/_left_navigation.html.haml +24 -0
  405. data/app/views/workarea/storefront/shared/_message.html.haml +4 -0
  406. data/app/views/workarea/storefront/sitemaps/_pagination.html.haml +37 -0
  407. data/app/views/workarea/storefront/sitemaps/show.html.haml +36 -0
  408. data/app/views/workarea/storefront/style_guides/_navigation.html.haml +11 -0
  409. data/app/views/workarea/storefront/style_guides/base/_forms.html.haml +82 -0
  410. data/app/views/workarea/storefront/style_guides/base/_tables.html.haml +63 -0
  411. data/app/views/workarea/storefront/style_guides/components/_box.html.haml +26 -0
  412. data/app/views/workarea/storefront/style_guides/components/_breadcrumbs.html.haml +12 -0
  413. data/app/views/workarea/storefront/style_guides/components/_button.html.haml +50 -0
  414. data/app/views/workarea/storefront/style_guides/components/_button_content_block.html.haml +20 -0
  415. data/app/views/workarea/storefront/style_guides/components/_button_property.html.haml +83 -0
  416. data/app/views/workarea/storefront/style_guides/components/_category_summary_content_block.html.haml +29 -0
  417. data/app/views/workarea/storefront/style_guides/components/_data_card.html.haml +215 -0
  418. data/app/views/workarea/storefront/style_guides/components/_divider_content_block.html.haml +40 -0
  419. data/app/views/workarea/storefront/style_guides/components/_hero_content_block.html.haml +29 -0
  420. data/app/views/workarea/storefront/style_guides/components/_html_content_block.html.haml +10 -0
  421. data/app/views/workarea/storefront/style_guides/components/_image_and_text_content_block.html.haml +28 -0
  422. data/app/views/workarea/storefront/style_guides/components/_image_content_block.html.haml +38 -0
  423. data/app/views/workarea/storefront/style_guides/components/_image_group_content_block.html.haml +17 -0
  424. data/app/views/workarea/storefront/style_guides/components/_inline_form.html.haml +18 -0
  425. data/app/views/workarea/storefront/style_guides/components/_loading.html.haml +106 -0
  426. data/app/views/workarea/storefront/style_guides/components/_message.html.haml +45 -0
  427. data/app/views/workarea/storefront/style_guides/components/_mobile_filters.html.haml +17 -0
  428. data/app/views/workarea/storefront/style_guides/components/_pagination.html.haml +24 -0
  429. data/app/views/workarea/storefront/style_guides/components/_payment_icon.html.haml +19 -0
  430. data/app/views/workarea/storefront/style_guides/components/_personalized_recommendations_content_block.html.haml +32 -0
  431. data/app/views/workarea/storefront/style_guides/components/_product_insights_content_block.html.haml +32 -0
  432. data/app/views/workarea/storefront/style_guides/components/_product_list.html.haml +302 -0
  433. data/app/views/workarea/storefront/style_guides/components/_product_list_content_block.html.haml +32 -0
  434. data/app/views/workarea/storefront/style_guides/components/_product_prices.html.haml +79 -0
  435. data/app/views/workarea/storefront/style_guides/components/_product_summary.html.haml +35 -0
  436. data/app/views/workarea/storefront/style_guides/components/_property.html.haml +93 -0
  437. data/app/views/workarea/storefront/style_guides/components/_quote_content_block.html.haml +18 -0
  438. data/app/views/workarea/storefront/style_guides/components/_recommendations.html.haml +34 -0
  439. data/app/views/workarea/storefront/style_guides/components/_social_networks_content_block.html.haml +20 -0
  440. data/app/views/workarea/storefront/style_guides/components/_svg_icon.html.haml +51 -0
  441. data/app/views/workarea/storefront/style_guides/components/_table.html.haml +112 -0
  442. data/app/views/workarea/storefront/style_guides/components/_taxonomy_content_block.html.haml +205 -0
  443. data/app/views/workarea/storefront/style_guides/components/_text_box.html.haml +73 -0
  444. data/app/views/workarea/storefront/style_guides/components/_text_button.html.haml +26 -0
  445. data/app/views/workarea/storefront/style_guides/components/_text_content_block.html.haml +10 -0
  446. data/app/views/workarea/storefront/style_guides/components/_ui_autocomplete.html.haml +11 -0
  447. data/app/views/workarea/storefront/style_guides/components/_ui_dialog.html.haml +5 -0
  448. data/app/views/workarea/storefront/style_guides/components/_ui_dialog_image.html.haml +5 -0
  449. data/app/views/workarea/storefront/style_guides/components/_ui_helper_hidden_accessible.html.haml +6 -0
  450. data/app/views/workarea/storefront/style_guides/components/_value.html.haml +70 -0
  451. data/app/views/workarea/storefront/style_guides/components/_video_and_text_content_block.html.haml +21 -0
  452. data/app/views/workarea/storefront/style_guides/components/_video_content_block.html.haml +11 -0
  453. data/app/views/workarea/storefront/style_guides/index.html.haml +87 -0
  454. data/app/views/workarea/storefront/style_guides/objects/_button_reset.html.haml +17 -0
  455. data/app/views/workarea/storefront/style_guides/objects/_inline_list.html.haml +20 -0
  456. data/app/views/workarea/storefront/style_guides/objects/_list_reset.html.haml +20 -0
  457. data/app/views/workarea/storefront/style_guides/objects/_text_field_reset.html.haml +11 -0
  458. data/app/views/workarea/storefront/style_guides/settings/_color_variables.html.haml +21 -0
  459. data/app/views/workarea/storefront/style_guides/show.html.haml +10 -0
  460. data/app/views/workarea/storefront/style_guides/trumps/_break_word.html.haml +15 -0
  461. data/app/views/workarea/storefront/style_guides/trumps/_clearfix.html.haml +21 -0
  462. data/app/views/workarea/storefront/style_guides/trumps/_hidden.html.haml +97 -0
  463. data/app/views/workarea/storefront/style_guides/trumps/_hidden_if_js_enabled.html.haml +17 -0
  464. data/app/views/workarea/storefront/style_guides/trumps/_image_replacement.html.haml +13 -0
  465. data/app/views/workarea/storefront/style_guides/trumps/_truncate.html.haml +13 -0
  466. data/app/views/workarea/storefront/style_guides/trumps/_visible.html.haml +97 -0
  467. data/app/views/workarea/storefront/style_guides/trumps/_visually_hidden.html.haml +17 -0
  468. data/app/views/workarea/storefront/style_guides/typography/_align.html.haml +25 -0
  469. data/app/views/workarea/storefront/style_guides/typography/_fonts.html.haml +9 -0
  470. data/app/views/workarea/storefront/style_guides/typography/_headings.html.haml +25 -0
  471. data/app/views/workarea/storefront/style_guides/typography/_links.html.haml +13 -0
  472. data/app/views/workarea/storefront/style_guides/typography/_text.html.haml +23 -0
  473. data/app/views/workarea/storefront/users/accounts/edit.html.haml +42 -0
  474. data/app/views/workarea/storefront/users/accounts/show.html.haml +118 -0
  475. data/app/views/workarea/storefront/users/addresses/edit.html.haml +24 -0
  476. data/app/views/workarea/storefront/users/addresses/new.html.haml +24 -0
  477. data/app/views/workarea/storefront/users/credit_cards/edit.html.haml +65 -0
  478. data/app/views/workarea/storefront/users/credit_cards/new.html.haml +58 -0
  479. data/app/views/workarea/storefront/users/current_user.json.jbuilder +8 -0
  480. data/app/views/workarea/storefront/users/logins/new.html.haml +51 -0
  481. data/app/views/workarea/storefront/users/orders/_summary.html.haml +23 -0
  482. data/app/views/workarea/storefront/users/orders/index.html.haml +21 -0
  483. data/app/views/workarea/storefront/users/orders/show.html.haml +19 -0
  484. data/app/views/workarea/storefront/users/passwords/change.html.haml +21 -0
  485. data/app/views/workarea/storefront/users/passwords/edit.html.haml +13 -0
  486. data/app/views/workarea/storefront/users/passwords/new.html.haml +24 -0
  487. data/bin/rails +18 -0
  488. data/config/locales/en.yml +403 -0
  489. data/config/routes.rb +110 -0
  490. data/lib/workarea/mailer_previews/storefront/account_mailer_preview.rb +16 -0
  491. data/lib/workarea/mailer_previews/storefront/fulfillment_mailer_preview.rb +27 -0
  492. data/lib/workarea/mailer_previews/storefront/inquiry_mailer_preview.rb +9 -0
  493. data/lib/workarea/mailer_previews/storefront/order_mailer_preview.rb +16 -0
  494. data/lib/workarea/mailer_previews/storefront/payment_mailer_preview.rb +9 -0
  495. data/lib/workarea/storefront.rb +7 -0
  496. data/lib/workarea/storefront/engine.rb +8 -0
  497. data/test/dummy/README.rdoc +28 -0
  498. data/test/dummy/Rakefile +6 -0
  499. data/test/dummy/app/assets/images/.keep +0 -0
  500. data/test/dummy/app/assets/javascripts/application.js +13 -0
  501. data/test/dummy/app/assets/stylesheets/application.css +15 -0
  502. data/test/dummy/app/controllers/application_controller.rb +5 -0
  503. data/test/dummy/app/controllers/concerns/.keep +0 -0
  504. data/test/dummy/app/helpers/application_helper.rb +2 -0
  505. data/test/dummy/app/mailers/.keep +0 -0
  506. data/test/dummy/app/models/.keep +0 -0
  507. data/test/dummy/app/models/concerns/.keep +0 -0
  508. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  509. data/test/dummy/bin/bundle +3 -0
  510. data/test/dummy/bin/rails +5 -0
  511. data/test/dummy/bin/rake +4 -0
  512. data/test/dummy/bin/setup +34 -0
  513. data/test/dummy/bin/update +29 -0
  514. data/test/dummy/config.ru +4 -0
  515. data/test/dummy/config/application.rb +22 -0
  516. data/test/dummy/config/boot.rb +5 -0
  517. data/test/dummy/config/cable.yml +9 -0
  518. data/test/dummy/config/environment.rb +5 -0
  519. data/test/dummy/config/environments/development.rb +51 -0
  520. data/test/dummy/config/environments/production.rb +86 -0
  521. data/test/dummy/config/environments/test.rb +43 -0
  522. data/test/dummy/config/initializers/application_controller_renderer.rb +6 -0
  523. data/test/dummy/config/initializers/assets.rb +11 -0
  524. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  525. data/test/dummy/config/initializers/cookies_serializer.rb +5 -0
  526. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  527. data/test/dummy/config/initializers/inflections.rb +16 -0
  528. data/test/dummy/config/initializers/mime_types.rb +4 -0
  529. data/test/dummy/config/initializers/new_framework_defaults.rb +17 -0
  530. data/test/dummy/config/initializers/session_store.rb +3 -0
  531. data/test/dummy/config/initializers/workarea.rb +8 -0
  532. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  533. data/test/dummy/config/locales/en.yml +23 -0
  534. data/test/dummy/config/puma.rb +47 -0
  535. data/test/dummy/config/routes.rb +8 -0
  536. data/test/dummy/config/secrets.yml +22 -0
  537. data/test/dummy/config/spring.rb +6 -0
  538. data/test/dummy/db/seeds.rb +10 -0
  539. data/test/dummy/lib/assets/.keep +0 -0
  540. data/test/dummy/log/.keep +0 -0
  541. data/test/dummy/public/404.html +67 -0
  542. data/test/dummy/public/422.html +67 -0
  543. data/test/dummy/public/500.html +66 -0
  544. data/test/dummy/public/favicon.ico +1 -0
  545. data/test/helpers/workarea/storefront/application_helper_test.rb +25 -0
  546. data/test/helpers/workarea/storefront/content_helper_test.rb +50 -0
  547. data/test/helpers/workarea/storefront/credit_cards_helper_test.rb +29 -0
  548. data/test/helpers/workarea/storefront/navigation_helper_test.rb +85 -0
  549. data/test/helpers/workarea/storefront/pagination_helper_test.rb +27 -0
  550. data/test/helpers/workarea/storefront/products_helper_test.rb +43 -0
  551. data/test/integration/workarea/storefront/accounts_integration_test.rb +128 -0
  552. data/test/integration/workarea/storefront/analytics_integration_test.rb +32 -0
  553. data/test/integration/workarea/storefront/browse_images_integration_test.rb +71 -0
  554. data/test/integration/workarea/storefront/cart_integration_test.rb +109 -0
  555. data/test/integration/workarea/storefront/cart_items_integration_test.rb +330 -0
  556. data/test/integration/workarea/storefront/categories_integration_test.rb +21 -0
  557. data/test/integration/workarea/storefront/checkout_side_effects_integration_test.rb +214 -0
  558. data/test/integration/workarea/storefront/checkout_with_pricing_override_integration_test.rb +168 -0
  559. data/test/integration/workarea/storefront/checkouts_integration_test.rb +267 -0
  560. data/test/integration/workarea/storefront/contact_form_integration_test.rb +33 -0
  561. data/test/integration/workarea/storefront/content_blocks_integration_test.rb +71 -0
  562. data/test/integration/workarea/storefront/current_checkout_integration_test.rb +30 -0
  563. data/test/integration/workarea/storefront/current_user_integration_test.rb +28 -0
  564. data/test/integration/workarea/storefront/email_signups_integration_test.rb +25 -0
  565. data/test/integration/workarea/storefront/errors_integration_test.rb +137 -0
  566. data/test/integration/workarea/storefront/favicons_integration_test.rb +16 -0
  567. data/test/integration/workarea/storefront/guest_browsing_integration_test.rb +24 -0
  568. data/test/integration/workarea/storefront/head_tags_integration_test.rb +127 -0
  569. data/test/integration/workarea/storefront/health_check_integration_test.rb +13 -0
  570. data/test/integration/workarea/storefront/host_integration_test.rb +32 -0
  571. data/test/integration/workarea/storefront/impersonations_integration_test.rb +128 -0
  572. data/test/integration/workarea/storefront/layout_integration_test.rb +29 -0
  573. data/test/integration/workarea/storefront/login_integration_test.rb +157 -0
  574. data/test/integration/workarea/storefront/order_data_integration_test.rb +264 -0
  575. data/test/integration/workarea/storefront/order_lookup_integration_test.rb +117 -0
  576. data/test/integration/workarea/storefront/pages_integration_test.rb +56 -0
  577. data/test/integration/workarea/storefront/place_order_integration_test.rb +140 -0
  578. data/test/integration/workarea/storefront/placing_order_integration_test.rb +92 -0
  579. data/test/integration/workarea/storefront/products_integration_test.rb +36 -0
  580. data/test/integration/workarea/storefront/search_integration_test.rb +128 -0
  581. data/test/integration/workarea/storefront/store_credit_integration_test.rb +121 -0
  582. data/test/integration/workarea/storefront/users/addresses_integration_test.rb +136 -0
  583. data/test/integration/workarea/storefront/users/credit_cards_integration_test.rb +96 -0
  584. data/test/integration/workarea/storefront/users/orders_integration_test.rb +15 -0
  585. data/test/integration/workarea/storefront/users/passwords_integration_test.rb +48 -0
  586. data/test/javascripts/address_region_fields_spec.js +46 -0
  587. data/test/javascripts/analytics_spec.js +91 -0
  588. data/test/javascripts/authenticity_token_spec.js +26 -0
  589. data/test/javascripts/back_to_top_button_spec.js +41 -0
  590. data/test/javascripts/break_points_spec.js +41 -0
  591. data/test/javascripts/checkout_primary_payments_spec.js +32 -0
  592. data/test/javascripts/dialog_spec.js +347 -0
  593. data/test/javascripts/fixtures/address_region_fields.html.haml +17 -0
  594. data/test/javascripts/fixtures/analytics_add_to_cart_form.html.haml +12 -0
  595. data/test/javascripts/fixtures/analytics_product_click.html.haml +7 -0
  596. data/test/javascripts/fixtures/authenticity_token.html.haml +2 -0
  597. data/test/javascripts/fixtures/back_to_top_button.html.haml +2 -0
  598. data/test/javascripts/fixtures/checkout_primary_payments.html.haml +12 -0
  599. data/test/javascripts/fixtures/dialog.html.haml +16 -0
  600. data/test/javascripts/fixtures/form.html.haml +10 -0
  601. data/test/javascripts/fixtures/optional_fields.html.haml +4 -0
  602. data/test/javascripts/fixtures/popup_button.html.haml +1 -0
  603. data/test/javascripts/fixtures/product_details_sku_select.html.haml +8 -0
  604. data/test/javascripts/fixtures/product_details_sku_select_without_sku_option_details.html.haml +7 -0
  605. data/test/javascripts/fixtures/scroll_to_element.html.haml +19 -0
  606. data/test/javascripts/forms_spec.js +85 -0
  607. data/test/javascripts/messages_spec.js +50 -0
  608. data/test/javascripts/optional_fields_spec.js +20 -0
  609. data/test/javascripts/popup_button_spec.js +19 -0
  610. data/test/javascripts/product_details_sku_selects_spec.js +154 -0
  611. data/test/javascripts/scroll_to_buttons_spec.js +46 -0
  612. data/test/javascripts/spec_helper.js +2 -0
  613. data/test/javascripts/traffic_referrer_spec.js +33 -0
  614. data/test/mailers/workarea/storefront/transactional_mailer_test.rb +29 -0
  615. data/test/performance/workarea/storefront/cart_performance_test.rb +52 -0
  616. data/test/performance/workarea/storefront/categories_performance_test.rb +26 -0
  617. data/test/performance/workarea/storefront/pages_performance_test.rb +31 -0
  618. data/test/performance/workarea/storefront/products_performance_test.rb +19 -0
  619. data/test/performance/workarea/storefront/search_performance_test.rb +27 -0
  620. data/test/system/workarea/storefront/accounts_system_test.rb +97 -0
  621. data/test/system/workarea/storefront/addresses_system_test.rb +60 -0
  622. data/test/system/workarea/storefront/analytics_system_test.rb +725 -0
  623. data/test/system/workarea/storefront/cart_items_system_test.rb +117 -0
  624. data/test/system/workarea/storefront/cart_system_test.rb +93 -0
  625. data/test/system/workarea/storefront/categories_system_test.rb +258 -0
  626. data/test/system/workarea/storefront/content_system_test.rb +114 -0
  627. data/test/system/workarea/storefront/credit_cards_system_test.rb +77 -0
  628. data/test/system/workarea/storefront/customer_service_system_test.rb +21 -0
  629. data/test/system/workarea/storefront/digital_products_system_test.rb +140 -0
  630. data/test/system/workarea/storefront/discounting_multiple_system_test.rb +87 -0
  631. data/test/system/workarea/storefront/discounting_system_test.rb +292 -0
  632. data/test/system/workarea/storefront/email_signup_system_test.rb +19 -0
  633. data/test/system/workarea/storefront/fulfillment_system_test.rb +78 -0
  634. data/test/system/workarea/storefront/guest_checkout_system_test.rb +426 -0
  635. data/test/system/workarea/storefront/logged_in_checkout_system_test.rb +336 -0
  636. data/test/system/workarea/storefront/login_system_test.rb +157 -0
  637. data/test/system/workarea/storefront/navigation_system_test.rb +73 -0
  638. data/test/system/workarea/storefront/no_js_system_test.rb +84 -0
  639. data/test/system/workarea/storefront/orders_system_test.rb +84 -0
  640. data/test/system/workarea/storefront/pages_system_test.rb +61 -0
  641. data/test/system/workarea/storefront/pagination_system_test.rb +129 -0
  642. data/test/system/workarea/storefront/passwords_system_test.rb +158 -0
  643. data/test/system/workarea/storefront/pricing_overrides_system_test.rb +45 -0
  644. data/test/system/workarea/storefront/products_system_test.rb +241 -0
  645. data/test/system/workarea/storefront/recommendations_system_test.rb +85 -0
  646. data/test/system/workarea/storefront/release_browsing_system_test.rb +73 -0
  647. data/test/system/workarea/storefront/search_system_test.rb +267 -0
  648. data/test/system/workarea/storefront/sitemap_system_test.rb +57 -0
  649. data/test/system/workarea/storefront/store_credit_system_test.rb +166 -0
  650. data/test/system/workarea/storefront/style_guides_system_test.rb +16 -0
  651. data/test/teaspoon_env.rb +10 -0
  652. data/test/test_helper.rb +10 -0
  653. data/test/view_models/workarea/storefront/cart_view_model_test.rb +36 -0
  654. data/test/view_models/workarea/storefront/category_view_model_test.rb +59 -0
  655. data/test/view_models/workarea/storefront/checkout/addresses_view_model_test.rb +16 -0
  656. data/test/view_models/workarea/storefront/checkout/payment_view_model_test.rb +76 -0
  657. data/test/view_models/workarea/storefront/checkout/summary_view_model_test.rb +29 -0
  658. data/test/view_models/workarea/storefront/content_block_view_model_test.rb +86 -0
  659. data/test/view_models/workarea/storefront/content_blocks/category_summary_view_model_test.rb +35 -0
  660. data/test/view_models/workarea/storefront/content_blocks/navigation_view_model_test.rb +53 -0
  661. data/test/view_models/workarea/storefront/content_blocks/product_insights_view_model_test.rb +73 -0
  662. data/test/view_models/workarea/storefront/content_blocks/product_list_view_model_test.rb +24 -0
  663. data/test/view_models/workarea/storefront/content_blocks/taxonomy_view_model_test.rb +81 -0
  664. data/test/view_models/workarea/storefront/content_blocks/video_view_model_test.rb +89 -0
  665. data/test/view_models/workarea/storefront/display_content_test.rb +105 -0
  666. data/test/view_models/workarea/storefront/fulfillment_item_view_model_test.rb +18 -0
  667. data/test/view_models/workarea/storefront/inventory_status_view_model_test.rb +39 -0
  668. data/test/view_models/workarea/storefront/option_set_view_model_test.rb +158 -0
  669. data/test/view_models/workarea/storefront/order_item_view_model_test.rb +49 -0
  670. data/test/view_models/workarea/storefront/order_view_model_test.rb +84 -0
  671. data/test/view_models/workarea/storefront/package_view_model_test.rb +32 -0
  672. data/test/view_models/workarea/storefront/product_templates/option_thumbnails_view_model_test.rb +25 -0
  673. data/test/view_models/workarea/storefront/product_view_model/cache_key_test.rb +16 -0
  674. data/test/view_models/workarea/storefront/product_view_model/image_collection_test.rb +93 -0
  675. data/test/view_models/workarea/storefront/product_view_model/option_set_test.rb +379 -0
  676. data/test/view_models/workarea/storefront/product_view_model/sku_options_test.rb +35 -0
  677. data/test/view_models/workarea/storefront/product_view_model_test.rb +235 -0
  678. data/test/view_models/workarea/storefront/recommendations_view_model_test.rb +62 -0
  679. data/test/view_models/workarea/storefront/refund_view_model_test.rb +23 -0
  680. data/test/view_models/workarea/storefront/search_suggestion_view_model_test.rb +42 -0
  681. data/test/view_models/workarea/storefront/search_view_model_test.rb +57 -0
  682. data/test/view_models/workarea/storefront/shipping_view_model_test.rb +29 -0
  683. data/test/view_models/workarea/storefront/user_activity_view_model_test.rb +65 -0
  684. data/test/view_models/workarea/storefront/user_view_model_test.rb +35 -0
  685. data/workarea-storefront.gemspec +16 -0
  686. metadata +742 -0
@@ -0,0 +1,73 @@
1
+ #text-box.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'text_box')
4
+
5
+ %p Provides uniform styling for <code>input</code> elements.
6
+
7
+ .style-guide__example-block
8
+ = text_field_tag 'wl_text_box_blank', nil, class: 'text-box'
9
+ .style-guide__example-block
10
+ = text_field_tag 'wl_text_box_placeholder', nil, class: 'text-box', placeholder: 'Placeholder'
11
+ .style-guide__example-block
12
+ = text_field_tag 'wl_text_box_value', 'Value', class: 'text-box'
13
+ .style-guide__example-block
14
+ = number_field_tag 'wl_text_box_number', 99, class: 'text-box'
15
+
16
+ %p should style the disabled state:
17
+ .style-guide__example-block
18
+ = text_field_tag 'wl_disabled_text_box_blank', nil, class: 'text-box', disabled: true
19
+ .style-guide__example-block
20
+ = text_field_tag 'wl_disabled_text_box_placeholder', nil, class: 'text-box', placeholder: 'Placeholder', disabled: true
21
+ .style-guide__example-block
22
+ = text_field_tag 'wl_disabled_text_box_value', 'Value', class: 'text-box', disabled: true
23
+ .style-guide__example-block
24
+ = number_field_tag 'wl_disabled_text_box_number', 99, class: 'text-box', disabled: true
25
+
26
+ #text-box--multi-line.style-guide__subsection
27
+
28
+ %h3= link_to_style_guide('components', 'text_box__multi_line')
29
+
30
+ %p Increases the height of a #{link_to_style_guide('components', 'text_box', true)}. Typically used with <code>textarea</code> elements.
31
+
32
+ .style-guide__example-block
33
+ = text_area_tag 'wl_text_box_multi_line_blank', nil, class: 'text-box text-box--multi-line'
34
+ .style-guide__example-block
35
+ = text_area_tag 'wl_text_box_multi_line_placeholder', nil, class: 'text-box text-box--multi-line', placeholder: 'Placeholder'
36
+ .style-guide__example-block
37
+ = text_area_tag 'wl_text_box_multi_line_value', "Value line 1\nValue line 2\nValue line 3\nValue line 4\nValue line 5\nValue line 6", class: 'text-box text-box--multi-line'
38
+
39
+ #text-box--small.style-guide__subsection
40
+
41
+ %h3= link_to_style_guide('components', 'text_box__small')
42
+
43
+ %p Reduces width of a #{link_to_style_guide('components', 'text_box', true)}. Used mostly for short strings of text, or longer numerical values.
44
+
45
+ .style-guide__example-block
46
+ = text_field_tag 'wl_text_box_small', 19106, class: 'text-box text-box--small'
47
+
48
+ #text-box--wide.style-guide__subsection
49
+
50
+ %h3= link_to_style_guide('components', 'text_box__wide')
51
+
52
+ %p Increases width of a #{link_to_style_guide('components', 'text_box', true)}. Frequently used with #{link_to_style_guide('components', 'text_box__multi_line', true)}.
53
+
54
+ .style-guide__example-block
55
+ = text_field_tag 'wl_text_box_wide', nil, class: 'text-box text-box--wide'
56
+
57
+ #text-box--x-small.style-guide__subsection
58
+
59
+ %h3= link_to_style_guide('components', 'text_box__x_small')
60
+
61
+ %p Reduces width of a #{link_to_style_guide('components', 'text_box', true)}. Used mostly for sort numerical values.
62
+
63
+ .style-guide__example-block
64
+ = number_field_tag 'wl_text_box_x_small', 99, class: 'text-box text-box--x-small'
65
+
66
+ #text-box--full.style-guide__subsection
67
+
68
+ %h3= link_to_style_guide('components', 'text_box__full')
69
+
70
+ %p Increases width to fill parent element
71
+
72
+ .style-guide__example-block
73
+ = number_field_tag 'wl_text_box_full', 99, class: 'text-box text-box--full'
@@ -0,0 +1,26 @@
1
+ #text-button.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'text_button')
4
+
5
+ %p Displays an element as a bold link, underlined on hover. Primarily used for styling secondary actions, like "Cancel" next to a "Submit" action.
6
+
7
+ %p should work with <code>button[type=button]</code> elements:
8
+ .style-guide__example-block
9
+ = button_tag 'Text Button', class: 'text-button', type: 'button'
10
+
11
+ %p should work with <code>button[type=submit]</code> elements:
12
+ .style-guide__example-block
13
+ = button_tag 'Text Button', class: 'text-button', type: 'submit'
14
+
15
+ %p should work with <code>input[type=submit]</code> elements:
16
+ .style-guide__example-block
17
+ = submit_tag 'Text Button', class: 'text-button'
18
+
19
+ %p should work with <code>a</code> elements:
20
+ .style-guide__example-block
21
+ = link_to 'Text Button', '#', class: 'text-button'
22
+
23
+ %p should style non-interactive buttons wrapped in an <code>a</code> element:
24
+ .style-guide__example-block
25
+ = link_to '#' do
26
+ %span.text-button Span Text Button
@@ -0,0 +1,10 @@
1
+ #text-content-block.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'text_content_block')
4
+
5
+ %p A content block that wraps user-set text
6
+
7
+ .style-guide__example-block
8
+ .text-content-block
9
+ %h1 Text Content Block
10
+ %p Cardboard shanty town tiger-team Tokyo augmented reality boy computer spook cyber-dead garage refrigerator carbon vinyl DIY singularity. Neural euro-pop hacker vinyl plastic franchise corrupted crypto-network bomb rebar sensory silent. Advert convenience store footage sensory knife Tokyo RAF singularity artisanal dead Legba neon office garage paranoid computer. Courier human plastic concrete 3D-printed boat cartel drone man assault stimulate vinyl. Digital 3D-printed nano-military-grade corporation dolphin monofilament advert vinyl semiotics tank-traps boat savant numinous. Decay hacker corrupted shoes augmented reality post-cartel warehouse long-chain hydrocarbons-space woman free-market. Drone hotdog camera motion denim computer vinyl shoes corrupted office.
@@ -0,0 +1,11 @@
1
+ #ui-autocomplete.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'ui_autocomplete')
4
+
5
+ %p An example of the default jQuery UI autocomplete widget instance.
6
+
7
+ %p Enter the string "sweater" in the field below to see an example.
8
+
9
+ .style-guide__example-block
10
+ = text_field_tag 'ui_autocomplete_field', nil, class: 'text-box', data: { style_guide_autocomplete_field: '' }
11
+
@@ -0,0 +1,5 @@
1
+ #ui-dialog.style-guide__subsection
2
+
3
+ %p An example of the default jQuery UI dialog widget instance.
4
+
5
+ %p Click here to view the example: #{link_to_style_guide('components', 'ui_dialog', true)}
@@ -0,0 +1,5 @@
1
+ #ui-dialog-image.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'ui_dialog_image')
4
+
5
+ %p An example of the default jQuery UI dialog widget instance, but specifically styled to house an image.
@@ -0,0 +1,6 @@
1
+ #ui-helper-hidden-accessible.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'ui_helper_hidden_accessible')
4
+
5
+ %p This component is used by many jQuery UI widgets. It simply extends the #{link_to_style_guide('trumps', 'visually_hidden', true)} trump.
6
+
@@ -0,0 +1,70 @@
1
+ #value.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'value')
4
+
5
+ %p Manages the layout of a form field, note, or error displayed for the field.
6
+
7
+ .style-guide__example-block
8
+ .value
9
+ = text_field_tag 'wl_value_text_field', nil, class: 'value__error text-box'
10
+ %span.value__error Error Message Text
11
+ = link_to 'What\'s This?', '#', class: 'value__note'
12
+
13
+ .style-guide__unit-test
14
+
15
+ %h4 Unit Test
16
+
17
+ %p should work with a <code>div</code> (block-level) element, containing only a form field
18
+ .style-guide__example-block
19
+ .value
20
+ = text_field_tag 'wl_value_text_field_div', nil, class: 'text-box'
21
+
22
+ %p should work with a <code>span</code> (inline) element, containing only a form field
23
+ .style-guide__example-block
24
+ %span.value
25
+ = text_field_tag 'wl_value_text_field_span', nil, class: 'text-box'
26
+
27
+ %p should work with a <code>p</code> (block-level) element, containing only a form field
28
+ .style-guide__example-block
29
+ %p.value
30
+ = text_field_tag 'wl_value_text_field_p', nil, class: 'text-box'
31
+
32
+ %p should work with a <code>div</code> (block-level) element, containing a form field and a note
33
+ .style-guide__example-block
34
+ .value
35
+ = text_field_tag 'wl_value_text_field_div_note', nil, class: 'text-box'
36
+ %span.value__note This is a note
37
+
38
+ %p should work with a <code>span</code> (inline) element, containing a form field and a note
39
+ .style-guide__example-block
40
+ %span.value
41
+ = text_field_tag 'wl_value_text_field_span_note', nil, class: 'text-box'
42
+ %span.value__note This is a note
43
+
44
+ %p should work with a <code>p</code> (block-level) element, containing a form field and a note
45
+ .style-guide__example-block
46
+ %p.value
47
+ = text_field_tag 'wl_value_text_field_p_note', nil, class: 'text-box'
48
+ %span.value__note This is a note
49
+
50
+ %p should work with a <code>div</code> (block-level) element, containing a form field, error message, and a note with a link:
51
+ .style-guide__example-block
52
+ .value
53
+ = text_field_tag 'wl_value_text_field_div_error', nil, class: 'value__error text-box'
54
+ %span.value__error Error Message Text
55
+ = link_to 'What\'s This?', '#', class: 'value__note'
56
+
57
+ %p should work with a <code>span</code> (inline) element, containing a form field, error message, and a note with a link:
58
+ .style-guide__example-block
59
+ %span.value
60
+ = text_field_tag 'wl_value_text_field_span_error', nil, class: 'value__error text-box'
61
+ %span.value__error Error Message Text
62
+ = link_to 'What\'s This?', '#', class: 'value__note'
63
+
64
+ %p should work with a <code>p</code> (block-level) element, containing a form field, error message, and a note with a link:
65
+ .style-guide__example-block
66
+ %p.value
67
+ = text_field_tag 'wl_value_text_field_p_error', nil, class: 'value__error text-box'
68
+ %span.value__error Error Message Text
69
+ = link_to 'What\'s This?', '#', class: 'value__note'
70
+
@@ -0,0 +1,21 @@
1
+ #video-and-text-content-block.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'video_and_text_content_block')
4
+
5
+ %p A content block that provides layout for a video and accompanying text.
6
+
7
+ - %w(left right).each do |video_alignment|
8
+ %p should display the <strong>video on the #{video_alignment}</strong>:
9
+ .style-guide__example-block
10
+ .video-and-text-content-block
11
+ .video-and-text-content-block__video-container{ class: "video-and-text-content-block__video-container--#{video_alignment}" }
12
+ %iframe{ width: 560, height: 315, frameborder: 0, allowfullscreen: true, src: ('https://www.youtube.com/embed/A21I70ggSQw' unless Rails.env.test?)}
13
+ .video-and-text-content-block__text Geodesic tower knife military-grade katana sensory courier fetishism singularity rifle pistol ablative warehouse media table woman. Industrial grade sub-orbital garage franchise futurity hacker corrupted office city military-grade tank-traps-space. Boat assault savant knife kanji convenience store decay. Savant drugs hacker industrial grade digital bicycle ablative dissident monofilament Legba.
14
+
15
+ - %w(left right center justify).each do |text_alignment|
16
+ %p should support <strong>text align #{text_alignment}</strong> when the <strong>video is aligned #{video_alignment}</strong>:
17
+ .style-guide__example-block
18
+ .video-and-text-content-block
19
+ .video-and-text-content-block__video-container{ class: "video-and-text-content-block__video-container--#{video_alignment}" }
20
+ %iframe{ width: 560, height: 315, frameborder: 0, allowfullscreen: true, src: ('https://www.youtube.com/embed/A21I70ggSQw' unless Rails.env.test?)}
21
+ .video-and-text-content-block__text{ style: "text-align: #{text_alignment}" } Geodesic tower knife military-grade katana sensory courier fetishism singularity rifle pistol ablative warehouse media table woman. Industrial grade sub-orbital garage franchise futurity hacker corrupted office city military-grade tank-traps-space. Boat assault savant knife kanji convenience store decay. Savant drugs hacker industrial grade digital bicycle ablative dissident monofilament Legba.
@@ -0,0 +1,11 @@
1
+ #video-content-block.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('components', 'video_content_block')
4
+
5
+ %p A content block that wraps an <code>iframe</code> embed code.
6
+
7
+ %p should preserve video ratio as it scales:
8
+ .style-guide__example-block
9
+ .video-content-block
10
+ .video-content-block__responsive-frame{ style: 'padding-bottom: 56.25%; height: 0;' }
11
+ %iframe{ width: 560, height: 315, frameborder: 0, allowfullscreen: true, src: ('https://www.youtube.com/embed/A21I70ggSQw' unless Rails.env.test?)}
@@ -0,0 +1,87 @@
1
+ .style-guide.view
2
+
3
+ = render 'navigation'
4
+
5
+ .style-guide__main
6
+
7
+ %h1 Style Guide
8
+
9
+ %p This page is intended to showcase the visual aspects of each layer of the CSS architecture.
10
+
11
+
12
+ #settings.style-guide__section
13
+
14
+ %h2 Settings
15
+
16
+ %p This layer contains global variables for use throughout the application. These are not the only variables available to use. Be sure to familiarize yourself with the code to see what else might be at your disposal.
17
+
18
+ - partial_paths_for('settings').each do |partial|
19
+ = render partial
20
+
21
+ = append_partials('storefront.style_guide_settings')
22
+
23
+
24
+ #base.style-guide__section
25
+
26
+ %h2 Base
27
+
28
+ %p This layer styles standalone elements.
29
+
30
+ - partial_paths_for('base').each do |partial|
31
+ = render partial
32
+
33
+ = append_partials('storefront.style_guide_base')
34
+
35
+
36
+ #typography.style-guide__section
37
+
38
+ %h2 Typography
39
+
40
+ %p Typography styles define global patterns for paragraphs, headings, links and other generic text elements.
41
+
42
+ %p Typography styles provide element selectors as well as <code>%placeholder-selectors</code> and <code>.class-selectors</code>. This allows you to use class selectors to force an element to use type styles for a different element, for example making headings appear larger, or making non-heading elements appear to be headings.
43
+
44
+ - partial_paths_for('typography').each.each do |partial|
45
+ = render partial
46
+
47
+ = append_partials('storefront.style_guide_typography')
48
+
49
+
50
+ #objects.style-guide__section
51
+
52
+ %h2 Objects
53
+
54
+ %p Objects are "design-free" patterns that can be applied throughout the application. If you notice yourself writing the same structural code over and over you'll probably want to abstract it into an object.
55
+
56
+ %p Objects are offered as both <code>%placeholder-selectors</code> and <code>.class-selectors</code>. They appear higher in the code code to ensure that, if you use an object, you'll be able to override it's styles contextually, if needed.
57
+
58
+ - partial_paths_for('objects').each.each do |partial|
59
+ = render partial
60
+
61
+ = append_partials('storefront.style_guide_objects')
62
+
63
+
64
+ #components.style-guide__section
65
+
66
+ %h2 Components
67
+
68
+ %p Components are the heavily designed building blocks of the site. They can include specific chunks of the UI (like the <code>page-header</code>) or reusable chunks of the UI (like a <code>button</code>). Below are the reusable patterns defined in the components layer:
69
+
70
+ - partial_paths_for('components').each.each do |partial|
71
+ = render partial
72
+
73
+ = append_partials('storefront.style_guide_components')
74
+
75
+
76
+ #trumps.style-guide__section
77
+
78
+ %h2 Trumps
79
+
80
+ %p Trumps are absolute decisions you make with an element. If you say to yourself "No matter what, this element should always X" then you should make a trump for X.
81
+
82
+ %p Trumps are offered as both <code>%placeholder-selectors</code> and as <code>.class-selectors</code>. They appear lower in the code to ensure that, if you use a trump, it will ensure that it's styles take precedence, overriding any other styles applied to that element as needed.
83
+
84
+ - partial_paths_for('trumps').each.each do |partial|
85
+ = render partial
86
+
87
+ = append_partials('storefront.style_guide_trumps')
@@ -0,0 +1,17 @@
1
+ #button-reset-object.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('objects', 'button_reset')
4
+
5
+ %p Resets browser-default button styling.
6
+
7
+ %p should work with a <code>button</code> element
8
+ .style-guide__example-block
9
+ = button_tag 'Button'
10
+ .style-guide__example-block
11
+ = button_tag 'Reset Button', class: 'button-reset'
12
+
13
+ %p should work with an <code>input</code> element
14
+ .style-guide__example-block
15
+ = submit_tag 'Button'
16
+ .style-guide__example-block
17
+ = submit_tag 'Reset Button', class: 'button-reset'
@@ -0,0 +1,20 @@
1
+ #inline-list-object.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('objects', 'inline_list')
4
+
5
+ %p Resets the list-specific styling of a <code>ul</code> or <code>ol</code> element, and displays each child <code>li</code> element as <code>inline-block</code>.
6
+
7
+ .style-guide__unit-test
8
+ %h4 Unit Test
9
+
10
+ %p should work with <code>ul</code> elements
11
+ .style-guide__example-block
12
+ %ul.inline-list
13
+ - 5.times do |i|
14
+ %li List Item #{i}
15
+
16
+ %p should work with <code>ol</code> elements
17
+ .style-guide__example-block
18
+ %ol.inline-list
19
+ - 5.times do |i|
20
+ %li List Item #{i}
@@ -0,0 +1,20 @@
1
+ #list-reset-object.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('objects', 'list_reset')
4
+
5
+ %p Resets the list-specific styling of a <code>ul</code> or <code>ol</code> element.
6
+
7
+ .style-guide__unit-test
8
+ %h4 Unit Test
9
+
10
+ %p should work with <code>ul</code> elements
11
+ .style-guide__example-block
12
+ %ul.list-reset
13
+ - 5.times do |i|
14
+ %li List Item #{i}
15
+
16
+ %p should work with <code>ol</code> elements
17
+ .style-guide__example-block
18
+ %ol.list-reset
19
+ - 5.times do |i|
20
+ %li List Item #{i}
@@ -0,0 +1,11 @@
1
+ #text-field-reset-object.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('objects', 'text_field_reset')
4
+
5
+ %p Resets browser-default text-field styling.
6
+
7
+ %p should work with a <code>input</code> element
8
+ .style-guide__example-block
9
+ = text_field_tag 'Text Field 1', nil, placeholder: 'Text Field'
10
+ .style-guide__example-block
11
+ = text_field_tag 'Text Field 2', nil, placeholder: 'Unstyled Text Field', class: 'text-field-reset'
@@ -0,0 +1,21 @@
1
+ #color-variables.style-guide__subsection
2
+
3
+ %h3= link_to_style_guide('settings', 'color_variables')
4
+
5
+ %p The color palette for the storefront.
6
+
7
+ .grid.grid--auto
8
+ - colors = %w(blue yellow red green white gray light-gray black black-alpha-50 black-alpha-15 white-alpha-50)
9
+ - colors.each do |color|
10
+ .grid__cell
11
+ .style-guide__color
12
+ .style-guide__color-swatch{ class: "style-guide__color-swatch--#{color}" }
13
+ $#{color}
14
+
15
+ .grid.grid--auto
16
+ - colors = %w(transparent background-color highlight-color link-color overlay-shadow-color focus-ring-color)
17
+ - colors.each do |color|
18
+ .grid__cell
19
+ .style-guide__color
20
+ .style-guide__color-swatch{ class: "style-guide__color-swatch--#{color}" }
21
+ $#{color}
@@ -0,0 +1,10 @@
1
+ .style-guide.view
2
+
3
+ .grid
4
+ .grid__cell.grid__cell--20
5
+
6
+ = render 'navigation'
7
+
8
+ .grid__cell.grid__cell--80
9
+
10
+ = render @style_guide_partial