merchi_checkout
Version:
Merchi's custom checkout step form
229 lines (228 loc) • 37.3 kB
JavaScript
'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); }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
import React from 'react';
import { useEffect, useRef } from 'react';
import Geosuggest from 'react-geosuggest';
import { CountryDropdown, RegionDropdown } from 'react-country-region-selector';
import { Controller } from 'react-hook-form';
import InputText from './InputText';
import { useMerchiCheckboutContext } from '../MerchiCheckoutProvider';
import { addressInOneLine, geoSuggestResultAsNewAddress } from '../../utils';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faTimes, faEdit, faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';
import { useState } from 'react';
import Collapse from '../Collapse';
import { jsx as _jsx } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
import { Fragment as _Fragment } from "react/jsx-runtime";
export function InputsAddress(_ref) {
var _ref$defaultAddress = _ref.defaultAddress,
defaultAddress = _ref$defaultAddress === void 0 ? {} : _ref$defaultAddress,
_ref$labelGeoSuggest = _ref.labelGeoSuggest,
labelGeoSuggest = _ref$labelGeoSuggest === void 0 ? 'Address' : _ref$labelGeoSuggest,
hookForm = _ref.hookForm,
name = _ref.name,
_ref$placeholder = _ref.placeholder,
placeholder = _ref$placeholder === void 0 ? 'Search your address' : _ref$placeholder,
updateAddress = _ref.updateAddress;
var geosuggestEl = useRef(null);
var _useMerchiCheckboutCo = useMerchiCheckboutContext(),
googlePlacesLoaded = _useMerchiCheckboutCo.googlePlacesLoaded,
classNameMerchiCheckoutFormGroup = _useMerchiCheckboutCo.classNameMerchiCheckoutFormGroup,
classNameMerchiCheckoutFormInput = _useMerchiCheckboutCo.classNameMerchiCheckoutFormInput,
classNameMerchiCheckoutFormSelect = _useMerchiCheckboutCo.classNameMerchiCheckoutFormSelect,
classNameMerchiCheckoutRow = _useMerchiCheckboutCo.classNameMerchiCheckoutRow,
classNameMerchiCheckoutRowColumn = _useMerchiCheckboutCo.classNameMerchiCheckoutRowColumn,
classNameMerchiCheckoutGoogleSuggestList = _useMerchiCheckboutCo.classNameMerchiCheckoutGoogleSuggestList,
classNameMerchiCheckoutGoogleSuggestListItem = _useMerchiCheckboutCo.classNameMerchiCheckoutGoogleSuggestListItem;
var control = hookForm.control,
_hookForm$formState = hookForm.formState,
errors = _hookForm$formState.errors,
isValid = _hookForm$formState.isValid,
submitCount = _hookForm$formState.submitCount,
setValue = hookForm.setValue,
getValues = hookForm.getValues;
var inputName = function inputName(_name) {
return "".concat(name ? "".concat(name, ".") : '').concat(_name);
};
function onSuggestSelect(suggest) {
if (suggest) {
updateAddress(geoSuggestResultAsNewAddress(suggest));
} else {
updateAddress({
city: '',
country: '',
lineOne: '',
lineTwo: '',
postcode: '',
state: ''
});
}
geosuggestEl.current.blur();
}
function onChangeCountryState() {
var addr = getValues();
updateAddress(addr[name]);
}
var _useState = useState(false),
_useState2 = _slicedToArray(_useState, 2),
addressFieldsOpen = _useState2[0],
setAddressFieldsOpen = _useState2[1];
var toggleAddressFieldsOpen = function toggleAddressFieldsOpen() {
return setAddressFieldsOpen(!addressFieldsOpen);
};
useEffect(function () {
if (!isValid && !addressFieldsOpen && submitCount > 0) {
toggleAddressFieldsOpen();
}
}, [isValid, submitCount]);
var addressForm = /*#__PURE__*/_jsxs(_Fragment, {
children: [/*#__PURE__*/_jsx(InputText, {
control: control,
label: "Address line one",
name: inputName("lineOne"),
placeholder: "123 Fake st",
rules: {
required: 'Address line one is required.'
}
}), /*#__PURE__*/_jsx(InputText, {
control: control,
label: "Continue address",
name: inputName("lineTwo"),
placeholder: "Continue address..."
}), /*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutRow,
children: [/*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutRowColumn,
children: /*#__PURE__*/_jsx(InputText, {
control: control,
label: "City / Province",
name: inputName("city"),
placeholder: "City",
rules: {
required: 'City / Province is required.'
}
})
}), /*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutRowColumn,
children: /*#__PURE__*/_jsx(InputText, {
control: control,
label: "Post / Zip code",
name: inputName("postcode"),
placeholder: "90210"
})
})]
}), /*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutRow,
children: [/*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutRowColumn,
children: /*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutFormGroup,
children: [/*#__PURE__*/_jsx("label", {
children: "Country"
}), /*#__PURE__*/_jsx(Controller, {
name: inputName("country"),
control: control,
defaultValue: defaultAddress && defaultAddress.country,
render: function render(_ref2) {
var field = _ref2.field;
return /*#__PURE__*/_jsx(CountryDropdown, _objectSpread(_objectSpread({}, field), {}, {
// value={defaultAddress && defaultAddress.country}
classes: classNameMerchiCheckoutFormSelect,
onChange: function onChange(val) {
setValue(inputName("country"), val);
field.onChange(val);
onChangeCountryState();
},
valueType: "short"
}));
}
})]
})
}), /*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutRowColumn,
children: /*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutFormGroup,
children: [/*#__PURE__*/_jsx("label", {
children: "State / Region"
}), /*#__PURE__*/_jsx(Controller, {
name: inputName("state"),
control: control,
defaultValue: defaultAddress && defaultAddress.state,
render: function render(_ref3) {
var field = _ref3.field;
return /*#__PURE__*/_jsx(RegionDropdown, _objectSpread(_objectSpread({}, field), {}, {
// value={defaultAddress && defaultAddress.state}
countryValueType: "short",
country: getValues(inputName("country")),
classes: classNameMerchiCheckoutFormSelect,
onChange: function onChange(val) {
setValue(inputName("state"), val);
field.onChange(val);
onChangeCountryState();
},
valueType: "short"
}));
}
})]
})
})]
})]
});
return /*#__PURE__*/_jsx(_Fragment, {
children: googlePlacesLoaded ? /*#__PURE__*/_jsxs(_Fragment, {
children: [/*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutFormGroup,
children: [/*#__PURE__*/_jsx("label", {
children: labelGeoSuggest
}), /*#__PURE__*/_jsx(Geosuggest, {
ref: geosuggestEl,
style: {
input: {
'::placeholder': {
color: '#525f7f'
}
}
},
initialValue: addressInOneLine(defaultAddress),
inputClassName: classNameMerchiCheckoutFormInput,
onSuggestSelect: onSuggestSelect,
placeholder: placeholder,
suggestsClassName: classNameMerchiCheckoutGoogleSuggestList,
suggestItemClassName: classNameMerchiCheckoutGoogleSuggestListItem,
types: ['establishment', 'geocode']
})]
}), /*#__PURE__*/_jsx(Collapse, {
isOpen: addressFieldsOpen,
children: addressForm
}), /*#__PURE__*/_jsxs("div", {
className: "d-flex align-items-center",
children: [!!errors.length && /*#__PURE__*/_jsxs("div", {
className: "text-danger",
children: [/*#__PURE__*/_jsx(FontAwesomeIcon, {
icon: faExclamationTriangle
}), " Invalid address!"]
}), /*#__PURE__*/_jsxs("a", {
className: "ml-auto btn btn-sm btn-link ".concat(!!errors.length && 'text-danger'),
onClick: toggleAddressFieldsOpen,
children: [/*#__PURE__*/_jsx(FontAwesomeIcon, {
icon: addressFieldsOpen ? faTimes : faEdit
}), " ", addressFieldsOpen ? 'Close' : 'Edit fields']
})]
})]
}) : addressForm
});
}
export default InputsAddress;
//# 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","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","minLen","_arrayLikeToArray","n","toString","slice","name","Array","from","test","len","arr2","l","u","a","f","next","done","isArray","React","useEffect","useRef","Geosuggest","CountryDropdown","RegionDropdown","Controller","InputText","useMerchiCheckboutContext","addressInOneLine","geoSuggestResultAsNewAddress","FontAwesomeIcon","faTimes","faEdit","faExclamationTriangle","useState","Collapse","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","InputsAddress","_ref","_ref$defaultAddress","defaultAddress","_ref$labelGeoSuggest","labelGeoSuggest","hookForm","_ref$placeholder","placeholder","updateAddress","geosuggestEl","_useMerchiCheckboutCo","googlePlacesLoaded","classNameMerchiCheckoutFormGroup","classNameMerchiCheckoutFormInput","classNameMerchiCheckoutFormSelect","classNameMerchiCheckoutRow","classNameMerchiCheckoutRowColumn","classNameMerchiCheckoutGoogleSuggestList","classNameMerchiCheckoutGoogleSuggestListItem","control","_hookForm$formState","formState","errors","isValid","submitCount","setValue","getValues","inputName","_name","concat","onSuggestSelect","suggest","city","country","lineOne","lineTwo","postcode","state","current","blur","onChangeCountryState","addr","_useState","_useState2","addressFieldsOpen","setAddressFieldsOpen","toggleAddressFieldsOpen","addressForm","children","label","rules","required","className","defaultValue","render","_ref2","field","classes","onChange","val","valueType","_ref3","countryValueType","ref","style","input","color","initialValue","inputClassName","suggestsClassName","suggestItemClassName","types","isOpen","icon","onClick"],"sources":["../../../src/components/forms/InputsAddress.tsx"],"sourcesContent":["'use client';\nimport React from 'react';\nimport { useEffect, useRef } from 'react';\nimport Geosuggest from 'react-geosuggest';\nimport { CountryDropdown, RegionDropdown } from 'react-country-region-selector';\nimport { Controller } from 'react-hook-form';\nimport InputText from './InputText';\nimport { useMerchiCheckboutContext } from '../MerchiCheckoutProvider';\nimport { addressInOneLine, geoSuggestResultAsNewAddress } from '../../utils';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faTimes, faEdit, faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';\nimport { useState } from 'react';\nimport Collapse from '../Collapse';\n\ninterface Props {\n  defaultAddress?: any;\n  labelGeoSuggest?: string;\n  hookForm: any;\n  name: string;\n  placeholder?: string;\n  updateAddress: (address: any) => void;\n}\n\nexport function InputsAddress({\n  defaultAddress = {},\n  labelGeoSuggest = 'Address',\n  hookForm,\n  name,\n  placeholder = 'Search your address',\n  updateAddress\n}: Props) {\n  const geosuggestEl = useRef(null);\n  const {\n    googlePlacesLoaded,\n    classNameMerchiCheckoutFormGroup,\n    classNameMerchiCheckoutFormInput,\n    classNameMerchiCheckoutFormSelect,\n    classNameMerchiCheckoutRow,\n    classNameMerchiCheckoutRowColumn,\n    classNameMerchiCheckoutGoogleSuggestList,\n    classNameMerchiCheckoutGoogleSuggestListItem,\n  } = useMerchiCheckboutContext();\n\n  const {\n    control,\n    formState: { errors, isValid, submitCount },\n    setValue,\n    getValues,\n  } = hookForm;\n  const inputName = (_name: string) => `${name ? `${name}.` : ''}${_name}`;\n  function onSuggestSelect(suggest: any) {\n    if (suggest) {\n      updateAddress(geoSuggestResultAsNewAddress(suggest));\n    } else {\n      updateAddress({\n        city: '',\n        country: '',\n        lineOne: '',\n        lineTwo: '',\n        postcode: '',\n        state: '',\n      });\n    }\n    (geosuggestEl as any).current.blur();\n  }\n  function onChangeCountryState() {\n    const addr = getValues();\n    updateAddress(addr[name]);\n  }\n  const [addressFieldsOpen, setAddressFieldsOpen] = useState(false);\n  const toggleAddressFieldsOpen = () => setAddressFieldsOpen(!addressFieldsOpen);\n  useEffect(() => {\n    if (!isValid && !addressFieldsOpen && submitCount > 0) {\n      toggleAddressFieldsOpen();\n    }\n  }, [isValid, submitCount]);\n  const addressForm = (\n    <>\n      <InputText\n        control={control}\n        label=\"Address line one\"\n        name={inputName(\"lineOne\")}\n        placeholder=\"123 Fake st\"\n        rules={{ required: 'Address line one is required.' }}\n      />\n      <InputText\n        control={control}\n        label=\"Continue address\"\n        name={inputName(\"lineTwo\")}\n        placeholder=\"Continue address...\"\n      />\n      <div className={classNameMerchiCheckoutRow}>\n        <div className={classNameMerchiCheckoutRowColumn}>\n          <InputText\n            control={control}\n            label=\"City / Province\"\n            name={inputName(\"city\")}\n            placeholder=\"City\"\n            rules={{ required: 'City / Province is required.' }}\n          />\n        </div>\n        <div className={classNameMerchiCheckoutRowColumn}>\n          <InputText\n            control={control}\n            label=\"Post / Zip code\"\n            name={inputName(\"postcode\")}\n            placeholder=\"90210\"\n          />\n        </div>\n      </div>\n      <div className={classNameMerchiCheckoutRow}>\n        <div className={classNameMerchiCheckoutRowColumn}>\n          <div className={classNameMerchiCheckoutFormGroup}>\n            <label>Country</label>\n            <Controller\n              name={inputName(\"country\")}\n              control={control}\n              defaultValue={defaultAddress && defaultAddress.country}\n              render={({ field }: any) => (\n                <CountryDropdown\n                  {...field}\n                  // value={defaultAddress && defaultAddress.country}\n                  classes={classNameMerchiCheckoutFormSelect}\n                  onChange={(val) => {\n                    setValue(inputName(\"country\"), val);\n                    field.onChange(val);\n                    onChangeCountryState();\n                  }}\n                  valueType='short'\n                />\n              )}\n            />\n          </div>\n        </div>\n        <div className={classNameMerchiCheckoutRowColumn}>\n          <div className={classNameMerchiCheckoutFormGroup}>\n            <label>State / Region</label>\n            <Controller\n              name={inputName(\"state\")}\n              control={control}\n              defaultValue={defaultAddress && defaultAddress.state}\n              render={({ field }: any) => (\n                <RegionDropdown\n                  {...field}\n                  // value={defaultAddress && defaultAddress.state}\n                  countryValueType=\"short\"\n                  country={getValues(inputName(\"country\"))}\n                  classes={classNameMerchiCheckoutFormSelect}\n                  onChange={(val) => {\n                    setValue(inputName(\"state\"), val);\n                    field.onChange(val);\n                    onChangeCountryState();\n                  }}\n                  valueType='short'\n                />\n              )}\n            />\n          </div>\n        </div>\n      </div>\n    </>\n  );\n  return (\n    <>\n      {googlePlacesLoaded\n        ? <>\n            <div className={classNameMerchiCheckoutFormGroup}>\n              <label>{labelGeoSuggest}</label>\n              <Geosuggest\n                ref={geosuggestEl}\n                style={{input: {'::placeholder': {color: '#525f7f'}}}}\n                initialValue={addressInOneLine(defaultAddress)}\n                inputClassName={classNameMerchiCheckoutFormInput}\n                onSuggestSelect={onSuggestSelect}\n                placeholder={placeholder}\n                suggestsClassName={classNameMerchiCheckoutGoogleSuggestList}\n                suggestItemClassName={classNameMerchiCheckoutGoogleSuggestListItem}\n                types={['establishment', 'geocode']}\n              />\n            </div>\n            <Collapse isOpen={addressFieldsOpen}>\n              {addressForm}\n            </Collapse>\n            <div className='d-flex align-items-center'>\n              {!!errors.length &&\n                <div className='text-danger'>\n                  <FontAwesomeIcon\n                    icon={faExclamationTriangle}\n                  /> Invalid address!\n                </div>\n              }\n              <a\n                className={`ml-auto btn btn-sm btn-link ${!!errors.length && 'text-danger'}`}\n                onClick={toggleAddressFieldsOpen}\n              >\n                <FontAwesomeIcon\n                  icon={addressFieldsOpen ? faTimes : faEdit}\n                /> {addressFieldsOpen ? 'Close' : 'Edit fields'}\n              </a>\n            </div>\n          </>\n        : addressForm\n      } \n    </>\n  );\n}\n\nexport default InputsAddress;\n"],"mappings":"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"}