No Description

index.js 32KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. import { g as _extends, c as _defineProperty, h as _objectSpread2 } from '../_rollupPluginBabelHelpers-bf46fecd.js';
  2. import React from 'react';
  3. import '../_commonjsHelpers-97e6d7b1.js';
  4. import { c as classnames } from '../index-c9837619.js';
  5. import { s as styleInject } from '../style-inject.es-1f59c1d0.js';
  6. import { e as exportStyleSizeClass } from '../utils-74f31cae.js';
  7. const img = '';
  8. const img$1 = '';
  9. const img$2 = '';
  10. const img$3 = '';
  11. const img$4 = '';
  12. const img$5 = '';
  13. var css = ".PayPlatformOptions_flexContainer__3WcqE {\n display: flex;\n justify-content: space-around;\n align-items: center;\n}\n.PayPlatformOptions_label__3NQvy {\n font-size: 14px;\n font-weight: 400;\n color: #616A79;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B {\n padding: 20px 10px 10px 10px;\n text-align: center;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_paymentImage__1D264 {\n display: inline-block;\n margin: 0;\n width: 60%;\n vertical-align: middle;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_paymentImage-before__TZpAA {\n display: inline-block;\n height: 100%;\n vertical-align: middle;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6 {\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n border: 1px solid transparent;\n height: 66px;\n line-height: 66px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6 .PayPlatformOptions_platformName__2iEFM {\n text-align: center;\n white-space: nowrap;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_small__3amR2 {\n width: 88px;\n height: 36px;\n line-height: 36px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_small__3amR2 .PayPlatformOptions_paymentImage__1D264 {\n margin: 0;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_normal__2uJLF {\n width: 132px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_large__3n5Yt {\n width: 162px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_active__2_V1M {\n border-radius: 5px;\n border-color: #1790FF;\n box-shadow: 0px 2px 6px 0px rgba(163, 163, 163, 0.3);\n}\n.PayPlatformOptions_payChannelBox__3Ai_B .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_en__1Wp1K {\n font-size: 12px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B.PayPlatformOptions_mobile__qgCT1 {\n padding: 8px 10px 10px 8px;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B.PayPlatformOptions_mobile__qgCT1 .PayPlatformOptions_payChannelBlock__1f7d6 {\n display: inline-flex;\n flex-direction: column;\n justify-content: space-around;\n width: 78px;\n height: 80px;\n line-height: initial;\n border: 1px solid transparent;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B.PayPlatformOptions_mobile__qgCT1 .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_active__2_V1M {\n border-radius: 4px;\n border-color: #1790FF;\n}\n.PayPlatformOptions_payChannelBox__3Ai_B.PayPlatformOptions_mobile__qgCT1 .PayPlatformOptions_payChannelBlock__1f7d6 .PayPlatformOptions_paymentImage__1D264 {\n display: inline-block;\n width: 34px;\n height: 34px;\n}\n@media (max-width: 768px) {\n .PayPlatformOptions_payChannelBlock__1f7d6 {\n cursor: pointer;\n border: 1px solid transparent;\n }\n .PayPlatformOptions_payChannelBlock__1f7d6.PayPlatformOptions_active__2_V1M {\n border-radius: 5px;\n border-color: #1790FF;\n }\n}\n";
  14. var styles = {"flexContainer":"PayPlatformOptions_flexContainer__3WcqE","label":"PayPlatformOptions_label__3NQvy","payChannelBox":"PayPlatformOptions_payChannelBox__3Ai_B","paymentImage":"PayPlatformOptions_paymentImage__1D264","paymentImage-before":"PayPlatformOptions_paymentImage-before__TZpAA","payChannelBlock":"PayPlatformOptions_payChannelBlock__1f7d6","platformName":"PayPlatformOptions_platformName__2iEFM","small":"PayPlatformOptions_small__3amR2","normal":"PayPlatformOptions_normal__2uJLF","large":"PayPlatformOptions_large__3n5Yt","active":"PayPlatformOptions_active__2_V1M","en":"PayPlatformOptions_en__1Wp1K","mobile":"PayPlatformOptions_mobile__qgCT1","paymentImageBefore":"PayPlatformOptions_paymentImage-before__TZpAA"};
  15. styleInject(css);
  16. var PAY_CHANNEL = {
  17. PAYPAL: "PAYPAL_PAYPAL",
  18. // PAYPAL_LIVE
  19. ALI_WEB: "ALI_WEB",
  20. ALI_WAP: "ALI_WAP",
  21. WX_WAP: "WX_WAP",
  22. WX_NATIVE: "WX_NATIVE"
  23. };
  24. var PAY_CHANNEL_CATEGORY = {
  25. ALI: "Alipay",
  26. WX: "Wechat",
  27. PAYPAL: "Paypal"
  28. };
  29. var PAY_CHANNEL_INSTANCE = [{
  30. image: {
  31. desktop: img,
  32. mobile: img$3
  33. },
  34. text: {
  35. zh: "支付宝",
  36. en: "Alipay"
  37. },
  38. key: PAY_CHANNEL_CATEGORY.ALI
  39. }, {
  40. image: {
  41. desktop: img$1,
  42. mobile: img$4
  43. },
  44. text: {
  45. zh: "微信",
  46. en: "WeChat"
  47. },
  48. key: PAY_CHANNEL_CATEGORY.WX
  49. }, {
  50. image: {
  51. desktop: img$2,
  52. mobile: img$5
  53. },
  54. text: {
  55. zh: "PayPal",
  56. en: "PayPal"
  57. },
  58. key: PAY_CHANNEL_CATEGORY.PAYPAL
  59. }];
  60. var PayPlatformBlock = function PayPlatformBlock(_ref) {
  61. var _ref$isMobile = _ref.isMobile,
  62. isMobile = _ref$isMobile === void 0 ? false : _ref$isMobile,
  63. _ref$isActive = _ref.isActive,
  64. isActive = _ref$isActive === void 0 ? false : _ref$isActive,
  65. _ref$size = _ref.size,
  66. size = _ref$size === void 0 ? "normal" : _ref$size,
  67. onClick = _ref.onClick,
  68. text = _ref.text,
  69. image = _ref.image,
  70. _ref$locale = _ref.locale,
  71. locale = _ref$locale === void 0 ? "zh" : _ref$locale;
  72. var showText = text[locale];
  73. if (isMobile) {
  74. return React.createElement("div", {
  75. className: styles.flexItem
  76. }, React.createElement("div", {
  77. className: classnames(styles.payChannelBlock, _objectSpread2(_defineProperty({}, styles.active, isActive), exportStyleSizeClass(styles, size)), styles[locale]),
  78. onClick: onClick
  79. }, React.createElement("img", {
  80. src: image.mobile,
  81. alt: showText,
  82. className: styles.paymentImage
  83. }), React.createElement("div", {
  84. className: styles.platformName
  85. }, showText)));
  86. }
  87. return React.createElement("div", {
  88. className: styles.flexItem
  89. }, React.createElement("div", {
  90. className: classnames(styles.payChannelBlock, _objectSpread2(_defineProperty({}, styles.active, isActive), exportStyleSizeClass(styles, size)), styles[locale]),
  91. onClick: onClick
  92. }, React.createElement("span", {
  93. className: styles["payment-method-before"]
  94. }), React.createElement("img", {
  95. src: image.desktop,
  96. alt: showText,
  97. className: styles.paymentImage
  98. })));
  99. };
  100. var PayPlatformOptions = function PayPlatformOptions(_ref2) {
  101. var payChannel = _ref2.payChannel,
  102. onPayChannelChange = _ref2.onPayChannelChange,
  103. _ref2$size = _ref2.size,
  104. size = _ref2$size === void 0 ? "normal" : _ref2$size,
  105. _ref2$isMobile = _ref2.isMobile,
  106. isMobile = _ref2$isMobile === void 0 ? false : _ref2$isMobile,
  107. _ref2$withTitle = _ref2.withTitle,
  108. withTitle = _ref2$withTitle === void 0 ? true : _ref2$withTitle,
  109. titleText = _ref2.titleText,
  110. _ref2$locale = _ref2.locale,
  111. locale = _ref2$locale === void 0 ? "zh" : _ref2$locale;
  112. var titleDOM = null;
  113. var payListDOM = [{
  114. valueKey: PAY_CHANNEL.ALI_WEB,
  115. categoryKey: PAY_CHANNEL_CATEGORY.ALI
  116. }, {
  117. valueKey: PAY_CHANNEL.WX_NATIVE,
  118. categoryKey: PAY_CHANNEL_CATEGORY.WX
  119. }, {
  120. valueKey: PAY_CHANNEL.PAYPAL,
  121. categoryKey: PAY_CHANNEL_CATEGORY.PAYPAL
  122. }].map(function (v) {
  123. var valueKey = v.valueKey,
  124. categoryKey = v.categoryKey;
  125. var targetInstance = PAY_CHANNEL_INSTANCE.find(function (ins) {
  126. return ins.key === categoryKey;
  127. });
  128. if (targetInstance) {
  129. var text = targetInstance.text,
  130. image = targetInstance.image;
  131. return React.createElement(PayPlatformBlock, _extends({
  132. key: valueKey
  133. }, {
  134. isMobile: isMobile,
  135. locale: locale,
  136. size: size
  137. }, {
  138. onClick: function onClick() {
  139. return onPayChannelChange(valueKey);
  140. },
  141. isActive: valueKey === payChannel,
  142. text: text,
  143. image: image
  144. }));
  145. }
  146. });
  147. if (withTitle) {
  148. titleDOM = React.createElement("div", {
  149. className: styles.label
  150. }, titleText || locale === "zh" ? "支付方式" : "Payment");
  151. }
  152. return React.createElement("div", null, titleDOM, React.createElement("div", {
  153. className: classnames(styles.payChannelBox, _defineProperty({}, styles.mobile, isMobile))
  154. }, React.createElement("div", {
  155. className: styles.flexContainer
  156. }, payListDOM)));
  157. };
  158. export default PayPlatformOptions;
  159. export { PAY_CHANNEL, PAY_CHANNEL_CATEGORY };
  160. //# sourceMappingURL=index.js.map