@paykka/card-checkout-ui 0.11.6 → 0.13.2

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 (217) hide show
  1. package/dist/card-checkout-ui.js +19 -19
  2. package/dist/card-checkout-ui.umd.cjs +19 -19
  3. package/dist/es/_commonjsHelpers.js +82 -1
  4. package/dist/es/api/index.js +1 -0
  5. package/dist/es/api/modules/address/index.js +9 -9
  6. package/dist/es/api/modules/ali-pay/index.js +10 -49
  7. package/dist/es/api/modules/apple-pay/index.js +13 -59
  8. package/dist/es/api/modules/boost/index.js +8 -48
  9. package/dist/es/api/modules/card/index.js +10 -54
  10. package/dist/es/api/modules/checkout/index.js +11 -9
  11. package/dist/es/api/modules/checkout/map.js +25 -18
  12. package/dist/es/api/modules/encrypted-card/index.js +3 -2
  13. package/dist/es/api/modules/gcash/index.js +8 -48
  14. package/dist/es/api/modules/get-browser-params.js +4 -1
  15. package/dist/es/api/modules/google-pay/index.js +10 -56
  16. package/dist/es/api/modules/grab-pay/index.js +8 -48
  17. package/dist/es/api/modules/index.js +1 -0
  18. package/dist/es/api/modules/line-pay/index.js +8 -48
  19. package/dist/es/api/modules/map.js +17 -11
  20. package/dist/es/api/modules/may-bank-qr-pay/index.js +8 -48
  21. package/dist/es/api/modules/nine-pay/index.js +8 -48
  22. package/dist/es/api/modules/paymaya/index.js +8 -48
  23. package/dist/es/api/modules/risk/index.js +2 -1
  24. package/dist/es/api/modules/sepa/index.js +10 -51
  25. package/dist/es/api/modules/shopee-pay/index.js +8 -48
  26. package/dist/es/api/modules/threeDS/index.js +3 -0
  27. package/dist/es/api/modules/tng-wallet/index.js +8 -48
  28. package/dist/es/api/modules/wechat-pay/index.js +10 -51
  29. package/dist/es/api/modules/zalopay/index.js +16 -0
  30. package/dist/es/api/utils/index.js +59 -0
  31. package/dist/es/components/AddressField/index.js +37 -37
  32. package/dist/es/components/AliPay/index.js +158 -111
  33. package/dist/es/components/ApplePay/index.js +99 -67
  34. package/dist/es/components/Boost/index.js +91 -70
  35. package/dist/es/components/Card/index.js +114 -107
  36. package/dist/es/components/CardSelector/index.js +1 -1
  37. package/dist/es/components/DropIn/index.js +12 -4
  38. package/dist/es/components/EncryptedCard/index.js +6 -2
  39. package/dist/es/components/GooglePay/index.js +94 -60
  40. package/dist/es/components/GrabPay/index.js +91 -70
  41. package/dist/es/components/GuideCard/index.js +10 -7
  42. package/dist/es/components/LinePay/index.js +91 -70
  43. package/dist/es/components/MayBankQRPay/index.js +302 -275
  44. package/dist/es/components/NinePay/index.js +91 -70
  45. package/dist/es/components/SecuredFieldsProvider/index.js +26 -9
  46. package/dist/es/components/SecuredIframe/index.js +40 -61
  47. package/dist/es/components/Sepa/index.js +72 -53
  48. package/dist/es/components/ShopeePay/index.js +91 -70
  49. package/dist/es/components/SubmitButton/index.js +8 -7
  50. package/dist/es/components/TNGWallet/index.js +91 -70
  51. package/dist/es/components/ThreeDS/index.js +32 -7
  52. package/dist/es/components/WechatPay/index.js +151 -102
  53. package/dist/es/components/business/QRCodeModal/QRCodeModal.js +26 -6
  54. package/dist/es/components/index.js +1 -0
  55. package/dist/es/components/internal/Form/FormItem.js +1 -1
  56. package/dist/es/components/internal/Form/util.js +1 -1
  57. package/dist/es/components/internal/Modal/Modal.js +1 -1
  58. package/dist/es/components/internal/Select/Select.js +19 -8
  59. package/dist/es/components/internal/Select/SelectMenu.js +2 -2
  60. package/dist/es/components/internal/Select/SelectMenuItem.js +12 -4
  61. package/dist/es/components/internal/icons/IconError.js +7 -4
  62. package/dist/es/components/internal/icons/IconZalopay.js +47 -0
  63. package/dist/es/components/internal/icons/IconZalopayComplete.js +48 -0
  64. package/dist/es/components/wallets/GCash/GCash.js +80 -56
  65. package/dist/es/components/wallets/Paymaya/Paymaya.js +91 -70
  66. package/dist/es/components/wallets/Zalopay/Zalopay.js +381 -0
  67. package/dist/es/components/wallets/Zalopay/index.js +1 -0
  68. package/dist/es/components/wallets/Zalopay/type.js +1 -0
  69. package/dist/es/components/wallets/Zalopay/zalopay2.js +1 -0
  70. package/dist/es/config.js +5 -5
  71. package/dist/es/constant.js +8 -2
  72. package/dist/es/core/{Address.js → address.js} +8 -16
  73. package/dist/es/core/{PayKKaCheckout.js → checkout.js} +101 -27
  74. package/dist/es/core/create.js +1 -1
  75. package/dist/es/core/query.js +3 -2
  76. package/dist/es/core/{Session.js → session.js} +28 -32
  77. package/dist/es/core/theme.js +65 -0
  78. package/dist/es/core.js +0 -4
  79. package/dist/es/hooks/usePayment.js +14 -0
  80. package/dist/es/i18n/locales/de-DE.js +3 -1
  81. package/dist/es/i18n/locales/en-GB.js +3 -1
  82. package/dist/es/i18n/locales/es-ES.js +3 -1
  83. package/dist/es/i18n/locales/fr-FR.js +3 -1
  84. package/dist/es/i18n/locales/ja-JP.js +3 -1
  85. package/dist/es/i18n/locales/ko-KR.js +3 -1
  86. package/dist/es/i18n/locales/nl-NL.js +3 -1
  87. package/dist/es/i18n/locales/pt-PT.js +3 -1
  88. package/dist/es/i18n/locales/ru-RU.js +3 -1
  89. package/dist/es/i18n/locales/zh-CN.js +3 -1
  90. package/dist/es/i18n/locales/zh-HK.js +3 -1
  91. package/dist/es/i18n/locales/zh-TW.js +3 -1
  92. package/dist/es/index.js +21 -7
  93. package/dist/es/style.css +1 -1
  94. package/dist/es/types/index.js +7 -0
  95. package/dist/es/utils/colors.js +5 -1
  96. package/dist/es/utils/format.js +0 -5
  97. package/dist/es/utils/object.js +31 -1
  98. package/dist/es/utils/payment.js +82 -0
  99. package/dist/es/utils/redirect.js +4 -4
  100. package/dist/es/utils/string.js +10 -0
  101. package/dist/es/utils/system-info/is-ua-webview.js +14 -12
  102. package/dist/es/utils/theme.js +7 -0
  103. package/dist/style.css +1 -1
  104. package/dist/types/api/modules/address/index.d.ts +15 -6
  105. package/dist/types/api/modules/ali-pay/index.d.ts +3 -19
  106. package/dist/types/api/modules/apple-pay/index.d.ts +4 -14
  107. package/dist/types/api/modules/boost/index.d.ts +3 -23
  108. package/dist/types/api/modules/card/index.d.ts +3 -30
  109. package/dist/types/api/modules/checkout/index.d.ts +3 -3
  110. package/dist/types/api/modules/checkout/map.d.ts +3 -3
  111. package/dist/types/api/modules/checkout/type.d.ts +33 -4
  112. package/dist/types/api/modules/gcash/index.d.ts +3 -23
  113. package/dist/types/api/modules/get-browser-params.d.ts +1 -0
  114. package/dist/types/api/modules/google-pay/index.d.ts +3 -13
  115. package/dist/types/api/modules/grab-pay/index.d.ts +3 -23
  116. package/dist/types/api/modules/index.d.ts +1 -0
  117. package/dist/types/api/modules/line-pay/index.d.ts +3 -23
  118. package/dist/types/api/modules/map.d.ts +2 -2
  119. package/dist/types/api/modules/may-bank-qr-pay/index.d.ts +3 -23
  120. package/dist/types/api/modules/nine-pay/index.d.ts +3 -23
  121. package/dist/types/api/modules/paymaya/index.d.ts +3 -23
  122. package/dist/types/api/modules/sepa/index.d.ts +3 -24
  123. package/dist/types/api/modules/shopee-pay/index.d.ts +3 -23
  124. package/dist/types/api/modules/tng-wallet/index.d.ts +3 -23
  125. package/dist/types/api/modules/type.d.ts +74 -21
  126. package/dist/types/api/modules/wechat-pay/index.d.ts +3 -20
  127. package/dist/types/api/modules/zalopay/index.d.ts +4 -0
  128. package/dist/types/api/utils/index.d.ts +48 -0
  129. package/dist/types/components/AddressField/type.d.ts +3 -9
  130. package/dist/types/components/AliPay/AliPay.d.ts +6 -2
  131. package/dist/types/components/AliPay/type.d.ts +15 -2
  132. package/dist/types/components/ApplePay/ApplePay.d.ts +6 -2
  133. package/dist/types/components/ApplePay/type.d.ts +10 -14
  134. package/dist/types/components/ApplePay/utils.d.ts +1 -1
  135. package/dist/types/components/Boost/Boost.d.ts +6 -2
  136. package/dist/types/components/Boost/type.d.ts +2 -24
  137. package/dist/types/components/Card/Card.d.ts +6 -2
  138. package/dist/types/components/Card/type.d.ts +3 -43
  139. package/dist/types/components/DropIn/DropIn.d.ts +6 -2
  140. package/dist/types/components/DropIn/type.d.ts +4 -10
  141. package/dist/types/components/GooglePay/GooglePay.d.ts +6 -2
  142. package/dist/types/components/GooglePay/createGooglePay.d.ts +2 -1
  143. package/dist/types/components/GooglePay/type.d.ts +10 -26
  144. package/dist/types/components/GrabPay/GrabPay.d.ts +6 -2
  145. package/dist/types/components/GrabPay/type.d.ts +3 -25
  146. package/dist/types/components/LinePay/LinePay.d.ts +6 -2
  147. package/dist/types/components/LinePay/type.d.ts +3 -25
  148. package/dist/types/components/MayBankQRPay/MayBankQRPay.d.ts +6 -2
  149. package/dist/types/components/MayBankQRPay/type.d.ts +3 -25
  150. package/dist/types/components/NinePay/NinePay.d.ts +6 -2
  151. package/dist/types/components/NinePay/type.d.ts +3 -25
  152. package/dist/types/components/SecuredFieldsProvider/type.d.ts +5 -0
  153. package/dist/types/components/SecuredIframe/HiddenIframe.d.ts +3 -1
  154. package/dist/types/components/Sepa/Sepa.d.ts +6 -2
  155. package/dist/types/components/Sepa/type.d.ts +3 -2
  156. package/dist/types/components/ShopeePay/ShopeePay.d.ts +6 -2
  157. package/dist/types/components/ShopeePay/type.d.ts +3 -25
  158. package/dist/types/components/TNGWallet/TNGWallet.d.ts +6 -2
  159. package/dist/types/components/TNGWallet/type.d.ts +3 -25
  160. package/dist/types/components/ThreeDS/components/ThreeDSAuth/type.d.ts +2 -0
  161. package/dist/types/components/WechatPay/WechatPay.d.ts +6 -2
  162. package/dist/types/components/WechatPay/type.d.ts +15 -2
  163. package/dist/types/components/business/QRCodeModal/type.d.ts +2 -0
  164. package/dist/types/components/index.d.ts +1 -0
  165. package/dist/types/components/internal/Loading/Loading.d.ts +1 -0
  166. package/dist/types/components/internal/Select/SelectMenu.d.ts +1 -1
  167. package/dist/types/components/internal/icons/IconZalopay.d.ts +2 -0
  168. package/dist/types/components/internal/icons/IconZalopayComplete.d.ts +2 -0
  169. package/dist/types/components/internal/icons/index.d.ts +3 -0
  170. package/dist/types/components/wallets/GCash/GCash.d.ts +6 -2
  171. package/dist/types/components/wallets/GCash/type.d.ts +3 -35
  172. package/dist/types/components/wallets/Paymaya/Paymaya.d.ts +6 -2
  173. package/dist/types/components/wallets/Paymaya/type.d.ts +3 -25
  174. package/dist/types/components/wallets/Zalopay/Zalopay.d.ts +10 -0
  175. package/dist/types/components/wallets/Zalopay/index.d.ts +2 -0
  176. package/dist/types/components/wallets/Zalopay/type.d.ts +39 -0
  177. package/dist/types/config.d.ts +2 -4
  178. package/dist/types/constant.d.ts +3 -1
  179. package/dist/types/core/{Address.d.ts → address.d.ts} +23 -24
  180. package/dist/types/core/{PayKKaCheckout.d.ts → checkout.d.ts} +9 -3
  181. package/dist/types/core/context.d.ts +3 -2
  182. package/dist/types/core/index.d.ts +3 -2
  183. package/dist/types/core/query.d.ts +2 -2
  184. package/dist/types/core/session.d.ts +23 -0
  185. package/dist/types/core/theme.d.ts +7 -0
  186. package/dist/types/hooks/index.d.ts +1 -0
  187. package/dist/types/hooks/usePayment.d.ts +8 -0
  188. package/dist/types/i18n/locales/de-DE.d.ts +2 -0
  189. package/dist/types/i18n/locales/en-GB.d.ts +2 -0
  190. package/dist/types/i18n/locales/es-ES.d.ts +2 -0
  191. package/dist/types/i18n/locales/fr-FR.d.ts +2 -0
  192. package/dist/types/i18n/locales/ja-JP.d.ts +2 -0
  193. package/dist/types/i18n/locales/ko-KR.d.ts +2 -0
  194. package/dist/types/i18n/locales/nl-NL.d.ts +2 -0
  195. package/dist/types/i18n/locales/pt-PT.d.ts +2 -0
  196. package/dist/types/i18n/locales/ru-RU.d.ts +2 -0
  197. package/dist/types/i18n/locales/zh-CN.d.ts +2 -0
  198. package/dist/types/i18n/locales/zh-HK.d.ts +2 -0
  199. package/dist/types/i18n/locales/zh-TW.d.ts +2 -0
  200. package/dist/types/index.d.ts +2 -1
  201. package/dist/types/types/index.d.ts +70 -32
  202. package/dist/types/types/message.d.ts +30 -25
  203. package/dist/types/utils/card-brand/index.d.ts +3 -3
  204. package/dist/types/utils/colors.d.ts +1 -0
  205. package/dist/types/utils/index.d.ts +4 -2
  206. package/dist/types/utils/object.d.ts +7 -0
  207. package/dist/types/utils/payment.d.ts +37 -0
  208. package/dist/types/utils/string.d.ts +1 -0
  209. package/dist/types/utils/style.d.ts +1 -1
  210. package/dist/types/utils/system-info/is-ua-webview.d.ts +1 -1
  211. package/dist/types/utils/theme.d.ts +4 -0
  212. package/package.json +3 -3
  213. package/dist/es/utils/deep-freeze.js +0 -13
  214. package/dist/es/utils/obj.js +0 -22
  215. package/dist/types/core/Session.d.ts +0 -16
  216. package/dist/types/utils/deep-freeze.d.ts +0 -1
  217. package/dist/types/utils/obj.d.ts +0 -6
