@blocklet/launcher-workflow 1.9.65 → 2.0.1

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.
@@ -0,0 +1,5 @@
1
+ <svg width="21" height="20" viewBox="0 0 21 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M10.75 20C16.273 20 20.75 15.523 20.75 10C20.75 4.477 16.273 0 10.75 0C5.227 0 0.75 4.477 0.75 10C0.75 15.523 5.227 20 10.75 20Z" fill="white"/>
3
+ <path d="M6.22449 10.6464L8.8105 13.2324L15.2755 6.76733" fill="white"/>
4
+ <path d="M6.22449 10.6464L8.8105 13.2324L15.2755 6.76733" stroke="#1DC1C7" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
5
+ </svg>
@@ -0,0 +1,5 @@
1
+ <svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M10 20C15.523 20 20 15.523 20 10C20 4.477 15.523 0 10 0C4.477 0 0 4.477 0 10C0 15.523 4.477 20 10 20Z" fill="#1DC1C7"/>
3
+ <path d="M5.47449 10.6464L8.0605 13.2324L14.5255 6.7674" fill="#1DC1C7"/>
4
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M15.2326 6.06029C15.6232 6.45081 15.6232 7.08398 15.2326 7.4745L8.76761 13.9395C8.37708 14.3301 7.74392 14.3301 7.35339 13.9395L4.76738 11.3535C4.37686 10.963 4.37686 10.3298 4.76738 9.93931C5.1579 9.54878 5.79107 9.54878 6.18159 9.93931L8.0605 11.8182L13.8184 6.06029C14.2089 5.66976 14.8421 5.66976 15.2326 6.06029Z" fill="white"/>
5
+ </svg>
@@ -0,0 +1,5 @@
1
+ <svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M10 20C15.523 20 20 15.523 20 10C20 4.477 15.523 0 10 0C4.477 0 0 4.477 0 10C0 15.523 4.477 20 10 20Z" fill="#1DC1C7"/>
3
+ <path d="M5.47449 10.6464L8.0605 13.2324L14.5255 6.7674" fill="#1DC1C7"/>
4
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M15.2326 6.06029C15.6232 6.45081 15.6232 7.08398 15.2326 7.4745L8.76761 13.9395C8.37708 14.3301 7.74392 14.3301 7.35339 13.9395L4.76738 11.3535C4.37686 10.963 4.37686 10.3298 4.76738 9.93931C5.1579 9.54878 5.79107 9.54878 6.18159 9.93931L8.0605 11.8182L13.8184 6.06029C14.2089 5.66976 14.8421 5.66976 15.2326 6.06029Z" fill="white"/>
5
+ </svg>
@@ -0,0 +1,3 @@
1
+ <svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M19.5 10C19.5 15.2469 15.2469 19.5 10 19.5C4.75314 19.5 0.5 15.2469 0.5 10C0.5 4.75314 4.75314 0.5 10 0.5C15.2469 0.5 19.5 4.75314 19.5 10Z" stroke="#DDDDDD"/>
3
+ </svg>
@@ -0,0 +1,9 @@
1
+ <svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <rect width="40" height="40" rx="20" fill="#FEAF49"/>
3
+ <path opacity="0.34" fill-rule="evenodd" clip-rule="evenodd" d="M20.1504 23.6001C20.6474 23.6001 21.0504 24.003 21.0504 24.5001V26.6001C21.0504 27.0972 20.6474 27.5001 20.1504 27.5001C19.6533 27.5001 19.2504 27.0972 19.2504 26.6001V24.5001C19.2504 24.003 19.6533 23.6001 20.1504 23.6001Z" fill="white"/>
4
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M14.2504 29.0001C14.2504 27.403 15.5533 26.1001 17.1504 26.1001H23.1504C24.7474 26.1001 26.0504 27.403 26.0504 29.0001V30.9001H14.2504V29.0001ZM17.1504 27.9001C16.5474 27.9001 16.0504 28.3972 16.0504 29.0001V29.1001H24.2504V29.0001C24.2504 28.3972 23.7533 27.9001 23.1504 27.9001H17.1504Z" fill="white"/>
5
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M13.2504 30.0001C13.2504 29.503 13.6533 29.1001 14.1504 29.1001H26.1504C26.6474 29.1001 27.0504 29.503 27.0504 30.0001C27.0504 30.4972 26.6474 30.9001 26.1504 30.9001H14.1504C13.6533 30.9001 13.2504 30.4972 13.2504 30.0001Z" fill="white"/>
6
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M17 10.9001C15.287 10.9001 13.9 12.2872 13.9 14.0001V17.0001C13.9 20.373 16.627 23.1001 20 23.1001C23.3729 23.1001 26.1 20.373 26.1 17.0001V14.0001C26.1 12.2872 24.7129 10.9001 23 10.9001H17ZM12.1 14.0001C12.1 11.293 14.2929 9.1001 17 9.1001H23C25.707 9.1001 27.9 11.293 27.9 14.0001V17.0001C27.9 21.3672 24.367 24.9001 20 24.9001C15.6329 24.9001 12.1 21.3672 12.1 17.0001V14.0001Z" fill="white"/>
7
+ <path opacity="0.34" fill-rule="evenodd" clip-rule="evenodd" d="M12.0157 13.3333C11.3804 13.5435 10.939 14.1317 10.939 14.8502C10.939 15.8847 11.3435 16.8108 12.0282 17.6397C12.0023 17.3806 11.989 17.1173 11.989 16.8502V13.8502C11.989 13.6769 11.9979 13.5044 12.0157 13.3333ZM9.13904 14.8502C9.13904 12.9531 10.642 11.4502 12.539 11.4502H13.189C13.4924 11.4502 13.7754 11.603 13.9417 11.8567C14.108 12.1104 14.1354 12.4308 14.0144 12.709C13.8678 13.0463 13.789 13.4329 13.789 13.8502V16.8502C13.789 17.7218 13.9716 18.5411 14.2958 19.2945C14.4352 19.6185 14.3725 19.994 14.1354 20.2551C13.8984 20.5163 13.5306 20.6149 13.1947 20.5074C12.289 20.2175 11.5087 19.6927 10.9026 19.0866C10.8915 19.0754 10.8806 19.064 10.8701 19.0523C9.86325 17.9336 9.13904 16.5281 9.13904 14.8502Z" fill="white"/>
8
+ <path opacity="0.34" fill-rule="evenodd" clip-rule="evenodd" d="M26.0566 11.8567C26.223 11.603 26.5059 11.4502 26.8093 11.4502H27.4593C29.3563 11.4502 30.8593 12.9531 30.8593 14.8502C30.8593 16.5281 30.1351 17.9336 29.1283 19.0523C29.1177 19.064 29.1068 19.0754 29.0957 19.0866C28.4896 19.6927 27.7094 20.2175 26.8036 20.5074C26.4677 20.6149 26.1 20.5163 25.8629 20.2551C25.6259 19.994 25.5632 19.6185 25.7026 19.2945C26.0267 18.5411 26.2093 17.7218 26.2093 16.8502V13.8502C26.2093 13.4329 26.1306 13.0463 25.9839 12.709C25.863 12.4308 25.8903 12.1104 26.0566 11.8567ZM27.9826 13.3333C28.0005 13.5044 28.0093 13.6769 28.0093 13.8502V16.8502C28.0093 17.1173 27.996 17.3806 27.9702 17.6397C28.6549 16.8108 29.0593 15.8847 29.0593 14.8502C29.0593 14.1317 28.6179 13.5435 27.9826 13.3333Z" fill="white"/>
9
+ </svg>
@@ -0,0 +1,9 @@
1
+ <svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
2
+ <rect width="40" height="40" rx="8" fill="url(#pattern0)"/>
3
+ <defs>
4
+ <pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
5
+ <use xlink:href="#image0_3275_3013" transform="scale(0.00833333)"/>
6
+ </pattern>
7
+ <image id="image0_3275_3013" width="120" height="120" xlink:href=""/>
8
+ </defs>
9
+ </svg>
@@ -0,0 +1,312 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _react = _interopRequireWildcard(require("react"));
8
+ var _jsCookie = _interopRequireDefault(require("js-cookie"));
9
+ var _urlJoin = _interopRequireDefault(require("url-join"));
10
+ var _reactRouterDom = require("react-router-dom");
11
+ var _styled = _interopRequireDefault(require("@emotion/styled"));
12
+ var _useAsync = _interopRequireDefault(require("react-use/lib/useAsync"));
13
+ var _Dialog = _interopRequireDefault(require("@arcblock/ux/lib/Dialog"));
14
+ var _button = _interopRequireDefault(require("@blocklet/launcher-ux/lib/button"));
15
+ var _constant = require("@blocklet/launcher-util/lib/constant");
16
+ var _useMobile = _interopRequireDefault(require("@blocklet/launcher-ux/lib/use-mobile"));
17
+ var _payment = _interopRequireDefault(require("@did-pay/react/lib/payment"));
18
+ var _Grid = _interopRequireDefault(require("@mui/material/Grid"));
19
+ var _Skeleton = _interopRequireDefault(require("@mui/material/Skeleton"));
20
+ var _layout = _interopRequireDefault(require("./components/layout"));
21
+ var _header = _interopRequireDefault(require("./components/layout/header"));
22
+ var _body = _interopRequireDefault(require("./components/layout/body"));
23
+ var _footer = _interopRequireDefault(require("./components/layout/footer"));
24
+ var _checkbox = _interopRequireDefault(require("./components/checkbox"));
25
+ var _locale = require("./contexts/locale");
26
+ var _request = _interopRequireDefault(require("./contexts/request"));
27
+ var _query = _interopRequireDefault(require("./hooks/query"));
28
+ var _session = require("./contexts/session");
29
+ var _util = require("./util");
30
+ var _agreement = _interopRequireDefault(require("./components/agreement"));
31
+ var _workflow = require("./contexts/workflow");
32
+ var _jsxRuntime = require("react/jsx-runtime");
33
+ var _templateObject;
34
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
36
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
38
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
39
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
40
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
41
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
42
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
43
+ var SpaceIcon = function SpaceIcon(props) {
44
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("svg", _objectSpread(_objectSpread({}, props), {}, {
45
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("rect", {
46
+ width: "40",
47
+ height: "40",
48
+ rx: "8",
49
+ fill: "url(#a)"
50
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("defs", {
51
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("pattern", {
52
+ id: "a",
53
+ patternContentUnits: "objectBoundingBox",
54
+ width: "1",
55
+ height: "1",
56
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("use", {
57
+ xlinkHref: "#b",
58
+ transform: "scale(.00833)"
59
+ })
60
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("image", {
61
+ id: "b",
62
+ width: "120",
63
+ height: "120",
64
+ xlinkHref: ""
65
+ })]
66
+ })]
67
+ }));
68
+ };
69
+ SpaceIcon.defaultProps = {
70
+ width: "40",
71
+ height: "40",
72
+ fill: "none",
73
+ xmlns: "http://www.w3.org/2000/svg",
74
+ xmlnsXlink: "http://www.w3.org/1999/xlink"
75
+ };
76
+ function CheckoutPage() {
77
+ var _session$user;
78
+ const {
79
+ t,
80
+ locale
81
+ } = (0, _locale.useLocaleContext)();
82
+ const {
83
+ session
84
+ } = (0, _session.useSessionContext)();
85
+ const [paying, setPaying] = (0, _react.useState)(false);
86
+ const [showAgreement, setShowAgreement] = (0, _react.useState)(false);
87
+ const [agree, setAgree] = (0, _react.useState)(false);
88
+ const navigate = (0, _reactRouterDom.useNavigate)();
89
+ const {
90
+ create
91
+ } = (0, _request.default)();
92
+ const [paymentMethod, setPaymentMethod] = (0, _react.useState)(null);
93
+ const query = (0, _query.default)();
94
+ const [searchParams] = (0, _reactRouterDom.useSearchParams)();
95
+ const {
96
+ mobileSize
97
+ } = (0, _useMobile.default)();
98
+ const {
99
+ routerPrefix,
100
+ didPayPrefix
101
+ } = (0, _workflow.useWorkflowContext)();
102
+ const api = create({
103
+ baseURL: didPayPrefix
104
+ });
105
+ const planId = query.get('planId');
106
+ const state = (0, _useAsync.default)(async () => {
107
+ try {
108
+ const [{
109
+ data: {
110
+ data: methods
111
+ }
112
+ }, {
113
+ data: {
114
+ data: plan
115
+ }
116
+ }] = await Promise.all([api.get('/payment-methods'), api.get("/plans/".concat(planId))]);
117
+ if (methods.length > 0) {
118
+ setPaymentMethod(methods[0]);
119
+ }
120
+ return {
121
+ methods,
122
+ plan
123
+ };
124
+ } catch (error) {
125
+ console.error('load data failed:', error);
126
+ return {
127
+ methods: [],
128
+ plan: null
129
+ };
130
+ }
131
+ });
132
+ const switchPayment = method => {
133
+ setPaymentMethod(method);
134
+ };
135
+ const handlePay = () => {
136
+ if (!(session !== null && session !== void 0 && session.user)) {
137
+ session.login(() => setPaying(true));
138
+ return;
139
+ }
140
+ setPaying(true);
141
+ };
142
+ const handleCancelPay = () => setPaying(false);
143
+ const handlePaid = async (_ref, decrypt) => {
144
+ let {
145
+ nftId,
146
+ launchToken
147
+ } = _ref;
148
+ if (launchToken) {
149
+ _jsCookie.default.set('launch-token', decrypt(launchToken));
150
+ }
151
+ const nftState = await (0, _util.getAsset)(window.blocklet.CHAIN_HOST, nftId);
152
+ if ((nftState.tags || []).includes(_constant.NFT_TYPE_SERVERLESS)) {
153
+ searchParams.set('launchType', 'serverless');
154
+ }
155
+ navigate({
156
+ pathname: (0, _urlJoin.default)(routerPrefix, "/launch/".concat(nftId)),
157
+ search: searchParams.toString()
158
+ });
159
+ setPaying(false);
160
+ };
161
+ const handlePayFailed = () => {
162
+ // TODO: Toast 错误
163
+ setPaying(false);
164
+ };
165
+ const calculateTotalPayment = prices => {
166
+ if (!paymentMethod) {
167
+ return '';
168
+ }
169
+ return (0, _util.getPrice)(prices, paymentMethod.provider.name);
170
+ };
171
+ const toggleAgreement = () => setAgree(!agree);
172
+ const {
173
+ methods,
174
+ plan
175
+ } = state.loading ? {} : state.value;
176
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(Container, {
177
+ mobileSize: mobileSize,
178
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_header.default, {
179
+ title: t('checkout.pageTitle')
180
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)(_body.default, {
181
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
182
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
183
+ className: "header",
184
+ children: t('common.details')
185
+ }), state.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
186
+ className: "skeleton",
187
+ sx: {
188
+ width: '100%',
189
+ height: '100%'
190
+ }
191
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
192
+ className: "space details",
193
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
194
+ className: "basic",
195
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(SpaceIcon, {}), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
196
+ className: "basic-info",
197
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
198
+ className: "title",
199
+ children: plan.name[locale]
200
+ })
201
+ })]
202
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
203
+ className: "price",
204
+ children: (0, _util.getPrice)(plan.prices, 'ocap')
205
+ })]
206
+ })]
207
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
208
+ className: "divider"
209
+ }), state.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
210
+ className: "skeleton",
211
+ sx: {
212
+ width: '100%',
213
+ height: '100%'
214
+ }
215
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
216
+ className: "total-order space",
217
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
218
+ children: t('checkout.orderTotal')
219
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
220
+ children: (0, _util.getPrice)((plan === null || plan === void 0 ? void 0 : plan.prices) || [], 'ocap')
221
+ })]
222
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
223
+ className: "total-payment space",
224
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
225
+ children: t('checkout.paymentTotal')
226
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
227
+ children: calculateTotalPayment((plan === null || plan === void 0 ? void 0 : plan.prices) || [])
228
+ })]
229
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
230
+ className: "payment-method space",
231
+ children: state.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
232
+ className: "skeleton",
233
+ sx: {
234
+ width: '100%',
235
+ height: '100%'
236
+ }
237
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
238
+ className: "body",
239
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
240
+ className: "payment-method__title",
241
+ children: t('checkout.paymentMethod.title')
242
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
243
+ className: "payment-method__list",
244
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_Grid.default, {
245
+ container: true,
246
+ spacing: 3,
247
+ justifyContent: "flex-start",
248
+ children: methods.map(method => /*#__PURE__*/(0, _jsxRuntime.jsx)(_Grid.default, {
249
+ item: true,
250
+ xs: 12,
251
+ sm: 12,
252
+ md: 3,
253
+ lg: 2,
254
+ xl: 2,
255
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_checkbox.default, {
256
+ label: method.name[locale],
257
+ checked: paymentMethod._id === method._id,
258
+ onClick: () => switchPayment(method)
259
+ })
260
+ }, method._id))
261
+ })
262
+ })]
263
+ })
264
+ })]
265
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)(_footer.default, {
266
+ className: "footer",
267
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
268
+ className: "left",
269
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_checkbox.default, {
270
+ checked: agree,
271
+ onClick: () => toggleAgreement(),
272
+ label: /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
273
+ children: [t('common.agreeTo'), /*#__PURE__*/(0, _jsxRuntime.jsxs)("span", {
274
+ className: "agreement",
275
+ onClick: e => {
276
+ e.stopPropagation();
277
+ setShowAgreement(true);
278
+ },
279
+ children: ["Blocklet ", t('common.agreement')]
280
+ })]
281
+ })
282
+ })
283
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
284
+ className: "right",
285
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.default, {
286
+ loading: paying,
287
+ className: "button-pay",
288
+ disabled: paying || !planId || !paymentMethod || !agree,
289
+ variant: "contained",
290
+ onClick: handlePay,
291
+ children: t('common.pay')
292
+ })
293
+ })]
294
+ }), paying && /*#__PURE__*/(0, _jsxRuntime.jsx)(_payment.default, {
295
+ baseURL: didPayPrefix,
296
+ method: paymentMethod,
297
+ userDid: session === null || session === void 0 ? void 0 : (_session$user = session.user) === null || _session$user === void 0 ? void 0 : _session$user.did,
298
+ productId: planId,
299
+ onComplete: handlePaid,
300
+ onFailed: handlePayFailed,
301
+ onCancel: handleCancelPay
302
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_Dialog.default, {
303
+ open: showAgreement,
304
+ title: t('common.agreement'),
305
+ onClose: () => setShowAgreement(false),
306
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_agreement.default, {})
307
+ })]
308
+ });
309
+ }
310
+ const Container = (0, _styled.default)(_layout.default)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n .header {\n font-weight: bolder;\n font-size: 1.2em;\n }\n\n .divider {\n margin-top: 20px;\n border: 1.2px solid #f6f6f6;\n }\n\n .skeleton {\n height: 64px;\n }\n\n .space {\n margin-top: 18px;\n }\n\n .total-order {\n display: flex;\n justify-content: space-between;\n align-items: center;\n font-weight: bolder;\n }\n\n .total-payment {\n display: flex;\n justify-content: space-between;\n align-items: center;\n color: ", ";\n font-size: 22px;\n font-weight: bolder;\n }\n\n .details {\n display: flex;\n justify-content: space-between;\n align-items: center;\n height: 40px;\n\n .basic {\n display: flex;\n height: 40px;\n\n .basic-info {\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n margin-left: 8px;\n\n .title {\n font-weight: bolder;\n }\n\n .sub-title {\n color: grey;\n font-size: 0.8em;\n }\n }\n }\n\n .period {\n display: flex;\n align-items: center;\n\n .info-icon {\n color: grey;\n margin-left: 8px;\n }\n }\n }\n\n .payment-method {\n background-color: #fbfbfb;\n padding: 18px;\n\n .payment-method__title {\n color: #9397a1;\n }\n\n .payment-method__list {\n margin-top: 8px;\n }\n }\n\n .footer {\n display: flex;\n align-items: center;\n justify-content: space-between;\n\n .left {\n .agreement {\n margin-left: 5px;\n color: ", ";\n }\n }\n\n .right {\n .button-pay {\n width: 200px;\n }\n }\n\n @media (max-width: ", ") {\n flex-direction: column;\n align-items: center;\n\n .right {\n width: 100%;\n\n .button-pay {\n width: 100%;\n margin-top: 18px;\n }\n }\n }\n }\n"])), props => props.theme.palette.primary.main, props => props.theme.palette.primary.main, props => props.mobileSize);
311
+ var _default = CheckoutPage;
312
+ exports.default = _default;
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = Agreement;
7
+ var _blocklet = _interopRequireDefault(require("@arcblock/license/lib/blocklet"));
8
+ var _jsxRuntime = require("react/jsx-runtime");
9
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
10
+ function Agreement() {
11
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_blocklet.default, {});
12
+ }
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = PaymentMethod;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _styled = _interopRequireDefault(require("@emotion/styled"));
9
+ var _propTypes = _interopRequireDefault(require("prop-types"));
10
+ var _jsxRuntime = require("react/jsx-runtime");
11
+ var _templateObject;
12
+ const _excluded = ["label", "checked"];
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
15
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
16
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
17
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
18
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
19
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
20
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
21
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
22
+ var CheckedIcon = function CheckedIcon(props) {
23
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("svg", _objectSpread(_objectSpread({}, props), {}, {
24
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("path", {
25
+ d: "M10 20c5.523 0 10-4.477 10-10S15.523 0 10 0 0 4.477 0 10s4.477 10 10 10Z",
26
+ fill: "#1DC1C7"
27
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("path", {
28
+ d: "m5.474 10.646 2.586 2.586 6.465-6.465",
29
+ fill: "#1DC1C7"
30
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("path", {
31
+ fillRule: "evenodd",
32
+ clipRule: "evenodd",
33
+ d: "M15.233 6.06a1 1 0 0 1 0 1.415L8.768 13.94a1 1 0 0 1-1.415 0l-2.586-2.586a1 1 0 1 1 1.415-1.415l1.878 1.88 5.758-5.759a1 1 0 0 1 1.415 0Z",
34
+ fill: "#fff"
35
+ })]
36
+ }));
37
+ };
38
+ CheckedIcon.defaultProps = {
39
+ width: "20",
40
+ height: "20",
41
+ fill: "none",
42
+ xmlns: "http://www.w3.org/2000/svg"
43
+ };
44
+ var UncheckedIcon = function UncheckedIcon(props) {
45
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("svg", _objectSpread(_objectSpread({}, props), {}, {
46
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("path", {
47
+ d: "M19.5 10a9.5 9.5 0 0 1-9.5 9.5A9.5 9.5 0 0 1 .5 10 9.5 9.5 0 0 1 10 .5a9.5 9.5 0 0 1 9.5 9.5Z",
48
+ stroke: "#DDD"
49
+ })
50
+ }));
51
+ };
52
+ UncheckedIcon.defaultProps = {
53
+ width: "20",
54
+ height: "20",
55
+ fill: "none",
56
+ xmlns: "http://www.w3.org/2000/svg"
57
+ };
58
+ function PaymentMethod(_ref) {
59
+ let {
60
+ label,
61
+ checked
62
+ } = _ref,
63
+ rest = _objectWithoutProperties(_ref, _excluded);
64
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(Container, _objectSpread(_objectSpread({}, rest), {}, {
65
+ children: [checked ? /*#__PURE__*/(0, _jsxRuntime.jsx)(CheckedIcon, {}) : /*#__PURE__*/(0, _jsxRuntime.jsx)(UncheckedIcon, {}), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
66
+ className: "label",
67
+ children: label
68
+ })]
69
+ }));
70
+ }
71
+ const Container = _styled.default.div(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: flex;\n justify-content: flex-start;\n align-items: center;\n cursor: pointer;\n\n .label {\n margin-left: 8px;\n }\n"])));
72
+ PaymentMethod.propTypes = {
73
+ checked: _propTypes.default.bool,
74
+ label: _propTypes.default.any
75
+ };
76
+ PaymentMethod.defaultProps = {
77
+ checked: false,
78
+ label: ''
79
+ };