@commercelayer/react-components 4.0.0-alpha.4 → 4.0.0-alpha.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (197) hide show
  1. package/lib/cjs/components/SubmitButton.d.ts +6 -15
  2. package/lib/cjs/components/SubmitButton.js +1 -1
  3. package/lib/cjs/components/addresses/AddressInput.d.ts +0 -11
  4. package/lib/cjs/components/addresses/AddressInput.js +1 -1
  5. package/lib/cjs/components/addresses/SaveAddressesButton.d.ts +4 -3
  6. package/lib/cjs/components/addresses/SaveAddressesButton.js +1 -1
  7. package/lib/cjs/components/auth/CommerceLayer.d.ts +2 -9
  8. package/lib/cjs/components/auth/CommerceLayer.js +1 -1
  9. package/lib/cjs/components/customers/CustomerAddressForm.js +1 -1
  10. package/lib/cjs/components/customers/SaveCustomerButton.d.ts +6 -7
  11. package/lib/cjs/components/customers/SaveCustomerButton.js +1 -1
  12. package/lib/cjs/components/gift_cards/GiftCardOrCouponCode.d.ts +8 -16
  13. package/lib/cjs/components/gift_cards/GiftCardOrCouponCode.js +1 -1
  14. package/lib/cjs/components/gift_cards/GiftCardOrCouponRemoveButton.d.ts +4 -12
  15. package/lib/cjs/components/gift_cards/GiftCardOrCouponRemoveButton.js +1 -1
  16. package/lib/cjs/components/gift_cards/GiftCardOrCouponSubmit.d.ts +6 -12
  17. package/lib/cjs/components/gift_cards/GiftCardOrCouponSubmit.js +1 -1
  18. package/lib/cjs/components/line_items/LineItemOption.d.ts +2 -2
  19. package/lib/cjs/components/line_items/LineItemQuantity.d.ts +4 -16
  20. package/lib/cjs/components/line_items/LineItemQuantity.js +1 -1
  21. package/lib/cjs/components/line_items/LineItemRemoveLink.d.ts +6 -16
  22. package/lib/cjs/components/line_items/LineItemRemoveLink.js +1 -1
  23. package/lib/cjs/components/line_items/LineItemsCount.d.ts +4 -14
  24. package/lib/cjs/components/line_items/LineItemsCount.js +1 -1
  25. package/lib/cjs/components/line_items/LineItemsEmpty.d.ts +6 -17
  26. package/lib/cjs/components/line_items/LineItemsEmpty.js +1 -1
  27. package/lib/cjs/components/orders/AddToCartButton.d.ts +4 -5
  28. package/lib/cjs/components/orders/AddToCartButton.js +1 -1
  29. package/lib/cjs/components/orders/CartLink.d.ts +6 -6
  30. package/lib/cjs/components/orders/CartLink.js +1 -1
  31. package/lib/cjs/components/orders/CheckoutLink.d.ts +4 -4
  32. package/lib/cjs/components/orders/CheckoutLink.js +1 -1
  33. package/lib/cjs/components/orders/ItemContainer.d.ts +2 -13
  34. package/lib/cjs/components/orders/ItemContainer.js +1 -1
  35. package/lib/cjs/components/orders/OrderList.d.ts +10 -11
  36. package/lib/cjs/components/orders/OrderList.js +1 -1
  37. package/lib/cjs/components/orders/OrderListEmpty.d.ts +14 -0
  38. package/lib/cjs/components/orders/OrderListEmpty.js +1 -0
  39. package/lib/cjs/components/orders/OrderListRow.d.ts +1 -1
  40. package/lib/cjs/components/orders/PlaceOrderButton.d.ts +4 -14
  41. package/lib/cjs/components/orders/PlaceOrderButton.js +1 -1
  42. package/lib/cjs/components/parcels/Parcel.d.ts +6 -0
  43. package/lib/cjs/components/parcels/Parcel.js +1 -0
  44. package/lib/cjs/components/payment_source/AdyenPayment.js +1 -1
  45. package/lib/cjs/components/payment_source/PaymentSourceBrandIcon.d.ts +4 -14
  46. package/lib/cjs/components/payment_source/PaymentSourceBrandIcon.js +1 -1
  47. package/lib/cjs/components/payment_source/PaymentSourceBrandName.d.ts +4 -11
  48. package/lib/cjs/components/payment_source/PaymentSourceBrandName.js +1 -1
  49. package/lib/cjs/components/payment_source/PaymentSourceDetail.d.ts +6 -12
  50. package/lib/cjs/components/payment_source/PaymentSourceDetail.js +1 -1
  51. package/lib/cjs/components/payment_source/PaymentSourceEditButton.d.ts +4 -10
  52. package/lib/cjs/components/payment_source/PaymentSourceEditButton.js +1 -1
  53. package/lib/cjs/components/prices/Price.d.ts +6 -18
  54. package/lib/cjs/components/prices/Price.js +1 -1
  55. package/lib/cjs/components/prices/PricesContainer.d.ts +4 -20
  56. package/lib/cjs/components/prices/PricesContainer.js +1 -1
  57. package/lib/cjs/components/shipments/Shipment.d.ts +2 -8
  58. package/lib/cjs/components/shipments/Shipment.js +1 -1
  59. package/lib/cjs/components/shipments/ShipmentField.d.ts +0 -7
  60. package/lib/cjs/components/shipments/ShipmentField.js +1 -1
  61. package/lib/cjs/components/shipments/ShipmentsContainer.d.ts +2 -8
  62. package/lib/cjs/components/shipments/ShipmentsContainer.js +1 -1
  63. package/lib/cjs/components/shipping_methods/ShippingMethod.d.ts +2 -9
  64. package/lib/cjs/components/shipping_methods/ShippingMethod.js +1 -1
  65. package/lib/cjs/components/shipping_methods/ShippingMethodName.d.ts +0 -6
  66. package/lib/cjs/components/shipping_methods/ShippingMethodName.js +1 -1
  67. package/lib/cjs/components/skus/AvailabilityTemplate.d.ts +4 -13
  68. package/lib/cjs/components/skus/AvailabilityTemplate.js +1 -1
  69. package/lib/cjs/components/skus/QuantitySelector.d.ts +4 -18
  70. package/lib/cjs/components/skus/QuantitySelector.js +1 -1
  71. package/lib/cjs/components/skus/VariantSelector.d.ts +4 -27
  72. package/lib/cjs/components/skus/VariantSelector.js +1 -1
  73. package/lib/cjs/components/utils/AddressCardsTemplate.d.ts +2 -2
  74. package/lib/cjs/components/utils/BaseInput.d.ts +1 -1
  75. package/lib/cjs/components/utils/ErrorBoundary.d.ts +14 -0
  76. package/lib/cjs/components/utils/ErrorBoundary.js +1 -0
  77. package/lib/cjs/components/utils/PaymentCardsTemplate.d.ts +2 -2
  78. package/lib/cjs/components/utils/PriceTemplate.d.ts +2 -2
  79. package/lib/cjs/components/utils/PriceTemplate.js +1 -1
  80. package/lib/cjs/context/BillingAddressFormContext.d.ts +2 -2
  81. package/lib/cjs/context/OrderListChildrenContext.d.ts +8 -0
  82. package/lib/cjs/context/ParcelChildrenContext.d.ts +7 -0
  83. package/lib/cjs/context/ParcelChildrenContext.js +1 -0
  84. package/lib/cjs/context/ShipmentChildrenContext.d.ts +6 -5
  85. package/lib/cjs/context/ShipmentChildrenContext.js +1 -1
  86. package/lib/cjs/index.d.ts +35 -34
  87. package/lib/cjs/index.js +1 -1
  88. package/lib/cjs/reducers/CustomerReducer.d.ts +16 -18
  89. package/lib/cjs/reducers/CustomerReducer.js +1 -1
  90. package/lib/cjs/reducers/OrderReducer.d.ts +14 -24
  91. package/lib/cjs/reducers/ShipmentReducer.d.ts +1 -3
  92. package/lib/cjs/typings/errors.d.ts +2 -2
  93. package/lib/cjs/typings/index.d.ts +8 -16
  94. package/lib/cjs/utils/getPrices.d.ts +4 -15
  95. package/lib/cjs/utils/getPrices.js +1 -1
  96. package/lib/cjs/utils/getSdk.d.ts +1 -1
  97. package/lib/cjs/utils/organization.d.ts +2 -2
  98. package/lib/esm/components/SubmitButton.d.ts +6 -15
  99. package/lib/esm/components/SubmitButton.js +1 -1
  100. package/lib/esm/components/addresses/AddressInput.d.ts +0 -11
  101. package/lib/esm/components/addresses/AddressInput.js +1 -1
  102. package/lib/esm/components/addresses/SaveAddressesButton.d.ts +4 -3
  103. package/lib/esm/components/addresses/SaveAddressesButton.js +1 -1
  104. package/lib/esm/components/auth/CommerceLayer.d.ts +2 -9
  105. package/lib/esm/components/auth/CommerceLayer.js +1 -1
  106. package/lib/esm/components/customers/CustomerAddressForm.js +1 -1
  107. package/lib/esm/components/customers/SaveCustomerButton.d.ts +6 -7
  108. package/lib/esm/components/customers/SaveCustomerButton.js +1 -1
  109. package/lib/esm/components/gift_cards/GiftCardOrCouponCode.d.ts +8 -16
  110. package/lib/esm/components/gift_cards/GiftCardOrCouponCode.js +1 -1
  111. package/lib/esm/components/gift_cards/GiftCardOrCouponRemoveButton.d.ts +4 -12
  112. package/lib/esm/components/gift_cards/GiftCardOrCouponRemoveButton.js +1 -1
  113. package/lib/esm/components/gift_cards/GiftCardOrCouponSubmit.d.ts +6 -12
  114. package/lib/esm/components/gift_cards/GiftCardOrCouponSubmit.js +1 -1
  115. package/lib/esm/components/line_items/LineItemOption.d.ts +2 -2
  116. package/lib/esm/components/line_items/LineItemQuantity.d.ts +4 -16
  117. package/lib/esm/components/line_items/LineItemQuantity.js +1 -1
  118. package/lib/esm/components/line_items/LineItemRemoveLink.d.ts +6 -16
  119. package/lib/esm/components/line_items/LineItemRemoveLink.js +1 -1
  120. package/lib/esm/components/line_items/LineItemsCount.d.ts +4 -14
  121. package/lib/esm/components/line_items/LineItemsCount.js +1 -1
  122. package/lib/esm/components/line_items/LineItemsEmpty.d.ts +6 -17
  123. package/lib/esm/components/line_items/LineItemsEmpty.js +1 -1
  124. package/lib/esm/components/orders/AddToCartButton.d.ts +4 -5
  125. package/lib/esm/components/orders/AddToCartButton.js +1 -1
  126. package/lib/esm/components/orders/CartLink.d.ts +6 -6
  127. package/lib/esm/components/orders/CartLink.js +1 -1
  128. package/lib/esm/components/orders/CheckoutLink.d.ts +4 -4
  129. package/lib/esm/components/orders/CheckoutLink.js +1 -1
  130. package/lib/esm/components/orders/ItemContainer.d.ts +2 -13
  131. package/lib/esm/components/orders/ItemContainer.js +1 -1
  132. package/lib/esm/components/orders/OrderList.d.ts +10 -11
  133. package/lib/esm/components/orders/OrderList.js +1 -1
  134. package/lib/esm/components/orders/OrderListEmpty.d.ts +14 -0
  135. package/lib/esm/components/orders/OrderListEmpty.js +1 -0
  136. package/lib/esm/components/orders/OrderListRow.d.ts +1 -1
  137. package/lib/esm/components/orders/PlaceOrderButton.d.ts +4 -14
  138. package/lib/esm/components/orders/PlaceOrderButton.js +1 -1
  139. package/lib/esm/components/parcels/Parcel.d.ts +6 -0
  140. package/lib/esm/components/parcels/Parcel.js +1 -0
  141. package/lib/esm/components/payment_source/AdyenPayment.js +1 -1
  142. package/lib/esm/components/payment_source/PaymentSourceBrandIcon.d.ts +4 -14
  143. package/lib/esm/components/payment_source/PaymentSourceBrandIcon.js +1 -1
  144. package/lib/esm/components/payment_source/PaymentSourceBrandName.d.ts +4 -11
  145. package/lib/esm/components/payment_source/PaymentSourceBrandName.js +1 -1
  146. package/lib/esm/components/payment_source/PaymentSourceDetail.d.ts +6 -12
  147. package/lib/esm/components/payment_source/PaymentSourceDetail.js +1 -1
  148. package/lib/esm/components/payment_source/PaymentSourceEditButton.d.ts +4 -10
  149. package/lib/esm/components/payment_source/PaymentSourceEditButton.js +1 -1
  150. package/lib/esm/components/prices/Price.d.ts +6 -18
  151. package/lib/esm/components/prices/Price.js +1 -1
  152. package/lib/esm/components/prices/PricesContainer.d.ts +4 -20
  153. package/lib/esm/components/prices/PricesContainer.js +1 -1
  154. package/lib/esm/components/shipments/Shipment.d.ts +2 -8
  155. package/lib/esm/components/shipments/Shipment.js +1 -1
  156. package/lib/esm/components/shipments/ShipmentField.d.ts +0 -7
  157. package/lib/esm/components/shipments/ShipmentField.js +1 -1
  158. package/lib/esm/components/shipments/ShipmentsContainer.d.ts +2 -8
  159. package/lib/esm/components/shipments/ShipmentsContainer.js +1 -1
  160. package/lib/esm/components/shipping_methods/ShippingMethod.d.ts +2 -9
  161. package/lib/esm/components/shipping_methods/ShippingMethod.js +1 -1
  162. package/lib/esm/components/shipping_methods/ShippingMethodName.d.ts +0 -6
  163. package/lib/esm/components/shipping_methods/ShippingMethodName.js +1 -1
  164. package/lib/esm/components/skus/AvailabilityTemplate.d.ts +4 -13
  165. package/lib/esm/components/skus/AvailabilityTemplate.js +1 -1
  166. package/lib/esm/components/skus/QuantitySelector.d.ts +4 -18
  167. package/lib/esm/components/skus/QuantitySelector.js +1 -1
  168. package/lib/esm/components/skus/VariantSelector.d.ts +4 -27
  169. package/lib/esm/components/skus/VariantSelector.js +1 -1
  170. package/lib/esm/components/utils/AddressCardsTemplate.d.ts +2 -2
  171. package/lib/esm/components/utils/BaseInput.d.ts +1 -1
  172. package/lib/esm/components/utils/ErrorBoundary.d.ts +14 -0
  173. package/lib/esm/components/utils/ErrorBoundary.js +1 -0
  174. package/lib/esm/components/utils/PaymentCardsTemplate.d.ts +2 -2
  175. package/lib/esm/components/utils/PriceTemplate.d.ts +2 -2
  176. package/lib/esm/components/utils/PriceTemplate.js +1 -1
  177. package/lib/esm/context/BillingAddressFormContext.d.ts +2 -2
  178. package/lib/esm/context/OrderListChildrenContext.d.ts +8 -0
  179. package/lib/esm/context/ParcelChildrenContext.d.ts +7 -0
  180. package/lib/esm/context/ParcelChildrenContext.js +1 -0
  181. package/lib/esm/context/ShipmentChildrenContext.d.ts +6 -5
  182. package/lib/esm/context/ShipmentChildrenContext.js +1 -1
  183. package/lib/esm/index.d.ts +35 -34
  184. package/lib/esm/index.js +1 -1
  185. package/lib/esm/reducers/CustomerReducer.d.ts +16 -18
  186. package/lib/esm/reducers/CustomerReducer.js +1 -1
  187. package/lib/esm/reducers/OrderReducer.d.ts +14 -24
  188. package/lib/esm/reducers/ShipmentReducer.d.ts +1 -3
  189. package/lib/esm/typings/errors.d.ts +2 -2
  190. package/lib/esm/typings/index.d.ts +8 -16
  191. package/lib/esm/utils/getPrices.d.ts +4 -15
  192. package/lib/esm/utils/getPrices.js +1 -1
  193. package/lib/esm/utils/getSdk.d.ts +1 -1
  194. package/lib/esm/utils/organization.d.ts +2 -2
  195. package/lib/tsconfig.prod.esm.tsbuildinfo +1 -1
  196. package/lib/tsconfig.prod.tsbuildinfo +1 -1
  197. package/package.json +46 -35
