UNPKG

fc-component-react

Version:

``` <ProductCard product={ product } className="bg-dark text-white" initialValues={{ count: 6, maxCount: 10, }} > { ({ r

197 lines (179 loc) 19.7 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } var React = require('react'); var React__default = _interopDefault(React); var useProduct = function useProduct(_ref) { var onChange = _ref.onChange, product = _ref.product, _ref$value = _ref.value, value = _ref$value === void 0 ? 0 : _ref$value, initialValues = _ref.initialValues; var _useState = React.useState((initialValues == null ? void 0 : initialValues.count) || value), counter = _useState[0], setCounter = _useState[1]; var isMounted = React.useRef(false); var increaseBy = function increaseBy(value) { var newValue = Math.max(counter + value, 0); if (initialValues != null && initialValues.maxCount) { newValue = Math.min(newValue, initialValues.maxCount); } setCounter(newValue); onChange && onChange({ count: newValue, product: product }); }; var reset = function reset() { setCounter((initialValues == null ? void 0 : initialValues.count) || value); }; React.useEffect(function () { if (!isMounted.current) return; setCounter(value); }, [value]); React.useEffect(function () { isMounted.current = true; }, []); return { counter: counter, isMaxCountReached: !!(initialValues != null && initialValues.count) && initialValues.maxCount === counter, maxCount: initialValues == null ? void 0 : initialValues.maxCount, increaseBy: increaseBy, reset: reset }; }; function styleInject(css, ref) { if ( ref === void 0 ) ref = {}; var insertAt = ref.insertAt; if (!css || typeof document === 'undefined') { return; } var head = document.head || document.getElementsByTagName('head')[0]; var style = document.createElement('style'); style.type = 'text/css'; if (insertAt === 'top') { if (head.firstChild) { head.insertBefore(style, head.firstChild); } else { head.appendChild(style); } } else { head.appendChild(style); } if (style.styleSheet) { style.styleSheet.cssText = css; } else { style.appendChild(document.createTextNode(css)); } } var css_248z = "\n\n.styles-module_productCard__oaIVo {\n background-color: #1E2025;\n border-radius: 15px;\n box-shadow: 0px 2px 10px rgba(0,0,0,0.15);\n color: white;\n padding-bottom: 5px;\n font-family: Arial, Helvetica, sans-serif;\n width: 250px;\n margin-right: 5px;\n margin-top: 5px;\n}\n\n.styles-module_productImg__vPsTp {\n border-radius: 15px 15px 0px 0px;\n width: 100%;\n}\n\n.styles-module_productDescription__Ariub {\n margin: 10px;\n}\n\n.styles-module_buttonsContainer__ghCDF {\n margin: 10px;\n display: flex;\n flex-direction: row;\n}\n\n.styles-module_buttonMinus__BTgTf {\n cursor: pointer;\n background-color: transparent;\n border: 1px solid white;\n border-radius: 5px 0px 0px 5px;\n color: white;\n font-size: 20px;\n width: 30px;\n}\n\n.styles-module_buttonMinus__BTgTf:hover {\n background-color: rgba(0, 0, 0, 0.1);\n}\n\n.styles-module_countLabel__S6HZ- {\n border-bottom: 1px solid white;\n border-top: 1px solid white;\n color: white;\n font-size: 16px;\n height: 25px;\n padding-top: 5px;\n text-align: center;\n width: 30px;\n}\n\n.styles-module_buttonAdd__s8wd6 {\n cursor: pointer;\n background-color: transparent;\n border: 1px solid white;\n border-radius: 0px 5px 5px 0px;\n color: white;\n font-size: 20px;\n width: 30px;\n}\n\n.styles-module_buttonAdd__s8wd6:hover {\n background-color: rgba(0, 0, 0, 0.1);\n}\n\n\n.styles-module_disabled__k5aZm {\n border-color: grey !important;\n border-left: 1px solid white !important;\n color: grey !important;\n}"; var styles = {"productCard":"styles-module_productCard__oaIVo","productImg":"styles-module_productImg__vPsTp","productDescription":"styles-module_productDescription__Ariub","buttonsContainer":"styles-module_buttonsContainer__ghCDF","buttonMinus":"styles-module_buttonMinus__BTgTf","countLabel":"styles-module_countLabel__S6HZ-","buttonAdd":"styles-module_buttonAdd__s8wd6","disabled":"styles-module_disabled__k5aZm"}; styleInject(css_248z); var ProductContext = /*#__PURE__*/React.createContext({}); var Provider = ProductContext.Provider; var ProductCard = function ProductCard(_ref) { var children = _ref.children, product = _ref.product, className = _ref.className, style = _ref.style, onChange = _ref.onChange, value = _ref.value, initialValues = _ref.initialValues; var _useProduct = useProduct({ onChange: onChange, product: product, value: value, initialValues: initialValues }), counter = _useProduct.counter, increaseBy = _useProduct.increaseBy, maxCount = _useProduct.maxCount, isMaxCountReached = _useProduct.isMaxCountReached, reset = _useProduct.reset; return React__default.createElement(Provider, { value: { counter: counter, increaseBy: increaseBy, maxCount: maxCount, product: product } }, React__default.createElement("div", { className: styles.productCard + " " + className, style: style }, children({ count: counter, isMaxCountReached: isMaxCountReached, maxCount: initialValues == null ? void 0 : initialValues.maxCount, product: product, increaseBy: increaseBy, reset: reset }))); }; var ProductButtons = function ProductButtons(_ref) { var className = _ref.className, style = _ref.style; var _useContext = React.useContext(ProductContext), increaseBy = _useContext.increaseBy, counter = _useContext.counter, maxCount = _useContext.maxCount; var isMaxReached = React.useCallback(function () { return !!maxCount && counter === maxCount; }, [counter, maxCount]); return React__default.createElement("div", { className: styles.buttonsContainer + " " + className, style: style }, React__default.createElement("button", { className: styles.buttonMinus, onClick: function onClick() { return increaseBy(-1); } }, " - "), React__default.createElement("div", { className: styles.countLabel }, " ", counter, " "), React__default.createElement("button", { className: styles.buttonAdd + " " + (isMaxReached() && styles.disabled) + " ", onClick: function onClick() { return increaseBy(+1); } }, " + ")); }; var img = ""; var ProductImage = function ProductImage(_ref) { var img$1 = _ref.img, className = _ref.className, style = _ref.style; var _useContext = React.useContext(ProductContext), product = _useContext.product; var imgToShow; if (img$1) { imgToShow = img$1; } else if (product.img) { imgToShow = product.img; } else { imgToShow = img; } return React__default.createElement("img", { className: styles.productImg + " " + className, src: imgToShow, style: style, alt: "Product" }); }; var ProductTitle = function ProductTitle(_ref) { var title = _ref.title, className = _ref.className, style = _ref.style; var _useContext = React.useContext(ProductContext), product = _useContext.product; return React__default.createElement("span", { className: styles.productDescription + " " + className, style: style }, title ? title : product.title); }; var ProductCard$1 = /*#__PURE__*/Object.assign(ProductCard, { Title: ProductTitle, Image: ProductImage, Buttons: ProductButtons }); exports.ProductButtons = ProductButtons; exports.ProductCard = ProductCard$1; exports.ProductImage = ProductImage; exports.ProductTitle = ProductTitle; //# sourceMappingURL=fc-component-react.cjs.development.js.map