wickes-css2 2.105.0-develop.7 → 2.105.0-develop.8

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 (211) hide show
  1. package/Readme.md +2 -2
  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/my-account-v2.css +1 -1
  9. package/build/css/pages/page_discount.css +1 -1
  10. package/build/css/pages/page_product_search.css +1 -1
  11. package/build/css/pages/page_products-list-combined.css +1 -1
  12. package/build/css/pages/page_products-list.css +1 -1
  13. package/build/css/pages/tradePro-rewards.css +1 -1
  14. package/build/css/pdp-main-before-combine.css +1 -1
  15. package/build/css/pdp-main-non-critical.css +1 -1
  16. package/build/css/pdp-main.css +1 -1
  17. package/build/css/plp-main.css +1 -1
  18. package/build/css/store-locator-main.css +1 -1
  19. package/build/js/basket.min.js +2 -2
  20. package/build/js/bundle.min.js +1 -1
  21. package/build/js/checkout.min.js +2 -2
  22. package/build/js/emulation.min.js +10255 -10784
  23. package/build/js/general.bundle.min.js +1 -1
  24. package/build/js/kitchen/kitchen-plp.min.js +9 -1
  25. package/build/js/merged-checkout.min.js +2 -2
  26. package/build/js/mini-basket-slider.min.js +1 -1
  27. package/build/js/my-account.min.js +1 -1
  28. package/build/js/page/accordion.js +35 -0
  29. package/build/js/page/basket/basket-update-cart-action.js +56 -59
  30. package/build/js/page/basket/basket-update-cart.js +27 -27
  31. package/build/js/page/basket/basket-utils.js +33 -40
  32. package/build/js/page/basket/mini-basket-total.js +66 -70
  33. package/build/js/page/basket/quantity-change-handler.js +55 -73
  34. package/build/js/page/basket/update-quantity-operation.js +30 -39
  35. package/build/js/page/basket/update-quantity.js +62 -62
  36. package/build/js/page/basket-v2.js +229 -362
  37. package/build/js/page/billie-business-type.js +27 -27
  38. package/build/js/page/checkout-payment-details.js +299 -301
  39. package/build/js/page/components/discounts.js +36 -39
  40. package/build/js/page/components/mini-basket-slider.js +545 -604
  41. package/build/js/page/kitchen/plp-filters-chips.js +90 -0
  42. package/build/js/page/kitchen/plp-filters-mobile.js +72 -0
  43. package/build/js/page/kitchen/plp-filters-panel.js +119 -0
  44. package/build/js/page/kitchen/plp-filters-utils.js +65 -0
  45. package/build/js/page/kitchen/plp-filters.js +205 -0
  46. package/build/js/page/kitchen/sort-by.js +157 -0
  47. package/build/js/page/klarna-modal-scroll-disable.js +4 -4
  48. package/build/js/page/my-account.js +14 -29
  49. package/build/js/page/online-exclusive.js +30 -28
  50. package/build/js/page/tradePro-rewards.js +39 -69
  51. package/build/js/page/utils/copy-to-clipboard.js +47 -79
  52. package/build/js/page/utils/helpers.js +9 -14
  53. package/build/js/pdp.bundle.min.js +1 -1
  54. package/build/js/plp.bundle.min.js +1 -1
  55. package/build/js/project-list.min.js +85 -143
  56. package/build/js/tradePro-rewards.min.js +1 -1
  57. package/package.json +3 -3
  58. package/src/components/.DS_Store +0 -0
  59. package/src/components/accordion.hbs +2 -2
  60. package/src/components/kitchen/dropdown.hbs +3 -6
  61. package/src/components/kitchen/filter-modal.hbs +13 -10
  62. package/src/components/kitchen/plp-filters.hbs +1 -3
  63. package/src/components/kitchen/sort-by.hbs +1 -1
  64. package/src/components/my-account/barcode.hbs +1 -3
  65. package/src/components/my-account/cards-swap.hbs +10 -0
  66. package/src/components/my-account/clipboard-code-card.hbs +3 -3
  67. package/src/components/my-account/discount.hbs +1 -1
  68. package/src/components/my-account/greetings.hbs +1 -1
  69. package/src/components/search-filter.hbs +112 -121
  70. package/src/data/data_plp_load-more.json +1 -1
  71. package/src/data/my-account/data_my-account.json +9 -0
  72. package/src/js/components/cards-swap.js +72 -0
  73. package/src/js/components/general/accordion.js +33 -44
  74. package/src/js/components/general/cart-slider.js +16 -19
  75. package/src/js/components/general/create-popup-slider.js +173 -168
  76. package/src/js/components/general/search-filter.js +21 -0
  77. package/src/js/components/share-project-list.js +53 -0
  78. package/src/js/emulation/big-wins.js +904 -1081
  79. package/src/js/emulation/billie-modal.js +19 -23
  80. package/src/js/emulation/checkout-payment-details.js +38 -47
  81. package/src/js/emulation/custom-slider-emulation.js +13 -17
  82. package/src/js/emulation/forms.js +323 -360
  83. package/src/js/emulation/mini-basket-data.js +923 -1051
  84. package/src/js/emulation/paymentLoader.js +17 -17
  85. package/src/js/emulation/pdf-file-loader.js +91 -89
  86. package/src/js/emulation/popover-mini-basket.js +239 -246
  87. package/src/js/emulation/project-list-pdp.js +316 -320
  88. package/src/js/emulation/repayment-toggle.js +24 -23
  89. package/src/js/emulation/selectable.js +18 -22
  90. package/src/js/emulation/wismo-details.js +31 -23
  91. package/src/js/page/accordion.js +35 -0
  92. package/src/js/page/basket/basket-update-cart-action.js +56 -59
  93. package/src/js/page/basket/basket-update-cart.js +27 -27
  94. package/src/js/page/basket/basket-utils.js +33 -40
  95. package/src/js/page/basket/mini-basket-total.js +66 -70
  96. package/src/js/page/basket/quantity-change-handler.js +55 -73
  97. package/src/js/page/basket/update-quantity-operation.js +30 -39
  98. package/src/js/page/basket/update-quantity.js +62 -62
  99. package/src/js/page/basket-v2.js +229 -362
  100. package/src/js/page/billie-business-type.js +27 -27
  101. package/src/js/page/checkout-payment-details.js +299 -301
  102. package/src/js/page/components/discounts.js +36 -39
  103. package/src/js/page/components/mini-basket-slider.js +545 -604
  104. package/src/js/page/kitchen/plp-filters-chips.js +90 -0
  105. package/src/js/page/kitchen/plp-filters-mobile.js +72 -0
  106. package/src/js/page/kitchen/plp-filters-panel.js +119 -0
  107. package/src/js/page/kitchen/plp-filters-utils.js +65 -0
  108. package/src/js/page/kitchen/plp-filters.js +205 -0
  109. package/src/js/page/kitchen/sort-by.js +157 -0
  110. package/src/js/page/klarna-modal-scroll-disable.js +4 -4
  111. package/src/js/page/my-account.js +14 -29
  112. package/src/js/page/online-exclusive.js +30 -28
  113. package/src/js/page/tradePro-rewards.js +39 -69
  114. package/src/js/page/utils/copy-to-clipboard.js +47 -79
  115. package/src/js/page/utils/helpers.js +9 -14
  116. package/src/page_empty-shared-project-list-bicester-hub.html +0 -4
  117. package/src/page_empty-shopping-list_guest.html +0 -1
  118. package/src/page_kitchen-plp.html +2 -2
  119. package/src/page_my-account-installer.html +1 -1
  120. package/src/page_my-account-trade-pro-carousel-double.html +127 -0
  121. package/src/page_my-account-trade-pro-carousel.html +134 -0
  122. package/src/page_my-account-trade-pro.html +1 -1
  123. package/src/page_my-shopping-list-add-notes.html +0 -1
  124. package/src/page_my-shopping-list-energy.html +0 -1
  125. package/src/page_my-shopping-list-hide-download.html +1 -2
  126. package/src/page_my-shopping-list-pdf.html +0 -2
  127. package/src/page_my-shopping-list-saved-ref.html +0 -1
  128. package/src/page_my-shopping-list-wisdom-oos-registered.html +0 -1
  129. package/src/page_my-shopping-list-wisdom-oos.html +0 -1
  130. package/src/page_my-shopping-list-wisdom-partial-registered.html +0 -1
  131. package/src/page_my-shopping-list-wisdom-registered.html +0 -1
  132. package/src/page_my-shopping-list-wisdom.html +0 -1
  133. package/src/page_my-shopping-list.html +0 -1
  134. package/src/page_my-shopping-list_not-register.html +0 -3
  135. package/src/page_plp-with-paint.html +7 -2
  136. package/src/page_plp.html +7 -2
  137. package/src/page_plp_v2-energy-efficiency.html +6 -1
  138. package/src/page_plp_v2-favourite-products.html +7 -6
  139. package/src/page_plp_v2-vat.html +7 -2
  140. package/src/page_plp_v2.html +9 -22
  141. package/src/page_product_search-vat.html +7 -2
  142. package/src/page_product_search.html +7 -2
  143. package/src/page_project-list-generate-project-list-ID.html +0 -3
  144. package/src/page_project-list-vat.html +0 -4
  145. package/src/page_project-list-with-new-share-popup-android.html +1 -3
  146. package/src/page_project-list-with-new-share-popup-ios.html +1 -3
  147. package/src/page_project-list-with-new-share-popup.html +1 -2
  148. package/src/page_search-results.html +7 -2
  149. package/src/page_shared-project-list-bicester-hub.html +1 -3
  150. package/src/page_tradepro-discount-app.html +1 -1
  151. package/src/page_tradepro-discount-double.html +109 -0
  152. package/src/page_tradepro-discount.html +36 -2
  153. package/src/scss/common/_common.scss +4 -5
  154. package/src/scss/components/_accordion.scss +3 -1
  155. package/src/scss/components/_custom-slider.scss +14 -15
  156. package/src/scss/components/_date-selection-add-new-styles.scss +7 -6
  157. package/src/scss/components/_date-selection.scss +1 -1
  158. package/src/scss/components/_popover-mini-basket.scss +3 -3
  159. package/src/scss/components/_search-filter.scss +15 -95
  160. package/src/scss/components/checkout-chip.scss +2 -2
  161. package/src/scss/components/checkout-payment-repayment-terms.scss +1 -1
  162. package/src/scss/components/{_filter-modal.scss → kitchen/_filter-modal.scss} +4 -55
  163. package/src/scss/components/{_plp-filters.scss → kitchen/_plp-filters.scss} +13 -31
  164. package/src/scss/components/my-account/_barcode.scss +8 -0
  165. package/src/scss/components/my-account/_cards-swap.scss +58 -0
  166. package/src/scss/components/my-account/_clipboard-code.scss +8 -0
  167. package/src/scss/components/my-account/_discount.scss +10 -0
  168. package/src/scss/globals/_global-components.scss +0 -3
  169. package/src/scss/helpers/_colors-semantic.scss +68 -68
  170. package/src/scss/helpers/_variables.scss +196 -242
  171. package/src/scss/kitchen-plp-main.scss +3 -0
  172. package/src/scss/main.scss +65 -65
  173. package/src/scss/pages/my-account-v2.scss +37 -0
  174. package/src/scss/pages/page_discount.scss +8 -4
  175. package/src/scss/pages/page_product-details-v2.scss +4 -1
  176. package/src/scss/pages/page_product_search.scss +1 -9
  177. package/src/scss/pages/page_products-list-combined.scss +24 -28
  178. package/src/scss/pages/page_products-list.scss +0 -8
  179. package/src/scss/pages/tradePro-rewards.scss +4 -3
  180. package/src/sitemap.html +3 -0
  181. package/build/js/page/filters/desktop-nav.js +0 -64
  182. package/build/js/page/filters/mobile-nav.js +0 -93
  183. package/build/js/page/filters/plp-filters-chips.js +0 -92
  184. package/build/js/page/filters/plp-filters-mobile.js +0 -150
  185. package/build/js/page/filters/plp-filters-panel.js +0 -123
  186. package/build/js/page/filters/plp-filters-utils.js +0 -66
  187. package/build/js/page/filters/plp-filters.js +0 -256
  188. package/build/js/page/filters/sort-by.js +0 -172
  189. package/build/js/page/search-filter.js +0 -62
  190. package/build/js/page/share-project-list.js +0 -57
  191. package/build/js/page/utils/show-more-less.js +0 -273
  192. package/build/js/plp-filters.min.js +0 -9
  193. package/build/js/search-filter.min.js +0 -1
  194. package/src/components/kitchen/filter-modal-content-kitchen.hbs +0 -10
  195. package/src/components/search-filter-modal-content.hbs +0 -102
  196. package/src/elements/btn.hbs +0 -7
  197. package/src/js/emulation/filters-emulation.js +0 -164
  198. package/src/js/emulation/product-counter.js +0 -50
  199. package/src/js/emulation/reset-filter-desktop.js +0 -5
  200. package/src/js/page/filters/desktop-nav.js +0 -64
  201. package/src/js/page/filters/mobile-nav.js +0 -93
  202. package/src/js/page/filters/plp-filters-chips.js +0 -92
  203. package/src/js/page/filters/plp-filters-mobile.js +0 -150
  204. package/src/js/page/filters/plp-filters-panel.js +0 -123
  205. package/src/js/page/filters/plp-filters-utils.js +0 -66
  206. package/src/js/page/filters/plp-filters.js +0 -256
  207. package/src/js/page/filters/sort-by.js +0 -172
  208. package/src/js/page/search-filter.js +0 -62
  209. package/src/js/page/share-project-list.js +0 -57
  210. package/src/js/page/utils/show-more-less.js +0 -273
  211. package/src/scss/components/_sort-by.scss +0 -190