@@ -1,19 +1,10 @@
1
1
  import { ReactNode } from 'react';
2
- import { FunctionChildren } from '../typings/index';
3
- declare type ChildrenProps = FunctionChildren<Omit<Props, 'children'>>;
4
- declare type Props = {
5
- children?: ChildrenProps;
2
+ import { ChildrenFunction } from '../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
+ }
5
+ interface Props extends Omit<JSX.IntrinsicElements['button'], 'children'> {
6
+ children?: ChildrenFunction<ChildrenProps>;
6
7
  label?: string | ReactNode;
7
- } & JSX.IntrinsicElements['button'];
8
- export declare function SubmitButton(props: Props): JSX.Element;
9
- export declare namespace SubmitButton {
10
- var propTypes: {
11
- children: import("prop-types").Requireable<(...args: any[]) => any>;
12
- label: import("prop-types").Requireable<NonNullable<string | import("prop-types").ReactElementLike | null | undefined>>;
13
- };
14
- var defaultProps: {
15
- label: string;
16
- };
17
- var displayName: string;
18
8
  }
9
+ export declare function SubmitButton(props: Props): JSX.Element;
19
10
  export default SubmitButton;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SubmitButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),Parent_1=tslib_1.__importDefault(require("./utils/Parent")),components_1=tslib_1.__importDefault(require("../config/components")),isFunction_1=tslib_1.__importDefault(require("lodash/isFunction")),propTypes=components_1.default.SubmitButton.propTypes,defaultProps=components_1.default.SubmitButton.defaultProps,displayName=components_1.default.SubmitButton.displayName;function SubmitButton(props){const{children,label="Submit",...p}=props,parentProps={...p,label};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"submit",...p,children:(0,isFunction_1.default)(label)?label():label})}exports.SubmitButton=SubmitButton,SubmitButton.propTypes=propTypes,SubmitButton.defaultProps=defaultProps,SubmitButton.displayName=displayName,exports.default=SubmitButton;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SubmitButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),Parent_1=tslib_1.__importDefault(require("./utils/Parent")),isFunction_1=tslib_1.__importDefault(require("lodash/isFunction"));function SubmitButton(props){const{children,label="Submit",...p}=props,parentProps={...p,label};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"submit",...p,children:(0,isFunction_1.default)(label)?label():label})}exports.SubmitButton=SubmitButton,exports.default=SubmitButton;
@@ -5,15 +5,4 @@ declare type Props = {
5
5
  name: Extract<AddressValuesKeys, AddressInputName>;
6
6
  } & Omit<BaseInputComponentProps, 'name'> & JSX.IntrinsicElements['input'] & JSX.IntrinsicElements['textarea'];
7
7
  export declare function AddressInput(props: Props): JSX.Element | null;
