wickes-css2 2.105.0-develop.1 → 2.105.0-develop.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/Readme.md +4 -3
  2. package/build/css/category-main.css +1 -1
  3. package/build/css/homepage-main.css +1 -1
  4. package/build/css/kitchen-plp-main.css +1 -1
  5. package/build/css/main.css +1 -1
  6. package/build/css/my-account-main-v2.css +1 -1
  7. package/build/css/my-account-main.css +1 -1
  8. package/build/css/pages/checkout-new.css +1 -1
  9. package/build/css/pages/checkout.css +1 -1
  10. package/build/css/pages/my-account-v2.css +1 -1
  11. package/build/css/pages/page_checkout_delivery-new.css +1 -1
  12. package/build/css/pages/page_discount.css +1 -1
  13. package/build/css/pages/page_product_search.css +1 -1
  14. package/build/css/pages/page_products-list-combined.css +1 -1
  15. package/build/css/pages/page_products-list.css +1 -1
  16. package/build/css/pages/tradePro-rewards.css +1 -1
  17. package/build/css/pdp-main-before-combine.css +1 -1
  18. package/build/css/pdp-main-critical.css +1 -1
  19. package/build/css/pdp-main-non-critical.css +1 -1
  20. package/build/css/pdp-main.css +1 -1
  21. package/build/css/plp-main.css +1 -1
  22. package/build/css/store-locator-main.css +1 -1
  23. package/build/img/quick-filters/bath1.svg +10 -0
  24. package/build/img/quick-filters/bath3.svg +3 -0
  25. package/build/img/quick-filters/bath4.svg +10 -0
  26. package/build/img/quick-filters/bath5.svg +10 -0
  27. package/build/img/quick-filters/image1.jpg +0 -0
  28. package/build/img/quick-filters/image2.jpg +0 -0
  29. package/build/img/quick-filters/image3.jpg +0 -0
  30. package/build/js/account-members.min.js +1 -1
  31. package/build/js/basket.min.js +2 -2
  32. package/build/js/bundle.min.js +1 -1
  33. package/build/js/checkout.min.js +2 -2
  34. package/build/js/emulation.min.js +12125 -11596
  35. package/build/js/general.bundle.min.js +1 -1
  36. package/build/js/kitchen/kitchen-plp.min.js +1 -9
  37. package/build/js/merged-checkout.min.js +2 -2
  38. package/build/js/mini-basket-slider.min.js +1 -1
  39. package/build/js/my-account.min.js +1 -1
  40. package/build/js/page/basket/basket-update-cart-action.js +59 -56
  41. package/build/js/page/basket/basket-update-cart.js +27 -27
  42. package/build/js/page/basket/basket-utils.js +40 -33
  43. package/build/js/page/basket/mini-basket-total.js +70 -66
  44. package/build/js/page/basket/quantity-change-handler.js +73 -55
  45. package/build/js/page/basket/update-quantity-operation.js +39 -30
  46. package/build/js/page/basket/update-quantity.js +62 -62
  47. package/build/js/page/basket-v2.js +362 -229
  48. package/build/js/page/billie-business-type.js +27 -27
  49. package/build/js/page/checkout-payment-details.js +301 -299
  50. package/build/js/page/components/discounts.js +39 -36
  51. package/build/js/page/components/mini-basket-slider.js +604 -545
  52. package/build/js/page/filters/desktop-nav.js +64 -0
  53. package/build/js/page/filters/mobile-nav.js +93 -0
  54. package/build/js/page/filters/plp-filters-chips.js +92 -0
  55. package/build/js/page/filters/plp-filters-mobile.js +150 -0
  56. package/build/js/page/filters/plp-filters-panel.js +123 -0
  57. package/build/js/page/filters/plp-filters-utils.js +66 -0
  58. package/build/js/page/filters/plp-filters.js +268 -0
  59. package/build/js/page/filters/sort-by.js +172 -0
  60. package/build/js/page/kitchen/colour-swatches.js +5 -2
  61. package/build/js/page/klarna-modal-scroll-disable.js +4 -4
  62. package/build/js/page/my-account.js +32 -47
  63. package/build/js/page/online-exclusive.js +28 -31
  64. package/build/js/page/quick-filter.js +108 -0
  65. package/build/js/page/search-filter.js +62 -0
  66. package/build/js/page/share-project-list.js +57 -0
  67. package/build/js/page/tradePro-rewards.js +69 -39
  68. package/build/js/page/utils/copy-to-clipboard.js +79 -47
  69. package/build/js/page/utils/helpers.js +14 -9
  70. package/build/js/page/utils/show-more-less.js +273 -0
  71. package/build/js/pdp.bundle.min.js +1 -1
  72. package/build/js/plp-filters.min.js +9 -0
  73. package/build/js/plp.bundle.min.js +1 -1
  74. package/build/js/project-list.min.js +143 -85
  75. package/build/js/search-filter.min.js +1 -0
  76. package/build/js/share-project-list.min.js +1 -0
  77. package/build/js/tradePro-rewards.min.js +1 -1
  78. package/package.json +4 -2
  79. package/src/components/.DS_Store +0 -0
  80. package/src/components/accordion.hbs +2 -2
  81. package/src/components/date-selection.hbs +25 -6
  82. package/src/components/generate-project-id.hbs +1 -1
  83. package/src/components/kitchen/dropdown.hbs +6 -3
  84. package/src/components/kitchen/filter-modal-content-kitchen.hbs +10 -0
  85. package/src/components/kitchen/filter-modal.hbs +10 -13
  86. package/src/components/kitchen/kitchen-card.hbs +1 -1
  87. package/src/components/kitchen/plp-filters.hbs +3 -1
  88. package/src/components/kitchen/sort-by.hbs +1 -1
  89. package/src/components/my-account/barcode.hbs +1 -3
  90. package/src/components/my-account/cards-swap.hbs +10 -0
  91. package/src/components/my-account/clipboard-code-card.hbs +3 -3
  92. package/src/components/my-account/discount.hbs +1 -1
  93. package/src/components/my-account/greetings.hbs +1 -1
  94. package/src/components/quick-filter.hbs +56 -0
  95. package/src/components/search-filter-modal-content.hbs +102 -0
  96. package/src/components/search-filter.hbs +121 -112
  97. package/src/components/shopping-list-with-share-list-v2.hbs +28 -10
  98. package/src/components/shopping-list.hbs +5 -5
  99. package/src/data/data_plp_load-more.json +1 -1
  100. package/src/data/data_quick-filter.json +508 -0
  101. package/src/data/my-account/data_my-account.json +9 -0
  102. package/src/elements/btn.hbs +7 -0
  103. package/src/img/quick-filters/bath1.svg +10 -0
  104. package/src/img/quick-filters/bath3.svg +3 -0
  105. package/src/img/quick-filters/bath4.svg +10 -0
  106. package/src/img/quick-filters/bath5.svg +10 -0
  107. package/src/img/quick-filters/image1.jpg +0 -0
  108. package/src/img/quick-filters/image2.jpg +0 -0
  109. package/src/img/quick-filters/image3.jpg +0 -0
  110. package/src/js/components/cards-swap.js +74 -0
  111. package/src/js/components/general/accordion.js +44 -33
  112. package/src/js/components/general/cart-slider.js +19 -16
  113. package/src/js/components/general/create-popup-slider.js +168 -173
  114. package/src/js/components/share-project-list.js +8 -5
  115. package/src/js/emulation/big-wins.js +1081 -904
  116. package/src/js/emulation/billie-modal.js +23 -19
  117. package/src/js/emulation/checkout-payment-details.js +47 -38
  118. package/src/js/emulation/custom-slider-emulation.js +17 -13
  119. package/src/js/emulation/filters-emulation.js +164 -0
  120. package/src/js/emulation/forms.js +360 -323
  121. package/src/js/emulation/mini-basket-data.js +1051 -923
  122. package/src/js/emulation/paymentLoader.js +17 -17
  123. package/src/js/emulation/pdf-file-loader.js +89 -91
  124. package/src/js/emulation/popover-mini-basket.js +246 -239
  125. package/src/js/emulation/product-counter.js +50 -0
  126. package/src/js/emulation/project-list-pdp.js +320 -316
  127. package/src/js/emulation/repayment-toggle.js +23 -24
  128. package/src/js/emulation/reset-filter-desktop.js +5 -0
  129. package/src/js/emulation/selectable.js +22 -18
  130. package/src/js/emulation/wismo-details.js +23 -31
  131. package/src/js/page/basket/basket-update-cart-action.js +59 -56
  132. package/src/js/page/basket/basket-update-cart.js +27 -27
  133. package/src/js/page/basket/basket-utils.js +40 -33
  134. package/src/js/page/basket/mini-basket-total.js +70 -66
  135. package/src/js/page/basket/quantity-change-handler.js +73 -55
  136. package/src/js/page/basket/update-quantity-operation.js +39 -30
  137. package/src/js/page/basket/update-quantity.js +62 -62
  138. package/src/js/page/basket-v2.js +362 -229
  139. package/src/js/page/billie-business-type.js +27 -27
  140. package/src/js/page/checkout-payment-details.js +301 -299
  141. package/src/js/page/components/discounts.js +39 -36
  142. package/src/js/page/components/mini-basket-slider.js +604 -545
  143. package/src/js/page/filters/desktop-nav.js +64 -0
  144. package/src/js/page/filters/mobile-nav.js +93 -0
  145. package/src/js/page/filters/plp-filters-chips.js +92 -0
  146. package/src/js/page/filters/plp-filters-mobile.js +150 -0
  147. package/src/js/page/filters/plp-filters-panel.js +123 -0
  148. package/src/js/page/filters/plp-filters-utils.js +66 -0
  149. package/src/js/page/filters/plp-filters.js +268 -0
  150. package/src/js/page/filters/sort-by.js +172 -0
  151. package/src/js/page/kitchen/colour-swatches.js +5 -2
  152. package/src/js/page/klarna-modal-scroll-disable.js +4 -4
  153. package/src/js/page/my-account.js +32 -47
  154. package/src/js/page/online-exclusive.js +28 -31
  155. package/src/js/page/quick-filter.js +108 -0
  156. package/src/js/page/search-filter.js +62 -0
  157. package/src/js/page/share-project-list.js +57 -0
  158. package/src/js/page/tradePro-rewards.js +69 -39
  159. package/src/js/page/utils/copy-to-clipboard.js +79 -47
  160. package/src/js/page/utils/helpers.js +14 -9
  161. package/src/js/page/utils/show-more-less.js +273 -0
  162. package/src/page_empty-shared-project-list-bicester-hub.html +4 -0
  163. package/src/page_empty-shopping-list_guest.html +1 -0
  164. package/src/page_kitchen-plp.html +2 -2
  165. package/src/page_my-account-installer.html +1 -1
  166. package/src/page_my-account-trade-pro-carousel-double.html +127 -0
  167. package/src/page_my-account-trade-pro-carousel.html +134 -0
  168. package/src/page_my-account-trade-pro.html +1 -1
  169. package/src/page_my-shopping-list-add-notes.html +1 -0
  170. package/src/page_my-shopping-list-energy.html +1 -0
  171. package/src/page_my-shopping-list-hide-download.html +3 -2
  172. package/src/page_my-shopping-list-pdf.html +2 -0
  173. package/src/page_my-shopping-list-saved-ref.html +1 -0
  174. package/src/page_my-shopping-list-wisdom-oos-registered.html +1 -0
  175. package/src/page_my-shopping-list-wisdom-oos.html +1 -0
  176. package/src/page_my-shopping-list-wisdom-partial-registered.html +1 -0
  177. package/src/page_my-shopping-list-wisdom-registered.html +1 -0
  178. package/src/page_my-shopping-list-wisdom.html +1 -0
  179. package/src/page_my-shopping-list.html +1 -0
  180. package/src/page_my-shopping-list_not-register.html +3 -0
  181. package/src/page_plp-with-paint.html +2 -7
  182. package/src/page_plp.html +2 -7
  183. package/src/page_plp_v2-energy-efficiency.html +1 -6
  184. package/src/page_plp_v2-favourite-products.html +6 -7
  185. package/src/page_plp_v2-quick-filter_colourSwatches_11.html +79 -0
  186. package/src/page_plp_v2-quick-filter_colourSwatches_5.html +79 -0
  187. package/src/page_plp_v2-quick-filter_iconAndText_5.html +79 -0
  188. package/src/page_plp_v2-quick-filter_iconAndText_9.html +79 -0
  189. package/src/page_plp_v2-quick-filter_iconOnly_11.html +79 -0
  190. package/src/page_plp_v2-quick-filter_iconOnly_5.html +79 -0
  191. package/src/page_plp_v2-quick-filter_imageAndText_5.html +79 -0
  192. package/src/page_plp_v2-quick-filter_imageAndText_9.html +79 -0
  193. package/src/page_plp_v2-quick-filter_textOnly_5.html +79 -0
  194. package/src/page_plp_v2-quick-filter_textOnly_9.html +79 -0
  195. package/src/page_plp_v2-vat.html +2 -7
  196. package/src/page_plp_v2.html +22 -9
  197. package/src/page_product_search-vat.html +2 -7
  198. package/src/page_product_search.html +2 -7
  199. package/src/page_project-list-generate-project-list-ID.html +3 -0
  200. package/src/page_project-list-vat.html +4 -0
  201. package/src/page_project-list-with-new-share-popup-android.html +16 -0
  202. package/src/page_project-list-with-new-share-popup-ios.html +16 -0
  203. package/src/page_project-list-with-new-share-popup.html +2 -1
  204. package/src/page_search-results.html +2 -7
  205. package/src/page_shared-project-list-bicester-hub.html +3 -1
  206. package/src/page_tradepro-discount-app.html +1 -1
  207. package/src/page_tradepro-discount-double.html +109 -0
  208. package/src/page_tradepro-discount.html +36 -2
  209. package/src/partials/head.hbs +1 -0
  210. package/src/scss/common/_common.scss +10 -4
  211. package/src/scss/components/_accordion.scss +1 -3
  212. package/src/scss/components/_custom-slider.scss +17 -16
  213. package/src/scss/components/_date-selection-add-new-styles.scss +48 -7
  214. package/src/scss/components/_date-selection.scss +80 -1
  215. package/src/scss/components/{kitchen/_filter-modal.scss → _filter-modal.scss} +55 -4
  216. package/src/scss/components/{kitchen/_plp-filters.scss → _plp-filters.scss} +31 -13
  217. package/src/scss/components/_popover-mini-basket.scss +3 -3
  218. package/src/scss/components/_quick-filter.scss +288 -0
  219. package/src/scss/components/_search-filter.scss +95 -15
  220. package/src/scss/components/_shared-shopping-list.scss +22 -0
  221. package/src/scss/components/_shopping-list.scss +18 -8
  222. package/src/scss/components/_sort-by.scss +190 -0
  223. package/src/scss/components/checkout-chip.scss +2 -2
  224. package/src/scss/components/checkout-payment-repayment-terms.scss +1 -1
  225. package/src/scss/components/kitchen/_price-tooltip.scss +1 -1
  226. package/src/scss/components/kitchen/_price.scss +1 -1
  227. package/src/scss/components/my-account/_barcode.scss +9 -1
  228. package/src/scss/components/my-account/_cards-swap.scss +60 -0
  229. package/src/scss/components/my-account/_clipboard-code.scss +11 -3
  230. package/src/scss/components/my-account/_discount.scss +12 -2
  231. package/src/scss/globals/_global-components.scss +3 -0
  232. package/src/scss/helpers/_colors-semantic.scss +68 -68
  233. package/src/scss/helpers/_variables.scss +244 -196
  234. package/src/scss/kitchen-plp-main.scss +0 -4
  235. package/src/scss/main.scss +65 -65
  236. package/src/scss/pages/my-account-v2.scss +42 -5
  237. package/src/scss/pages/page_discount.scss +8 -4
  238. package/src/scss/pages/page_product-details-v2.scss +1 -4
  239. package/src/scss/pages/page_product_search.scss +9 -1
  240. package/src/scss/pages/page_products-list-combined.scss +28 -24
  241. package/src/scss/pages/page_products-list.scss +8 -0
  242. package/src/scss/pages/tradePro-rewards.scss +3 -4
  243. package/src/scss/plp-main.scss +1 -0
  244. package/src/sitemap.html +25 -1
  245. package/build/js/page/accordion.js +0 -35
  246. package/build/js/page/kitchen/plp-filters-chips.js +0 -90
  247. package/build/js/page/kitchen/plp-filters-mobile.js +0 -72
  248. package/build/js/page/kitchen/plp-filters-panel.js +0 -119
  249. package/build/js/page/kitchen/plp-filters-utils.js +0 -65
  250. package/build/js/page/kitchen/plp-filters.js +0 -205
  251. package/build/js/page/kitchen/sort-by.js +0 -157
  252. package/src/js/components/general/search-filter.js +0 -21
  253. package/src/js/page/accordion.js +0 -35
  254. package/src/js/page/kitchen/plp-filters-chips.js +0 -90
  255. package/src/js/page/kitchen/plp-filters-mobile.js +0 -72
  256. package/src/js/page/kitchen/plp-filters-panel.js +0 -119
  257. package/src/js/page/kitchen/plp-filters-utils.js +0 -65
  258. package/src/js/page/kitchen/plp-filters.js +0 -205
  259. package/src/js/page/kitchen/sort-by.js +0 -157