@@ -1,16 +1,10 @@
1
+ import type { AddressMode } from '../../types';
2
+ import type { Address } from '../../core/address';
1
3
  export interface AddressFieldProps {
2
4
  value: Address;
3
5
  onAddressChange: (value: Address) => void;
4
6
  country?: string;
5
- }
6
- export interface Address {
7
- country: string;
8
- province: string;
9
- city: string;
10
- area: string;
11
- postCode: string;
12
- address1: string;
13
- address2: string;
7
+ mode?: AddressMode;
14
8
  }
15
9
  export interface AddressFieldRef {
16
10
  update: (value: Address) => void;
@@ -1,6 +1,10 @@
1
1
  import './ali-pay.scss';
2
2
  import type { AliPayProps, AliPayRef } from './type';
3
- import type { CoreProps } from '../../types';
4
- export declare const AliPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<AliPayProps & CoreProps> & {
3
+ export declare const AliPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<AliPayProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<AliPayRef> | undefined;
6
10
  }>;
@@ -1,9 +1,22 @@
1
1
  import type { PayRes } from '../../api';
2
2
  import type { PayKKaError } from '../../core';
3
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
4
  import type { FormValidateError } from '../internal/Form';
4
- export interface AliPayProps {
5
+ export interface AliPayProps extends PayKKaCommonConfig {
6
+ /**
7
+ * 是否展示邮箱
8
+ * 若配置 true 但创建收银台时已经传了,就展示禁用状态。
9
+ * 若配置 false 但创建收银台时未传,依旧会展示该输入框。
10
+ */
11
+ showEmail?: boolean;
12
+ /**
13
+ * 是否展示邮箱
14
+ * 若配置 true 但创建收银台时已经传了,还是展示,先不禁用。
15
+ * 若配置 false 但创建收银台时未传,依旧会展示该输入框。
16
+ */
17
+ showAddress?: boolean;
5
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
6
- onSuccess?: (...args: any[]) => void;
19
+ onSuccess?: (data: PaymentInfo) => void;
7
20
  onError?: (error: PayKKaError) => void;
8
21
  onTimeout?: (source: 'retry' | 'channel') => void;
9
22
  onExpired?: () => void;
@@ -1,6 +1,10 @@
1
1
  import './apple-pay.scss';
2
2
  import type { ApplePayProps, ApplePayRef } from './type';
3
- import type { CoreProps } from '../../types';
4
- export declare const ApplePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<ApplePayProps & CoreProps> & {
3
+ export declare const ApplePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<ApplePayProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<ApplePayRef> | undefined;
6
10
  }>;
@@ -1,11 +1,14 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PaymentSuccessData } from '../../types';
3
- export interface ApplePayProps {
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
+ export interface ApplePayProps extends PayKKaCommonConfig {
4
4
  /** 支付授权成功后触发 */
5
5
  onSubmit?: () => void;
6
6
  /** 支付成功后触发 */
7
- onSuccess?: (data: PaymentSuccessData) => void;
8
- /** SDK 加载回调,status 为 true 表示加载成功,false 表示加载失败 */
7
+ onSuccess?: (data: PaymentInfo) => void;
8
+ /**
9
+ * SDK 加载回调,status 为 true 表示加载成功,false 表示加载失败
10
+ * 注意:该回调在 SDK 加载成功后触发,但不一定表示 Apple Pay 可用
11
+ */
9
12
  onLoad?: (status: boolean) => void;
10
13
  /** 支付失败时触发 */
11
14
  onError?: (error: PayKKaError) => void;
@@ -15,18 +18,11 @@ export interface ApplePayProps {
15
18
  onExpired?: () => void;
16
19
  /** 支付取消时触发 */
17
20
  onCancel?: () => void;
18
- /** Apple Pay 按钮是否可用 */
19
- onCanUse?: (canUse: boolean) => void;
20
21
  /**
21
- * @internal
22
- * 交易被风控拦截时触发
22
+ * Apple Pay 按钮是否可用
23
+ * 注意:在 onLoad 返回 false 的情况下不会触发该回调
23
24
  */
24
- onAuthorized?: () => void;
25
- /**
26
- * @internal
27
- * 点击 GooglePay 按钮
28
- */
29
- onBtnClick?: () => void;
25
+ onCanUse?: (canUse: boolean) => void;
30
26
  }
31
27
  export interface ApplePayRef {
32
28
  }
@@ -1,3 +1,3 @@
1
1
  /** 动态加载ApplePay */
2
2
  export declare const loadApplePayJS: (onload?: () => void, onerror?: () => void) => void;
3
- export declare function applePayEnv(id?: string): Promise<boolean | undefined>;
3
+ export declare function applePayEnv(id?: string): Promise<boolean>;
@@ -1,7 +1,11 @@
1
1
  import type { BoostProps } from './type';
2
2
  import type { BoostRef } from './type';
3
- import type { CoreProps } from '../../types';
4
3
  import './boost.scss';
5
- export declare const Boost: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<BoostProps & CoreProps> & {
4
+ export declare const Boost: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<BoostProps & import("../../types").PayKKaCommonConfig & {
5
+ session: import("../../core").Session;
6
+ core: import("../../core").PayKKaCheckout;
7
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
8
+ isDropIn?: boolean | undefined;
9
+ }> & {
6
10
  ref?: import("preact").Ref<BoostRef> | undefined;
7
11
  }>;
@@ -1,6 +1,6 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PayRes } from '../../api';
3
2
  import type { FormValidateError } from '../internal/Form';
3
+ import type { PaymentInfo } from '../../types';
4
4
  export interface BoostProps {
5
5
  /**
6
6
  * 是否展示邮箱
@@ -17,35 +17,13 @@ export interface BoostProps {
17
17
  /** 提交表单时触发 */
18
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
19
19
  /** 支付成功后触发 */
20
- onSuccess?: (...args: any[]) => void;
20
+ onSuccess?: (data: PaymentInfo) => void;
21
21
  /** 支付失败时触发 */
22
22
  onError?: (error: PayKKaError) => void;
23
23
  /** 支付超时时触发 */
24
24
  onTimeout?: () => void;
25
25
  /** 收银台已过期时触发 */
26
26
  onExpired?: () => void;
27
- /**
28
- * @internal
29
- * 请求支付接口成功后返回跳转链接
30
- */
31
- onSubmitResponse?: (payRes: PayRes) => void;
32
- /**
33
- * @internal
34
- * 跳转模式,钱包支付时需要跳转到第三方页面进行支付,流程结束在返回收银台
35
- * auto: 自动跳转
36
- * manual: 需要在 onSubmitResponse 中接收跳转链接并手动跳转
37
- */
38
- redirectMode?: 'auto' | 'manual';
39
- /**
40
- * @internal
41
- * 从第三方支付页面跳转回来时,是否自动查询支付结果
42
- */
43
- autoQuery?: boolean;
44
- /**
45
- * @internal
46
- * 是否展示引导卡片
47
- */
48
- showGuideCard?: boolean;
49
27
  }
50
28
  export interface BoostRef {
51
29
  /** 停止轮询支付结果 */
@@ -1,6 +1,10 @@
1
1
  import './card.scss';
2
2
  import type { CardProps, CardRef } from './type';
3
- import { type CoreProps } from '../../types';
4
- export declare const Card: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<CardProps & CoreProps> & {
3
+ export declare const Card: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<CardProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<CardRef> | undefined;
6
10
  }>;
@@ -1,7 +1,7 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { ElementStylesConfig, PaymentSuccessData } from '../../types';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import type { FormValidateError } from '../internal/Form';
4
- export interface CardProps {
4
+ export interface CardProps extends PayKKaCommonConfig {
5
5
  /** 定义卡敏感信息表单布局展示,split 为分割布局,combine 为合并布局 */
6
6
  cardInfoLayout?: CardInfoLayout;
7
7
  /**
@@ -18,59 +18,19 @@ export interface CardProps {
18
18
  showAddress?: boolean;
19
19
  /** 是否在卡号输入框下展示收银台支持的发卡行图标 */
20
20
  showCardBrands?: boolean;
21
- /**
22
- * @internal
23
- * 是否展示持卡人姓名,目前一定展示
24
- */
25
- styles?: ElementStylesConfig;
26
- /**
27
- * @internal
28
- * 是否展示持卡人姓名,目前一定展示
29
- */
30
- showHolderName?: boolean;
31
- /**
32
- * @internal
33
- * 是否展示3ds modal,默认为 true,配置 false 则抛出 onThreeDS 回调
34
- */
35
- enable3DSModal?: boolean;
36
21
  /** 提交表单时触发 */
37
22
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
38
23
  /** 支付成功后触发 */
39
- onSuccess?: (data: PaymentSuccessData) => void;
24
+ onSuccess?: (data: PaymentInfo) => void;
40
25
  /** 支付失败时触发 */
41
26
  onError?: (error: PayKKaError) => void;
42
27
  /** 支付超时时触发 */
43
28
  onTimeout?: () => void;
44
29
  /** 收银台已过期时触发 */
45
30
  onExpired?: () => void;
46
- /**
47
- * @internal
48
- * 交易被风控拦截时触发
49
- */
50
- onAuthorized?: () => void;
51
- /**
52
- * @internal
53
- * 交易需要 3DS 验证时触发,url 为 3DS 验证链接,incomplete 为 false 表示目前要开始进行 3DS 验证,为 true 表示上一次 3DS 验证还未完成
54
- */
55
- onThreeDS?: (url: string, incomplete: boolean) => void;
56
31
  }
57
32
  export interface CardRef {
58
33
  /** 不展示支付按钮时,可调用该方法进行支付 */
59
34
  payment: () => void;
60
- /**
61
- * @internal
62
- * 3DS 验证流程结束后可调用该方法轮询收银台支付状态
63
- */
64
- checkThreeDS: () => void;
65
- /**
66
- * @internal
67
- * 进行表单切换时更新已填的地址信息
68
- */
69
- updateAddress: () => void;
70
- /**
71
- * @internal
72
- * 进行表单切换时更新已填的邮箱信息
73
- */
74
- updateEmail: () => void;
75
35
  }
76
36
  export type CardInfoLayout = 'split' | 'combine';
@@ -1,6 +1,10 @@
1
1
  import { type DropInProps, type DropInRefs } from './type';
2
2
  import './drop-in.scss';
3
- import type { CoreProps } from '../../types';
4
- export declare const DropIn: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<DropInProps & CoreProps> & {
3
+ export declare const DropIn: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<DropInProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<DropInRefs> | undefined;
6
10
  }>;
@@ -1,10 +1,10 @@
1
1
  import type { ReactNode } from 'preact/compat';
2
- import type { PaymentSuccessData } from '../../types';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import { PaymentCategory, PaymentMethod } from '../../constant';
4
4
  import type { ComponentType } from 'preact';
5
5
  import type { FormValidateError } from '../internal/Form';
6
6
  import type { PayKKaError } from '../../core';
7
- export interface DropInProps {
7
+ export interface DropInProps extends PayKKaCommonConfig {
8
8
  /**
9
9
  * 配置各种支付方式的参数
10
10
  * 最终展示的支付方式由创建收银台请求返回结果决定,而不是由该参数决定
@@ -21,19 +21,13 @@ export interface DropInProps {
21
21
  /** 提交表单时触发 */
22
22
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
23
23
  /** 支付成功后触发 */
24
- onSuccess?: (data: PaymentSuccessData) => void;
24
+ onSuccess?: (data: PaymentInfo) => void;
25
25
  /** 支付失败时触发 */
26
26
  onError?: (error: PayKKaError) => void;
27
27
  /** 支付超时时触发 */
28
28
  onTimeout?: () => void;
29
29
  /** 收银台已过期时触发 */
30
30
  onExpired?: () => void;
31
- /**
32
- * @internal
33
- * 是否启用过渡动画,layout 为 accordion 时有效
34
- * 默认为 true
35
- */
36
- enableAccordionTransition?: boolean;
37
31
  }
38
32
  export interface DropInRefs {
39
33
  /** 不展示支付按钮时,可调用该方法进行支付 */
@@ -52,6 +46,6 @@ export interface PaymentTypeOptions {
52
46
  * 目前暂不支持 WeChatPay 和 Alipay
53
47
  */
54
48
  export declare const dropInSupportedPaymentMethods: PaymentMethod[];
55
- export type DropInPaymentCategory = PaymentCategory.APPLE_PAY | PaymentCategory.GOOGLE_PAY | PaymentCategory.CARD | PaymentCategory.BOOST | PaymentCategory.GRAB_PAY | PaymentCategory.TNG_WALLET | PaymentCategory.MAY_BANK_QR_PAY | PaymentCategory.SHOPEE_PAY | PaymentCategory.LINE_PAY | PaymentCategory.NINE_PAY | PaymentCategory.GCASH | PaymentCategory.PAYMAYA;
49
+ export type DropInPaymentCategory = PaymentCategory.APPLE_PAY | PaymentCategory.GOOGLE_PAY | PaymentCategory.CARD | PaymentCategory.BOOST | PaymentCategory.GRAB_PAY | PaymentCategory.TNG_WALLET | PaymentCategory.MAY_BANK_QR_PAY | PaymentCategory.SHOPEE_PAY | PaymentCategory.LINE_PAY | PaymentCategory.NINE_PAY | PaymentCategory.GCASH | PaymentCategory.PAYMAYA | PaymentCategory.ZALOPAY;
56
50
  export declare const PaymentComponentMap: Record<DropInPaymentCategory, ComponentType<any>>;
57
51
  export type PaymentComponentProps<P extends keyof typeof PaymentComponentMap> = React.ComponentProps<(typeof PaymentComponentMap)[P]>;
@@ -1,6 +1,10 @@
1
1
  import './google-pay.scss';
2
2
  import type { GooglePayProps, GooglePayRef } from './type';
3
- import type { CoreProps } from '../../types';
4
- export declare const GooglePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<GooglePayProps & CoreProps> & {
3
+ export declare const GooglePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<GooglePayProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<GooglePayRef> | undefined;
6
10
  }>;
@@ -1,5 +1,6 @@
1
1
  import type { CheckoutRes } from '../../api';
2
- export declare function createGooglePay(checkout: CheckoutRes, pay: (token?: string, billAddress?: {
2
+ import type { GooglePayProps } from './type';
3
+ export declare function createGooglePay(checkout: CheckoutRes, googlePayConfig: GooglePayProps['config'], pay: (token?: string, billAddress?: {
3
4
  email?: string;
4
5
  } & google.payments.api.Address, search?: boolean, timeout?: number) => Promise<{
5
6
  res?: google.payments.api.PaymentAuthorizationResult;
@@ -1,11 +1,14 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PaymentSuccessData } from '../../types';
3
- export interface GooglePayProps {
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
+ export interface GooglePayProps extends PayKKaCommonConfig {
4
4
  /** 支付授权成功后触发 */
5
5
  onSubmit?: () => void;
6
6
  /** 支付成功后触发 */
7
- onSuccess?: (data: PaymentSuccessData) => void;
8
- /** SDK 加载回调,status 为 true 表示加载成功,false 表示加载失败 */
7
+ onSuccess?: (data: PaymentInfo) => void;
8
+ /**
9
+ * SDK 加载回调,status 为 true 表示加载成功,false 表示加载失败
10
+ * 注意:该回调在 SDK 加载成功后触发,但不一定表示 Google Pay 可用
11
+ */
9
12
  onLoad?: (status: boolean) => void;
10
13
  /** 支付失败时触发 */
11
14
  onError?: (error: PayKKaError) => void;
@@ -13,30 +16,11 @@ export interface GooglePayProps {
13
16
  onTimeout?: (source: 'retry' | 'channel') => void;
14
17
  /** 收银台已过期时触发 */
15
18
  onExpired?: () => void;
16
- /** 当前设备环境是否可用于 Google Pay 支付 */
17
- onCanUse?: (canUse: boolean) => void;
18
- /**
19
- * @internal
20
- * 交易被风控拦截时触发
21
- */
22
- onAuthorized?: () => void;
23
19
  /**
24
- * @internal
25
- * 交易需要 3DS 验证时触发
26
- * url 为 3DS 验证链接
27
- * incomplete 为 false 表示目前要开始进行 3DS 验证,为 true 表示上一次 3DS 验证还未完成
20
+ * 当前设备环境是否可用于 Google Pay 支付
21
+ * 注意:在 onLoad 返回 false 的情况下不会触发该回调
28
22
  */
29
- onThreeDS?: (url: string, incomplete: boolean) => void;
30
- /**
31
- * @internal
32
- * 点击 GooglePay 按钮
33
- */
34
- onBtnClick?: () => void;
23
+ onCanUse?: (canUse: boolean) => void;
35
24
  }
36
25
  export interface GooglePayRef {
37
- /**
38
- * @internal
39
- * 3DS 验证流程结束后可调用该方法轮询收银台支付状态
40
- */
41
- checkThreeDS: () => void;
42
26
  }
@@ -1,7 +1,11 @@
1
1
  import type { GrabPayProps } from './type';
2
2
  import type { GrabPayRef } from './type';
3
- import type { CoreProps } from '../../types';
4
3
  import './grab-pay.scss';
5
- export declare const GrabPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<GrabPayProps & CoreProps> & {
4
+ export declare const GrabPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<GrabPayProps & import("../../types").PayKKaCommonConfig & {
5
+ session: import("../../core").Session;
6
+ core: import("../../core").PayKKaCheckout;
7
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
8
+ isDropIn?: boolean | undefined;
9
+ }> & {
6
10
  ref?: import("preact").Ref<GrabPayRef> | undefined;
7
11
  }>;
@@ -1,7 +1,7 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PayRes } from '../../api';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import type { FormValidateError } from '../internal/Form';
4
- export interface GrabPayProps {
4
+ export interface GrabPayProps extends PayKKaCommonConfig {
5
5
  /**
6
6
  * 是否展示邮箱
7
7
  * 若配置 true 但创建收银台时已经传了,就展示禁用状态。
@@ -17,35 +17,13 @@ export interface GrabPayProps {
17
17
  /** 提交表单时触发 */
18
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
19
19
  /** 支付成功后触发 */
20
- onSuccess?: (...args: any[]) => void;
20
+ onSuccess?: (data: PaymentInfo) => void;
21
21
  /** 支付失败时触发 */
22
22
  onError?: (error: PayKKaError) => void;
23
23
  /** 支付超时时触发 */
24
24
  onTimeout?: () => void;
25
25
  /** 收银台已过期时触发 */
26
26
  onExpired?: () => void;
27
- /**
28
- * @internal
29
- * 请求支付接口成功后返回跳转链接
30
- */
31
- onSubmitResponse?: (payRes: PayRes) => void;
32
- /**
33
- * @internal
34
- * 跳转模式,钱包支付时需要跳转到第三方页面进行支付,流程结束在返回收银台
35
- * auto: 自动跳转
36
- * manual: 需要在 onSubmitResponse 中接收跳转链接并手动跳转
37
- */
38
- redirectMode?: 'auto' | 'manual';
39
- /**
40
- * @internal
41
- * 从第三方支付页面跳转回来时,是否自动查询支付结果
42
- */
43
- autoQuery?: boolean;
44
- /**
45
- * @internal
46
- * 是否展示引导卡片
47
- */
48
- showGuideCard?: boolean;
49
27
  }
50
28
  export interface GrabPayRef {
51
29
  /** 停止轮询支付结果 */
@@ -1,7 +1,11 @@
1
1
  import type { LinePayProps } from './type';
2
2
  import type { LinePayRef } from './type';
3
- import type { CoreProps } from '../../types';
4
3
  import './line-pay.scss';
5
- export declare const LinePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<LinePayProps & CoreProps> & {
4
+ export declare const LinePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<LinePayProps & import("../../types").PayKKaCommonConfig & {
5
+ session: import("../../core").Session;
6
+ core: import("../../core").PayKKaCheckout;
7
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
8
+ isDropIn?: boolean | undefined;
9
+ }> & {
6
10
  ref?: import("preact").Ref<LinePayRef> | undefined;
7
11
  }>;
@@ -1,7 +1,7 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PayRes } from '../../api';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import type { FormValidateError } from '../internal/Form';
4
- export interface LinePayProps {
4
+ export interface LinePayProps extends PayKKaCommonConfig {
5
5
  /**
6
6
  * 是否展示邮箱
7
7
  * 若配置 true 但创建收银台时已经传了,就展示禁用状态。
@@ -17,35 +17,13 @@ export interface LinePayProps {
17
17
  /** 提交表单时触发 */
18
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
19
19
  /** 支付成功后触发 */
20
- onSuccess?: (...args: any[]) => void;
20
+ onSuccess?: (data: PaymentInfo) => void;
21
21
  /** 支付失败时触发 */
22
22
  onError?: (error: PayKKaError) => void;
23
23
  /** 支付超时时触发 */
24
24
  onTimeout?: () => void;
25
25
  /** 收银台已过期时触发 */
26
26
  onExpired?: () => void;
27
- /**
28
- * @internal
29
- * 请求支付接口成功后返回跳转链接
30
- */
31
- onSubmitResponse?: (payRes: PayRes) => void;
32
- /**
33
- * @internal
34
- * 跳转模式,钱包支付时需要跳转到第三方页面进行支付,流程结束在返回收银台
35
- * auto: 自动跳转
36
- * manual: 需要在 onSubmitResponse 中接收跳转链接并手动跳转
37
- */
38
- redirectMode?: 'auto' | 'manual';
39
- /**
40
- * @internal
41
- * 从第三方支付页面跳转回来时,是否自动查询支付结果
42
- */
43
- autoQuery?: boolean;
44
- /**
45
- * @internal
46
- * 是否展示引导卡片
47
- */
48
- showGuideCard?: boolean;
49
27
  }
50
28
  export interface LinePayRef {
51
29
  /** 停止轮询支付结果 */
@@ -1,6 +1,10 @@
1
1
  import type { MayBankQRPayProps, MayBankQRPayRef } from './type';
2
- import type { CoreProps } from '../../types';
3
2
  import './may-bank-qr-pay.scss';
4
- export declare const MayBankQRPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<MayBankQRPayProps & CoreProps> & {
3
+ export declare const MayBankQRPay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<MayBankQRPayProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<MayBankQRPayRef> | undefined;
6
10
  }>;
@@ -1,7 +1,7 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PayRes } from '../../api';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import type { FormValidateError } from '../internal/Form';
4
- export interface MayBankQRPayProps {
4
+ export interface MayBankQRPayProps extends PayKKaCommonConfig {
5
5
  /**
6
6
  * 是否展示邮箱
7
7
  * 若配置 true 但创建收银台时已经传了,就展示禁用状态。
@@ -17,35 +17,13 @@ export interface MayBankQRPayProps {
17
17
  /** 提交表单时触发 */
18
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
19
19
  /** 支付成功后触发 */
20
- onSuccess?: (...args: any[]) => void;
20
+ onSuccess?: (data: PaymentInfo) => void;
21
21
  /** 支付失败时触发 */
22
22
  onError?: (error: PayKKaError) => void;
23
23
  /** 支付超时时触发 */
24
24
  onTimeout?: () => void;
25
25
  /** 收银台已过期时触发 */
26
26
  onExpired?: () => void;
27
- /**
28
- * @internal
29
- * 请求支付接口成功后返回跳转链接
30
- */
31
- onSubmitResponse?: (payRes: PayRes) => void;
32
- /**
33
- * @internal
34
- * 跳转模式,钱包支付时需要跳转到第三方页面进行支付,流程结束在返回收银台
35
- * auto: 自动跳转
36
- * manual: 需要在 onSubmitResponse 中接收跳转链接并手动跳转
37
- */
38
- redirectMode?: 'auto' | 'manual';
39
- /**
40
- * @internal
41
- * 从第三方支付页面跳转回来时,是否自动查询支付结果
42
- */
43
- autoQuery?: boolean;
44
- /**
45
- * @internal
46
- * 是否展示引导卡片
47
- */
48
- showGuideCard?: boolean;
49
27
  }
50
28
  export interface MayBankQRPayRef {
51
29
  /** 停止轮询支付结果 */
@@ -1,6 +1,10 @@
1
1
  import type { NinePayProps, NinePayRef } from './type';
2
- import type { CoreProps } from '../../types';
3
2
  import './nine-pay.scss';
4
- export declare const NinePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<NinePayProps & CoreProps> & {
3
+ export declare const NinePay: import("preact").FunctionalComponent<import("preact/compat").PropsWithoutRef<NinePayProps & import("../../types").PayKKaCommonConfig & {
4
+ session: import("../../core").Session;
5
+ core: import("../../core").PayKKaCheckout;
6
+ threeDSFrame?: import("../../types").ThreeDSFrameConfig | undefined;
7
+ isDropIn?: boolean | undefined;
8
+ }> & {
5
9
  ref?: import("preact").Ref<NinePayRef> | undefined;
6
10
  }>;
@@ -1,7 +1,7 @@
1
1
  import type { PayKKaError } from '../../core';
2
- import type { PayRes } from '../../api';
2
+ import type { PayKKaCommonConfig, PaymentInfo } from '../../types';
3
3
  import type { FormValidateError } from '../internal/Form';
4
- export interface NinePayProps {
4
+ export interface NinePayProps extends PayKKaCommonConfig {
5
5
  /**
6
6
  * 是否展示邮箱
7
7
  * 若配置 true 但创建收银台时已经传了,就展示禁用状态。
@@ -17,35 +17,13 @@ export interface NinePayProps {
17
17
  /** 提交表单时触发 */
18
18
  onSubmit?: (formValidateError?: Recordable<FormValidateError[]>) => void;
19
19
  /** 支付成功后触发 */
20
- onSuccess?: (...args: any[]) => void;
20
+ onSuccess?: (data: PaymentInfo) => void;
21
21
  /** 支付失败时触发 */
22
22
  onError?: (error: PayKKaError) => void;
23
23
  /** 支付超时时触发 */
24
24
  onTimeout?: () => void;
25
25
  /** 收银台已过期时触发 */
26
26
  onExpired?: () => void;
27
- /**
28
- * @internal
29
- * 请求支付接口成功后返回跳转链接
30
- */
31
- onSubmitResponse?: (payRes: PayRes) => void;
32
- /**
33
- * @internal
34
- * 跳转模式,钱包支付时需要跳转到第三方页面进行支付,流程结束在返回收银台
35
- * auto: 自动跳转
36
- * manual: 需要在 onSubmitResponse 中接收跳转链接并手动跳转
37
- */
38
- redirectMode?: 'auto' | 'manual';
39
- /**
40
- * @internal
41
- * 从第三方支付页面跳转回来时,是否自动查询支付结果
42
- */
43
- autoQuery?: boolean;
44
- /**
45
- * @internal
46
- * 是否展示引导卡片
47
- */
48
- showGuideCard?: boolean;
49
27
  }
50
28
  export interface NinePayRef {
51
29
  /** 停止轮询支付结果 */