wickes-css2 2.103.0-RG-1658-apply-dynamic-logic-gift-card.1 → 2.103.0-develop.1

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 (79) hide show
  1. package/Readme.md +3 -1
  2. package/build/css/components/card-product-banner.css +1 -1
  3. package/build/css/components/checkout-payment-details-v2.css +1 -1
  4. package/build/css/main.css +1 -1
  5. package/build/css/pages/page_checkout_delivery-new.css +1 -1
  6. package/build/css/pages/page_products-list-combined.css +1 -1
  7. package/build/css/pages/page_products-list.css +1 -1
  8. package/build/css/plp-main.css +1 -1
  9. package/build/js/account-members.min.js +1 -1
  10. package/build/js/add-project-list-id.min.js +1 -1
  11. package/build/js/address-book.min.js +1 -1
  12. package/build/js/basket.min.js +2 -2
  13. package/build/js/bundle.min.js +1 -1
  14. package/build/js/change-password.min.js +1 -1
  15. package/build/js/checkout.min.js +2 -2
  16. package/build/js/emulation.min.js +70 -268
  17. package/build/js/general.bundle.min.js +1 -1
  18. package/build/js/merged-checkout.min.js +2 -2
  19. package/build/js/page/components/order-summary.js +25 -42
  20. package/build/js/page/plp-cards-v2.js +15 -6
  21. package/build/js/page/plp-load-more.js +1 -1
  22. package/build/js/page/utils/validation.js +1 -46
  23. package/build/js/pdp.bundle.min.js +1 -1
  24. package/build/js/personal-details.min.js +1 -1
  25. package/build/js/plp.bundle.min.js +1 -1
  26. package/build/js/project-list.min.js +1 -44
  27. package/build/js/quiz.min.js +1 -1
  28. package/build/js/track-my-order.min.js +1 -1
  29. package/package.json +2 -2
  30. package/src/components/card_product_v2.hbs +10 -5
  31. package/src/components/card_sponsor_banner.hbs +8 -0
  32. package/src/components/card_sponsor_product.hbs +6 -0
  33. package/src/components/checkout-payment-details-v2.hbs +2 -3
  34. package/src/components/injected-content.hbs +1 -1
  35. package/src/data/data_search-results_v2.json +56 -141
  36. package/src/elements/form-row.hbs +1 -1
  37. package/src/elements/input.hbs +2 -31
  38. package/src/js/components/banner-placement-manager.js +258 -0
  39. package/src/js/components/general/notification.js +1 -2
  40. package/src/js/components/toggle-password-visibility.js +58 -0
  41. package/src/js/emulation/banner-placement-manager.js +53 -0
  42. package/src/js/emulation/checkout-payment-details.js +14 -23
  43. package/src/js/emulation/forms.js +2 -7
  44. package/src/js/page/components/order-summary.js +25 -42
  45. package/src/js/page/plp-cards-v2.js +15 -6
  46. package/src/js/page/plp-load-more.js +1 -1
  47. package/src/js/page/utils/validation.js +1 -46
  48. package/src/layouts/checkout.hbs +5 -1
  49. package/src/page_my-account_change-password.html +0 -1
  50. package/src/page_payment-details-with-gift-card.html +4 -7
  51. package/src/page_plp_v2.html +16 -6
  52. package/src/page_search-results.html +12 -2
  53. package/src/scss/components/card-product-banner.scss +91 -3
  54. package/src/scss/components/checkout-payment-details-v2.scss +0 -2
  55. package/src/scss/pages/page_checkout_delivery-new.scss +0 -26
  56. package/src/scss/pages/page_products-list-combined.scss +11 -0
  57. package/src/scss/pages/page_products-list.scss +8 -0
  58. package/build/img/giftcard.svg +0 -28
  59. package/build/js/gift-cards.min.js +0 -1
  60. package/build/js/page/components/gift-cards.js +0 -877
  61. package/build/js/page/components/toggle-password-visibility.js +0 -22
  62. package/build/js/page/utils/gift-cards-utils.js +0 -144
  63. package/build/js/page/utils/input-handling.js +0 -92
  64. package/build/js/page/utils/show-hide-input.js +0 -28
  65. package/build/js/toggle-password-visibility.min.js +0 -1
  66. package/src/components/gift-cards-hint.hbs +0 -9
  67. package/src/components/gift-cards.hbs +0 -90
  68. package/src/components/giftcard-chip.hbs +0 -23
  69. package/src/components/giftcard-summary.hbs +0 -6
  70. package/src/img/giftcard.svg +0 -28
  71. package/src/js/components/product-banner.js +0 -148
  72. package/src/js/emulation/checkout-data.js +0 -35
  73. package/src/js/emulation/gift-cards.js +0 -201
  74. package/src/js/page/components/gift-cards.js +0 -877
  75. package/src/js/page/components/toggle-password-visibility.js +0 -22
  76. package/src/js/page/utils/gift-cards-utils.js +0 -144
  77. package/src/js/page/utils/input-handling.js +0 -92
  78. package/src/js/page/utils/show-hide-input.js +0 -28
  79. package/src/scss/components/_gift-cards.scss +0 -361
