1 line
5.2 KiB
JavaScript
1 line
5.2 KiB
JavaScript
!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.HSQuantityCounter=e():n.HSQuantityCounter=e()}(window,function(){return d={"./src/js/hs-quantity-counter.js":function(module,__webpack_exports__,__webpack_require__){"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return HSQuantityCounter; });\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nvar dataAttributeName = \'data-hs-quantity-counter-options\';\nvar defaults = {\n classMap: {\n plus: \'.js-plus\',\n minus: \'.js-minus\',\n result: \'.js-result\'\n },\n resultVal: null\n};\n\nvar HSQuantityCounter = /*#__PURE__*/function () {\n function HSQuantityCounter(el, options, id) {\n _classCallCheck(this, HSQuantityCounter);\n\n this.collection = [];\n var that = this;\n var elems;\n\n if (el instanceof HTMLElement) {\n elems = [el];\n } else if (el instanceof Object) {\n elems = el;\n } else {\n elems = document.querySelectorAll(el);\n }\n\n for (var i = 0; i < elems.length; i += 1) {\n that.addToCollection(elems[i], options, id || elems[i].id);\n }\n\n if (!that.collection.length) {\n return false;\n } // initialization calls\n\n\n that._init();\n\n return this;\n }\n\n _createClass(HSQuantityCounter, [{\n key: "_init",\n value: function _init() {\n var that = this;\n\n var _loop = function _loop(i) {\n var _$el = void 0;\n\n var _options = void 0;\n\n if (that.collection[i].hasOwnProperty(\'$initializedEl\')) {\n return "continue";\n }\n\n _$el = that.collection[i].$el;\n _options = that.collection[i].options; // Change Default Values\n\n _options.resultVal = parseInt(_$el.querySelector(_options.classMap.result).value); // Plus Click Events\n\n _$el.querySelector(_options.classMap.plus).addEventListener(\'click\', function () {\n that._plusClickEvents(_$el, _options);\n }); // Minus Click Events\n\n\n _$el.querySelector(_options.classMap.minus).addEventListener(\'click\', function () {\n that._minusClickEvents(_$el, _options);\n });\n };\n\n for (var i = 0; i < that.collection.length; i += 1) {\n var _ret = _loop(i);\n\n if (_ret === "continue") continue;\n }\n }\n }, {\n key: "_plusClickEvents",\n value: function _plusClickEvents($el, settings) {\n settings.resultVal += 1;\n $el.querySelector(settings.classMap.result).value++;\n }\n }, {\n key: "_minusClickEvents",\n value: function _minusClickEvents($el, settings) {\n if (settings.resultVal >= 1) {\n settings.resultVal -= 1;\n $el.querySelector(settings.classMap.result).value--;\n } else {\n return false;\n }\n }\n }, {\n key: "addToCollection",\n value: function addToCollection(item, options, id) {\n this.collection.push({\n $el: item,\n id: id || null,\n options: Object.assign({}, defaults, item.hasAttribute(dataAttributeName) ? JSON.parse(item.getAttribute(dataAttributeName)) : {}, options)\n });\n }\n }, {\n key: "getItem",\n value: function getItem(item) {\n if (typeof item === \'number\') {\n return this.collection[item].$initializedEl;\n } else {\n return this.collection.find(function (el) {\n return el.id === item;\n }).$initializedEl;\n }\n }\n }]);\n\n return HSQuantityCounter;\n}();\n\n\n\n//# sourceURL=webpack://HSQuantityCounter/./src/js/hs-quantity-counter.js?')}},e={},f.m=d,f.c=e,f.d=function(n,e,t){f.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:t})},f.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},f.t=function(e,n){if(1&n&&(e=f(e)),8&n)return e;if(4&n&&"object"==typeof e&&e&&e.__esModule)return e;var t=Object.create(null);if(f.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:e}),2&n&&"string"!=typeof e)for(var i in e)f.d(t,i,function(n){return e[n]}.bind(null,i));return t},f.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return f.d(e,"a",e),e},f.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},f.p="",f(f.s="./src/js/hs-quantity-counter.js").default;function f(n){if(e[n])return e[n].exports;var t=e[n]={i:n,l:!1,exports:{}};return d[n].call(t.exports,t,t.exports,f),t.l=!0,t.exports}var d,e}); |