{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./cartridges/app_articles/cartridge/client/default/js/experience/components/dynamic/articleTile.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;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,mCAAmC,oCAAoC;AACvE;AACA;AACA;;AAEA;AACA;AACA,mCAAmC,qCAAqC;AACxE;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA,IAAI","file":"default/js/experience/components/dynamic/articleTile.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_articles/cartridge/client/default/js/experience/components/dynamic/articleTile.js\");\n","'use strict';\n\n/**\n * Append URL parameters to the article images based on site preference configuration\n * @param {Object} currentPdArticleTile JQuery Element\n * @param {Object} articleImage object with src values for desktop, tablet, and mobile\n * @returns articleImage object with DIS values appended, if the site preference is set properly\n */\nfunction appendDisConfig(currentPdArticleTile, articleImage) {\n if (articleImage && articleImage.src && articleImage.src.desktop && articleImage.src.tablet && articleImage.src.mobile) {\n let features;\n let parsedArticleBlockDisConfig;\n try {\n features = JSON.parse(document.querySelector('body').dataset.features);\n parsedArticleBlockDisConfig = JSON.parse(features.articleBlockDisConfig);\n } catch (e) {\n console.error('Error parsing articleBlockDisConfig JSON:' + e.message);\n return articleImage;\n }\n if (parsedArticleBlockDisConfig && currentPdArticleTile.closest('.featured-article')) {\n // if it's the featured article, we have different configs to apply\n try {\n articleImage.src.desktop = articleImage.src.desktop + \"?sw=\" + parsedArticleBlockDisConfig.featured.desktop;\n articleImage.src.tablet = articleImage.src.tablet + \"?sw=\" + parsedArticleBlockDisConfig.featured.tablet;\n articleImage.src.mobile = articleImage.src.mobile + \"?sw=\" + parsedArticleBlockDisConfig.featured.mobile;\n } catch (e) {\n console.error('Error assigning articleBlockDisConfig JSON to featured image:' + e.message);\n }\n } else if (parsedArticleBlockDisConfig) {\n try {\n articleImage.src.desktop = articleImage.src.desktop + \"?sw=\" + parsedArticleBlockDisConfig.standard.desktop;\n articleImage.src.tablet = articleImage.src.tablet + \"?sw=\" + parsedArticleBlockDisConfig.standard.tablet;\n articleImage.src.mobile = articleImage.src.mobile + \"?sw=\" + parsedArticleBlockDisConfig.standard.mobile;\n } catch (e) {\n console.error('Error assigning articleBlockDisConfig JSON to standard image:' + e.message);\n }\n }\n }\n return articleImage;\n}\n\n/**\n * Setup feature toggle functionality\n */\nfunction initArticleTile() {\n var $pdArticles = $('.pd.article-data');\n\n if ($pdArticles.length) {\n $pdArticles.each(function () {\n var articleData;\n try {\n articleData = JSON.parse($(this).text());\n } catch (e) {\n return;\n }\n\n var $articleTile = $(this).siblings('.article-tile');\n var articleImage;\n var articleImageAlt;\n var articleTitle;\n var articleDesc;\n var articleBadges;\n var textBadgesExist = false;\n var catBadgesExist = false;\n var articleImageWidth;\n var articleImageHeight;\n\n if (articleData && articleData.custom) {\n articleImage = articleData.custom.articleImage ? articleData.custom.articleImage : null;\n articleImageAlt = articleData.custom.articleImageAlt ? articleData.custom.articleImageAlt : null;\n articleTitle = articleData.custom.articleTitle ? articleData.custom.articleTitle : null;\n articleDesc = articleData.custom.articleDesc ? articleData.custom.articleDesc : null;\n articleImageWidth = articleData.custom.articleImageWidth ? articleData.custom.articleImageWidth : null;\n articleImageHeight = articleData.custom.articleImageHeight ? articleData.custom.articleImageHeight : null;\n if (articleData.custom.articleBadges) {\n articleBadges = articleData.custom.articleBadges;\n }\n articleImage = appendDisConfig(this, articleImage);\n }\n\n $articleTile.removeClass('template').addClass('tile-' + articleData.id);\n\n if (articleImage) {\n $articleTile.find('.content-thumbnail-image').parents('picture').prepend('');\n $articleTile.find('.content-thumbnail-image').parents('picture').prepend('');\n $articleTile.find('.content-thumbnail-image').attr({\n 'data-src': articleImage.src.mobile,\n width: articleImageWidth,\n height: articleImageHeight\n }).addClass('lazyload');\n }\n\n if (articleImageAlt) {\n $articleTile.find('.content-thumbnail-image').attr('alt', articleImageAlt);\n }\n\n if (articleTitle) {\n $articleTile.find('.content-thumbnail-title .content-thumbnail-title-text').text(articleTitle);\n }\n\n if (articleDesc) {\n $articleTile.find('.content-thumbnail-description').append('

' + articleDesc + '

');\n }\n\n if (articleBadges) {\n if (articleBadges.catBadges && articleBadges.catBadges.length > 0) {\n catBadgesExist = true;\n for (let i = 0; i < articleBadges.catBadges.length; i++) {\n $articleTile.find('.content-thumbnail-badges').append('
  • ' + articleBadges.catBadges[i].name + '
  • ');\n }\n }\n\n if (articleBadges.textBadges && articleBadges.textBadges.length > 0) {\n textBadgesExist = true;\n for (let i = 0; i < articleBadges.textBadges.length; i++) {\n $articleTile.find('.content-thumbnail-badges').append('
  • ' + articleBadges.textBadges[i] + '
  • ');\n }\n }\n\n if (!catBadgesExist && !textBadgesExist) {\n $articleTile.find('.content-thumbnail-badges').remove();\n }\n }\n\n if (!articleImage && !catBadgesExist && !textBadgesExist) {\n $articleTile.find('.content-thumbnail-figure').remove();\n }\n });\n }\n}\n\n/**\n * Init Article Blocks\n */\nfunction initArticleBlock() {\n var $pdArticleBlock = $('.article-tiles-block');\n\n if ($pdArticleBlock.length) {\n $pdArticleBlock.each(function () {\n $(this).find('.view-all-articles').on('click', function () {\n $(this).parents('.article-tiles-block').removeClass('hiding-tiles');\n $(this).parents('.article-tiles-block').find('.article-tiles-summary').remove();\n });\n });\n }\n}\n\n$(document).ready(function () {\n initArticleTile();\n initArticleBlock();\n});\n\n// $(window).smartresize(function () {\n// initArticleTile();\n// });\n"],"sourceRoot":""}