@@ -1,46 +1,35 @@
1
1
  var Wick = Wick || {};
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();
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();
46
35
  })();
@@ -1,23 +1,20 @@
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(
16
- 'scroll',
17
- _.debounce(() => handleScroll(el.sliderWrap), 100)
18
- );
19
- },
20
- onClose: function () {
21
- Wick.MiniBasketSliderFE.cartEntries = [];
22
- },
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
+ }
23
20
  });
@@ -1,194 +1,199 @@
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 */
12
11
  function createPopupSlider({ type, sliderSelector, onAppendEvent, onAppend, onClose }) {
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';
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);
38
79
  }
80
+ }
39
81
 
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)`);
82
+ function showSlider() {
83
+ if (isSmallBreakpoint()) {
84
+ adjustHeight();
46
85
  }
47
86
 
48
- function hideSlider() {
49
- $(el.slider).removeClass('show');
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);
50
92
 
51
- setTimeout(() => {
52
- el.$body.removeClass(el.scrollDisable);
93
+ $('html, body').animate({ scrollTop: 0 }, 300, () => {
94
+ Wick.Backdrop.show();
95
+ $(el.slider).removeClass('d-none');
53
96
 
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
- }
97
+ setTimeout(() => {
98
+ $(el.slider).addClass('show');
99
+ handleScroll(el.sliderWrap);
100
+ el.$body.addClass(el.scrollDisable);
65
101
 
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);
102
+ if (!isSmallBreakpoint()) {
103
+ el.$body.css('padding-right', `${scrollBarWidth}px`);
78
104
  }
79
- }
80
-
81
- function showSlider() {
82
- if (isSmallBreakpoint()) {
83
- adjustHeight();
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();
84
124
  }
125
+ })
126
+ }
85
127
 
86
- const animationClass = getAnimationClass();
87
- const scrollBarWidth = window.innerWidth - document.documentElement.clientWidth;
88
- $(el.slider).removeClass('bottom-to-top right-to-left').addClass(animationClass);
89
-
90
- $('html, body').animate({ scrollTop: 0 }, 300, () => {
91
- Wick.Backdrop.show();
92
- $(el.slider).removeClass('d-none');
128
+ function bindClosePopup() {
129
+ $(document).on('click', el.closePopup, async () => {
130
+ if (type === 'cart') {
131
+ await handleSliderClose(events.CLOSE_JUST_ADDED);
132
+ }
93
133
 
94
- setTimeout(() => {
95
- $(el.slider).addClass('show');
96
- handleScroll(el.sliderWrap);
97
- el.$body.addClass(el.scrollDisable);
134
+ if (type === 'miniBasket') {
135
+ await handleSliderClose(events.CLOSE_MINI_BASKET)
136
+ }
98
137
 
99
- if (!isSmallBreakpoint()) {
100
- el.$body.css('padding-right', `${scrollBarWidth}px`);
101
- }
102
- }, 100);
103
- });
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
+ }
104
157
  }
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
- });
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
+ });
123
176
  }
124
177
 
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
- }
178
+ $(window).on('resize', _.debounce(handleResize, 100));
134
179
 
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
- }
180
+ $('body').on('click', async (event) => {
181
+ if (shouldClosePopup(event)) {
182
+ if (type === 'cart') {
183
+ await handleSliderClose(events.CLOSE_JUST_ADDED);
152
184
  }
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
- }
163
185
 
164
- function init() {
165
- bindClosePopup();
166
-
167
- if (onAppendEvent && onAppend) {
168
- window.addEventListener(onAppendEvent, (event) => {
169
- onAppend(event, { showSlider, handleScroll, el });
170
- });
186
+ if (type === 'miniBasket') {
187
+ await handleSliderClose(events.CLOSE_MINI_BASKET)
171
188
  }
189
+ }
190
+ });
191
+ }
172
192
 
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();
193
+ init();
189
194
 
190
- return {
191
- showSlider,
192
- handleScroll,
193
- };
195
+ return {
196
+ showSlider,
197
+ handleScroll,
198
+ };
194
199
  }
@@ -0,0 +1,21 @@
1
+ var Wick = Wick || {};
2
+ Wick.Overlay = (function () {
3
+ var filterMobile = $('.filter-results_mobile');
4
+ $('#open-overlay').click(function (event) {
5
+ event.preventDefault();
6
+ $('body').addClass('is-filters-visible');
7
+ filterMobile.toggleClass('show');
8
+ });
9
+
10
+ $('#close-overlay, .filter-results__btn-close').click(function (event) {
11
+ event.preventDefault();
12
+ if (filterMobile.hasClass('show')) {
13
+ $('body').removeClass('is-filters-visible');
14
+ filterMobile.removeClass('show');
15
+ }
16
+ });
17
+
18
+ $('.filter-results_desktop .filter__item input[type="checkbox"]').click(function () {
19
+ $(this).closest('form').submit();
20
+ });
21
+ })();
@@ -0,0 +1,53 @@
1
+ var Wick = Wick || {};
2
+ Wick.ShareProjectList = (function () {
3
+
4
+ function init() {
5
+ var shoppingListLinkInput = $('#share-list-modal #shopping-list-link'),
6
+ shoppingListLinkEl = shoppingListLinkInput[0],
7
+ linkContainer = $('#copy-link'),
8
+ actualLink = linkContainer.find('a'),
9
+ copyClass = 'copy-link_hovered';
10
+
11
+ actualLink.click(function (e) {
12
+ e.preventDefault();
13
+ });
14
+
15
+ linkContainer.click(function () {
16
+ if (navigator.userAgent.match(/TradeProMobile_iOS|DIYMobile_iOS/i)) {
17
+ iosCopyToClipboard(shoppingListLinkInput);
18
+ } else if (navigator.userAgent.match(/ipad|ipod|iphone/i)) {
19
+ shoppingListLinkEl.select();
20
+ shoppingListLinkEl.setSelectionRange(0, 999999);
21
+ } else {
22
+ shoppingListLinkEl.select();
23
+ }
24
+
25
+ document.execCommand("copy");
26
+ actualLink.addClass(copyClass);
27
+ });
28
+
29
+ shoppingListLinkInput.click(function () {
30
+ linkContainer.click();
31
+ actualLink.removeClass(copyClass);
32
+ });
33
+ }
34
+
35
+ function iosCopyToClipboard($input) {
36
+ var el = $input.get(0);
37
+ var editable = el.contentEditable;
38
+ var readOnly = el.readOnly;
39
+
40
+ el.contentEditable = true;
41
+ el.readOnly = false;
42
+ var range = document.createRange();
43
+ range.selectNodeContents(el);
44
+ var sel = window.getSelection();
45
+ sel.removeAllRanges();
46
+ sel.addRange(range);
47
+ el.setSelectionRange(0, 999999);
48
+ el.contentEditable = editable;
49
+ el.readOnly = readOnly;
50
+ }
51
+
52
+ init();
53
+ })();