@@ -303,6 +303,60 @@ Wick.Autocomplete = (function(){
303
303
  init();
304
304
  })();
305
305
 
306
+ // Simulate prompt for input
307
+ function getInputs() {
308
+ const productBannerPositions = prompt("Enter Product Banner Positions:", "2") || "";
309
+ const sponsorProductPositions = prompt("Enter Sponsor Product Positions (comma-separated):", "6,7,8") || "";
310
+ const sponsorBannerPositions = prompt("Enter Sponsor Banner Positions:", "10") || "";
311
+
312
+ return {
313
+ productBannerPositions: productBannerPositions ? productBannerPositions.split(",").map(Number) : [],
314
+ sponsorProductPositions: sponsorProductPositions ? sponsorProductPositions.split(",").map(Number) : [],
315
+ sponsorBannerPositions: sponsorBannerPositions ? sponsorBannerPositions.split(",").map(Number) : [],
316
+ };
317
+ }
318
+
319
+ function getPositionAttr() {
320
+ const isMobile = Wick.BannerPlacementManager.isMobileResolution();
321
+ return isMobile
322
+ ? 'data-mobile-position'
323
+ : 'data-desktop-position';
324
+ }
325
+
326
+ function updatePositions(inputs) {
327
+ const productBannerElements = document.querySelectorAll(".card-product-banner");
328
+ productBannerElements.forEach((el, index) => {
329
+ if (inputs.productBannerPositions[index] !== undefined) {
330
+ el.setAttribute(getPositionAttr(), inputs.productBannerPositions[index]);
331
+ }
332
+ });
333
+
334
+ const sponsorProductElements = document.querySelectorAll(".card-sponsor-product");
335
+ sponsorProductElements.forEach((el, index) => {
336
+ if (inputs.sponsorProductPositions[index] !== undefined) {
337
+ el.setAttribute(getPositionAttr(), inputs.sponsorProductPositions[index]);
338
+ }
339
+ });
340
+
341
+ const sponsorBannerElements = document.querySelectorAll(".card-sponsor-banner");
342
+ sponsorBannerElements.forEach((el, index) => {
343
+ if (inputs.sponsorBannerPositions[index] !== undefined) {
344
+ el.setAttribute(getPositionAttr(), inputs.sponsorBannerPositions[index]);
345
+ }
346
+ });
347
+ }
348
+
349
+ function init() {
350
+ const inputs = getInputs();
351
+ updatePositions(inputs);
352
+ }
353
+
354
+ $(document).ready(function () {
355
+ if ($('.retail-media .products-list.products-list-v2').length) {
356
+ setTimeout(() => init(), 100)
357
+ }
358
+ });
359
+
306
360
  var Wick = Wick || {};