8
- export declare namespace AddressInput {
9
- var propTypes: {
10
- children: import("prop-types").Requireable<(...args: any[]) => any>;
11
- name: import("prop-types").Validator<NonNullable<AddressInputName>>;
12
- type: import("prop-types").Validator<NonNullable<import("../../typings/index").BaseInputType>>;
13
- placeholder: import("prop-types").Requireable<string>;
14
- disabled: import("prop-types").Requireable<boolean>;
15
- required: import("prop-types").Requireable<boolean>;
16
- };
17
- var displayName: string;
18
- }
19
8
  export default AddressInput;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.AddressInput=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),BaseInput_1=tslib_1.__importDefault(require("../utils/BaseInput")),components_1=tslib_1.__importDefault(require("../../config/components")),BillingAddressFormContext_1=tslib_1.__importDefault(require("../../context/BillingAddressFormContext")),ShippingAddressFormContext_1=tslib_1.__importDefault(require("../../context/ShippingAddressFormContext")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty")),validateFormFields_1=require("../../utils/validateFormFields"),CustomerAddressFormContext_1=tslib_1.__importDefault(require("../../context/CustomerAddressFormContext")),propTypes=components_1.default.AddressInput.propTypes,displayName=components_1.default.AddressInput.displayName;function AddressInput(props){const{placeholder="",required,value,className,...p}=props,billingAddress=(0,react_1.useContext)(BillingAddressFormContext_1.default),shippingAddress=(0,react_1.useContext)(ShippingAddressFormContext_1.default),customerAddress=(0,react_1.useContext)(CustomerAddressFormContext_1.default),[hasError,setHasError]=(0,react_1.useState)(!1);(0,react_1.useEffect)(()=>(value&&billingAddress?.setValue&&billingAddress.setValue(p.name,value),value&&shippingAddress?.setValue&&shippingAddress.setValue(p.name,value),value&&customerAddress?.setValue&&customerAddress.setValue(p.name,value),billingAddress.errors&&billingAddress?.errors?.[p.name]?.error&&setHasError(!0),billingAddress&&(0,isEmpty_1.default)(billingAddress?.errors?.[p.name])&&hasError&&setHasError(!1),customerAddress.errors&&customerAddress?.errors?.[p.name]?.error&&setHasError(!0),(0,isEmpty_1.default)(customerAddress?.errors?.[p.name])&&hasError&&setHasError(!1),shippingAddress.errors&&shippingAddress?.errors?.[p.name]?.error&&setHasError(!0),shippingAddress&&(0,isEmpty_1.default)(shippingAddress?.errors?.[p.name])&&hasError&&setHasError(!1),()=>{setHasError(!1)}),[value,billingAddress?.errors,shippingAddress?.errors]);const mandatoryField=billingAddress?.isBusiness?(0,validateFormFields_1.businessMandatoryField)(p.name,billingAddress.isBusiness):(0,validateFormFields_1.businessMandatoryField)(p.name,shippingAddress.isBusiness),reqField=required!==void 0?required:mandatoryField,errorClassName=billingAddress?.errorClassName||shippingAddress?.errorClassName,classNameComputed=`${className||""} ${hasError&&errorClassName?errorClassName:""}`;return p.name==="billing_address_billing_info"&&!billingAddress.requiresBillingInfo?null:(0,jsx_runtime_1.jsx)(BaseInput_1.default,{ref:billingAddress?.validation||shippingAddress?.validation||customerAddress?.validation,className:classNameComputed,required:reqField,placeholder,defaultValue:value,...p})}exports.AddressInput=AddressInput,AddressInput.propTypes=propTypes,AddressInput.displayName=displayName,exports.default=AddressInput;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.AddressInput=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),BaseInput_1=tslib_1.__importDefault(require("../utils/BaseInput")),BillingAddressFormContext_1=tslib_1.__importDefault(require("../../context/BillingAddressFormContext")),ShippingAddressFormContext_1=tslib_1.__importDefault(require("../../context/ShippingAddressFormContext")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty")),validateFormFields_1=require("../../utils/validateFormFields"),CustomerAddressFormContext_1=tslib_1.__importDefault(require("../../context/CustomerAddressFormContext"));function AddressInput(props){const{placeholder="",required,value,className,...p}=props,billingAddress=(0,react_1.useContext)(BillingAddressFormContext_1.default),shippingAddress=(0,react_1.useContext)(ShippingAddressFormContext_1.default),customerAddress=(0,react_1.useContext)(CustomerAddressFormContext_1.default),[hasError,setHasError]=(0,react_1.useState)(!1);(0,react_1.useEffect)(()=>(value&&billingAddress?.setValue&&billingAddress.setValue(p.name,value),value&&shippingAddress?.setValue&&shippingAddress.setValue(p.name,value),value&&customerAddress?.setValue&&customerAddress.setValue(p.name,value),billingAddress.errors&&billingAddress?.errors?.[p.name]?.error&&setHasError(!0),billingAddress&&(0,isEmpty_1.default)(billingAddress?.errors?.[p.name])&&hasError&&setHasError(!1),customerAddress.errors&&customerAddress?.errors?.[p.name]?.error&&setHasError(!0),(0,isEmpty_1.default)(customerAddress?.errors?.[p.name])&&hasError&&setHasError(!1),shippingAddress.errors&&shippingAddress?.errors?.[p.name]?.error&&setHasError(!0),shippingAddress&&(0,isEmpty_1.default)(shippingAddress?.errors?.[p.name])&&hasError&&setHasError(!1),()=>{setHasError(!1)}),[value,billingAddress?.errors,shippingAddress?.errors]);const mandatoryField=billingAddress?.isBusiness?(0,validateFormFields_1.businessMandatoryField)(p.name,billingAddress.isBusiness):(0,validateFormFields_1.businessMandatoryField)(p.name,shippingAddress.isBusiness),reqField=required!==void 0?required:mandatoryField,errorClassName=billingAddress?.errorClassName||shippingAddress?.errorClassName,classNameComputed=`${className||""} ${hasError&&errorClassName?errorClassName:""}`;return p.name==="billing_address_billing_info"&&!billingAddress.requiresBillingInfo?null:(0,jsx_runtime_1.jsx)(BaseInput_1.default,{ref:billingAddress?.validation||shippingAddress?.validation||customerAddress?.validation,className:classNameComputed,required:reqField,placeholder,defaultValue:value,...p})}exports.AddressInput=AddressInput,exports.default=AddressInput;
@@ -1,8 +1,9 @@
1
1
  import { ReactNode } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type ChildrenProps = FunctionChildren<Omit<Props, 'children'>>;
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
+ }
4
5
  declare type Props = {
5
- children?: ChildrenProps;
6
+ children?: ChildrenFunction<ChildrenProps>;
6
7
  label?: string | ReactNode;
7
8
  onClick?: () => void;
8
9
  addressId?: string;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SaveAddressesButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),AddressContext_1=tslib_1.__importDefault(require("../../context/AddressContext")),addressesManager_1=require("../../utils/addressesManager"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),CustomerContext_1=tslib_1.__importDefault(require("../../context/CustomerContext")),isFunction_1=tslib_1.__importDefault(require("lodash/isFunction"));function SaveAddressesButton(props){const{children,label="Continue to delivery",resource,disabled=!1,addressId,onClick,...p}=props,{errors,billing_address,shipToDifferentAddress,shipping_address,saveAddresses,billingAddressId,shippingAddressId}=(0,react_1.useContext)(AddressContext_1.default),{order}=(0,react_1.useContext)(OrderContext_1.default),{addresses,isGuest,createCustomerAddress}=(0,react_1.useContext)(CustomerContext_1.default),[forceDisable,setForceDisable]=(0,react_1.useState)(disabled),customerEmail=(isGuest===!0||typeof isGuest>"u")&&!order?.customer_email,billingDisable=(0,addressesManager_1.billingAddressController)({billing_address,errors,billingAddressId,requiresBillingInfo:order?.requires_billing_info}),shippingDisable=(0,addressesManager_1.shippingAddressController)({billingDisable,errors,shipToDifferentAddress,shipping_address,shippingAddressId}),countryLockDisable=(0,addressesManager_1.countryLockController)({countryCodeLock:order?.shipping_country_code_lock,addresses,shipToDifferentAddress,billingAddressId,billing_address,shipping_address,shippingAddressId}),disable=disabled||customerEmail||billingDisable||shippingDisable||countryLockDisable,handleClick=()=>{if(errors&&Object.keys(errors).length===0&&!disable){if(setForceDisable(!0),order)saveAddresses();else if(createCustomerAddress&&billing_address){const address={...billing_address};addressId&&(address.id=addressId),createCustomerAddress(address)}setForceDisable(!1),onClick&&onClick()}},parentProps={...p,label,resource,handleClick,disabled:disable};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"button",disabled:disable||forceDisable,onClick:handleClick,...p,children:(0,isFunction_1.default)(label)?label():label})}exports.SaveAddressesButton=SaveAddressesButton,exports.default=SaveAddressesButton;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SaveAddressesButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),AddressContext_1=tslib_1.__importDefault(require("../../context/AddressContext")),addressesManager_1=require("../../utils/addressesManager"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),CustomerContext_1=tslib_1.__importDefault(require("../../context/CustomerContext")),isFunction_1=tslib_1.__importDefault(require("lodash/isFunction"));function SaveAddressesButton(props){const{children,label="Continue to delivery",resource,disabled=!1,addressId,onClick,...p}=props,{errors,billing_address:billingAddress,shipToDifferentAddress,shipping_address:shippingAddress,saveAddresses,billingAddressId,shippingAddressId}=(0,react_1.useContext)(AddressContext_1.default),{order}=(0,react_1.useContext)(OrderContext_1.default),{addresses,isGuest,createCustomerAddress}=(0,react_1.useContext)(CustomerContext_1.default),[forceDisable,setForceDisable]=(0,react_1.useState)(disabled),customerEmail=(isGuest===!0||typeof isGuest>"u")&&!order?.customer_email,billingDisable=(0,addressesManager_1.billingAddressController)({billing_address:billingAddress,errors,billingAddressId,requiresBillingInfo:order?.requires_billing_info}),shippingDisable=(0,addressesManager_1.shippingAddressController)({billingDisable,errors,shipToDifferentAddress,shipping_address:shippingAddress,shippingAddressId}),countryLockDisable=(0,addressesManager_1.countryLockController)({countryCodeLock:order?.shipping_country_code_lock,addresses,shipToDifferentAddress,billingAddressId,billing_address:billingAddress,shipping_address:shippingAddress,shippingAddressId}),disable=disabled||customerEmail||billingDisable||shippingDisable||countryLockDisable,handleClick=()=>{if(errors&&Object.keys(errors).length===0&&!disable){if(setForceDisable(!0),order)saveAddresses();else if(createCustomerAddress&&billingAddress){const address={...billingAddress};addressId&&(address.id=addressId),createCustomerAddress(address)}setForceDisable(!1),onClick&&onClick()}},parentProps={...p,label,resource,handleClick,disabled:disable};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"button",disabled:disable||forceDisable,onClick:handleClick,...p,children:(0,isFunction_1.default)(label)?label():label})}exports.SaveAddressesButton=SaveAddressesButton,exports.default=SaveAddressesButton;
