Ei kuvausta

index.js 33KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
  4. var React = require('react');
  5. var React__default = _interopDefault(React);
  6. var styleInject_es = require('../style-inject.es-dcee06b6.js');
  7. var defineProperty = require('../defineProperty-ba7cd53d.js');
  8. require('../_commonjsHelpers-72d386ba.js');
  9. var index = require('../index-44e17595.js');
  10. var utils = require('../utils-b800dc99.js');
  11. var img = "";
  12. var img$1 = "";
  13. var img$2 = "";
  14. var img$3 = "";
  15. var img$4 = "";
  16. var img$5 = "";
  17. var css = ".PayPlatformOptions_flexContainer__b-T24 {\n display: flex;\n justify-content: space-around;\n align-items: center;\n}\n.PayPlatformOptions_label__3uVHv {\n font-size: 14px;\n font-weight: 400;\n color: #616A79;\n}\n.PayPlatformOptions_payChannelBox__3_kPR {\n padding: 20px 10px 10px 10px;\n text-align: center;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_paymentImage__1Jwya {\n display: inline-block;\n margin: 0;\n width: 60%;\n vertical-align: middle;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_paymentImage-before__2mPbW {\n display: inline-block;\n height: 100%;\n vertical-align: middle;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL {\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__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL .PayPlatformOptions_platformName__U1hFh {\n text-align: center;\n white-space: nowrap;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_small__rnqDt {\n width: 88px;\n height: 36px;\n line-height: 36px;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_small__rnqDt .PayPlatformOptions_paymentImage__1Jwya {\n margin: 0;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_normal__12jfT {\n width: 132px;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_large__Q_Mjs {\n width: 162px;\n}\n.PayPlatformOptions_payChannelBox__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_active__3wAdi {\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__3_kPR .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_en__Ns_g7 {\n font-size: 12px;\n}\n.PayPlatformOptions_payChannelBox__3_kPR.PayPlatformOptions_mobile__3Ckag {\n padding: 8px 10px 10px 8px;\n}\n.PayPlatformOptions_payChannelBox__3_kPR.PayPlatformOptions_mobile__3Ckag .PayPlatformOptions_payChannelBlock__3YbXL {\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__3_kPR.PayPlatformOptions_mobile__3Ckag .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_active__3wAdi {\n border-radius: 4px;\n border-color: #1790FF;\n}\n.PayPlatformOptions_payChannelBox__3_kPR.PayPlatformOptions_mobile__3Ckag .PayPlatformOptions_payChannelBlock__3YbXL .PayPlatformOptions_paymentImage__1Jwya {\n display: inline-block;\n width: 34px;\n height: 34px;\n}\n@media (max-width: 768px) {\n .PayPlatformOptions_payChannelBlock__3YbXL {\n cursor: pointer;\n border: 1px solid transparent;\n }\n .PayPlatformOptions_payChannelBlock__3YbXL.PayPlatformOptions_active__3wAdi {\n border-radius: 5px;\n border-color: #1790FF;\n }\n}\n";
  18. var styles = {
  19. "flexContainer": "PayPlatformOptions_flexContainer__b-T24",
  20. "label": "PayPlatformOptions_label__3uVHv",
  21. "payChannelBox": "PayPlatformOptions_payChannelBox__3_kPR",
  22. "paymentImage": "PayPlatformOptions_paymentImage__1Jwya",
  23. "paymentImage-before": "PayPlatformOptions_paymentImage-before__2mPbW",
  24. "payChannelBlock": "PayPlatformOptions_payChannelBlock__3YbXL",
  25. "platformName": "PayPlatformOptions_platformName__U1hFh",
  26. "small": "PayPlatformOptions_small__rnqDt",
  27. "normal": "PayPlatformOptions_normal__12jfT",
  28. "large": "PayPlatformOptions_large__Q_Mjs",
  29. "active": "PayPlatformOptions_active__3wAdi",
  30. "en": "PayPlatformOptions_en__Ns_g7",
  31. "mobile": "PayPlatformOptions_mobile__3Ckag",
  32. "paymentImageBefore": "PayPlatformOptions_paymentImage-before__2mPbW"
  33. };
  34. styleInject_es.styleInject(css);
  35. function ownKeys(object, enumerableOnly) {
  36. var keys = Object.keys(object);
  37. if (Object.getOwnPropertySymbols) {
  38. var symbols = Object.getOwnPropertySymbols(object);
  39. if (enumerableOnly) symbols = symbols.filter(function (sym) {
  40. return Object.getOwnPropertyDescriptor(object, sym).enumerable;
  41. });
  42. keys.push.apply(keys, symbols);
  43. }
  44. return keys;
  45. }
  46. function _objectSpread(target) {
  47. for (var i = 1; i < arguments.length; i++) {
  48. var source = arguments[i] != null ? arguments[i] : {};
  49. if (i % 2) {
  50. ownKeys(Object(source), true).forEach(function (key) {
  51. defineProperty._defineProperty(target, key, source[key]);
  52. });
  53. } else if (Object.getOwnPropertyDescriptors) {
  54. Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
  55. } else {
  56. ownKeys(Object(source)).forEach(function (key) {
  57. Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
  58. });
  59. }
  60. }
  61. return target;
  62. }
  63. var PAY_CHANNEL = {
  64. PAYPAL: "PAYPAL_PAYPAL",
  65. ALI_WEB: "ALI_WEB",
  66. ALI_WAP: "ALI_WAP",
  67. WX_WAP: "WX_WAP",
  68. WX_NATIVE: "WX_NATIVE"
  69. };
  70. var PAY_CHANNEL_CATEGORY = {
  71. ALI: "Alipay",
  72. WX: "Wechat",
  73. PAYPAL: "Paypal"
  74. };
  75. var PAY_CHANNEL_INSTANCE = [{
  76. image: {
  77. desktop: img,
  78. mobile: img$3
  79. },
  80. text: {
  81. zh: "支付宝",
  82. en: "Alipay"
  83. },
  84. key: PAY_CHANNEL_CATEGORY.ALI
  85. }, {
  86. image: {
  87. desktop: img$1,
  88. mobile: img$4
  89. },
  90. text: {
  91. zh: "微信",
  92. en: "WeChat"
  93. },
  94. key: PAY_CHANNEL_CATEGORY.WX
  95. }, {
  96. image: {
  97. desktop: img$2,
  98. mobile: img$5
  99. },
  100. text: {
  101. zh: "PayPal",
  102. en: "PayPal"
  103. },
  104. key: PAY_CHANNEL_CATEGORY.PAYPAL
  105. }];
  106. var PayPlatformBlock = function PayPlatformBlock(_ref) {
  107. var _ref$isMobile = _ref.isMobile,
  108. isMobile = _ref$isMobile === void 0 ? false : _ref$isMobile,
  109. _ref$isActive = _ref.isActive,
  110. isActive = _ref$isActive === void 0 ? false : _ref$isActive,
  111. _ref$size = _ref.size,
  112. size = _ref$size === void 0 ? "normal" : _ref$size,
  113. onClick = _ref.onClick,
  114. text = _ref.text,
  115. image = _ref.image,
  116. _ref$locale = _ref.locale,
  117. locale = _ref$locale === void 0 ? "zh" : _ref$locale;
  118. var showText = text[locale];
  119. if (isMobile) {
  120. return React__default.createElement("div", {
  121. className: styles.flexItem
  122. }, React__default.createElement("div", {
  123. className: index.classnames(styles.payChannelBlock, _objectSpread(defineProperty._defineProperty({}, styles.active, isActive), utils.exportStyleSizeClass(styles, size)), styles[locale]),
  124. onClick: onClick
  125. }, React__default.createElement("img", {
  126. src: image.mobile,
  127. alt: showText,
  128. className: styles.paymentImage
  129. }), React__default.createElement("div", {
  130. className: styles.platformName
  131. }, showText)));
  132. }
  133. return React__default.createElement("div", {
  134. className: styles.flexItem
  135. }, React__default.createElement("div", {
  136. className: index.classnames(styles.payChannelBlock, _objectSpread(defineProperty._defineProperty({}, styles.active, isActive), utils.exportStyleSizeClass(styles, size)), styles[locale]),
  137. onClick: onClick
  138. }, React__default.createElement("span", {
  139. className: styles["payment-method-before"]
  140. }), React__default.createElement("img", {
  141. src: image.desktop,
  142. alt: showText,
  143. className: styles.paymentImage
  144. })));
  145. };
  146. var PayPlatformOptions = function PayPlatformOptions(_ref2) {
  147. var payChannel = _ref2.payChannel,
  148. onPayChannelChange = _ref2.onPayChannelChange,
  149. _ref2$size = _ref2.size,
  150. size = _ref2$size === void 0 ? "normal" : _ref2$size,
  151. _ref2$isMobile = _ref2.isMobile,
  152. isMobile = _ref2$isMobile === void 0 ? false : _ref2$isMobile,
  153. _ref2$withTitle = _ref2.withTitle,
  154. withTitle = _ref2$withTitle === void 0 ? true : _ref2$withTitle,
  155. titleText = _ref2.titleText,
  156. _ref2$locale = _ref2.locale,
  157. locale = _ref2$locale === void 0 ? "zh" : _ref2$locale;
  158. var titleDOM = null;
  159. var payListDOM = [{
  160. valueKey: PAY_CHANNEL.ALI_WEB,
  161. categoryKey: PAY_CHANNEL_CATEGORY.ALI
  162. }, {
  163. valueKey: PAY_CHANNEL.WX_NATIVE,
  164. categoryKey: PAY_CHANNEL_CATEGORY.WX
  165. }, {
  166. valueKey: PAY_CHANNEL.PAYPAL,
  167. categoryKey: PAY_CHANNEL_CATEGORY.PAYPAL
  168. }].map(function (v) {
  169. var valueKey = v.valueKey,
  170. categoryKey = v.categoryKey;
  171. var targetInstance = PAY_CHANNEL_INSTANCE.find(function (ins) {
  172. return ins.key === categoryKey;
  173. });
  174. if (targetInstance) {
  175. var text = targetInstance.text,
  176. image = targetInstance.image;
  177. return React__default.createElement(PayPlatformBlock, Object.assign({
  178. key: valueKey
  179. }, {
  180. isMobile: isMobile,
  181. locale: locale,
  182. size: size
  183. }, {
  184. onClick: function onClick() {
  185. return onPayChannelChange(valueKey);
  186. },
  187. isActive: valueKey === payChannel,
  188. text: text,
  189. image: image
  190. }));
  191. }
  192. });
  193. if (withTitle) {
  194. titleDOM = React__default.createElement("div", {
  195. className: styles.label
  196. }, titleText || locale === "zh" ? "支付方式" : "Payment");
  197. }
  198. return React__default.createElement("div", null, titleDOM, React__default.createElement("div", {
  199. className: index.classnames(styles.payChannelBox, defineProperty._defineProperty({}, styles.mobile, isMobile))
  200. }, React__default.createElement("div", {
  201. className: styles.flexContainer
  202. }, payListDOM)));
  203. };
  204. exports.PAY_CHANNEL = PAY_CHANNEL;
  205. exports.PAY_CHANNEL_CATEGORY = PAY_CHANNEL_CATEGORY;
  206. exports.default = PayPlatformOptions;
  207. //# sourceMappingURL=index.js.map