307
361
  Wick.BasketData = (function () {
308
362
  return {
@@ -3428,42 +3482,6 @@ Wick.checkLocalEnv = (function () {
3428
3482
  }
3429
3483
  })();
3430
3484
 
3431
- var Wick = Wick || {};
3432
- Wick.CheckoutData = (function () {
3433
- return {
3434
- //TODO: update after BE confirmation
3435
- successGiftCardData: {
3436
- "subTotal": "£100.00",
3437
- "deliveryCost": "£4.00",
3438
- "freeDelivery": false,
3439
- "clickAndCollectCost": "FREE",
3440
- "totalForDelivery": "£69.00",
3441
- "totalForClickAndCollect": "FREE",
3442
- "total": "£0.00",
3443
- "vat": "£11.17",
3444
- "deliveryOrder": true,
3445
- "clickAndCollectOrder": false,
3446
- "discountTotal": "£2.00",
3447
- "giftCardApplied": "-£100.00",
3448
- "discounts": [
3449
- "Spend over £10 and get £2 fixed discount"
3450
- ],
3451
- "promotionsInfo": [
3452
- {
3453
- "description": "Spend over £10 and get £2 fixed discount",
3454
- "usedCouponCode": "RT_02"
3455
- }
3456
- ],
3457
- "subTotalWithDeliveryCost": "£69.00",
3458
- "net": false,
3459
- "subtotalWithDeliveryAndDiscounts": "£67.00",
3460
- "discountAmounts": [],
3461
- "goodsTotalWithoutDiscount": "£65.00",
3462
- "charityPrice": ""
3463
- },
3464
- }
3465
- })();
3466
-
3467
3485
  var Wick = Wick || {};
3468
3486
  Wick.DeliveryDetails = (function () {
3469
3487
  var $page = $('.page_checkout-delivery-details');
@@ -3504,33 +3522,24 @@ var Wick = Wick || {};
3504
3522
 
3505
3523
  Wick.PaymentDetails = (function () {
3506
3524
  var $btnEnterDetails = $('.btn-enter-details'),
3525
+ $form = $btnEnterDetails.parents('form'),
3507
3526
  isGuestPage = $('.page_checkout-payment-details_guest').length;
3508
3527
 
3509
3528
  function bindEvents () {
3510
- $btnEnterDetails.on('click', function (e) {
3511
- e.preventDefault();
3512
- var $scope = $(this).closest('form');
3513
- if (!$scope.length) $scope = $(this).closest('.billing-address');
3514
- if (!$scope.length) $scope = $('.billing-address');
3515
- var nameVal= ($scope.find('#card-name').val() || '').trim();
3516
- var finderVal= ($scope.find('#first-line-address').val() || '').trim();
3517
- var manualLine1= ($scope.find('#address-line-1').val() || '').trim();
3518
- var manualTown= ($scope.find('#town-city').val() || '').trim();
3519
- var manualPost= ($scope.find('#postcode_additional').val() || '').trim();
3520
- var addressFinderOk = finderVal.length > 0;
3521
- var addressManualOk = manualLine1 && manualTown && manualPost;
3522
-
3523
- if (nameVal && (addressFinderOk || addressManualOk)) {
3524
- var $details = $('.checkout-payment-details__card-details');
3525
- $details.removeClass('checkout-payment-details__card-details_hidden');
3526
- $('html, body').animate({ scrollTop: $details.offset().top - 15 }, 700);
3527
- return;
3528
- }
3529
-
3530
- var formEl = $scope.closest('form').get(0) || $scope.get(0);
3531
- if (formEl && Wick.Forms && Wick.Forms.showValidationErrors) {
3532
- Wick.Forms.showValidationErrors(formEl);
3529
+ $btnEnterDetails.on('click', function(){
3530
+ if ($form.find('#card-name').val().length &&
3531
+ $form.find('#first-line-address').val().length &&
3532
+ $form.find('#address-line-1').val().length &&
3533
+ $form.find('#town-city').val().length &&
3534
+ $form.find('#postcode_additional').val().length){
3535
+ $('.checkout-payment-details__card-details').removeClass('checkout-payment-details__card-details_hidden');
3536
+ $('html, body').animate({
3537
+ scrollTop: $('.checkout-payment-details__card-details').offset().top - 15
3538
+ }, 700);
3539
+ return false;
3533
3540
  }
3541
+ Wick.Forms.showValidationErrors($form[0]);
3542
+ return false;
3534
3543
  });
3535
3544
 
3536
3545
  $('.checkout-payment-details__card-details').on('submit', function(){
@@ -4067,16 +4076,11 @@ Wick.Forms = (function(){
4067
4076
 
4068
4077
  var showValidationErrors = function (form, errorMsg) {
4069
4078
  var $form = $(form);
4070
- var $rows = $form.find(fieldRow).not('[data-no-global-validation]');
4071
- if (!$rows.length) return;
4072
- $rows.find('.form-row__error').remove();
4073
-
4074
4079
  if (!$form.hasClass(formInvalid)) {
4075
- $form.addClass(formInvalid);
4080
+ $form.find('.form-row__error').remove();
4081
+ $form.addClass(formInvalid).find(fieldRow).append(validationError(errorMsg)).addClass(rowValidationError);
4076
4082
  }
4077
4083
 
4078
- $rows.append(validationError(errorMsg)).addClass(rowValidationError);
4079
-
4080
4084
  var $firstMsg = $form.find(fieldRow).first();
4081
4085
  if($firstMsg.length && !isElementInViewport($firstMsg)){
4082
4086
  var inModal = $firstMsg.closest('.modal').length,
@@ -4386,208 +4390,6 @@ $(document).ready(function () {
4386
4390
  Wick.GenerateProjectIdLocal.init();
4387
4391
  });
4388
4392
 
4389
- (function () {
4390
- if (!window.Wick) return;
4391
-
4392
- const M_OK = '0000000000000001';
4393
- const M_ZERO_BALANCE = '0000000000000000';
4394
- const M_NOT_RECOGNISED = '1111111111111111';
4395
- const M_LOCKED = '2222222222222222';
4396
- const M_MERCHANT_ISSUE = '3333333333333333';
4397
- const M_EXCHANGE = '4040404040404040';
4398
- const M_EXPIRED = '4444444444444444';
4399
- const M_INVALID = '5555555555555555';
4400
- const M_ADDED = '6666666666666666';
4401
- const M_CONFIG_PROBLEM = '9999999999999999';
4402
-
4403
- const M_PAY_ERR_101 = '7777777777777101';
4404
- const M_PAY_ERR_102 = '7777777777777102';
4405
- const M_PAY_ERR_103 = '7777777777777103';
4406
-
4407
- const PAY_ERROR_CARD_MAP = {
4408
- [M_PAY_ERR_101]: 101,
4409
- [M_PAY_ERR_102]: 102,
4410
- [M_PAY_ERR_103]: 103,
4411
- };
4412
-
4413
- const GIFT_CARDS_LIMIT = 3;
4414
- const BASE_ORDER_TOTAL = 300.00;
4415
-
4416
- let PAY_ERROR_CODE;
4417
-
4418
- const mock = {
4419
- orderTotal: BASE_ORDER_TOTAL,
4420
- giftCardTotal: 0.00,
4421
- giftCards: [],
4422
- };
4423
-
4424
- const toMasked = (num) => `************${String(num || '').slice(-5)}`;
4425
-
4426
- function recomputeTotalsAndOrder() {
4427
- mock.giftCardTotal = mock.giftCards.reduce((sum, c) => sum + Number(c.amountToRedeem || 0), 0);
4428
- const remaining = Math.max(0, BASE_ORDER_TOTAL - mock.giftCardTotal);
4429
- mock.orderTotal = Number(remaining.toFixed(2));
4430
- }
4431
-
4432
- function applyWithClamp(requestedAmount) {
4433
- const remaining = Math.max(0, BASE_ORDER_TOTAL - mock.giftCardTotal);
4434
- const applied = Math.min(Number(requestedAmount || 0), remaining);
4435
- return Number(applied.toFixed(2));
4436
- }
4437
-
4438
- function successPayload() {
4439
- return {
4440
- orderTotal: mock.orderTotal,
4441
- giftCardTotal: mock.giftCardTotal,
4442
- giftCards: mock.giftCards.slice()
4443
- };
4444
- }
4445
-
4446
- function getGiftCardErrorCode(giftCardNumber) {
4447
- switch (giftCardNumber) {
4448
- case M_NOT_RECOGNISED:
4449
- return 10;
4450
- case M_LOCKED:
4451
- return 16;
4452
- case M_MERCHANT_ISSUE:
4453
- return 20;
4454
- case M_EXCHANGE:
4455
- return 40;
4456
- case M_EXPIRED:
4457
- return 60;
4458
- case M_INVALID:
4459
- return 99;
4460
- case M_ADDED:
4461
- return 89;
4462
- case M_CONFIG_PROBLEM:
4463
- return -1;
4464
- default:
4465
- return null;
4466
- }
4467
- }
4468
-
4469
- function addGiftCardMock(giftCardNumber) {
4470
- const errorCode = getGiftCardErrorCode(giftCardNumber);
4471
-
4472
- let requested;
4473
- if (giftCardNumber === M_OK) {
4474
- requested = 123.45;
4475
- } else if (giftCardNumber === M_ZERO_BALANCE) {
4476
- requested = 0;
4477
- } else {
4478
- requested = 50.00;
4479
- }
4480
-
4481
- if (mock.giftCards.length >= GIFT_CARDS_LIMIT) {
4482
- return Promise.reject({ code: 20 });
4483
- }
4484
-
4485
- const beforeTotal = mock.giftCardTotal;
4486
- const applied = applyWithClamp(requested);
4487
-
4488
- mock.giftCards.push({
4489
- id: (Date.now() + Math.random()).toString(36),
4490
- maskedNumber: toMasked(giftCardNumber),
4491
- amountToRedeem: applied,
4492
- originalNumber: giftCardNumber,
4493
- });
4494
-
4495
- if (mock.giftCards.length === GIFT_CARDS_LIMIT) {
4496
- const leftover = Math.max(0, BASE_ORDER_TOTAL - (beforeTotal + applied));
4497
- if (leftover > 0) {
4498
- const last = mock.giftCards[mock.giftCards.length - 1];
4499
- last.amountToRedeem = Number((Number(last.amountToRedeem) + leftover).toFixed(2));
4500
- }
4501
- mock.giftCardTotal = BASE_ORDER_TOTAL;
4502
- mock.orderTotal = 0;
4503
- return Promise.resolve(successPayload());
4504
- }
4505
-
4506
- recomputeTotalsAndOrder();
4507
- return Promise.resolve(successPayload());
4508
- }
4509
-
4510
- function removeGiftCardMock(index) {
4511
- const beforeLen = mock.giftCards.length;
4512
- if (index < 0 || index >= beforeLen) return Promise.reject({ code: 20 });
4513
-
4514
- mock.giftCards.splice(index, 1);
4515
- recomputeTotalsAndOrder();
4516
- return Promise.resolve(successPayload());
4517
- }
4518
-
4519
- function anyPayErrorCardApplied() {
4520
- for (const gc of mock.giftCards) {
4521
- const code = PAY_ERROR_CARD_MAP[gc.originalNumber];
4522
- if (Number.isFinite(code)) return code;
4523
- }
4524
- return undefined;
4525
- }
4526
-
4527
- function initGiftCardMock() {
4528
- if (!$('.giftcard-row, .giftcard').length) return;
4529
-
4530
- $(window).off(Wick.GiftCard.ADD_GIFT_CARD);
4531
- $(window).off(Wick.GiftCard.REMOVE_GIFT_CARD);
4532
- $(window).off(Wick.GiftCard.PAY_WITH_GIFT_CARD);
4533
-
4534
- $(window).on(Wick.GiftCard.ADD_GIFT_CARD, function (e) {
4535
- const payload = (e.detail && e.detail.payload) || {};
4536
- const giftCardNumber = payload.giftCardNumber;
4537
- setTimeout(function () {
4538
- addGiftCardMock(giftCardNumber)
4539
- .then(function (p) { e.detail.resolve(Object.assign({ code: 0 }, p)); })
4540
- .catch(function (err) { e.detail.reject(err); });
4541
- }, 1000);
4542
- });
4543
-
4544
- $(window).on(Wick.GiftCard.REMOVE_GIFT_CARD, function (e) {
4545
- const payload = (e.detail && e.detail.payload) || {};
4546
- const index = Number(payload.index);
4547
- setTimeout(function () {
4548
- removeGiftCardMock(index)
4549
- .then(function (p) { e.detail.resolve(Object.assign({ code: 0 }, p)); })
4550
- .catch(function (err) { e.detail.reject(err); });
4551
- }, 1000);
4552
- });
4553
-
4554
- $(window).on(Wick.GiftCard.PAY_WITH_GIFT_CARD, function (e) {
4555
- setTimeout(function () {
4556
- const forcedErrorFromCard = anyPayErrorCardApplied();
4557
- if (Number.isFinite(forcedErrorFromCard)) {
4558
- return e.detail.reject({
4559
- errorCode: forcedErrorFromCard,
4560
- giftCards: mock.giftCards.slice(),
4561
- });
4562
- }
4563
-
4564
- if (Number(mock.orderTotal) === 0) {
4565
- e.detail.resolve({ url: 'page_checkout_confirmation-billie.html' });
4566
- } else {
4567
- const errorCode = Number.isFinite(PAY_ERROR_CODE) ? PAY_ERROR_CODE : undefined;
4568
- e.detail.reject({
4569
- errorCode,
4570
- giftCards: mock.giftCards.slice(),
4571
- });
4572
- }
4573
- }, 1000);
4574
- });
4575
- }
4576
-
4577
- $(document).ready(function () {
4578
- mock.giftCards = [];
4579
- recomputeTotalsAndOrder();
4580
-
4581
- Wick.GiftCard.init({
4582
- giftCardsLimit: GIFT_CARDS_LIMIT,
4583
- errorCode: PAY_ERROR_CODE,
4584
- giftCards: mock.giftCards.slice()
4585
- });
4586
- });
4587
-
4588
- $(document).ready(initGiftCardMock);
4589
- })();
4590
-
4591
4393
  const suggestions = [
4592
4394
  {
4593
4395
  value: 'lintel',