@@ -1,15 +1,8 @@
1
- import type { ReactNode } from 'react';
1
+ /// <reference types="react" />
2
2
  declare type Props = {
3
- children: ReactNode;
3
+ children: JSX.Element[] | JSX.Element;
4
4
  accessToken: string;
5
5
  endpoint: string;
6
6
  };
7
7
  export declare function CommerceLayer(props: Props): JSX.Element;
8
- export declare namespace CommerceLayer {
9
- var propTypes: {
10
- children: import("prop-types").Validator<NonNullable<ReactNode | (() => JSX.Element)>>;
11
- accessToken: import("prop-types").Validator<string>;
12
- endpoint: import("prop-types").Validator<string>;
13
- };
14
- }
15
8
  export default CommerceLayer;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CommerceLayer=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.CommerceLayer.propTypes;function CommerceLayer(props){const{children,...p}=props;return(0,jsx_runtime_1.jsx)(CommerceLayerContext_1.default.Provider,{value:{...p},children})}exports.CommerceLayer=CommerceLayer,CommerceLayer.propTypes=propTypes,exports.default=CommerceLayer;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CommerceLayer=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext")),ErrorBoundary_1=tslib_1.__importDefault(require("../utils/ErrorBoundary"));function CommerceLayer(props){const{children,...p}=props;return(0,jsx_runtime_1.jsx)(ErrorBoundary_1.default,{children:(0,jsx_runtime_1.jsx)(CommerceLayerContext_1.default.Provider,{value:{...p},children})})}exports.CommerceLayer=CommerceLayer,exports.default=CommerceLayer;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CustomerAddressForm=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),AddressContext_1=tslib_1.__importDefault(require("../../context/AddressContext")),rapid_form_1=require("rapid-form"),react_1=require("react"),CustomerAddressFormContext_1=tslib_1.__importDefault(require("../../context/CustomerAddressFormContext")),components_1=tslib_1.__importDefault(require("../../config/components")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),isEmptyStates_1=tslib_1.__importDefault(require("../../utils/isEmptyStates")),propTypes=components_1.default.CustomerAddressForm.propTypes;function CustomerAddressForm(props){const{children,errorClassName,autoComplete="on",reset=!1,...p}=props;console.log(rapid_form_1.useRapidForm);debugger;const{validation,values,errors,reset:resetForm}=(0,rapid_form_1.useRapidForm)(),{setAddressErrors,setAddress}=(0,react_1.useContext)(AddressContext_1.default),{order}=(0,react_1.useContext)(OrderContext_1.default),ref=(0,react_1.useRef)(null);(0,react_1.useEffect)(()=>{if(Object.keys(errors).length>0){const formErrors=[];for(const fieldName in errors){const code=errors[fieldName]?.code,message=errors[fieldName]?.message||"";fieldName==="billing_address_state_code"?values.state_code?delete errors[fieldName]:formErrors.push({code,message,resource:"billing_address",field:fieldName}):formErrors.push({code,message,resource:"billing_address",field:fieldName})}setAddressErrors(formErrors,"billing_address")}else if(Object.keys(values).length>0){setAddressErrors([],"billing_address");for(const name in values){const field=values[name];if(field?.value&&(values[name.replace("billing_address_","")]=field.value,delete values[name]),["billing_address_state_code"].includes(name)){const countryCode=values.billing_address_country_code?.value||values.country_code;!(0,isEmptyStates_1.default)(countryCode)&&!field.value&&delete values.billing_address_state_code}}setAddress({values,resource:"billing_address"})}reset&&(Object.keys(values).length>0||Object.keys(errors).length>0)&&ref&&(ref.current?.reset(),resetForm({target:ref.current}),setAddressErrors([],"billing_address"),setAddress({values:{},resource:"billing_address"}))},[errors,values,reset]);const providerValues={values,validation,setValue:(name,value)=>{const field={[name.replace("billing_address_","")]:value};setAddress({values:{...values,...field},resource:"billing_address"})},errorClassName,requiresBillingInfo:order?.requiresBillingInfo||!1,errors,resetField:name=>resetForm({currentTarget:ref.current},name)};return(0,jsx_runtime_1.jsx)(CustomerAddressFormContext_1.default.Provider,{value:providerValues,children:(0,jsx_runtime_1.jsx)("form",{ref,autoComplete,...p,children})})}exports.CustomerAddressForm=CustomerAddressForm,CustomerAddressForm.propTypes=propTypes,exports.default=CustomerAddressForm;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CustomerAddressForm=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),AddressContext_1=tslib_1.__importDefault(require("../../context/AddressContext")),rapid_form_1=require("rapid-form"),react_1=require("react"),CustomerAddressFormContext_1=tslib_1.__importDefault(require("../../context/CustomerAddressFormContext")),components_1=tslib_1.__importDefault(require("../../config/components")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),isEmptyStates_1=tslib_1.__importDefault(require("../../utils/isEmptyStates")),propTypes=components_1.default.CustomerAddressForm.propTypes;function CustomerAddressForm(props){const{children,errorClassName,autoComplete="on",reset=!1,...p}=props,{validation,values,errors,reset:resetForm}=(0,rapid_form_1.useRapidForm)(),{setAddressErrors,setAddress}=(0,react_1.useContext)(AddressContext_1.default),{order}=(0,react_1.useContext)(OrderContext_1.default),ref=(0,react_1.useRef)(null);(0,react_1.useEffect)(()=>{if(Object.keys(errors).length>0){const formErrors=[];for(const fieldName in errors){const code=errors[fieldName]?.code,message=errors[fieldName]?.message||"";fieldName==="billing_address_state_code"?values.state_code?delete errors[fieldName]:formErrors.push({code,message,resource:"billing_address",field:fieldName}):formErrors.push({code,message,resource:"billing_address",field:fieldName})}setAddressErrors(formErrors,"billing_address")}else if(Object.keys(values).length>0){setAddressErrors([],"billing_address");for(const name in values){const field=values[name];if(field?.value&&(values[name.replace("billing_address_","")]=field.value,delete values[name]),["billing_address_state_code"].includes(name)){const countryCode=values.billing_address_country_code?.value||values.country_code;!(0,isEmptyStates_1.default)(countryCode)&&!field.value&&delete values.billing_address_state_code}}setAddress({values,resource:"billing_address"})}reset&&(Object.keys(values).length>0||Object.keys(errors).length>0)&&ref&&(ref.current?.reset(),resetForm({target:ref.current}),setAddressErrors([],"billing_address"),setAddress({values:{},resource:"billing_address"}))},[errors,values,reset]);const providerValues={values,validation,setValue:(name,value)=>{const field={[name.replace("billing_address_","")]:value};setAddress({values:{...values,...field},resource:"billing_address"})},errorClassName,requiresBillingInfo:order?.requiresBillingInfo||!1,errors,resetField:name=>resetForm({currentTarget:ref.current},name)};return(0,jsx_runtime_1.jsx)(CustomerAddressFormContext_1.default.Provider,{value:providerValues,children:(0,jsx_runtime_1.jsx)("form",{ref,autoComplete,...p,children})})}exports.CustomerAddressForm=CustomerAddressForm,CustomerAddressForm.propTypes=propTypes,exports.default=CustomerAddressForm;
@@ -1,13 +1,12 @@
1
1
  import { ReactNode } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type ParentProps = {
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  handleClick: () => void;
5
- };
6
- declare type ChildrenProps = FunctionChildren<Omit<Props & ParentProps, 'children'>>;
7
- declare type Props = {
8
- children?: ChildrenProps;
5
+ }
6
+ interface Props extends Omit<JSX.IntrinsicElements['button'], 'children'> {
7
+ children?: ChildrenFunction<ChildrenProps>;
9
8
  label?: string | ReactNode;
10
9
  onClick?: () => void;
11
- } & JSX.IntrinsicElements['button'];
10
+ }
12
11
  export declare function SaveCustomerButton(props: Props): JSX.Element;