@@ -1,35 +1,46 @@
1
1
  var Wick = Wick || {};
2
- Wick.Accordion = (function(){
3
- var $accordion = $('.accordion'),
4
- accordionToggler = '.accordion__header',
5
- accordionIcon = '.accordion__action',
6
- accordionContent = '.accordion__content',
7
- collapsed = 'accordion_collapsed',
8
- $asideAccordion = $('.aside-accordion .js-toggle-aside-accordion');
9
- var bindEvents = function (index, element) {
10
- var $acc = $(element);
11
-
12
- var accordionTrigger = $acc.attr('data-action-element') === 'icon' ? accordionIcon : accordionToggler
13
- $acc.find(accordionTrigger).on('click', function(){
14
- $acc.toggleClass(collapsed);
15
- $acc.children(accordionContent).slideToggle(200);
16
- });
17
- };
18
-
19
- var init = function () {
20
- $accordion.each(bindEvents);
21
-
22
- $asideAccordion.click(function() {
23
- if (window.matchMedia("(min-width: 992px)").matches) {
24
- if ($(this).text().toLowerCase() != 'useful links') {
25
- $(this).closest('.aside-nav2__holder')
26
- .toggleClass('is-active')
27
- .find('.aside-nav2__list')
28
- .slideToggle(250);
29
- }
30
- }
31
- });
32
- }
33
-
34
- init();
2
+ Wick.Accordion = (function () {
3
+ var accordionRoot = '.accordion',
4
+ accordionToggler = '.accordion__header',
5
+ accordionIcon = '.accordion__action',
6
+ accordionContent = '.accordion__content',
7
+ collapsed = 'accordion_collapsed',
8
+ $asideAccordion = $('.aside-accordion .js-toggle-aside-accordion');
9
+
10
+ function getTriggerSelector($acc) {
11
+ return $acc.attr('data-action-element') === 'icon' ? accordionIcon : accordionToggler;
12
+ }
13
+
14
+ function onAccordionClick(e) {
15
+ var $trigger = $(e.currentTarget);
16
+ var $acc = $trigger.closest(accordionRoot);
17
+ if (!$acc.length) return;
18
+
19
+ var triggerSel = getTriggerSelector($acc);
20
+
21
+ if (!$trigger.is(triggerSel)) return;
22
+
23
+ $acc.toggleClass(collapsed);
24
+ $acc.children(accordionContent).stop(true, true).slideToggle(200);
25
+ }
26
+
27
+ function init() {
28
+ $(document)
29
+ .off('click.wickAccordion', accordionToggler + ',' + accordionIcon)
30
+ .on('click.wickAccordion', accordionToggler + ',' + accordionIcon, onAccordionClick);
31
+
32
+ $asideAccordion.off('click.wickAsideAccordion').on('click.wickAsideAccordion', function () {
33
+ if (window.matchMedia('(min-width: 992px)').matches) {
34
+ if ($(this).text().toLowerCase() !== 'useful links') {
35
+ $(this)
36
+ .closest('.aside-nav2__holder')
37
+ .toggleClass('is-active')
38
+ .find('.aside-nav2__list')
39
+ .slideToggle(250);
40
+ }
41
+ }
42
+ });
43
+ }
44
+
45
+ init();
35
46
  })();
@@ -1,20 +1,23 @@
1
1
  const cartSliderHTML = '<div class="custom-slider just-added d-none"></div>';
2
2
 
3
3
  createPopupSlider({
4
- type: 'cart',
5
- sliderSelector: '.custom-slider.just-added',
6
- onAppendEvent: 'productAddedToCart',
7
- onAppend: function (event, { showSlider, handleScroll, el }) {
8
- if (!$('.custom-slider.just-added').length) {
9
- $('body').append(cartSliderHTML);
10
- }
11
- const htmlContent = event.detail.html;
12
- $(el.slider).append(htmlContent);
13
- showSlider();
14
- Wick.MiniBasketSliderFE.isMiniBasketLoaded = false;
15
- $(el.sliderWrap).on('scroll', _.debounce(() => handleScroll(el.sliderWrap), 100));
16
- },
17
- onClose: function () {
18
- Wick.MiniBasketSliderFE.cartEntries = [];
19
- }
4
+ type: 'cart',
5
+ sliderSelector: '.custom-slider.just-added',
6
+ onAppendEvent: 'productAddedToCart',
7
+ onAppend: function (event, { showSlider, handleScroll, el }) {
8
+ if (!$('.custom-slider.just-added').length) {
9
+ $('body').append(cartSliderHTML);
10
+ }
11
+ const htmlContent = event.detail.html;
12
+ $(el.slider).append(htmlContent);
13
+ showSlider();
14
+ Wick.MiniBasketSliderFE.isMiniBasketLoaded = false;
15
+ $(el.sliderWrap).on(
16
+ 'scroll',
17
+ _.debounce(() => handleScroll(el.sliderWrap), 100)
18
+ );
19
+ },
20
+ onClose: function () {
21
+ Wick.MiniBasketSliderFE.cartEntries = [];
22
+ },
20
23
  });
@@ -1,199 +1,194 @@
1
1
  function createEvent(eventName, payload, eventDetail) {
2
- return new CustomEvent(eventName, {
3
- detail: {
4
- payload,
5
- resolve: eventDetail.resolve,
6
- reject: eventDetail.reject,
7
- },
8
- });
2
+ return new CustomEvent(eventName, {
3
+ detail: {
4
+ payload,
5
+ resolve: eventDetail.resolve,
6
+ reject: eventDetail.reject,
7
+ },
8
+ });
9
9
  }
10
10
 
11
+ /* eslint-disable no-unused-vars -- used globally */
11
12
  function createPopupSlider({ type, sliderSelector, onAppendEvent, onAppend, onClose }) {
12
- const events = {
13
- CLOSE_JUST_ADDED: 'CLOSE_JUST_ADDED',
14
- CLOSE_MINI_BASKET: 'CLOSE_MINI_BASKET'
15
- }
16
-
17
- const el = {
18
- $body: $('body'),
19
- slider: sliderSelector,
20
- sliderWrap: `${sliderSelector} .custom-slider__wrap`,
21
- sliderWrapScroll: 'custom-slider__wrap--scroll',
22
- footer: '.custom-slider__footer',
23
- closePopup: `${sliderSelector} .close-popup`,
24
- $stickyWrapper: $('.sticky-wrapper'),
25
- $headerWrapper: $('.header-wrapper'),
26
- scrollDisable: 'slider-scroll-disable',
27
- footerFixed: 'footer-fixed',
28
- btnMiniBasket: '.header-minicart__btn',
29
- };
30
-
31
- function isSmallBreakpoint() {
32
- return Wick.Responsive.getCurrentBreakpoint() === 'down-sm';
33
- }
34
-
35
- function getAnimationClass() {
36
- return isSmallBreakpoint() ? 'bottom-to-top' : 'right-to-left';
37
- }
38
-
39
- function adjustHeight() {
40
- const stickyWrapperHeight = el.$stickyWrapper.outerHeight() || 0;
41
- const headerWrapperHeight = el.$headerWrapper.outerHeight() || 0;
42
-
43
- const totalHeight = stickyWrapperHeight + headerWrapperHeight;
44
- $(el.slider).css('height', `calc(100% - ${totalHeight}px)`);
45
- }
46
-
47
- function hideSlider() {
48
- $(el.slider).removeClass('show');
49
-
50
- setTimeout(() => {
51
- el.$body.removeClass(el.scrollDisable);
52
-
53
- if (!isSmallBreakpoint()) {
54
- el.$body.css('padding-right', '');
55
- }
56
-
57
- if (type === 'cart') {
58
- $(el.slider)
59
- .removeAttr('style')
60
- .empty();
61
- }
62
-
63
- $(el.slider).addClass('d-none');
64
- }, 400);
65
- }
66
-
67
- function handleScroll(sliderWrap) {
68
- const scrollHeight = $(sliderWrap)[0].scrollHeight;
69
- const scrollTop = $(sliderWrap).scrollTop();
70
- const clientHeight = $(sliderWrap)[0].clientHeight;
71
- const scrollBottom = scrollHeight - scrollTop - clientHeight;
72
-
73
- if (scrollBottom > 75) {
74
- $(el.footer).addClass(el.footerFixed);
75
- $(sliderWrap).addClass(el.sliderWrapScroll);
76
- } else {
77
- $(el.footer).removeClass(el.footerFixed);
78
- $(sliderWrap).removeClass(el.sliderWrapScroll);
13
+ const events = {
14
+ CLOSE_JUST_ADDED: 'CLOSE_JUST_ADDED',
15
+ CLOSE_MINI_BASKET: 'CLOSE_MINI_BASKET',
16
+ };
17
+
18
+ const el = {
19
+ $body: $('body'),
20
+ slider: sliderSelector,
21
+ sliderWrap: `${sliderSelector} .custom-slider__wrap`,
22
+ sliderWrapScroll: 'custom-slider__wrap--scroll',
23
+ footer: '.custom-slider__footer',
24
+ closePopup: `${sliderSelector} .close-popup`,
25
+ $stickyWrapper: $('.sticky-wrapper'),
26
+ $headerWrapper: $('.header-wrapper'),
27
+ scrollDisable: 'slider-scroll-disable',
28
+ footerFixed: 'footer-fixed',
29
+ btnMiniBasket: '.header-minicart__btn',
30
+ };
31
+
32
+ function isSmallBreakpoint() {
33
+ return Wick.Responsive.getCurrentBreakpoint() === 'down-sm';
34
+ }
35
+
36
+ function getAnimationClass() {
37
+ return isSmallBreakpoint() ? 'bottom-to-top' : 'right-to-left';
79
38
  }
80
- }
81
39
 
82
- function showSlider() {
83
- if (isSmallBreakpoint()) {
84
- adjustHeight();
40
+ function adjustHeight() {
41
+ const stickyWrapperHeight = el.$stickyWrapper.outerHeight() || 0;
42
+ const headerWrapperHeight = el.$headerWrapper.outerHeight() || 0;
43
+
44
+ const totalHeight = stickyWrapperHeight + headerWrapperHeight;
45
+ $(el.slider).css('height', `calc(100% - ${totalHeight}px)`);
85
46
  }
86
47
 
87
- const animationClass = getAnimationClass();
88
- const scrollBarWidth = window.innerWidth - document.documentElement.clientWidth;
89
- $(el.slider)
90
- .removeClass('bottom-to-top right-to-left')
91
- .addClass(animationClass);
48
+ function hideSlider() {
49
+ $(el.slider).removeClass('show');
92
50
 
93
- $('html, body').animate({ scrollTop: 0 }, 300, () => {
94
- Wick.Backdrop.show();
95
- $(el.slider).removeClass('d-none');
51
+ setTimeout(() => {
52
+ el.$body.removeClass(el.scrollDisable);
96
53
 
97
- setTimeout(() => {
98
- $(el.slider).addClass('show');
99
- handleScroll(el.sliderWrap);
100
- el.$body.addClass(el.scrollDisable);
54
+ if (!isSmallBreakpoint()) {
55
+ el.$body.css('padding-right', '');
56
+ }
57
+
58
+ if (type === 'cart') {
59
+ $(el.slider).removeAttr('style').empty();
60
+ }
61
+
62
+ $(el.slider).addClass('d-none');
63
+ }, 400);
64
+ }
101
65
 
102
- if (!isSmallBreakpoint()) {
103
- el.$body.css('padding-right', `${scrollBarWidth}px`);
66
+ function handleScroll(sliderWrap) {
67
+ const scrollHeight = $(sliderWrap)[0].scrollHeight;
68
+ const scrollTop = $(sliderWrap).scrollTop();
69
+ const clientHeight = $(sliderWrap)[0].clientHeight;
70
+ const scrollBottom = scrollHeight - scrollTop - clientHeight;
71
+
72
+ if (scrollBottom > 75) {
73
+ $(el.footer).addClass(el.footerFixed);
74
+ $(sliderWrap).addClass(el.sliderWrapScroll);
75
+ } else {
76
+ $(el.footer).removeClass(el.footerFixed);
77
+ $(sliderWrap).removeClass(el.sliderWrapScroll);
104
78
  }
105
- }, 100);
106
- });
107
- }
108
-
109
- function handleSliderClose(eventName) {
110
- return new Promise((resolve, reject) => {
111
- const eventDetail = {resolve, reject};
112
- const event = createEvent(eventName, {}, eventDetail);
113
- window.dispatchEvent(event);
114
- })
115
- .then(() => {})
116
- .catch((error) => {
117
- console.error(error);
118
- })
119
- .finally(() => {
120
- hideSlider();
121
- Wick.Backdrop.hide();
122
- if (typeof onClose === 'function') {
123
- onClose();
79
+ }
80
+
81
+ function showSlider() {
82
+ if (isSmallBreakpoint()) {
83
+ adjustHeight();
124
84
  }
125
- })
126
- }
127
85
 
128
- function bindClosePopup() {
129
- $(document).on('click', el.closePopup, async () => {
130
- if (type === 'cart') {
131
- await handleSliderClose(events.CLOSE_JUST_ADDED);
132
- }
86
+ const animationClass = getAnimationClass();
87
+ const scrollBarWidth = window.innerWidth - document.documentElement.clientWidth;
88
+ $(el.slider).removeClass('bottom-to-top right-to-left').addClass(animationClass);
133
89
 
134
- if (type === 'miniBasket') {
135
- await handleSliderClose(events.CLOSE_MINI_BASKET)
136
- }
90
+ $('html, body').animate({ scrollTop: 0 }, 300, () => {
91
+ Wick.Backdrop.show();
92
+ $(el.slider).removeClass('d-none');
137
93
 
138
- hideSlider();
139
- Wick.Backdrop.hide();
140
- });
141
- }
142
-
143
- function handleResize() {
144
- const animationClass = getAnimationClass();
145
-
146
- if ($(el.slider).hasClass('show')) {
147
- $(el.slider)
148
- .removeClass('bottom-to-top right-to-left')
149
- .addClass(animationClass);
150
-
151
- if (isSmallBreakpoint()) {
152
- adjustHeight();
153
- } else {
154
- $(el.slider).css('height', '');
155
- Wick.Backdrop.show();
156
- }
94
+ setTimeout(() => {
95
+ $(el.slider).addClass('show');
96
+ handleScroll(el.sliderWrap);
97
+ el.$body.addClass(el.scrollDisable);
98
+
99
+ if (!isSmallBreakpoint()) {
100
+ el.$body.css('padding-right', `${scrollBarWidth}px`);
101
+ }
102
+ }, 100);
103
+ });
157
104
  }
158
- }
159
-
160
- function shouldClosePopup(event) {
161
- const $target = $(event.target);
162
- return (
163
- !$target.closest(el.slider).length &&
164
- !$target.closest(el.closePopup).length &&
165
- $(el.slider).hasClass('show')
166
- );
167
- }
168
-
169
- function init() {
170
- bindClosePopup();
171
-
172
- if (onAppendEvent && onAppend) {
173
- window.addEventListener(onAppendEvent, (event) => {
174
- onAppend(event, { showSlider, handleScroll, el });
175
- });
105
+
106
+ function handleSliderClose(eventName) {
107
+ return new Promise((resolve, reject) => {
108
+ const eventDetail = { resolve, reject };
109
+ const event = createEvent(eventName, {}, eventDetail);
110
+ window.dispatchEvent(event);
111
+ })
112
+ .then(() => {})
113
+ .catch((error) => {
114
+ console.error(error);
115
+ })
116
+ .finally(() => {
117
+ hideSlider();
118
+ Wick.Backdrop.hide();
119
+ if (typeof onClose === 'function') {
120
+ onClose();
121
+ }
122
+ });
176
123
  }
177
124
 
178
- $(window).on('resize', _.debounce(handleResize, 100));
125
+ function bindClosePopup() {
126
+ $(document).on('click', el.closePopup, async () => {
127
+ if (type === 'cart') {
128
+ await handleSliderClose(events.CLOSE_JUST_ADDED);
129
+ }
130
+
131
+ if (type === 'miniBasket') {
132
+ await handleSliderClose(events.CLOSE_MINI_BASKET);
133
+ }
179
134
 
180
- $('body').on('click', async (event) => {
181
- if (shouldClosePopup(event)) {
182
- if (type === 'cart') {
183
- await handleSliderClose(events.CLOSE_JUST_ADDED);
135
+ hideSlider();
136
+ Wick.Backdrop.hide();
137
+ });
138
+ }
139
+
140
+ function handleResize() {
141
+ const animationClass = getAnimationClass();
142
+
143
+ if ($(el.slider).hasClass('show')) {
144
+ $(el.slider).removeClass('bottom-to-top right-to-left').addClass(animationClass);
145
+
146
+ if (isSmallBreakpoint()) {
147
+ adjustHeight();
148
+ } else {
149
+ $(el.slider).css('height', '');
150
+ Wick.Backdrop.show();
151
+ }
184
152
  }
153
+ }
154
+
155
+ function shouldClosePopup(event) {
156
+ const $target = $(event.target);
157
+ return (
158
+ !$target.closest(el.slider).length &&
159
+ !$target.closest(el.closePopup).length &&
160
+ $(el.slider).hasClass('show')
161
+ );
162
+ }
185
163
 
186
- if (type === 'miniBasket') {
187
- await handleSliderClose(events.CLOSE_MINI_BASKET)
164
+ function init() {
165
+ bindClosePopup();
166
+
167
+ if (onAppendEvent && onAppend) {
168
+ window.addEventListener(onAppendEvent, (event) => {
169
+ onAppend(event, { showSlider, handleScroll, el });
170
+ });
188
171
  }
189
- }
190
- });
191
- }
192
172
 
193
- init();
173
+ $(window).on('resize', _.debounce(handleResize, 100));
174
+
175
+ $('body').on('click', async (event) => {
176
+ if (shouldClosePopup(event)) {
177
+ if (type === 'cart') {
178
+ await handleSliderClose(events.CLOSE_JUST_ADDED);
179
+ }
180
+
181
+ if (type === 'miniBasket') {
182
+ await handleSliderClose(events.CLOSE_MINI_BASKET);
183
+ }
184
+ }
185
+ });
186
+ }
187
+
188
+ init();
194
189
 
195
- return {
196
- showSlider,
197
- handleScroll,
198
- };
190
+ return {
191
+ showSlider,
192
+ handleScroll,
193
+ };
199
194
  }
@@ -1,17 +1,20 @@
1
+ // this file should be delete after <script defer="defer" src="./js/share-project-list.min.js"></script>
2
+ // implementation on backend (IC-1182 comment https://wickesit.atlassian.net/browse/IC-1182?focusedCommentId=312018)
3
+
1
4
  var Wick = Wick || {};
5
+
2
6
  Wick.ShareProjectList = (function () {
3
-
4
7
  function init() {
5
8
  var shoppingListLinkInput = $('#share-list-modal #shopping-list-link'),
6
9
  shoppingListLinkEl = shoppingListLinkInput[0],
7
10
  linkContainer = $('#copy-link'),
8
11
  actualLink = linkContainer.find('a'),
9
12
  copyClass = 'copy-link_hovered';
10
-
13
+
11
14
  actualLink.click(function (e) {
12
15
  e.preventDefault();
13
16
  });
14
-
17
+
15
18
  linkContainer.click(function () {
16
19
  if (navigator.userAgent.match(/TradeProMobile_iOS|DIYMobile_iOS/i)) {
17
20
  iosCopyToClipboard(shoppingListLinkInput);
@@ -22,7 +25,7 @@ Wick.ShareProjectList = (function () {
22
25
  shoppingListLinkEl.select();
23
26
  }
24
27
 
25
- document.execCommand("copy");
28
+ document.execCommand('copy');
26
29
  actualLink.addClass(copyClass);
27
30
  });
28
31
 
@@ -48,6 +51,6 @@ Wick.ShareProjectList = (function () {
48
51
  el.contentEditable = editable;
49
52
  el.readOnly = readOnly;
50
53
  }
51
-
54
+
52
55
  init();
53
56
  })();