@blocklet/launcher-workflow 2.3.80 → 2.3.82

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.
package/lib/checkout.js DELETED
@@ -1,498 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _Dialog = _interopRequireDefault(require("@arcblock/ux/lib/Dialog"));
8
- var _constant = require("@blocklet/launcher-util/es/constant");
9
- var _util = require("@blocklet/launcher-util/es/util");
10
- var _button = _interopRequireDefault(require("@blocklet/launcher-ux/lib/button"));
11
- var _useMobile = _interopRequireDefault(require("@blocklet/launcher-ux/lib/use-mobile"));
12
- var _payment = _interopRequireDefault(require("@blocklet/payment/lib/payment"));
13
- var _styled = _interopRequireDefault(require("@emotion/styled"));
14
- var _Grid = _interopRequireDefault(require("@mui/material/Grid"));
15
- var _Skeleton = _interopRequireDefault(require("@mui/material/Skeleton"));
16
- var _dsbridge = _interopRequireDefault(require("dsbridge"));
17
- var _lodash = _interopRequireDefault(require("lodash.get"));
18
- var _propTypes = _interopRequireDefault(require("prop-types"));
19
- var _react = _interopRequireWildcard(require("react"));
20
- var _reactRouterDom = require("react-router-dom");
21
- var _useAsync = _interopRequireDefault(require("react-use/lib/useAsync"));
22
- var _useSetState = _interopRequireDefault(require("react-use/lib/useSetState"));
23
- var _urlJoin = _interopRequireDefault(require("url-join"));
24
- var _useBrowser = _interopRequireDefault(require("@arcblock/react-hooks/lib/useBrowser"));
25
- var _confirm = _interopRequireDefault(require("@arcblock/ux/lib/Dialog/confirm"));
26
- var _launchResultMessage = _interopRequireDefault(require("@blocklet/launcher-layout/lib/launch-result-message"));
27
- var _formatError = _interopRequireDefault(require("@blocklet/launcher-util/es/format-error"));
28
- var _agreement = _interopRequireDefault(require("./components/agreement"));
29
- var _checkbox = _interopRequireDefault(require("./components/checkbox"));
30
- var _layout = _interopRequireDefault(require("./components/layout"));
31
- var _body = _interopRequireDefault(require("./components/layout/body"));
32
- var _footer = _interopRequireDefault(require("./components/layout/footer"));
33
- var _header = _interopRequireDefault(require("./components/layout/header"));
34
- var _locale = require("./contexts/locale");
35
- var _request = _interopRequireDefault(require("./contexts/request"));
36
- var _session = require("./contexts/session");
37
- var _workflow = require("./contexts/workflow");
38
- var _util2 = require("./util");
39
- var _jsxRuntime = require("react/jsx-runtime");
40
- var _templateObject;
41
- /* eslint-disable react-hooks/exhaustive-deps */
42
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
43
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
44
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
45
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
46
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
47
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
48
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
49
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
50
- function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
51
- var SpaceIcon = function SpaceIcon(props) {
52
- return /*#__PURE__*/(0, _jsxRuntime.jsxs)("svg", _objectSpread(_objectSpread({}, props), {}, {
53
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("rect", {
54
- width: "40",
55
- height: "40",
56
- rx: "8",
57
- fill: "url(#a)"
58
- }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("defs", {
59
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("pattern", {
60
- id: "a",
61
- patternContentUnits: "objectBoundingBox",
62
- width: "1",
63
- height: "1",
64
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)("use", {
65
- xlinkHref: "#b",
66
- transform: "scale(.00833)"
67
- })
68
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("image", {
69
- id: "b",
70
- width: "120",
71
- height: "120",
72
- xlinkHref: ""
73
- })]
74
- })]
75
- }));
76
- };
77
- SpaceIcon.defaultProps = {
78
- width: "40",
79
- height: "40",
80
- fill: "none",
81
- xmlns: "http://www.w3.org/2000/svg",
82
- xmlnsXlink: "http://www.w3.org/1999/xlink"
83
- };
84
- function CheckoutPage(_ref) {
85
- var _session$user, _session$user2, _session$user3;
86
- let {
87
- blocklet
88
- } = _ref;
89
- const {
90
- t,
91
- locale
92
- } = (0, _locale.useLocaleContext)();
93
- const {
94
- session,
95
- events
96
- } = (0, _session.useSessionContext)();
97
- const [params] = (0, _reactRouterDom.useSearchParams)();
98
- const [state, setState] = (0, _useSetState.default)({
99
- error: '',
100
- showAgreement: false,
101
- showPayment: false,
102
- showAgreeHint: false,
103
- showPaidDialog: {
104
- open: false,
105
- nftId: ''
106
- },
107
- agreed: true,
108
- paying: false,
109
- planId: params.get('planId'),
110
- sessionId: params.get('sessionId'),
111
- paymentMethod: params.get('paymentMethod'),
112
- autoLogin: true
113
- });
114
- const browser = (0, _useBrowser.default)();
115
- const navigate = (0, _reactRouterDom.useNavigate)();
116
- const {
117
- create,
118
- api: launchSessionAPI
119
- } = (0, _request.default)();
120
- const {
121
- mobileSize,
122
- isMobile
123
- } = (0, _useMobile.default)();
124
- const {
125
- routerPrefix,
126
- didPayPrefix,
127
- embed,
128
- isPurchaseOnly
129
- } = (0, _workflow.useWorkflowContext)();
130
- const api = create({
131
- baseURL: didPayPrefix
132
- });
133
- (0, _react.useEffect)(() => {
134
- if (isPurchaseOnly) {
135
- return;
136
- }
137
- if (session.user) {
138
- _util2.launchSession.connect(launchSessionAPI, routerPrefix, state.sessionId, session.user.did);
139
- }
140
- }, [session.user]);
141
- const enableBlockletAgreement = !!blocklet;
142
- const context = (0, _useAsync.default)(async () => {
143
- const [{
144
- data: {
145
- data: paymentMethods
146
- }
147
- }, {
148
- data: {
149
- data: plan
150
- }
151
- }] = await Promise.all([api.get('/payment-methods'), api.get("/plans/".concat(state.planId))]);
152
- if (!plan || paymentMethods.length === 0) {
153
- throw new Error(t('purchase.noProducts'));
154
- }
155
- if (paymentMethods.length > 0 && !state.paymentMethod) {
156
- setState({
157
- paymentMethod: paymentMethods[0]._id
158
- });
159
- }
160
- return {
161
- paymentMethods,
162
- plan
163
- };
164
- });
165
-
166
- // 用户退出的时候自动重新创建启动会话
167
- (0, _react.useEffect)(() => {
168
- if (isPurchaseOnly) {
169
- return;
170
- }
171
- events.on('logout', () => {
172
- const metaUrl = params.get('blocklet_meta_url');
173
- _util2.launchSession.create(launchSessionAPI, routerPrefix, metaUrl, (err, launch) => {
174
- var _context$value;
175
- setState({
176
- sessionId: launch._id
177
- });
178
- params.set('sessionId', launch._id);
179
- const type = (0, _lodash.default)((_context$value = context.value) === null || _context$value === void 0 ? void 0 : _context$value.plan, 'extra.type') || 'serverless';
180
- _util2.launchSession.select(launchSessionAPI, routerPrefix, launch._id, type, state.planId);
181
- });
182
- });
183
- }, []);
184
- const switchPayment = method => {
185
- setState({
186
- paymentMethod: method
187
- });
188
- };
189
- const handleCancelPay = () => {
190
- setState({
191
- showPayment: false,
192
- paying: false
193
- });
194
- };
195
- const ensureLogin = () => {
196
- return new Promise(resolve => {
197
- if (!session.user) {
198
- session.login(() => {
199
- resolve();
200
- });
201
- } else {
202
- resolve();
203
- }
204
- });
205
- };
206
- const handlePay = () => {
207
- if (enableBlockletAgreement && !state.agreed) {
208
- setState({
209
- showAgreeHint: true
210
- });
211
- setTimeout(() => {
212
- setState({
213
- showAgreeHint: false
214
- });
215
- }, 2000);
216
- return;
217
- }
218
- if (browser.wallet) {
219
- ensureLogin().then(() => {
220
- setState({
221
- showPayment: true,
222
- paying: true,
223
- autoLogin: false
224
- });
225
- });
226
- } else {
227
- setState({
228
- showPayment: true,
229
- paying: true,
230
- autoLogin: true
231
- });
232
- }
233
- };
234
- const handleConnected = result => {
235
- if (isPurchaseOnly) {
236
- session.refresh();
237
- return;
238
- }
239
- _util2.launchSession.connect(launchSessionAPI, routerPrefix, state.sessionId, result.did, () => {
240
- session.refresh();
241
- });
242
- };
243
- const handlePaid = _ref2 => {
244
- let {
245
- nftId,
246
- nftState
247
- } = _ref2;
248
- if ((nftState.tags || []).includes(_constant.NFT_TYPE_SERVERLESS)) {
249
- if (!embed) {
250
- setState({
251
- showPaidDialog: {
252
- open: true,
253
- nftId
254
- }
255
- });
256
- handleCancelPay();
257
- return;
258
- }
259
- params.set('launchType', 'serverless');
260
- }
261
- if (isPurchaseOnly && !(nftState.tags || []).includes(_constant.NFT_TYPE_DEDICATE)) {
262
- handleCancelPay();
263
- _dsbridge.default.call('arcClosePage');
264
- return;
265
- }
266
- handleCancelPay();
267
- navigate({
268
- pathname: (0, _urlJoin.default)(routerPrefix, "/launch/".concat(nftId)),
269
- search: params.toString()
270
- });
271
- };
272
- const handlePayFailed = () => {
273
- // TODO: Toast 错误
274
- handleCancelPay();
275
- };
276
- const calculateTotalPayment = prices => {
277
- var _paymentMethods$find;
278
- if (!state.paymentMethod) {
279
- return '';
280
- }
281
- const providerName = paymentMethods === null || paymentMethods === void 0 || (_paymentMethods$find = paymentMethods.find(x => x._id === state.paymentMethod)) === null || _paymentMethods$find === void 0 ? void 0 : _paymentMethods$find.provider.name;
282
- return (0, _util2.getPrice)(prices, providerName);
283
- };
284
- const toggleAgreement = () => setState({
285
- agreed: !state.agreed
286
- });
287
- const {
288
- paymentMethods,
289
- plan
290
- } = context.value || {};
291
- const paymentMethod = paymentMethods === null || paymentMethods === void 0 ? void 0 : paymentMethods.find(x => x._id === state.paymentMethod);
292
- const providerName = paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.provider.name;
293
- return /*#__PURE__*/(0, _jsxRuntime.jsxs)(Container, {
294
- mobileSize: mobileSize,
295
- enableBlockletAgreement: enableBlockletAgreement,
296
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_header.default, {
297
- title: t('checkout.pageTitle')
298
- }), context.error && /*#__PURE__*/(0, _jsxRuntime.jsx)(_body.default, {
299
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_launchResultMessage.default, {
300
- variant: "error",
301
- title: t('common.error'),
302
- subTitle: (0, _formatError.default)(context.error)
303
- })
304
- }), !context.error && /*#__PURE__*/(0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
305
- children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_body.default, {
306
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
307
- className: "header",
308
- children: t('common.details')
309
- }), context.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
310
- className: "skeleton",
311
- sx: {
312
- width: '100%',
313
- height: '100%'
314
- }
315
- }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
316
- className: "space details",
317
- children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
318
- className: "basic",
319
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(SpaceIcon, {}), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
320
- className: "basic-info",
321
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
322
- className: "title",
323
- children: plan.name[locale]
324
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
325
- className: "sub-title",
326
- children: t('common.space')
327
- })]
328
- })]
329
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
330
- className: "price",
331
- children: (0, _util2.getPrice)(plan.prices, providerName)
332
- })]
333
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
334
- className: "divider"
335
- }), context.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
336
- className: "skeleton",
337
- sx: {
338
- width: '100%',
339
- height: '100%'
340
- }
341
- }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
342
- className: "total-order space",
343
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
344
- children: t('checkout.orderTotal')
345
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
346
- children: (0, _util2.getPrice)((plan === null || plan === void 0 ? void 0 : plan.prices) || [], providerName)
347
- })]
348
- }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
349
- className: "total-payment space",
350
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
351
- children: t('checkout.paymentTotal')
352
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
353
- children: calculateTotalPayment((plan === null || plan === void 0 ? void 0 : plan.prices) || [])
354
- })]
355
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
356
- className: "payment-method space",
357
- children: context.loading ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_Skeleton.default, {
358
- className: "skeleton",
359
- sx: {
360
- width: '100%',
361
- height: '100%'
362
- }
363
- }) : /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
364
- className: "body",
365
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
366
- className: "payment-method__title",
367
- children: t('checkout.paymentMethod.title')
368
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
369
- className: "payment-method__list",
370
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_Grid.default, {
371
- container: true,
372
- spacing: 3,
373
- justifyContent: "flex-start",
374
- children: paymentMethods.map(method => /*#__PURE__*/(0, _jsxRuntime.jsx)(_Grid.default, {
375
- item: true,
376
- xs: 12,
377
- sm: 12,
378
- md: 3,
379
- lg: 2,
380
- xl: 2,
381
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_checkbox.default, {
382
- label: method.currency.displayName[locale] || method.currency.displayName.en,
383
- checked: state.paymentMethod === method._id,
384
- onClick: () => switchPayment(method._id)
385
- })
386
- }, method._id))
387
- })
388
- })]
389
- })
390
- })]
391
- }), !context.loading && /*#__PURE__*/(0, _jsxRuntime.jsxs)(_footer.default, {
392
- className: "footer",
393
- children: [enableBlockletAgreement && /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
394
- className: "agreement",
395
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_checkbox.default, {
396
- checked: state.agreed,
397
- showHint: state.showAgreeHint,
398
- onClick: () => toggleAgreement(),
399
- label: /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
400
- style: {
401
- display: 'flex',
402
- alignItems: 'center'
403
- },
404
- children: [t('common.agreeTo'), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
405
- className: "agreement-label",
406
- onClick: e => {
407
- e.stopPropagation();
408
- setState({
409
- showAgreement: true
410
- });
411
- },
412
- children: t('checkout.agreement', {
413
- name: (0, _util.getBlockletDisplayName)(blocklet)
414
- })
415
- })]
416
- })
417
- })
418
- }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
419
- className: "actions",
420
- children: [isMobile && /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.default, {
421
- className: "button-previous",
422
- variant: "outlined",
423
- onClick: () => navigate(-1),
424
- children: t('common.previous')
425
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_button.default, {
426
- loading: state.paying,
427
- className: "button-pay",
428
- disabled: state.paying || state.showPayment || !state.planId || !state.paymentMethod,
429
- variant: "contained",
430
- onClick: handlePay,
431
- children: t('common.pay')
432
- })]
433
- })]
434
- })]
435
- }), state.showPayment && /*#__PURE__*/(0, _jsxRuntime.jsx)(_payment.default, {
436
- baseURL: didPayPrefix,
437
- method: paymentMethod,
438
- userDid: session === null || session === void 0 || (_session$user = session.user) === null || _session$user === void 0 ? void 0 : _session$user.did,
439
- productId: state.planId,
440
- useSocket: false,
441
- onConnect: handleConnected,
442
- onComplete: handlePaid,
443
- onFailed: handlePayFailed,
444
- onCancel: handleCancelPay,
445
- metadata: {
446
- sessionId: state.sessionId,
447
- currentUserDid: session === null || session === void 0 || (_session$user2 = session.user) === null || _session$user2 === void 0 ? void 0 : _session$user2.did,
448
- forceSwitch: !(session !== null && session !== void 0 && session.user),
449
- // HACK: 在 openPopup 阶段需要手动添加 sourceAppPid 字段
450
- sourceAppPid: session === null || session === void 0 || (_session$user3 = session.user) === null || _session$user3 === void 0 ? void 0 : _session$user3.sourceAppPid
451
- },
452
- autoLogin: state.autoLogin
453
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_confirm.default, {
454
- open: state.showPaidDialog.open,
455
- disableEscapeKeyDown: true,
456
- title: t('purchase.serverlessDialog.title'),
457
- confirmButton: {
458
- text: t('purchase.serverlessDialog.redirectToStoreButton')
459
- },
460
- PaperProps: {
461
- style: {
462
- maxWidth: 1200,
463
- minWidth: isMobile ? undefined : 600
464
- }
465
- },
466
- onCancel: () => setState({
467
- showPaidDialog: {
468
- open: false,
469
- nftId: ''
470
- }
471
- }),
472
- showCancelButton: false,
473
- onConfirm: () => {
474
- const url = new URL(_util2.BLOCKLET_STORE_URL);
475
- url.searchParams.set('launcher_nft_id', state.showPaidDialog.nftId);
476
- window.location = url.href;
477
- },
478
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
479
- children: t('purchase.serverlessDialog.purchaseServerlessSuccess')
480
- })
481
- }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_Dialog.default, {
482
- open: state.showAgreement,
483
- title: t('common.agreement'),
484
- onClose: () => setState({
485
- showAgreement: false
486
- }),
487
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_agreement.default, {})
488
- })]
489
- });
490
- }
491
- CheckoutPage.propTypes = {
492
- blocklet: _propTypes.default.object
493
- };
494
- CheckoutPage.defaultProps = {
495
- blocklet: null
496
- };
497
- 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: ", ";\n\n .agreement {\n .agreement-label {\n margin-left: 4px;\n color: ", ";\n text-decoration: underline;\n }\n }\n\n @media (min-width: ", ") {\n .actions {\n .button-pay {\n width: 200px;\n }\n }\n }\n\n @media (max-width: ", ") {\n flex-direction: column;\n align-items: center;\n\n .actions {\n display: flex;\n justify-content: space-between;\n width: 100%;\n margin-top: 20px;\n\n & > button {\n width: 48%;\n }\n }\n }\n }\n"])), props => props.theme.palette.primary.main, props => props.enableBlockletAgreement ? 'space-between' : 'flex-end', props => props.theme.palette.primary.main, props => props.mobileSize, props => props.mobileSize);
498
- var _default = exports.default = CheckoutPage;