13
12
  export default SaveCustomerButton;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SaveCustomerButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),lodash_1=require("lodash"),CustomerContext_1=tslib_1.__importDefault(require("../../context/CustomerContext"));function SaveCustomerButton(props){const{children,label="Save",resource,disabled,onClick,...p}=props,{errors,saveCustomerUser,customerEmail}=(0,react_1.useContext)(CustomerContext_1.default),disable=disabled||!(0,lodash_1.isEmpty)(errors)||(0,lodash_1.isEmpty)(customerEmail),handleClick=async()=>{(0,lodash_1.isEmpty)(errors)&&!disable&&(saveCustomerUser&&await saveCustomerUser(customerEmail),onClick&&onClick())},parentProps={...p,label,resource,handleClick,disabled:disable};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"button",disabled:disable,onClick:void 0,...p,children:label})}exports.SaveCustomerButton=SaveCustomerButton,exports.default=SaveCustomerButton;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.SaveCustomerButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),lodash_1=require("lodash"),CustomerContext_1=tslib_1.__importDefault(require("../../context/CustomerContext"));function SaveCustomerButton(props){const{children,label="Save",resource,disabled,onClick,...p}=props,{errors,saveCustomerUser,customerEmail}=(0,react_1.useContext)(CustomerContext_1.default),disable=disabled||!(0,lodash_1.isEmpty)(errors)||(0,lodash_1.isEmpty)(customerEmail),handleClick=async()=>{(0,lodash_1.isEmpty)(errors)&&!disable&&(saveCustomerUser&&await saveCustomerUser(customerEmail),onClick&&onClick())},parentProps={...p,label,resource,handleClick,disabled:disable};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"button",disabled:disable,onClick:()=>{handleClick()},...p,children:label})}exports.SaveCustomerButton=SaveCustomerButton,exports.default=SaveCustomerButton;
@@ -1,24 +1,16 @@
1
1
  /// <reference types="react" />
2
- import { FunctionChildren } from '../../typings/index';
2
+ import { ChildrenFunction } from '../../typings/index';
3
3
  import type { CodeType } from '../../reducers/OrderReducer';
4
- declare type ChildrenProps = Omit<Props, 'children'> & {
4
+ interface ChildrenProps extends Omit<Props, 'children'> {
5
5
  code?: string;
6
6
  hide?: boolean;
7
- discountAmountCents?: string;
8
- discountAmountFloat?: string;
7
+ discountAmountCents?: number;
8
+ discountAmountFloat?: number;
9
9
  formattedDiscountAmount?: string;
10
- };
11
- declare type GiftCardOrCouponCodeChildrenProps = FunctionChildren<ChildrenProps>;
12
- declare type Props = {
10
+ }
11
+ interface Props extends Omit<JSX.IntrinsicElements['span'], 'children'> {
13
12
  type?: CodeType;
14
- children?: GiftCardOrCouponCodeChildrenProps;
15
- } & JSX.IntrinsicElements['span'];
16
- export declare function GiftCardOrCouponCode({ children, type, ...props }: Props): JSX.Element | null;
17
- export declare namespace GiftCardOrCouponCode {
18
- var propTypes: {
19
- children: import("prop-types").Requireable<(...args: any[]) => any>;
20
- type: import("prop-types").Requireable<CodeType>;
21
- };
22
- var displayName: string;
13
+ children?: ChildrenFunction<ChildrenProps>;
23
14
  }
15
+ export declare function GiftCardOrCouponCode({ children, type, ...props }: Props): JSX.Element | null;
24
16
  export default GiftCardOrCouponCode;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponCode=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),components_1=tslib_1.__importDefault(require("../../config/components")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),has_1=tslib_1.__importDefault(require("lodash/has")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty")),propTypes=components_1.default.GiftCardOrCouponCode.propTypes,displayName=components_1.default.GiftCardOrCouponCode.displayName;function GiftCardOrCouponCode({children,type,...props}){const{order}=(0,react_1.useContext)(OrderContext_1.default);let codeType=type&&`${type}_code`;!type&&order&&(0,has_1.default)(order,"coupon_code")&&!(0,isEmpty_1.default)(order.coupon_code)?codeType="coupon_code":type||(codeType="gift_card_code");const code=order&&codeType?order[codeType]:"",hide=!(order&&code),parentProps={...props,code,hide,discountAmountCents:order?.discount_amount_cents,discountAmountFloat:order?.discount_amount_float,formattedDiscountAmount:order?.formatted_discount_amount};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):hide?null:(0,jsx_runtime_1.jsx)("span",{...props,children:code})}exports.GiftCardOrCouponCode=GiftCardOrCouponCode,GiftCardOrCouponCode.propTypes=propTypes,GiftCardOrCouponCode.displayName=displayName,exports.default=GiftCardOrCouponCode;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponCode=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),has_1=tslib_1.__importDefault(require("lodash/has")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty"));function GiftCardOrCouponCode({children,type,...props}){const{order}=(0,react_1.useContext)(OrderContext_1.default);let codeType=type&&`${type}_code`;!type&&order&&(0,has_1.default)(order,"coupon_code")&&!(0,isEmpty_1.default)(order.coupon_code)?codeType="coupon_code":type||(codeType="gift_card_code");const code=order&&codeType?order[codeType]:"",hide=!(order&&code),parentProps={...props,code,hide,discountAmountCents:order?.discount_amount_cents,discountAmountFloat:order?.discount_amount_float,formattedDiscountAmount:order?.formatted_discount_amount};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):hide?null:(0,jsx_runtime_1.jsx)("span",{...props,children:code})}exports.GiftCardOrCouponCode=GiftCardOrCouponCode,exports.default=GiftCardOrCouponCode;
@@ -1,26 +1,18 @@
1
1
  import { ReactNode } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
2
+ import { ChildrenFunction } from '../../typings/index';
3
3
  import { CodeType, OrderCodeType } from '../../reducers/OrderReducer';
4
- declare type GiftCardOrCouponRemoveButtonChildrenProps = FunctionChildren<Omit<Props, 'children'> & {
4
+ interface ChildrenProps extends Omit<Props, 'children'> {
5
5
  codeType?: OrderCodeType;
6
6
  hide?: boolean;
7
7
  handleClick?: () => void;
8
- }>;
8
+ }
9
9
  declare type Props = {
10
10
  type?: CodeType;
11
- children?: GiftCardOrCouponRemoveButtonChildrenProps;
11
+ children?: ChildrenFunction<ChildrenProps>;
12
12
  label?: string | ReactNode;
13
13
  onClick?: (response: {
14
14
  success: boolean;
15
15
  }) => void;
16
16
  } & Omit<JSX.IntrinsicElements['button'], 'type'>;
17
17
  export declare function GiftCardOrCouponRemoveButton(props: Props): JSX.Element | null;
18
- export declare namespace GiftCardOrCouponRemoveButton {
19
- var propTypes: {
20
- children: import("prop-types").Requireable<(...args: any[]) => any>;
21
- type: import("prop-types").Requireable<CodeType>;
22
- label: import("prop-types").Requireable<NonNullable<string | object | null | undefined>>;
23
- };
24
- var displayName: string;
25
- }
26
18
  export default GiftCardOrCouponRemoveButton;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponRemoveButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),components_1=tslib_1.__importDefault(require("../../config/components")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),lodash_1=require("lodash"),propTypes=components_1.default.GiftCardOrCouponRemoveButton.propTypes,displayName=components_1.default.GiftCardOrCouponRemoveButton.displayName;function GiftCardOrCouponRemoveButton(props){const{children,label="Remove",onClick,type,...p}=props,{order,removeGiftCardOrCouponCode}=(0,react_1.useContext)(OrderContext_1.default);let codeType=`${type}_code`;!type&&order&&(0,lodash_1.has)(order,"coupon_code")&&!(0,lodash_1.isEmpty)(order.coupon_code)?codeType="coupon_code":type||(codeType="gift_card_code");const code=order&&codeType?order[codeType]:"",hide=!(order&&code),handleClick=async()=>{const response=removeGiftCardOrCouponCode&&await removeGiftCardOrCouponCode({codeType});onClick&&onClick(response)},parentProps={...p,label,handleClick,codeType};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):hide?null:(0,jsx_runtime_1.jsx)("button",{type:"button",onClick:handleClick,...p,children:label})}exports.GiftCardOrCouponRemoveButton=GiftCardOrCouponRemoveButton,GiftCardOrCouponRemoveButton.propTypes=propTypes,GiftCardOrCouponRemoveButton.displayName=displayName,exports.default=GiftCardOrCouponRemoveButton;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponRemoveButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),lodash_1=require("lodash");function GiftCardOrCouponRemoveButton(props){const{children,label="Remove",onClick,type,...p}=props,{order,removeGiftCardOrCouponCode}=(0,react_1.useContext)(OrderContext_1.default);let codeType=type?`${type}_code`:void 0;!type&&order&&(0,lodash_1.has)(order,"coupon_code")&&!(0,lodash_1.isEmpty)(order.coupon_code)?codeType="coupon_code":type||(codeType="gift_card_code");const code=order&&codeType?order[codeType]:"",hide=!(order&&code),handleClick=async()=>{const response=removeGiftCardOrCouponCode&&codeType&&await removeGiftCardOrCouponCode({codeType});onClick&&response&&onClick(response)},parentProps={...p,label,handleClick,codeType};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):hide?null:(0,jsx_runtime_1.jsx)("button",{type:"button",onClick:()=>{handleClick()},...p,children:label})}exports.GiftCardOrCouponRemoveButton=GiftCardOrCouponRemoveButton,exports.default=GiftCardOrCouponRemoveButton;
@@ -1,16 +1,10 @@
1
1
  import { ReactNode } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type GiftCardOrCouponSubmitChildrenProps = FunctionChildren<Omit<Props, 'children'>>;
4
- declare type Props = {
5
- children?: GiftCardOrCouponSubmitChildrenProps;
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
+ }
5
+ interface Props extends Omit<JSX.IntrinsicElements['button'], 'children'> {
6
+ children?: ChildrenFunction<ChildrenProps>;
6
7
  label?: string | ReactNode;
7
- } & JSX.IntrinsicElements['button'];
8
- export declare function GiftCardOrCouponSubmit(props: Props): JSX.Element;
9
- export declare namespace GiftCardOrCouponSubmit {
10
- var propTypes: {
11
- children: import("prop-types").Requireable<(...args: any[]) => any>;
12
- label: import("prop-types").Requireable<NonNullable<string | object | null | undefined>>;
13
- };
14
- var displayName: string;
15
8
  }
