{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./cartridges/app_core/cartridge/client/default/js/experience/components/commerceLayouts/tabbedContent.js","webpack:///./cartridges/app_core/cartridge/client/default/js/helpers/viewport.js"],"names":[],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFa;;AAEb,qBAAqB,mBAAO,CAAC,wGAA2B;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA,qBAAqB;AACrB;AACA,qBAAqB;;AAErB;AACA;AACA,qBAAqB;;AAErB;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;;AAEb,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;;AAEjB;AACA;AACA;AACA;AACA,iBAAiB;AACjB,aAAa;AACb,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,qDAAqD,kBAAkB;AACvE;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,qDAAqD,cAAc;AACnE;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA,SAAS;;AAET;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA,SAAS;;AAET;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;AACA,CAAC;;;;;;;;;;;;;AC5OY;;AAEb;AACA;AACA;AACA;AACA","file":"default/js/experience/components/commerceLayouts/tabbedContent.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./cartridges/app_core/cartridge/client/default/js/experience/components/commerceLayouts/tabbedContent.js\");\n","'use strict';\n\nvar viewPortHelper = require('../../../helpers/viewport');\n\n/**\n * Initialize tabbed content\n */\nfunction initTabs() {\n // Get all tabbedContent instances\n var $tabGroups = $('.experience-commerce_layouts-tabbedContent');\n var dragMoved = false; // monitor if tab is being dragged or clicked on mobile\n $tabGroups.each(function (idx) {\n // Get tabs & panels for the tab group\n var $tabs = $(this).find('.tabs .experience-commerce_assets-tab');\n var $panels = $(this).find('.tab-panels .experience-commerce_layouts-tabPanel');\n\n // Set tab nav\n $tabs.each(function (tabIdx) {\n var tabID = 'tab-' + idx + '-' + tabIdx;\n var defaultMobileState = $($tabs[tabIdx]).find('.tab').attr('data-defaultActive');\n\n // Set tab attributes\n $(this).attr({\n 'data-id': tabID,\n 'aria-controls': tabID,\n 'aria-expanded': 'false'\n });\n\n // Set panel attributes | mobile tab labels\n $($panels[tabIdx]).attr('id', tabID).find('.tab-panel .tab-anchor--mobile')\n .attr('data-id', tabID).text($($tabs[tabIdx]).find('.tab-anchor').text()).removeClass('d-none')\n .parent().attr('data-defaultActive', defaultMobileState);\n\n\n // Set tab action\n $(this).find('.tab-anchor').on('click', function() {\n if (!dragMoved){\n $($tabGroups[idx]).find('.tabs .js-active').removeClass('js-active').attr('aria-expanded', function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n });\n $($tabGroups[idx]).find('.tab-panels .js-active').removeClass('js-active').attr('aria-expanded', function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n }).find('.tab-anchor--mobile').attr('aria-expanded', function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n });\n\n $($tabs[tabIdx]).addClass('js-active').attr('aria-expanded', function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n });\n\n $($panels[tabIdx]).addClass('js-active').attr({\n 'aria-expanded': function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n }\n }).find('.fade-in-up').addClass('visible');\n }\n });\n\n });\n\n // Set panel mobile nav\n $panels.each(function (pnlIdx) {\n // Set mobile tab action\n $(this).find('.tab-anchor--mobile').on('click', function() {\n\n $($tabs[pnlIdx]).toggleClass('js-active').attr({\n 'aria-expanded': function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n }\n });\n\n $($panels[pnlIdx]).toggleClass('js-active').attr({\n 'aria-visible': function(i, attr){\n return attr == 'true' ? 'false' : 'true';\n }\n });\n });\n });\n\n // Set defaults on init\n if (viewPortHelper.isDesktop()) {\n // Set first active tab\n $($tabs[0]).addClass('js-active').attr('aria-expanded', true);\n $($panels[0]).addClass('js-active').attr('aria-visible', true);\n } else {\n // Set active tabs based on default value configured for mobile\n $panels.each(function (pnlIdx) {\n var defaultActive = $(this).find('.tab-panel').attr('data-defaultactive');\n\n if (defaultActive === 'true') {\n $($tabs[pnlIdx]).addClass('js-active').attr('aria-expanded', true);\n $($panels[pnlIdx]).addClass('js-active').attr('aria-visible', true);\n }\n });\n }\n\n });\n\n $(window).smartresize(function() {\n // Mobile tab functionality allows multiple active tabs (accordion UI) but desktop functionality only allows a single active tab.\n // Multiple active tabs should be cleared on desktop in the case where resize triggers desktop viewport and multiple active tabs are present.\n\n if (viewPortHelper.isDesktop()) {\n $($tabGroups).each(function(index) {\n // Get tabs & panels for the tab group\n var activeTabs = $(this).find('.tabs .experience-commerce_assets-tab.js-active');\n var activePanels = $(this).find('.tab-panels .experience-commerce_layouts-tabPanel.js-active');\n var activePanelCount = activePanels.length;\n\n // Clear multiple active tab panels if present\n if (activePanelCount > 0) {\n // Keep only first active tab\n activeTabs.each(function(tIdx) {\n if (tIdx > 0) {\n $(this).removeClass('js-active').attr('aria-expanded', false);\n }\n });\n // Keep only first active panel\n activePanels.each(function(pIdx) {\n if (pIdx > 0) {\n $(this).removeClass('js-active').attr('aria-visible', false);\n }\n });\n } else {\n // Activate first tabs if no active tabs exist\n $(this).find('.tabs .experience-commerce_assets-tab').first().addClass('js-active').attr('aria-expanded', true);\n $(this).find('.tab-panels .experience-commerce_layouts-tabPanel').first().addClass('js-active').attr('aria-visible', true);\n }\n });\n }\n });\n \n // get all tabs that are tab view enabled for mobile\n var $mobileTabs = $(\".tab-view-enabled .tabs.row\");\n $mobileTabs.each(function () {\n const parent = $(this);\n const draggable = parent.find(\".draggableTabs\");\n\n let isDragging = false;\n let startX = 0;\n let currentTranslateX = 0;\n let newTranslateX = 0;\n\n let parentWidth = 0;\n let draggableWidth = 0;\n\n let minDrag = 0;\n const maxDrag = 0;\n\n // Recalculate dimensions and boundaries\n const updateDimensions = () => {\n parentWidth = parent.width();\n draggableWidth = draggable.get(0).scrollWidth;\n minDrag = -(draggableWidth - parentWidth);\n\n // Ensure draggable doesn't exceed boundaries on resize\n if (currentTranslateX < minDrag) currentTranslateX = minDrag;\n if (currentTranslateX > maxDrag) currentTranslateX = maxDrag;\n\n draggable.css(\"transform\", `translateX(${currentTranslateX}px)`);\n };\n\n $(window).on(\"load resize\", updateDimensions);\n\n // Handle start of drag\n const startDrag = (pageX) => {\n isDragging = true;\n startX = pageX;\n draggable.css(\"cursor\", \"grabbing\");\n };\n\n // Apply transform with requestAnimationFrame\n const applyTransform = () => {\n draggable.css(\"transform\", `translateX(${newTranslateX}px)`);\n };\n\n // Handle dragging\n const doDrag = (pageX) => {\n if (!isDragging) return;\n\n const deltaX = pageX - startX;\n newTranslateX = currentTranslateX + deltaX;\n\n // Clamp to boundaries\n if (newTranslateX > maxDrag) newTranslateX = maxDrag;\n if (newTranslateX < minDrag) newTranslateX = minDrag;\n\n requestAnimationFrame(applyTransform);\n };\n\n // Handle end of drag\n const endDrag = () => {\n if (!isDragging) return;\n\n isDragging = false;\n currentTranslateX = newTranslateX;\n draggable.css(\"cursor\", \"grab\");\n };\n\n // Mouse events\n draggable.on(\"mousedown\", function (e) {\n startDrag(e.pageX);\n });\n\n $(document).on(\"mousemove\", function (e) {\n doDrag(e.pageX);\n });\n\n $(document).on(\"mouseup\", function () {\n endDrag();\n });\n\n // Touch events\n draggable.on(\"touchstart\", function (e) {\n const touch = e.originalEvent.touches[0];\n startDrag(touch.pageX);\n });\n\n $(document).on(\"touchmove\", function (e) {\n if (!isDragging) return;\n const touch = e.originalEvent.touches[0];\n doDrag(touch.pageX);\n });\n\n $(document).on(\"touchend\", function () {\n endDrag();\n });\n\n // Initialize dimensions on page load\n updateDimensions();\n });\n\n}\n\n$(document).ready(function () {\n initTabs();\n});\n","'use strict';\n\nmodule.exports = {\n isDesktop: function() {\n return window.matchMedia('(min-width: 769px)').matches;\n }\n}\n"],"sourceRoot":""}