{"version":3,"sources":["webpack://sal/webpack/universalModuleDefinition","webpack://sal/./src/sal.js","webpack://sal/webpack/bootstrap","webpack://sal/webpack/startup","webpack://sal/webpack/runtime/define property getters","webpack://sal/webpack/runtime/hasOwnProperty shorthand"],"names":["root","factory","exports","module","define","amd","this","SSR_MESSAGE","NOT_SUPPORTED_MESSAGE","options","rootMargin","threshold","animateClassName","disabledClassName","enterEventName","exitEventName","selector","once","disabled","elements","intersectionObserver","setOptions","settings","clearAnimation","element","classList","remove","fireEvent","name","entry","event","CustomEvent","bubbles","detail","target","dispatchEvent","disableAnimations","document","body","add","clearObserver","disconnect","isDisabled","onIntersection","entries","observer","forEach","hasRepeatFlag","undefined","dataset","salRepeat","hasOnceFlag","salOnce","shouldRepeat","intersectionRatio","animate","unobserve","reverse","disable","enable","IntersectionObserver","filter","call","querySelectorAll","contains","isAnimated","observe","reset","Array","from","window","console","warn","Error","__webpack_module_cache__","__webpack_require__","moduleId","__webpack_modules__","d","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty"],"mappings":"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","file":"sal.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"sal\"] = factory();\n\telse\n\t\troot[\"sal\"] = factory();\n})(this, function() {\nreturn ","/**\n * Sal - Scroll Animation Library\n * Performance focused, lightweight scroll animation library\n */\n\nimport './sal.scss';\n\nconst SSR_MESSAGE = 'Sal was not initialised! Probably it is used in SSR.';\n\nconst NOT_SUPPORTED_MESSAGE = ''\n + 'Your browser does not support IntersectionObserver!\\n'\n + 'Get a polyfill from here:\\n'\n + 'https://github.com/w3c/IntersectionObserver/tree/master/polyfill';\n\n/**\n * Default options\n */\nlet options = {\n rootMargin: '0% 50%',\n threshold: 0.5,\n animateClassName: 'sal-animate',\n disabledClassName: 'sal-disabled',\n enterEventName: 'sal:in',\n exitEventName: 'sal:out',\n selector: '[data-sal]',\n once: true,\n disabled: false,\n};\n\n/**\n * Private\n */\nlet elements = [];\nlet intersectionObserver = null;\n\n/**\n * Set options\n * @param {Object} settings\n */\nconst setOptions = (settings) => {\n if (settings && settings !== options) {\n options = {\n ...options,\n ...settings,\n };\n }\n};\n\n/**\n * Clear animation for given element\n * @param {HTMLElement} element\n */\nconst clearAnimation = (element) => {\n element.classList.remove(options.animateClassName);\n};\n\n/**\n * Dispatches the animate event on the intersection observer entry.\n * @param {IntersectionObserverEntry} detail The entry to fire event on.\n */\nconst fireEvent = (name, entry) => {\n const event = new CustomEvent(name, {\n bubbles: true,\n detail: entry,\n });\n\n entry.target.dispatchEvent(event);\n};\n\n/**\n * Launch animation by adding class\n * @param {IntersectionObserverEntry} entry\n */\nconst animate = (entry) => {\n entry.target.classList.add(options.animateClassName);\n fireEvent(options.enterEventName, entry);\n};\n\n/**\n * Reverse animation by removing class\n * @param {IntersectionObserverEntry} entry\n */\nconst reverse = (entry) => {\n clearAnimation(entry.target);\n fireEvent(options.exitEventName, entry);\n};\n\n/**\n * Check if element was animated\n * @param {HTMLElement} element\n */\nconst isAnimated = (element) => (\n element.classList.contains(options.animateClassName)\n);\n\n/**\n * Enable animations by remove class from body\n */\nconst enableAnimations = () => {\n document.body.classList.remove(options.disabledClassName);\n};\n\n/**\n * Disable animations by add class from body\n */\nconst disableAnimations = () => {\n document.body.classList.add(options.disabledClassName);\n};\n\n/**\n * Clears observer\n */\nconst clearObserver = () => {\n intersectionObserver.disconnect();\n intersectionObserver = null;\n};\n\n/**\n * Check if should be disabled\n * @return {Boolean}\n */\nconst isDisabled = () => (\n options.disabled\n || (\n (typeof options.disabled === 'function')\n && options.disabled()\n )\n);\n\n/**\n * IntersectionObserver callback\n * @param {Array} entries\n * @param {IntersectionObserver} observer\n */\nconst onIntersection = (entries, observer) => {\n entries.forEach((entry) => {\n const { target } = entry;\n const hasRepeatFlag = target.dataset.salRepeat !== undefined;\n const hasOnceFlag = target.dataset.salOnce !== undefined;\n const shouldRepeat = hasRepeatFlag || !(hasOnceFlag || options.once);\n\n if (entry.intersectionRatio >= options.threshold) {\n animate(entry);\n\n if (!shouldRepeat) {\n observer.unobserve(target);\n }\n } else if (shouldRepeat) {\n reverse(entry);\n }\n });\n};\n\n/**\n * Disable sal\n */\nconst disable = () => {\n disableAnimations();\n clearObserver();\n};\n\n/**\n * Enable sal by launching new IntersectionObserver\n */\nconst enable = () => {\n enableAnimations();\n\n intersectionObserver = new IntersectionObserver(onIntersection, {\n rootMargin: options.rootMargin,\n threshold: options.threshold,\n });\n\n elements = [].filter.call(\n document.querySelectorAll(options.selector),\n (element) => !isAnimated(element, options.animateClassName),\n );\n\n elements.forEach((element) => intersectionObserver.observe(element));\n};\n\n/**\n * Reset instance and provide new settings\n * @param {Object} settings\n */\nconst reset = (settings = {}) => {\n clearObserver();\n\n Array.from(document.querySelectorAll(options.selector))\n .forEach(clearAnimation);\n\n setOptions(settings);\n enable();\n};\n\n/**\n * Init\n * @param {Object} settings\n * @return {Object} public API\n */\nconst init = (settings = options) => {\n setOptions(settings);\n\n // Early return, when window object is not defined\n // e.g. during Server Side Rendering\n if (typeof window === 'undefined') {\n // eslint-disable-next-line no-console\n console.warn(SSR_MESSAGE);\n\n return {\n elements,\n disable,\n enable,\n reset,\n };\n }\n\n if (!window.IntersectionObserver) {\n disableAnimations();\n\n throw Error(NOT_SUPPORTED_MESSAGE);\n }\n\n if (!isDisabled()) {\n enable();\n } else {\n disableAnimations();\n }\n\n return {\n elements,\n disable,\n enable,\n reset,\n };\n};\n\nexport default init;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(855);\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)"],"sourceRoot":""}