9
+ export declare function GiftCardOrCouponSubmit(props: Props): JSX.Element;
16
10
  export default GiftCardOrCouponSubmit;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponSubmit=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.GiftCardOrCouponSubmit.propTypes,displayName=components_1.default.GiftCardOrCouponSubmit.displayName;function GiftCardOrCouponSubmit(props){const{children,label="Submit",...p}=props,parentProps={...p,label};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"submit",...p,children:label})}exports.GiftCardOrCouponSubmit=GiftCardOrCouponSubmit,GiftCardOrCouponSubmit.propTypes=propTypes,GiftCardOrCouponSubmit.displayName=displayName,exports.default=GiftCardOrCouponSubmit;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.GiftCardOrCouponSubmit=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),Parent_1=tslib_1.__importDefault(require("../utils/Parent"));function GiftCardOrCouponSubmit(props){const{children,label="Submit",...p}=props,parentProps={...p,label};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{type:"submit",...p,children:label})}exports.GiftCardOrCouponSubmit=GiftCardOrCouponSubmit,exports.default=GiftCardOrCouponSubmit;
@@ -1,7 +1,7 @@
1
1
  import { CSSProperties } from 'react';
2
2
  import { LineItemOption as LineItemOptionType } from '@commercelayer/sdk';
3
- import { FunctionChildren } from '../../typings/index';
4
- declare type LineItemOptionChildrenProps = FunctionChildren<Omit<Props, 'children'> & {
3
+ import { ChildrenFunction } from '../../typings/index';
4
+ declare type LineItemOptionChildrenProps = ChildrenFunction<Omit<Props, 'children'> & {
5
5
  lineItemOption: LineItemOptionType;
6
6
  }>;
7
7
  declare type Props = {
@@ -1,26 +1,14 @@
1
1
  /// <reference types="react" />
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type LineItemQuantityChildrenProps = FunctionChildren<Omit<Props, 'children'> & {
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  quantity: number;
5
5
  handleChange: (event: React.MouseEvent<HTMLSelectElement>) => void;
6
- }>;
6
+ }
7
7
  declare type Props = {
8
- children?: LineItemQuantityChildrenProps;
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  max?: number;
10
10
  disabled?: boolean;
11
11
  readonly?: boolean;
12
12
  } & (JSX.IntrinsicElements['select'] & JSX.IntrinsicElements['span']);
13
13
  export declare function LineItemQuantity(props: Props): JSX.Element;
14
- export declare namespace LineItemQuantity {
15
- var propTypes: {
16
- children: import("prop-types").Requireable<(...args: any[]) => any>;
17
- max: import("prop-types").Requireable<number>;
18
- disabled: import("prop-types").Requireable<boolean>;
19
- readonly: import("prop-types").Requireable<boolean>;
20
- };
21
- var defaultProps: {
22
- max: number;
23
- };
24
- var displayName: string;
25
- }
26
14
  export default LineItemQuantity;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemQuantity=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),LineItemChildrenContext_1=tslib_1.__importDefault(require("../../context/LineItemChildrenContext")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.LineItemQuantity.propTypes,defaultProps=components_1.default.LineItemQuantity.defaultProps,displayName=components_1.default.LineItemQuantity.displayName;function LineItemQuantity(props){const{max=50,readonly=!1,...p}=props,{lineItem}=(0,react_1.useContext)(LineItemChildrenContext_1.default),{updateLineItem}=(0,react_1.useContext)(LineItemContext_1.default),options=[];for(let i=1;i<=max;i++)options.push((0,jsx_runtime_1.jsx)("option",{value:`${i}`,children:i},i));const handleChange=e=>{const quantity2=Number(e.target.value);updateLineItem&&lineItem&&updateLineItem(lineItem.id,quantity2)},quantity=lineItem?.quantity,parentProps={handleChange,quantity,...props};return props.children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children:props.children}):readonly?(0,jsx_runtime_1.jsx)("span",{...p,children:quantity}):(0,jsx_runtime_1.jsx)("select",{title:lineItem?.name,value:quantity,onChange:handleChange,...p,children:options})}exports.LineItemQuantity=LineItemQuantity,LineItemQuantity.propTypes=propTypes,LineItemQuantity.defaultProps=defaultProps,LineItemQuantity.displayName=displayName,exports.default=LineItemQuantity;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemQuantity=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),LineItemChildrenContext_1=tslib_1.__importDefault(require("../../context/LineItemChildrenContext")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent"));function LineItemQuantity(props){const{max=50,readonly=!1,...p}=props,{lineItem}=(0,react_1.useContext)(LineItemChildrenContext_1.default),{updateLineItem}=(0,react_1.useContext)(LineItemContext_1.default),options=[];for(let i=1;i<=max;i++)options.push((0,jsx_runtime_1.jsx)("option",{value:`${i}`,children:i},i));const handleChange=e=>{const quantity2=Number(e.target.value);updateLineItem&&lineItem&&updateLineItem(lineItem.id,quantity2)},quantity=lineItem?.quantity,parentProps={handleChange,quantity,...props};return props.children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children:props.children}):readonly?(0,jsx_runtime_1.jsx)("span",{...p,children:quantity}):(0,jsx_runtime_1.jsx)("select",{title:lineItem?.name,value:quantity,onChange:handleChange,...p,children:options})}exports.LineItemQuantity=LineItemQuantity,exports.default=LineItemQuantity;
@@ -1,22 +1,12 @@
1
1
  import { PropsWithoutRef } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type ChildrenProps = FunctionChildren<{
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  handleRemove: (event: React.MouseEvent<HTMLAnchorElement>) => void;
5
5
  label?: string;
6
- }>;
7
- declare type Props = {
8
- children?: ChildrenProps;
6
+ }
7
+ interface Props extends PropsWithoutRef<Omit<JSX.IntrinsicElements['a'], 'children'>> {
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  label?: string;
10
- } & PropsWithoutRef<JSX.IntrinsicElements['a']>;
11
- export declare function LineItemRemoveLink(props: Props): JSX.Element;
12
- export declare namespace LineItemRemoveLink {
13
- var propTypes: {
14
- children: import("prop-types").Requireable<(...args: any[]) => any>;
15
- label: import("prop-types").Requireable<string>;
16
- };
17
- var defaultProps: {
18
- label: string;
19
- };
20
- var displayName: string;
21
10
  }
11
+ export declare function LineItemRemoveLink(props: Props): JSX.Element;
22
12
  export default LineItemRemoveLink;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemRemoveLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),LineItemChildrenContext_1=tslib_1.__importDefault(require("../../context/LineItemChildrenContext")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.LineItemRemoveLink.propTypes,defaultProps=components_1.default.LineItemRemoveLink.defaultProps,displayName=components_1.default.LineItemRemoveLink.displayName;function LineItemRemoveLink(props){const{label="Remove"}=props,{lineItem}=(0,react_1.useContext)(LineItemChildrenContext_1.default),{deleteLineItem}=(0,react_1.useContext)(LineItemContext_1.default),handleRemove=e=>{e.preventDefault(),deleteLineItem&&lineItem&&deleteLineItem(lineItem.id)},parentProps={handleRemove,...props};return props.children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children:props.children}):(0,jsx_runtime_1.jsx)("a",{...props,href:"#",onClick:handleRemove,children:label})}exports.LineItemRemoveLink=LineItemRemoveLink,LineItemRemoveLink.propTypes=propTypes,LineItemRemoveLink.defaultProps=defaultProps,LineItemRemoveLink.displayName=displayName,exports.default=LineItemRemoveLink;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemRemoveLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),LineItemChildrenContext_1=tslib_1.__importDefault(require("../../context/LineItemChildrenContext")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent"));function LineItemRemoveLink(props){const{label="Remove"}=props,{lineItem}=(0,react_1.useContext)(LineItemChildrenContext_1.default),{deleteLineItem}=(0,react_1.useContext)(LineItemContext_1.default),handleRemove=e=>{e.preventDefault(),deleteLineItem&&lineItem&&deleteLineItem(lineItem.id)},parentProps={handleRemove,...props};return props.children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children:props.children}):(0,jsx_runtime_1.jsx)("a",{...props,href:"#",onClick:handleRemove,children:label})}exports.LineItemRemoveLink=LineItemRemoveLink,exports.default=LineItemRemoveLink;
@@ -1,22 +1,12 @@
1
1
  /// <reference types="react" />
2
2
  import { TypeAccepted } from '../../utils/getLineItemsCount';
3
- import { FunctionChildren } from '../../typings/index';
4
- declare type LineItemsCountChildrenProps = FunctionChildren<Omit<Props, 'children'> & {
3
+ import { ChildrenFunction } from '../../typings/index';
4
+ interface ChildrenProps extends Omit<Props, 'children'> {
5
5
  quantity: number;
6
- }>;
6
+ }
7
7
  declare type Props = {
8
- children?: LineItemsCountChildrenProps;
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  typeAccepted?: TypeAccepted[];
10
10
  } & JSX.IntrinsicElements['span'];
11
11
  export declare function LineItemsCount(props: Props): JSX.Element;
12
- export declare namespace LineItemsCount {
13
- var propTypes: {
14
- children: import("prop-types").Requireable<(...args: any[]) => any>;
15
- id: import("prop-types").Requireable<string>;
16
- className: import("prop-types").Requireable<string>;
17
- name: import("prop-types").Requireable<string>;
18
- style: import("prop-types").Requireable<object>;
19
- };
20
- var displayName: string;
21
- }
22
12
  export default LineItemsCount;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemsCount=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),getLineItemsCount_1=tslib_1.__importDefault(require("../../utils/getLineItemsCount")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.LineItemsCount.propTypes,displayName=components_1.default.LineItemsCount.displayName;function LineItemsCount(props){const{children,typeAccepted,...p}=props,{lineItems}=(0,react_1.useContext)(LineItemContext_1.default),[quantity,setQuantity]=(0,react_1.useState)(0);(0,react_1.useEffect)(()=>{if(lineItems&&lineItems.length>0){const qty=(0,getLineItemsCount_1.default)({lineItems:lineItems||[],typeAccepted});setQuantity(qty)}return()=>{setQuantity(0)}},[lineItems,typeAccepted]);const parentProps={quantity,typeAccepted,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("span",{...p,children:quantity})}exports.LineItemsCount=LineItemsCount,LineItemsCount.propTypes=propTypes,LineItemsCount.displayName=displayName,exports.default=LineItemsCount;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemsCount=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),getLineItemsCount_1=tslib_1.__importDefault(require("../../utils/getLineItemsCount")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext"));function LineItemsCount(props){const{children,typeAccepted,...p}=props,{lineItems}=(0,react_1.useContext)(LineItemContext_1.default),[quantity,setQuantity]=(0,react_1.useState)(0);(0,react_1.useEffect)(()=>{if(lineItems&&lineItems.length>0){const qty=(0,getLineItemsCount_1.default)({lineItems:lineItems||[],typeAccepted});setQuantity(qty)}return()=>{setQuantity(0)}},[lineItems,typeAccepted]);const parentProps={quantity,typeAccepted,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("span",{...p,children:quantity})}exports.LineItemsCount=LineItemsCount,exports.default=LineItemsCount;
@@ -1,23 +1,12 @@
1
1
  /// <reference types="react" />
2
- import { FunctionChildren } from '../../typings/index';
3
- export declare type LineItemsCountType = FunctionChildren<Omit<LineItemsCountProps, 'children'> & {
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  quantity: number;
5
5
  text: string;
6
- }>;
7
- declare type LineItemsCountProps = {
8
- children?: LineItemsCountType;
6
+ }
7
+ interface Props extends Omit<JSX.IntrinsicElements['span'], 'children'> {
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  text?: string;
10
- } & JSX.IntrinsicElements['span'];
11
- export declare function LineItemsEmpty(props: LineItemsCountProps): JSX.Element | null;
12
- export declare namespace LineItemsEmpty {
13
- var propTypes: {
14
- children: import("prop-types").Requireable<(...args: any[]) => any>;
15
- id: import("prop-types").Requireable<string>;
16
- className: import("prop-types").Requireable<string>;
17
- name: import("prop-types").Requireable<string>;
18
- style: import("prop-types").Requireable<object>;
19
- text: import("prop-types").Requireable<string>;
20
- };
21
- var displayName: string;
22
10
  }
11
+ export declare function LineItemsEmpty(props: Props): JSX.Element | null;
23
12
  export default LineItemsEmpty;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemsEmpty=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),getLineItemsCount_1=tslib_1.__importDefault(require("../../utils/getLineItemsCount")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext")),components_1=tslib_1.__importDefault(require("../../config/components")),propTypes=components_1.default.LineItemsEmpty.propTypes,displayName=components_1.default.LineItemsEmpty.displayName;function LineItemsEmpty(props){const{children,text="Your shopping bag is empty",...p}=props,{lineItems}=(0,react_1.useContext)(LineItemContext_1.default),[quantity,setQuantity]=(0,react_1.useState)(),emptyText=quantity===0?(0,jsx_runtime_1.jsx)("span",{...p,children:text}):null;(0,react_1.useEffect)(()=>{if(lineItems)if(lineItems.length>0){const qty=(0,getLineItemsCount_1.default)({lineItems:lineItems||[]});setQuantity(qty)}else setQuantity(0);return()=>{setQuantity(void 0)}},[lineItems]);const parentProps={quantity,text,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):emptyText}exports.LineItemsEmpty=LineItemsEmpty,LineItemsEmpty.propTypes=propTypes,LineItemsEmpty.displayName=displayName,exports.default=LineItemsEmpty;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LineItemsEmpty=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),getLineItemsCount_1=tslib_1.__importDefault(require("../../utils/getLineItemsCount")),LineItemContext_1=tslib_1.__importDefault(require("../../context/LineItemContext"));function LineItemsEmpty(props){const{children,text="Your shopping bag is empty",...p}=props,{lineItems}=(0,react_1.useContext)(LineItemContext_1.default),[quantity,setQuantity]=(0,react_1.useState)(),emptyText=quantity===0?(0,jsx_runtime_1.jsx)("span",{...p,children:text}):null;(0,react_1.useEffect)(()=>{if(lineItems)if(lineItems.length>0){const qty=(0,getLineItemsCount_1.default)({lineItems:lineItems||[]});setQuantity(qty)}else setQuantity(0);return()=>{setQuantity(void 0)}},[lineItems]);const parentProps={quantity,text,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):emptyText}exports.LineItemsEmpty=LineItemsEmpty,exports.default=LineItemsEmpty;
@@ -1,11 +1,10 @@
1
1
  import { PropsWithoutRef } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
2
+ import { ChildrenFunction } from '../../typings/index';
3
3
  import { AddToCartReturn } from '../../reducers/OrderReducer';
4
4
  import { VariantOption } from '../skus/VariantSelector';
5
- declare type ChildrenProps = {
5
+ interface ChildrenProps extends Omit<Props, 'children'> {
6
6
  handleClick: () => AddToCartReturn;
7
- } & Omit<Props, 'children'>;
8
- declare type AddToCartButtonChildrenProps = FunctionChildren<ChildrenProps>;
7
+ }
9
8
  export declare type AddToCartButtonType = ChildrenProps;
10
9
  declare type BuyNowMode = {
11
10
  buyNowMode: true;
@@ -22,7 +21,7 @@ declare type THostedCart = {
22
21
  hostedCartUrl?: never;
23
22
  };
24
23
  declare type Props = {
25
- children?: AddToCartButtonChildrenProps;
24
+ children?: ChildrenFunction<ChildrenProps>;
26
25
  label?: string | JSX.Element;
27
26
  skuCode?: string;
28
27
  bundleCode?: string;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.AddToCartButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty")),has_1=tslib_1.__importDefault(require("lodash/has")),ItemContext_1=tslib_1.__importDefault(require("../../context/ItemContext")),getCurrentItemKey_1=tslib_1.__importDefault(require("../../utils/getCurrentItemKey")),SkuListsContext_1=tslib_1.__importDefault(require("../../context/SkuListsContext")),ExternalFunctionContext_1=tslib_1.__importDefault(require("../../context/ExternalFunctionContext")),SkuChildrenContext_1=tslib_1.__importDefault(require("../../context/SkuChildrenContext")),getCartLink_1=tslib_1.__importDefault(require("../../utils/getCartLink")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext"));function AddToCartButton(props){const{label="Add to cart",children,skuCode,bundleCode,disabled,skuListId,lineItem,buyNowMode=!1,checkoutUrl,redirectToHostedCart,hostedCartUrl,...p}=props,{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),{addToCart,orderId,getOrder,setOrderErrors}=(0,react_1.useContext)(OrderContext_1.default),{url,callExternalFunction}=(0,react_1.useContext)(ExternalFunctionContext_1.default),{item,items,quantity,option,prices,lineItems,lineItem:lineItemContext,skuCode:itemSkuCode}=(0,react_1.useContext)(ItemContext_1.default),{skuLists}=(0,react_1.useContext)(SkuListsContext_1.default),{sku}=(0,react_1.useContext)(SkuChildrenContext_1.default),[slug]=endpoint?endpoint.split(".commercelayer"):[""],sCode=!(0,isEmpty_1.default)(items)&&skuCode?items[skuCode]?.code:sku?.code||skuCode||(0,getCurrentItemKey_1.default)(item)||itemSkuCode,availabilityQuantity=item[sCode]?.inventory?.quantity,handleClick=async()=>{const qty=quantity[sCode],opt=option[sCode],customLineItem=(0,isEmpty_1.default)(lineItem||lineItemContext)?lineItems[sCode]:lineItem||lineItemContext;if(!(0,isEmpty_1.default)(skuLists)&&skuListId&&url){const slQty=quantity[skuListId]||1;if((0,has_1.default)(skuLists,skuListId)){const lineItems2=skuLists&&skuLists[skuListId].map(skuCode2=>({skuCode:skuCode2,quantity:slQty,_update_quantity:1}));return callExternalFunction({url,data:{resourceType:"orders",inputs:[{id:orderId,lineItems:lineItems2}]}}).then(async res=>(getOrder&&orderId&&await getOrder(orderId),res)).catch(({response})=>(setOrderErrors&&setOrderErrors(response.data),response))}}if(!url&&addToCart){const res=await addToCart({bundleCode,skuCode:sCode,skuId:item[sCode]?.id,quantity:qty,option:opt,lineItem:customLineItem,buyNowMode,checkoutUrl});if(redirectToHostedCart){const orderId2=res.orderId;hostedCartUrl?location.href=`https://${hostedCartUrl}/${orderId2}?accessToken=${accessToken}`:orderId2&&slug&&(location.href=(0,getCartLink_1.default)({orderId:orderId2,slug,accessToken}))}return res}else if(url)return callExternalFunction({url,data:{bundleCode,skuCode:sCode,skuId:item[sCode]?.id,quantity:qty,option:opt,lineItem:customLineItem,buyNowMode,checkoutUrl}}).then(async res=>(getOrder&&orderId&&await getOrder(orderId),res)).catch(({response})=>(setOrderErrors&&setOrderErrors(response.data),response))},autoDisabled=!(0,isEmpty_1.default)(skuLists)||skuListId?!1:disabled||!prices[sCode]||!sCode||availabilityQuantity===0,parentProps={handleClick,disabled:disabled||autoDisabled,label,...props};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{...p,disabled:autoDisabled,onClick:handleClick,children:label})}exports.AddToCartButton=AddToCartButton,exports.default=AddToCartButton;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.AddToCartButton=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),isEmpty_1=tslib_1.__importDefault(require("lodash/isEmpty")),has_1=tslib_1.__importDefault(require("lodash/has")),ItemContext_1=tslib_1.__importDefault(require("../../context/ItemContext")),getCurrentItemKey_1=tslib_1.__importDefault(require("../../utils/getCurrentItemKey")),SkuListsContext_1=tslib_1.__importDefault(require("../../context/SkuListsContext")),ExternalFunctionContext_1=tslib_1.__importDefault(require("../../context/ExternalFunctionContext")),SkuChildrenContext_1=tslib_1.__importDefault(require("../../context/SkuChildrenContext")),getCartLink_1=tslib_1.__importDefault(require("../../utils/getCartLink")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext"));function AddToCartButton(props){const{label="Add to cart",children,skuCode,bundleCode,disabled,skuListId,lineItem,buyNowMode=!1,checkoutUrl,redirectToHostedCart,hostedCartUrl,...p}=props,{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),{addToCart,orderId,getOrder,setOrderErrors}=(0,react_1.useContext)(OrderContext_1.default),{url,callExternalFunction}=(0,react_1.useContext)(ExternalFunctionContext_1.default),{item,items,quantity,option,prices,lineItems,lineItem:lineItemContext,skuCode:itemSkuCode}=(0,react_1.useContext)(ItemContext_1.default),{skuLists}=(0,react_1.useContext)(SkuListsContext_1.default),{sku}=(0,react_1.useContext)(SkuChildrenContext_1.default),[slug]=endpoint?endpoint.split(".commercelayer"):[""],sCode=!(0,isEmpty_1.default)(items)&&skuCode?items[skuCode]?.code:sku?.code||skuCode||(0,getCurrentItemKey_1.default)(item)||itemSkuCode,availabilityQuantity=item[sCode]?.inventory?.quantity,handleClick=async()=>{const qty=quantity[sCode],opt=option[sCode],customLineItem=(0,isEmpty_1.default)(lineItem||lineItemContext)?lineItems[sCode]:lineItem||lineItemContext;if(!(0,isEmpty_1.default)(skuLists)&&skuListId&&url){const slQty=quantity[skuListId]||1;if((0,has_1.default)(skuLists,skuListId)){const lineItems2=skuLists?.[skuListId]?.map(skuCode2=>({skuCode:skuCode2,quantity:slQty,_update_quantity:1}));return await callExternalFunction({url,data:{resourceType:"orders",inputs:[{id:orderId,lineItems:lineItems2}]}}).then(async res=>(getOrder&&orderId&&await getOrder(orderId),res)).catch(({response})=>(setOrderErrors&&setOrderErrors(response.data),response))}}if(!url&&addToCart){const res=await addToCart({bundleCode,skuCode:sCode,skuId:item[sCode]?.id,quantity:qty,option:opt,lineItem:customLineItem,buyNowMode,checkoutUrl});if(redirectToHostedCart){const orderId2=res.orderId;hostedCartUrl&&orderId2?location.href=`https://${hostedCartUrl}/${orderId2}?accessToken=${accessToken}`:orderId2&&slug&&(location.href=(0,getCartLink_1.default)({orderId:orderId2,slug,accessToken}))}return res}else if(url)return await callExternalFunction({url,data:{bundleCode,skuCode:sCode,skuId:item[sCode]?.id,quantity:qty,option:opt,lineItem:customLineItem,buyNowMode,checkoutUrl}}).then(async res=>(getOrder&&orderId&&await getOrder(orderId),res)).catch(({response})=>(setOrderErrors&&setOrderErrors(response.data),response))},autoDisabled=!(0,isEmpty_1.default)(skuLists)||skuListId?!1:disabled||!prices[sCode]||!sCode||availabilityQuantity===0,parentProps={handleClick,disabled:disabled||autoDisabled,label,...props};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("button",{...p,disabled:autoDisabled,onClick:()=>{handleClick()},children:label})}exports.AddToCartButton=AddToCartButton,exports.default=AddToCartButton;
@@ -1,12 +1,12 @@
1
1
  import { MouseEvent, ReactNode } from 'react';
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type TChildren = FunctionChildren<Omit<Props, 'children'> & {
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  href: string;
5
5
  handleClick?: (e: MouseEvent<HTMLAnchorElement>) => Promise<void>;
6
- }>;
7
- declare type Props = {
8
- children?: TChildren;
6
+ }
7
+ interface Props extends Omit<JSX.IntrinsicElements['a'], 'children'> {
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  label?: string | ReactNode;
10
- } & JSX.IntrinsicElements['a'];
10
+ }
11
11
  export declare function CartLink(props: Props): JSX.Element | null;
