UNPKG

merchi_checkout

Version:
89 lines (88 loc) 15.1 kB
'use client'; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } import { useEffect } from 'react'; import { useMerchiCheckboutContext } from './MerchiCheckoutProvider'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { faCheckCircle, faExclamationCircle, faExclamationTriangle, faInfoCircle, faTimes } from '@fortawesome/free-solid-svg-icons'; import { jsx as _jsx } from "react/jsx-runtime"; import { jsxs as _jsxs } from "react/jsx-runtime"; var iconsMap = { danger: faExclamationCircle, info: faInfoCircle, success: faCheckCircle, warning: faExclamationTriangle }; function AlertSmall(_ref) { var _ref$alertType = _ref.alertType, alertType = _ref$alertType === void 0 ? 'error' : _ref$alertType, close = _ref.close, _ref$delay = _ref.delay, delay = _ref$delay === void 0 ? 5000 : _ref$delay, message = _ref.message, title = _ref.title; var _useMerchiCheckboutCo = useMerchiCheckboutContext(), classNameMerchiCheckoutAlert = _useMerchiCheckboutCo.classNameMerchiCheckoutAlert, classNameMerchiCheckoutAlertError = _useMerchiCheckboutCo.classNameMerchiCheckoutAlertError, classNameMerchiCheckoutAlertSuccess = _useMerchiCheckboutCo.classNameMerchiCheckoutAlertSuccess; function setTimer() { setTimeout(close, delay); } useEffect(function () { if (!['danger', 'error'].includes(alertType)) { setTimer(); } }, [message]); var classNameAlertType = alertType === 'error' ? classNameMerchiCheckoutAlertError : classNameMerchiCheckoutAlertSuccess; return /*#__PURE__*/_jsx("div", { className: "".concat(classNameMerchiCheckoutAlert, " ").concat(classNameAlertType), children: /*#__PURE__*/_jsxs("div", { style: { display: 'flex', justifyContent: 'space-between' }, children: [/*#__PURE__*/_jsx(FontAwesomeIcon, { className: "alert-icon", icon: iconsMap[alertType] }), /*#__PURE__*/_jsxs("div", { className: "alert-text", children: [/*#__PURE__*/_jsx("span", { className: "alert-title", "data-notify": "title", children: title }), ' ', /*#__PURE__*/_jsx("span", { "data-notify": "message", children: message })] }), /*#__PURE__*/_jsx("div", { onClick: close, children: /*#__PURE__*/_jsx(FontAwesomeIcon, { icon: faTimes }) })] }) }); } function Alerts() { var _useMerchiCheckboutCo2 = useMerchiCheckboutContext(), alerts = _useMerchiCheckboutCo2.alerts, alertClose = _useMerchiCheckboutCo2.alertClose, classNameMerchiCheckoutAlertsContainer = _useMerchiCheckboutCo2.classNameMerchiCheckoutAlertsContainer; ; return /*#__PURE__*/_jsx("div", { className: classNameMerchiCheckoutAlertsContainer, children: alerts.map(function (alert, index) { return /*#__PURE__*/_jsx(AlertSmall, _objectSpread({ close: function close() { return alertClose(index); } }, alert), "alert-index-key-".concat(index)); }) }); } export default Alerts; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_typeof","o","Symbol","iterator","constructor","prototype","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","key","value","_toPropertyKey","configurable","writable","i","_toPrimitive","String","toPrimitive","call","TypeError","Number","useEffect","useMerchiCheckboutContext","FontAwesomeIcon","faCheckCircle","faExclamationCircle","faExclamationTriangle","faInfoCircle","faTimes","jsx","_jsx","jsxs","_jsxs","iconsMap","danger","info","success","warning","AlertSmall","_ref","_ref$alertType","alertType","close","_ref$delay","delay","message","title","_useMerchiCheckboutCo","classNameMerchiCheckoutAlert","classNameMerchiCheckoutAlertError","classNameMerchiCheckoutAlertSuccess","setTimer","setTimeout","includes","classNameAlertType","className","concat","children","style","display","justifyContent","icon","onClick","Alerts","_useMerchiCheckboutCo2","alerts","alertClose","classNameMerchiCheckoutAlertsContainer","map","alert","index"],"sources":["../../src/components/Alerts.tsx"],"sourcesContent":["'use client';\nimport { useEffect } from 'react';\nimport { useMerchiCheckboutContext } from './MerchiCheckoutProvider'; \nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n  faCheckCircle,\n  faExclamationCircle,\n  faExclamationTriangle,\n  faInfoCircle,\n  faTimes,\n} from '@fortawesome/free-solid-svg-icons';\n\ninterface PropsAlertSmall {\n  alertType?: string;\n  close: () => void;\n  delay?: number;\n  title: string;\n  message: string;\n}\n\ninterface IconsMapType {\n  [key: string]: any;\n}\n\nconst iconsMap: IconsMapType = {\n  danger: faExclamationCircle,\n  info: faInfoCircle,\n  success: faCheckCircle,\n  warning: faExclamationTriangle,\n};\n\nfunction AlertSmall({\n  alertType = 'error',\n  close,\n  delay = 5000,\n  message,\n  title,\n}: PropsAlertSmall) {\n  const {\n    classNameMerchiCheckoutAlert,\n    classNameMerchiCheckoutAlertError,\n    classNameMerchiCheckoutAlertSuccess,\n  } = useMerchiCheckboutContext();\n  function setTimer() {\n    setTimeout(close, delay);\n  }\n  useEffect(() => {\n    if (!['danger', 'error'].includes(alertType)) { \n      setTimer();\n    }\n  }, [message]);\n  const classNameAlertType = alertType === 'error'\n    ? classNameMerchiCheckoutAlertError\n    : classNameMerchiCheckoutAlertSuccess;\n  return (\n    <div\n      className={`${classNameMerchiCheckoutAlert} ${classNameAlertType}`}\n    >\n      <div style={{display: 'flex', justifyContent: 'space-between'}}>\n        <FontAwesomeIcon\n          className='alert-icon'\n          icon={iconsMap[alertType]}\n        />\n        <div className='alert-text'>\n          <span\n            className='alert-title'\n            data-notify='title'\n          >\n            {title}\n          </span>\n          {' '}\n          <span data-notify='message'>\n            {message}\n          </span>\n        </div>\n        <div onClick={close}>\n          <FontAwesomeIcon icon={faTimes} />\n        </div>\n      </div>\n    </div>\n  );\n}\n\nfunction Alerts() {\n  const {\n    alerts,\n    alertClose,\n    classNameMerchiCheckoutAlertsContainer,\n  } = useMerchiCheckboutContext();;\n  return (\n    <div className={classNameMerchiCheckoutAlertsContainer}>\n      {\n        alerts.map((alert: any, index: number) =>\n          <AlertSmall\n            key={`alert-index-key-${index}`}\n            close={() => alertClose(index)}\n            {...alert}\n          />\n        )\n      }\n    </div>\n  );\n}\n\nexport default Alerts;\n    "],"mappings":"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"}