merchi_checkout
Version:
Merchi's custom checkout step form
139 lines (138 loc) • 18.1 kB
JavaScript
'use client';
import React from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faCheck } from '@fortawesome/free-solid-svg-icons';
import { CgSpinner } from 'react-icons/cg';
import { useMerchiCheckboutContext } from '../MerchiCheckoutProvider';
import { addressInOneLine } from '../../utils';
import { currencyTaxAndCost } from '../currency';
import { jsx as _jsx } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
import { Fragment as _Fragment } from "react/jsx-runtime";
function ShipmentPrice(_ref) {
var shipment = _ref.shipment;
var shipmentMethod = shipment.shipmentMethod,
taxType = shipment.taxType;
var currency = shipmentMethod.currency;
return /*#__PURE__*/_jsx("div", {
children: !!shipment.cost && /*#__PURE__*/_jsx("small", {
className: "font-weight-bold",
children: currencyTaxAndCost(currency, taxType, shipment.cost)
})
});
}
function PickupInfo(_ref2) {
var originAddress = _ref2.originAddress;
return /*#__PURE__*/_jsxs("small", {
children: ["Pick up from: ", addressInOneLine(originAddress)]
});
}
function ShipmentOptionInfo(_ref3) {
var shipment = _ref3.shipment;
var name = shipment.name,
shipmentMethod = shipment.shipmentMethod,
transportCompanyName = shipment.transportCompanyName;
var originAddress = shipmentMethod.originAddress,
pickUp = shipmentMethod.pickUp;
return /*#__PURE__*/_jsxs("div", {
className: "shipment-option-info",
children: [!name ? /*#__PURE__*/_jsxs(_Fragment, {
children: [!!transportCompanyName && /*#__PURE__*/_jsx("div", {
className: "shipment-option-name",
children: shipmentMethod.name
}), pickUp ? /*#__PURE__*/_jsx(PickupInfo, {
originAddress: originAddress
}) : /*#__PURE__*/_jsx("small", {
children: transportCompanyName
})]
}) : /*#__PURE__*/_jsxs(_Fragment, {
children: [/*#__PURE__*/_jsx("div", {
className: "shipment-option-name",
children: name
}), pickUp && /*#__PURE__*/_jsx(PickupInfo, {
originAddress: originAddress
})]
}), /*#__PURE__*/_jsx(ShipmentPrice, {
shipment: shipment
})]
});
}
function ListItemShipmentQuoteOption(_ref4) {
var doSelect = _ref4.doSelect,
isSelected = _ref4.isSelected,
shipment = _ref4.shipment;
var _useMerchiCheckboutCo = useMerchiCheckboutContext(),
classNameMerchiCheckoutListGroupItem = _useMerchiCheckboutCo.classNameMerchiCheckoutListGroupItem;
return /*#__PURE__*/_jsx("div", {
className: "".concat(classNameMerchiCheckoutListGroupItem, " ").concat(isSelected ? 'active' : ''),
style: {
cursor: 'pointer'
},
onClick: doSelect,
children: /*#__PURE__*/_jsxs("div", {
style: {
display: 'flex',
justifyContent: 'space-between',
alignItems: 'center'
},
children: [/*#__PURE__*/_jsx(ShipmentOptionInfo, {
shipment: shipment
}), /*#__PURE__*/_jsx("div", {
children: isSelected && /*#__PURE__*/_jsx(FontAwesomeIcon, {
icon: faCheck
})
})]
})
});
}
function ListItemLoading() {
var _useMerchiCheckboutCo2 = useMerchiCheckboutContext(),
classNameMerchiCheckoutListGroupItemLoader = _useMerchiCheckboutCo2.classNameMerchiCheckoutListGroupItemLoader;
return /*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutListGroupItemLoader + ' d-flex align-items-center',
children: /*#__PURE__*/_jsx(CgSpinner, {
fontSize: "1.5rem",
className: "animate_spin"
})
});
}
function ListItemNoOptions() {
var _useMerchiCheckboutCo3 = useMerchiCheckboutContext(),
classNameMerchiCheckoutListGroupItem = _useMerchiCheckboutCo3.classNameMerchiCheckoutListGroupItem;
return /*#__PURE__*/_jsxs("div", {
className: classNameMerchiCheckoutListGroupItem,
children: [/*#__PURE__*/_jsx("div", {
className: "merchi_monster_shipment_option_not_found"
}), /*#__PURE__*/_jsx("small", {
className: "text-muted shipment-option-checkout-form",
children: "Enter your address to select a shipment option"
})]
});
}
function ListShipmentQuoteOptions(_ref5) {
var doSelectShipmentOption = _ref5.doSelectShipmentOption,
loading = _ref5.loading,
selectedOption = _ref5.selectedOption,
shipmentOptions = _ref5.shipmentOptions;
var _useMerchiCheckboutCo4 = useMerchiCheckboutContext(),
classNameMerchiCheckoutListGroup = _useMerchiCheckboutCo4.classNameMerchiCheckoutListGroup;
var index = selectedOption ? shipmentOptions.map(function (s) {
return s.shipment;
}).findIndex(function (item) {
return item.id === selectedOption.id;
}) : null;
return /*#__PURE__*/_jsx("div", {
className: classNameMerchiCheckoutListGroup,
children: loading ? /*#__PURE__*/_jsx(ListItemLoading, {}) : shipmentOptions.length ? shipmentOptions.map(function (s, i) {
return /*#__PURE__*/_jsx(ListItemShipmentQuoteOption, {
doSelect: function doSelect() {
return doSelectShipmentOption(s.shipment);
},
isSelected: index === i,
shipment: s.shipment
}, "".concat(i, "-option"));
}) : /*#__PURE__*/_jsx(ListItemNoOptions, {})
});
}
export default ListShipmentQuoteOptions;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","FontAwesomeIcon","faCheck","CgSpinner","useMerchiCheckboutContext","addressInOneLine","currencyTaxAndCost","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","ShipmentPrice","_ref","shipment","shipmentMethod","taxType","currency","children","cost","className","PickupInfo","_ref2","originAddress","ShipmentOptionInfo","_ref3","name","transportCompanyName","pickUp","ListItemShipmentQuoteOption","_ref4","doSelect","isSelected","_useMerchiCheckboutCo","classNameMerchiCheckoutListGroupItem","concat","style","cursor","onClick","display","justifyContent","alignItems","icon","ListItemLoading","_useMerchiCheckboutCo2","classNameMerchiCheckoutListGroupItemLoader","fontSize","ListItemNoOptions","_useMerchiCheckboutCo3","ListShipmentQuoteOptions","_ref5","doSelectShipmentOption","loading","selectedOption","shipmentOptions","_useMerchiCheckboutCo4","classNameMerchiCheckoutListGroup","index","map","s","findIndex","item","id","length","i"],"sources":["../../../src/components/lists/ListShipmentQuoteOptions.tsx"],"sourcesContent":["'use client';\nimport React from 'react';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCheck } from '@fortawesome/free-solid-svg-icons';\nimport { CgSpinner } from 'react-icons/cg';\nimport { useMerchiCheckboutContext } from '../MerchiCheckoutProvider';\nimport { addressInOneLine } from '../../utils';\nimport { currencyTaxAndCost } from '../currency';\n\nfunction ShipmentPrice({ shipment }: any) {\n  const { shipmentMethod, taxType } = shipment;\n  const { currency } = shipmentMethod;\n  return (\n    <div>\n      {!!shipment.cost && (\n        <small className='font-weight-bold'>\n          {currencyTaxAndCost(currency, taxType, shipment.cost)}\n        </small>\n      )}\n    </div>\n  );\n}\n\ninterface PropsPickupInfo {\n  originAddress: any;\n}\n\nfunction PickupInfo({ originAddress }: PropsPickupInfo) {\n  return <small>Pick up from: {addressInOneLine(originAddress)}</small>;\n}\n\ninterface PropsShipmentOptionInfo {\n  shipment: any;\n}\n\nfunction ShipmentOptionInfo({ shipment }: PropsShipmentOptionInfo) {\n  const { name, shipmentMethod, transportCompanyName } = shipment;\n  const { originAddress, pickUp } = shipmentMethod;\n  return (\n    <div className='shipment-option-info'>\n      {!name ? (\n        <>\n          {!!transportCompanyName && (\n            <div className='shipment-option-name'>{shipmentMethod.name}</div>\n          )}\n          {pickUp ? (\n            <PickupInfo originAddress={originAddress} />\n          ) : (\n            <small>{transportCompanyName}</small>\n          )}\n        </>\n      ) : (\n        <>\n          <div className='shipment-option-name'>{name}</div>\n          {pickUp && <PickupInfo originAddress={originAddress} />}\n        </>\n      )}\n      <ShipmentPrice shipment={shipment} />\n    </div>\n  );\n}\n\ninterface PropsListItemShipmentQuoteOption {\n  doSelect: () => void;\n  shipment: any;\n  isSelected: boolean;\n}\n\nfunction ListItemShipmentQuoteOption({\n  doSelect,\n  isSelected,\n  shipment,\n}: PropsListItemShipmentQuoteOption) {\n  const { classNameMerchiCheckoutListGroupItem } = useMerchiCheckboutContext();\n  return (\n    <div\n      className={`${classNameMerchiCheckoutListGroupItem} ${\n        isSelected ? 'active' : ''\n      }`}\n      style={{ cursor: 'pointer' }}\n      onClick={doSelect}\n    >\n      <div\n        style={{\n          display: 'flex',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n      >\n        <ShipmentOptionInfo shipment={shipment} />\n        <div>\n          {isSelected && <FontAwesomeIcon icon={faCheck} />}\n        </div>\n      </div>\n    </div>\n  );\n}\n\nfunction ListItemLoading() {\n  const { classNameMerchiCheckoutListGroupItemLoader } =\n    useMerchiCheckboutContext();\n  return (\n    <div\n      className={\n        classNameMerchiCheckoutListGroupItemLoader +\n        ' d-flex align-items-center'\n      }\n    >\n      <CgSpinner fontSize='1.5rem' className='animate_spin' />\n    </div>\n  );\n}\n\nfunction ListItemNoOptions() {\n  const { classNameMerchiCheckoutListGroupItem } = useMerchiCheckboutContext();\n  return (\n    <div className={classNameMerchiCheckoutListGroupItem}>\n      <div className='merchi_monster_shipment_option_not_found' />\n      <small className='text-muted shipment-option-checkout-form'>\n        Enter your address to select a shipment option\n      </small>\n    </div>\n  );\n}\n\ninterface Props {\n  doSelectShipmentOption: (option: any) => void;\n  loading: boolean;\n  selectedOption?: any;\n  shipmentOptions: Array<any>;\n}\n\nfunction ListShipmentQuoteOptions({\n  doSelectShipmentOption,\n  loading,\n  selectedOption,\n  shipmentOptions,\n}: Props) {\n  const { classNameMerchiCheckoutListGroup } = useMerchiCheckboutContext();\n  const index = selectedOption\n    ? shipmentOptions\n        .map((s: any) => s.shipment)\n        .findIndex((item: any) => item.id === (selectedOption as any).id)\n    : null;\n  return (\n    <div className={classNameMerchiCheckoutListGroup}>\n      {loading ? (\n        <ListItemLoading />\n      ) : shipmentOptions.length ? (\n        shipmentOptions.map((s: any, i: number) => (\n          <ListItemShipmentQuoteOption\n            doSelect={() => doSelectShipmentOption(s.shipment)}\n            isSelected={index === i}\n            shipment={s.shipment}\n            key={`${i}-option`}\n          />\n        ))\n      ) : (\n        <ListItemNoOptions />\n      )}\n    </div>\n  );\n}\n\nexport default ListShipmentQuoteOptions;\n"],"mappings":"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"}