12
12
  export default CartLink;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CartLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext")),getCartLink_1=tslib_1.__importDefault(require("../../utils/getCartLink"));function CartLink(props){const{label,children,...p}=props,{order,createOrder}=(0,react_1.useContext)(OrderContext_1.default),{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),[slug]=endpoint.split(".commercelayer"),href=slug&&order?.id?(0,getCartLink_1.default)({slug,orderId:order?.id,accessToken}):"",handleClick=async event=>{if(event.preventDefault(),order?.id)location.href=href;else{const orderId=await createOrder();slug&&(location.href=(0,getCartLink_1.default)({slug,orderId,accessToken}))}},parentProps={handleClick,label,href,...p};return accessToken?children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("a",{href,...p,onClick:handleClick,children:label}):null}exports.CartLink=CartLink,exports.default=CartLink;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CartLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext")),getCartLink_1=tslib_1.__importDefault(require("../../utils/getCartLink"));function CartLink(props){const{label,children,...p}=props,{order,createOrder}=(0,react_1.useContext)(OrderContext_1.default),{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),[slug]=endpoint.split(".commercelayer"),href=slug&&order?.id?(0,getCartLink_1.default)({slug,orderId:order?.id,accessToken}):"",handleClick=async event=>{if(event.preventDefault(),order?.id)location.href=href;else{const orderId=await createOrder();slug&&(location.href=(0,getCartLink_1.default)({slug,orderId,accessToken}))}},parentProps={handleClick,label,href,...p};return accessToken?children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("a",{href,...p,onClick:e=>{handleClick(e)},children:label}):null}exports.CartLink=CartLink,exports.default=CartLink;
