{"version":3,"sources":["webpack:///scripts/plugin--observe-grid--d4572b1314bee7510215.js","webpack:///./project/client/src/core/plugins/jquery__observe-grid/plugin.js"],"names":["webpackJsonp","/tool/node_modules/babel-loader/lib/index.js??ref--7-0!/tool/node_modules/eslint-loader/index.js!/tool/project/client/src/core/plugins/jquery__observe-grid/plugin.js","module","exports","__webpack_require__","_interopRequireDefault","obj","__esModule","default","_classCallCheck","instance","Constructor","TypeError","measureWidth","contextElement","cssWidth","test","document","createElement","style","width","appendChild","pixelWidth","offsetWidth","removeChild","_debug","_debug2","_lib","_lib2","_index","log","PLUGIN_NAME","ObserveGrid","element","options","_this","this","min","window","ResizeObserver","wideClass","minToPixels","entries","_iteratorNormalCompletion","_didIteratorError","_iteratorError","undefined","_step","_iterator","Symbol","iterator","next","done","entry","value","rect","contentRect","isWide","classList","toggle","err","return","observe","DEFAULTS"],"mappings":"AAAAA,cAAc,yBAERC,wKACA,SAAUC,EAAQC,EAASC,GAEjC,YAaA,SAASC,GAAuBC,GAAO,MAAOA,IAAOA,EAAIC,WAAaD,GAAQE,QAASF,GAEvF,QAASG,GAAgBC,EAAUC,GAAe,KAAMD,YAAoBC,IAAgB,KAAM,IAAIC,WAAU,qCCdhH,QAASC,GAAaC,EAAgBC,GACrC,GAAMC,GAAOC,SAASC,cAAc,MACpCF,GAAKG,MAAMC,MAAQL,EACnBD,EAAeO,YAAYL,EAC3B,IAAMM,GAAaN,EAAKO,WAExB,OADAT,GAAeU,YAAYR,GACpBM,EAZR,GAAAG,GAAArB,EAAA,4IDUIsB,EAAUrB,EAAuBoB,GCTrCE,EAAAvB,EAAA,uJDaIwB,EAAQvB,EAAuBsB,GCZnCE,EAAAzB,EAAA,wKAEM0B,GAAM,EAAAJ,EAAAlB,SAAA,WAAiBuB,eAWvBC,EACL,QAAAA,GAAYC,EAASC,GAAS,GAAAC,GAAAC,IAI7B,IAJ6B3B,EAAA2B,KAAAJ,GAC7BI,KAAKH,QAAUA,EACfG,KAAKF,QAAUA,EAEU,IAArBE,KAAKF,QAAQG,IAEhB,MADAP,GAAI,4DACG,CAGR,KAAKQ,OAAOC,eAEX,MADAT,GAAI,yCACG,CAGR,IAAMO,GAAMD,KAAKF,QAAQG,IACnBG,EAAYJ,KAAKF,QAAQM,UACzBC,EAAc5B,EAAauB,KAAKH,QAASI,EAEpC,IAAIE,gBAAe,SAAAG,GAAW,GAAAC,IAAA,EAAAC,GAAA,EAAAC,MAAAC,EAAA,KACxC,OAAAC,GAAAC,EAAkBN,EAAlBO,OAAAC,cAAAP,GAAAI,EAAAC,EAAAG,QAAAC,MAAAT,GAAA,EAA2B,IAAlBU,GAAkBN,EAAAO,MAEpBC,EAAOF,EAAMG,YAGbC,EAASF,EAAKnC,MAAQqB,CAG5BN,GAAKF,QAAQyB,UAAUC,OAAOnB,EAAWiB,IATF,MAAAG,GAAAhB,GAAA,EAAAC,EAAAe,EAAA,aAAAjB,GAAAK,EAAAa,QAAAb,EAAAa,SAAA,WAAAjB,EAAA,KAAAC,OAatCiB,QAAQ1B,KAAKH,SAKlBD,GAAY+B,UACXvB,UAAW,qBACXH,IAAK,IAGN,EAAAT,EAAApB,SAAOuB,cAAaC","file":"scripts/plugin--observe-grid--d4572b1314bee7510215.js","sourcesContent":["webpackJsonp([\"plugin--observe-grid\"],{\n\n/***/ \"/tool/node_modules/babel-loader/lib/index.js??ref--7-0!/tool/node_modules/eslint-loader/index.js!/tool/project/client/src/core/plugins/jquery__observe-grid/plugin.js\":\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar _debug = __webpack_require__(\"/tool/node_modules/babel-loader/lib/index.js??ref--7-0!/tool/node_modules/eslint-loader/index.js!/tool/node_modules/debug/src/browser.js\");\n\nvar _debug2 = _interopRequireDefault(_debug);\n\nvar _lib = __webpack_require__(\"/tool/node_modules/babel-loader/lib/index.js??ref--7-0!/tool/node_modules/eslint-loader/index.js!/tool/project/client/src/core/plugins/lib/index.js\");\n\nvar _lib2 = _interopRequireDefault(_lib);\n\nvar _index = __webpack_require__(\"/tool/node_modules/babel-loader/lib/index.js??ref--7-0!/tool/node_modules/eslint-loader/index.js!/tool/project/client/src/core/plugins/jquery__observe-grid/index.js\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar log = (0, _debug2.default)('plugins/' + _index.PLUGIN_NAME);\n\nfunction measureWidth(contextElement, cssWidth) {\n\tvar test = document.createElement('div');\n\ttest.style.width = cssWidth;\n\tcontextElement.appendChild(test);\n\tvar pixelWidth = test.offsetWidth;\n\tcontextElement.removeChild(test);\n\treturn pixelWidth;\n}\n\nvar ObserveGrid = function ObserveGrid(element, options) {\n\tvar _this = this;\n\n\t_classCallCheck(this, ObserveGrid);\n\n\tthis.element = element;\n\tthis.options = options;\n\n\tif (this.options.min === 0) {\n\t\tlog('No minimum specified [data-observe-grid--min]. Aborting');\n\t\treturn false;\n\t}\n\n\tif (!window.ResizeObserver) {\n\t\tlog('ResizeObserver unavailable. Aborting');\n\t\treturn false;\n\t}\n\n\tvar min = this.options.min;\n\tvar wideClass = this.options.wideClass;\n\tvar minToPixels = measureWidth(this.element, min);\n\n\tvar ro = new ResizeObserver(function (entries) {\n\t\tvar _iteratorNormalCompletion = true;\n\t\tvar _didIteratorError = false;\n\t\tvar _iteratorError = undefined;\n\n\t\ttry {\n\t\t\tfor (var _iterator = entries[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n\t\t\t\tvar entry = _step.value;\n\n\t\t\t\t// Get the element's current dimensions\n\t\t\t\tvar rect = entry.contentRect;\n\n\t\t\t\t// `true` if the container is wider than the minimum\n\t\t\t\tvar isWide = rect.width > minToPixels;\n\n\t\t\t\t// toggle the class conditionally\n\t\t\t\t_this.element.classList.toggle(wideClass, isWide);\n\t\t\t}\n\t\t} catch (err) {\n\t\t\t_didIteratorError = true;\n\t\t\t_iteratorError = err;\n\t\t} finally {\n\t\t\ttry {\n\t\t\t\tif (!_iteratorNormalCompletion && _iterator.return) {\n\t\t\t\t\t_iterator.return();\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (_didIteratorError) {\n\t\t\t\t\tthrow _iteratorError;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\n\tro.observe(this.element);\n};\n\nObserveGrid.DEFAULTS = {\n\twideClass: 'is-above-min-width',\n\tmin: 0\n};\n\n(0, _lib2.default)(_index.PLUGIN_NAME, ObserveGrid);\n\n/***/ })\n\n});\n\n\n// WEBPACK FOOTER //\n// scripts/plugin--observe-grid--d4572b1314bee7510215.js","import debug from 'debug';\r\nimport plugin from '@core/plugins/lib';\r\nimport { ELEMENT_SELECTOR, PLUGIN_NAME } from './index';\r\n\r\nconst log = debug(`plugins/${PLUGIN_NAME}`);\r\n\r\nfunction measureWidth(contextElement, cssWidth) {\r\n\tconst test = document.createElement('div');\r\n\ttest.style.width = cssWidth;\r\n\tcontextElement.appendChild(test);\r\n\tconst pixelWidth = test.offsetWidth;\r\n\tcontextElement.removeChild(test);\r\n\treturn pixelWidth;\r\n}\r\n\r\nclass ObserveGrid {\r\n\tconstructor(element, options) {\r\n\t\tthis.element = element;\r\n\t\tthis.options = options;\r\n\r\n\t\tif (this.options.min === 0) {\r\n\t\t\tlog('No minimum specified [data-observe-grid--min]. Aborting');\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tif (!window.ResizeObserver) {\r\n\t\t\tlog('ResizeObserver unavailable. Aborting');\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tconst min = this.options.min;\r\n\t\tconst wideClass = this.options.wideClass;\r\n\t\tconst minToPixels = measureWidth(this.element, min);\r\n\r\n\t\tconst ro = new ResizeObserver(entries => {\r\n\t\t\tfor (let entry of entries) {\r\n\t\t\t\t// Get the element's current dimensions\r\n\t\t\t\tconst rect = entry.contentRect;\r\n\r\n\t\t\t\t// `true` if the container is wider than the minimum\r\n\t\t\t\tconst isWide = rect.width > minToPixels;\r\n\r\n\t\t\t\t// toggle the class conditionally\r\n\t\t\t\tthis.element.classList.toggle(wideClass, isWide);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tro.observe(this.element);\r\n\t}\r\n\r\n}\r\n\r\nObserveGrid.DEFAULTS = {\r\n\twideClass: 'is-above-min-width',\r\n\tmin: 0\r\n};\r\n\r\nplugin(PLUGIN_NAME, ObserveGrid);\r\n\n\n\n// WEBPACK FOOTER //\n// ./project/client/src/core/plugins/jquery__observe-grid/plugin.js"],"sourceRoot":""}