@@ -1,11 +1,11 @@
1
1
  /// <reference types="react" />
2
- import { FunctionChildren } from '../../typings/index';
3
- declare type CheckoutLinkChildrenProps = FunctionChildren<Omit<Props, 'children'> & {
2
+ import { ChildrenFunction } from '../../typings/index';
3
+ interface ChildrenProps extends Omit<Props, 'children'> {
4
4
  checkoutUrl: string;
5
5
  href: string;
6
- }>;
6
+ }
7
7
  declare type Props = {
8
- children?: CheckoutLinkChildrenProps;
8
+ children?: ChildrenFunction<ChildrenProps>;
9
9
  label?: string;
10
10
  hostedCheckout?: boolean;
11
11
  } & JSX.IntrinsicElements['a'];
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CheckoutLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext"));function CheckoutLink(props){const{label,hostedCheckout=!0,children,...p}=props,{order}=(0,react_1.useContext)(OrderContext_1.default),{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),[slug]=endpoint.split(".commercelayer"),href=hostedCheckout?`${slug}.checkout.commercelayer.app/${order?.id}?accessToken=${accessToken}`:order?.checkout_url,parentProps={checkoutUrl:order?.checkout_url,hostedCheckout,label,href,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("a",{href,...p,children:label})}exports.CheckoutLink=CheckoutLink,exports.default=CheckoutLink;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.CheckoutLink=void 0;const tslib_1=require("tslib"),jsx_runtime_1=require("react/jsx-runtime"),react_1=require("react"),OrderContext_1=tslib_1.__importDefault(require("../../context/OrderContext")),Parent_1=tslib_1.__importDefault(require("../utils/Parent")),CommerceLayerContext_1=tslib_1.__importDefault(require("../../context/CommerceLayerContext"));function CheckoutLink(props){const{label,hostedCheckout=!0,children,...p}=props,{order}=(0,react_1.useContext)(OrderContext_1.default),{accessToken,endpoint}=(0,react_1.useContext)(CommerceLayerContext_1.default),[slug]=endpoint.split(".commercelayer"),href=hostedCheckout&&slug&&order?.id?`${slug}.checkout.commercelayer.app/${order.id}?accessToken=${accessToken}`:order?.checkout_url,parentProps={checkoutUrl:order?.checkout_url,hostedCheckout,label,href,...p};return children?(0,jsx_runtime_1.jsx)(Parent_1.default,{...parentProps,children}):(0,jsx_runtime_1.jsx)("a",{href,...p,children:label})}exports.CheckoutLink=CheckoutLink,exports.default=CheckoutLink;
@@ -1,22 +1,11 @@
1
1
  import { ReactNode } from 'react';
2
- declare type Props = {
2
+ interface Props {
3
3
  children: ReactNode;
4
4
  skuCode?: string | null;
5
5
  lineItem?: {
6
6
  name: string;
7
7
  imageUrl?: string | null;
8
8
  } | null;
9
- };
10
- export declare function ItemContainer(props: Props): JSX.Element;
11
- export declare namespace ItemContainer {
12
- var propTypes: {
13
- children: import("prop-types").Validator<NonNullable<ReactNode | (() => JSX.Element)>>;
14
- skuCode: import("prop-types").Requireable<string>;
15
- lineItem: import("prop-types").Requireable<import("prop-types").InferProps<{
16
- name: import("prop-types").Validator<string>;
17
- imageUrl: import("prop-types").Requireable<string>;
18
- }>>;
19
- };
20
- var displayName: string;
21
9
  }
10
+ export declare function ItemContainer(props: Props): JSX.Element;
22
11
  export default ItemContainer;