@uxda/appkit 1.2.73 → 4.0.0

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 (83) hide show
  1. package/.eslintrc.mjs +7 -7
  2. package/README.md +187 -187
  3. package/babel.config.js +12 -12
  4. package/dist/appkit.css +7 -27
  5. package/dist/index.js +58 -84
  6. package/package.json +78 -78
  7. package/project.config.json +15 -15
  8. package/project.tt.json +13 -13
  9. package/rollup.config.mjs +54 -54
  10. package/src/Appkit.ts +65 -65
  11. package/src/balance/api/endpoints.ts +126 -126
  12. package/src/balance/api/index.ts +82 -82
  13. package/src/balance/components/AccountView.vue +748 -748
  14. package/src/balance/components/BalanceCard.vue +209 -209
  15. package/src/balance/components/BalanceReminder.vue +85 -85
  16. package/src/balance/components/ConsumptionFilter.vue +218 -218
  17. package/src/balance/components/ConsumptionRules.vue +68 -68
  18. package/src/balance/components/DateFilter.vue +235 -235
  19. package/src/balance/components/SecondBalance.vue +71 -71
  20. package/src/balance/components/Tip.vue +45 -45
  21. package/src/balance/components/index.ts +9 -9
  22. package/src/balance/types.ts +90 -90
  23. package/src/components/dd-area/index.vue +225 -225
  24. package/src/components/dd-icon/doc.md +21 -21
  25. package/src/components/dd-icon/index.vue +23 -23
  26. package/src/components/dd-notice-bar/index.vue +78 -78
  27. package/src/components/dd-search/doc.md +34 -34
  28. package/src/components/dd-search/index.vue +168 -168
  29. package/src/components/dd-selector/index.vue +124 -124
  30. package/src/components/ocr-id/index.vue +114 -114
  31. package/src/components/ocr-id/types.d.ts +12 -12
  32. package/src/global.ts +6 -6
  33. package/src/index.ts +88 -88
  34. package/src/main.scss +1 -1
  35. package/src/notice/api/endpoints.ts +17 -17
  36. package/src/notice/api/index.ts +82 -82
  37. package/src/notice/components/LoginSetting.vue +112 -112
  38. package/src/notice/components/NoticeBanner.vue +243 -243
  39. package/src/notice/components/NoticeEntry.vue +99 -99
  40. package/src/notice/components/NoticeList.vue +278 -313
  41. package/src/notice/components/NoticePopup.vue +163 -161
  42. package/src/notice/components/index.ts +6 -6
  43. package/src/notice/components/useCommonList.ts +86 -86
  44. package/src/notice/components/useNotice.ts +35 -35
  45. package/src/notice/index.ts +1 -1
  46. package/src/notice/types.ts +25 -25
  47. package/src/payment/api/config.ts +7 -7
  48. package/src/payment/api/endpoints.ts +103 -103
  49. package/src/payment/api/index.ts +71 -71
  50. package/src/payment/components/AmountPicker.vue +93 -93
  51. package/src/payment/components/RechargeResult.vue +69 -69
  52. package/src/payment/components/RechargeView.vue +154 -154
  53. package/src/payment/components/RightsPicker.vue +105 -105
  54. package/src/payment/components/TradeView.vue +298 -298
  55. package/src/payment/components/UserAgreement.vue +141 -141
  56. package/src/payment/components/index.ts +22 -22
  57. package/src/payment/index.ts +5 -5
  58. package/src/payment/services/index.ts +16 -16
  59. package/src/payment/services/invoke-recharge.ts +25 -25
  60. package/src/payment/services/request-payment.ts +58 -58
  61. package/src/payment/types.ts +28 -28
  62. package/src/register/components/SelfRegistration.vue +227 -227
  63. package/src/register/components/index.ts +2 -2
  64. package/src/shared/components/AppDrawer.vue +58 -58
  65. package/src/shared/components/DeviceVersion.vue +67 -67
  66. package/src/shared/components/EmptyView.vue +33 -33
  67. package/src/shared/components/PageHeader.vue +79 -79
  68. package/src/shared/components/index.ts +5 -5
  69. package/src/shared/composables/index.ts +2 -2
  70. package/src/shared/composables/useSafeArea.ts +46 -46
  71. package/src/shared/composables/useTabbar.ts +24 -24
  72. package/src/shared/http/Http.ts +135 -135
  73. package/src/shared/http/index.ts +1 -1
  74. package/src/shared/http/types.ts +157 -157
  75. package/src/shared/index.ts +3 -3
  76. package/src/shared/weixin/payment.ts +38 -38
  77. package/src/styles/fonts.scss +2 -2
  78. package/src/styles/vars.scss +3 -3
  79. package/tsconfig.json +30 -30
  80. package/types/global.d.ts +21 -21
  81. package/types/vue.d.ts +10 -10
  82. package/dist/main.css +0 -3
  83. package/dist/styles.css +0 -1
@@ -1,135 +1,135 @@
1
- import {
2
- HttpInstance,
3
- HttpClientConfig,
4
- HttpMethod,
5
- HttpRequestConfig,
6
- RequestData,
7
- ResponseData,
8
- ResponseRaw,
9
- Paging,
10
- HttpTranslate,
11
- } from './types'
12
- /**
13
- * Useage:
14
- * const $http = createHttp({
15
- *
16
- * })
17
- * $http.get('/url').then(data => {
18
- *
19
- * })
20
- */
21
-
22
- /**
23
- * 统一请求过程
24
- * @param config
25
- * @returns
26
- */
27
- const request: HttpInstance['request'] = <T>(config: HttpRequestConfig) => {
28
- const c = {
29
- ...clientConfig,
30
- ...config,
31
- }
32
- return new Promise<T>((resolve, reject) => {
33
- const data =
34
- config.data && clientConfig.translates && clientConfig.translates[c.url]
35
- ? (clientConfig.translates[c.url] as HttpTranslate)(c.data || {})
36
- : c.data
37
- console.log(`[][][][][]HTTP.${c.method}, ${c.baseUrl}${c.url}`, data)
38
-
39
- clientConfig.vendor &&
40
- clientConfig.vendor
41
- .request({
42
- url: `${c.baseUrl}${c.url}`,
43
- data,
44
- headers: c.headers,
45
- method: c.method,
46
- })
47
- .then((raw: ResponseRaw) => {
48
- // 按顺序执行拦截器
49
- for (const interc of c.interceptors || []) {
50
- const r = interc(raw)
51
- if (r) {
52
- // 某拦截器命中时
53
- // 按拦截结果 决定是否继续执行
54
- reject('===INTERCEPTED===' + raw.status)
55
- return false
56
- }
57
- }
58
- if (raw.data !== void 0) {
59
- // 当用户配置含有 transforms 时, 使用用户提供的 transform
60
- // 先 endpoints transform
61
- // 再组装分页数据
62
- const response =
63
- clientConfig.transforms && clientConfig.transforms[c.url]
64
- ? ((clientConfig.transforms[c.url] as HttpTranslate)(raw.data) as T)
65
- : (raw.data as T)
66
- // 前端要求分页
67
- // 在 endpoints transform 之前格式化分页数据
68
- // 并拼装回原 raw 数据
69
- const paging = (config.data as RequestData).page
70
- ? (clientConfig.paging as Paging).transform(raw.data)
71
- : void 0
72
- resolve(
73
- paging
74
- ? ({
75
- ...paging,
76
- data: response,
77
- } as T)
78
- : response
79
- )
80
- } else {
81
- resolve(raw as any)
82
- }
83
- })
84
- .catch((e: any) => {
85
- console.log('request.catch===', e)
86
- })
87
- })
88
- }
89
-
90
- const get: HttpInstance['get'] = <T = ResponseData>(url: string, data?: RequestData) => {
91
- return request<T>({
92
- url,
93
- data,
94
- method: HttpMethod.get,
95
- })
96
- }
97
-
98
- const post: HttpInstance['post'] = <T = ResponseData>(url: string, data: RequestData) => {
99
- return request<T>({
100
- url,
101
- data,
102
- method: HttpMethod.post,
103
- })
104
- }
105
-
106
- /**
107
- * 场景配置
108
- * 本地后台团队统一返回值外层
109
- */
110
- const defaultClientConfig: HttpClientConfig = {
111
- baseUrl: '/',
112
- interceptors: [(raw) => raw.status == 401],
113
- }
114
-
115
- let clientConfig = {
116
- ...defaultClientConfig,
117
- }
118
-
119
- /**
120
- * 写入配置并返回 HTTP instance
121
- * @param config
122
- * @returns
123
- */
124
- export function createHttp(config: HttpClientConfig): HttpInstance {
125
- clientConfig = {
126
- ...defaultClientConfig,
127
- ...config,
128
- }
129
-
130
- return {
131
- request,
132
- get,
133
- post,
134
- }
135
- }
1
+ import {
2
+ HttpInstance,
3
+ HttpClientConfig,
4
+ HttpMethod,
5
+ HttpRequestConfig,
6
+ RequestData,
7
+ ResponseData,
8
+ ResponseRaw,
9
+ Paging,
10
+ HttpTranslate,
11
+ } from './types'
12
+ /**
13
+ * Useage:
14
+ * const $http = createHttp({
15
+ *
16
+ * })
17
+ * $http.get('/url').then(data => {
18
+ *
19
+ * })
20
+ */
21
+
22
+ /**
23
+ * 统一请求过程
24
+ * @param config
25
+ * @returns
26
+ */
27
+ const request: HttpInstance['request'] = <T>(config: HttpRequestConfig) => {
28
+ const c = {
29
+ ...clientConfig,
30
+ ...config,
31
+ }
32
+ return new Promise<T>((resolve, reject) => {
33
+ const data =
34
+ config.data && clientConfig.translates && clientConfig.translates[c.url]
35
+ ? (clientConfig.translates[c.url] as HttpTranslate)(c.data || {})
36
+ : c.data
37
+ console.log(`[][][][][]HTTP.${c.method}, ${c.baseUrl}${c.url}`, data)
38
+
39
+ clientConfig.vendor &&
40
+ clientConfig.vendor
41
+ .request({
42
+ url: `${c.baseUrl}${c.url}`,
43
+ data,
44
+ headers: c.headers,
45
+ method: c.method,
46
+ })
47
+ .then((raw: ResponseRaw) => {
48
+ // 按顺序执行拦截器
49
+ for (const interc of c.interceptors || []) {
50
+ const r = interc(raw)
51
+ if (r) {
52
+ // 某拦截器命中时
53
+ // 按拦截结果 决定是否继续执行
54
+ reject('===INTERCEPTED===' + raw.status)
55
+ return false
56
+ }
57
+ }
58
+ if (raw.data) {
59
+ // 当用户配置含有 transforms 时, 使用用户提供的 transform
60
+ // 先 endpoints transform
61
+ // 再组装分页数据
62
+ const response =
63
+ clientConfig.transforms && clientConfig.transforms[c.url]
64
+ ? ((clientConfig.transforms[c.url] as HttpTranslate)(raw.data) as T)
65
+ : (raw.data as T)
66
+ // 前端要求分页
67
+ // 在 endpoints transform 之前格式化分页数据
68
+ // 并拼装回原 raw 数据
69
+ const paging = (config.data as RequestData).page
70
+ ? (clientConfig.paging as Paging).transform(raw.data)
71
+ : void 0
72
+ resolve(
73
+ paging
74
+ ? ({
75
+ ...paging,
76
+ data: response,
77
+ } as T)
78
+ : response
79
+ )
80
+ } else {
81
+ resolve(raw as any)
82
+ }
83
+ })
84
+ .catch((e: any) => {
85
+ console.log('request.catch===', e)
86
+ })
87
+ })
88
+ }
89
+
90
+ const get: HttpInstance['get'] = <T = ResponseData>(url: string, data?: RequestData) => {
91
+ return request<T>({
92
+ url,
93
+ data,
94
+ method: HttpMethod.get,
95
+ })
96
+ }
97
+
98
+ const post: HttpInstance['post'] = <T = ResponseData>(url: string, data: RequestData) => {
99
+ return request<T>({
100
+ url,
101
+ data,
102
+ method: HttpMethod.post,
103
+ })
104
+ }
105
+
106
+ /**
107
+ * 场景配置
108
+ * 本地后台团队统一返回值外层
109
+ */
110
+ const defaultClientConfig: HttpClientConfig = {
111
+ baseUrl: '/',
112
+ interceptors: [(raw) => raw.status == 401],
113
+ }
114
+
115
+ let clientConfig = {
116
+ ...defaultClientConfig,
117
+ }
118
+
119
+ /**
120
+ * 写入配置并返回 HTTP instance
121
+ * @param config
122
+ * @returns
123
+ */
124
+ export function createHttp(config: HttpClientConfig): HttpInstance {
125
+ clientConfig = {
126
+ ...defaultClientConfig,
127
+ ...config,
128
+ }
129
+
130
+ return {
131
+ request,
132
+ get,
133
+ post,
134
+ }
135
+ }
@@ -1,2 +1,2 @@
1
- export * from './Http'
1
+ export * from './Http'
2
2
  export type * from './types'
@@ -1,158 +1,158 @@
1
- /**
2
- * 由使用场景提供的配置
3
- * createHttp() 使用的配置
4
- */
5
- export type HttpClientConfig = {
6
- vendor?: HttpVendor,
7
- baseUrl: string,
8
- /**
9
- * 向 HTTP header 加入的数据
10
- * 通常含有 JWT token 以及其他参数
11
- */
12
- headers?: HeaderParams,
13
- paging?: Paging,
14
- /**
15
- * 拦截器组
16
- * 请求返回异常时进行一定的操作
17
- */
18
- interceptors?: HttpInterceptor[],
19
- translates?: HttpTranslates,
20
- transforms?: HttpTransforms,
21
- }
22
-
23
- /**
24
- * HTTP 请求的底层实现
25
- * Axios/Taro.request
26
- */
27
- export type HttpVendor = {
28
- request <T = ResponseData>(config: HttpRequestConfig): Promise<ResponseRaw<T>>
29
- }
30
-
31
- export type HttpInterceptor = (raw: ResponseRaw) => boolean
32
-
33
- /**
34
- * Request Config for request API
35
- * 沿用 Axios 的部分配置
36
- */
37
- export type HttpRequestConfig<D = RequestData> = {
38
- url: string,
39
- method?: HttpMethod,
40
- baseUrl?: string,
41
- headers?: HeaderData,
42
- data?: D,
43
- }
44
-
45
- /**
46
- * Request data for http get & post method
47
- */
48
- export type RequestData = Record<string, any>
49
-
50
- /**
51
- * 接口请求返回的标准格式
52
- */
53
- export type ResponseRaw<T = ResponseData> = {
54
- status: number,
55
- message: string,
56
- data: T
57
- }
58
-
59
- /**
60
- * 拆箱之后前端拿到的数据
61
- */
62
- export type ResponseData = Record<string, any> | any[]
63
-
64
- export type HttpInstance = {
65
- request<T = ResponseData>(config: HttpRequestConfig): Promise<T>
66
- get<T = ResponseData>(url: string, data?: RequestData): Promise<T>,
67
- post<T = ResponseData>(url: string, data?: RequestData): Promise<T>,
68
- }
69
-
70
- /**
71
- *
72
- */
73
- export type HttpTranslates = Record<string, HttpTranslate | undefined>
74
- export type HttpTransforms = Record<string, HttpTransform | undefined>
75
-
76
- /**
77
- * 向 request header 加入参数
78
- * 多数是 token
79
- */
80
- export type HeaderParams = Record<string, string>
81
-
82
- export enum HttpMethod {
83
- get = 'GET',
84
- post = 'POST',
85
- put = 'PUT',
86
- delete = 'DELETE',
87
- }
88
-
89
- export enum HttpError {
90
- auth = 'auth',
91
- server = 'server'
92
- }
93
-
94
- export type HeaderData = Record<string, string>
95
-
96
- /**
97
- * 接口参数转换器
98
- */
99
- export type HttpTranslate = (data: RequestData) => RequestData
100
-
101
- /**
102
- * 接口数据转换器
103
- */
104
- export type HttpTransform = (data: ResponseData) => ResponseData
105
-
106
- /**
107
- * 接口设置
108
- */
109
- export type HttpEndpoint = {
110
- path: string,
111
- translate?: HttpTranslate,
112
- transform?: HttpTransform,
113
- }
114
-
115
- /**
116
- * 接口组
117
- */
118
- export type HttpEndpoints = {
119
- [name: string]: HttpEndpoint
120
- }
121
-
122
- /**
123
- * 分页参数
124
- */
125
- export type PagingParams = {
126
- /**
127
- * 页数
128
- */
129
- page: number,
130
- /**
131
- * 页数据条数
132
- */
133
- pageSize: number,
134
- }
135
-
136
- export type PagingData = {
137
- /**
138
- * 页总数
139
- */
140
- totalPages: number,
141
- }
142
-
143
- /**
144
- * Wrapped with Paging Data
145
- */
146
- export type WithPaging<T = ResponseData> = {
147
- [K in keyof PagingData]: PagingData[K];
148
- } & {
149
- data: T;
150
- }
151
-
152
- /**
153
- * 分页设置
154
- */
155
- export type Paging = {
156
- translate (params: PagingParams): any,
157
- transform (resonse: any): PagingData,
1
+ /**
2
+ * 由使用场景提供的配置
3
+ * createHttp() 使用的配置
4
+ */
5
+ export type HttpClientConfig = {
6
+ vendor?: HttpVendor,
7
+ baseUrl: string,
8
+ /**
9
+ * 向 HTTP header 加入的数据
10
+ * 通常含有 JWT token 以及其他参数
11
+ */
12
+ headers?: HeaderParams,
13
+ paging?: Paging,
14
+ /**
15
+ * 拦截器组
16
+ * 请求返回异常时进行一定的操作
17
+ */
18
+ interceptors?: HttpInterceptor[],
19
+ translates?: HttpTranslates,
20
+ transforms?: HttpTransforms,
21
+ }
22
+
23
+ /**
24
+ * HTTP 请求的底层实现
25
+ * Axios/Taro.request
26
+ */
27
+ export type HttpVendor = {
28
+ request <T = ResponseData>(config: HttpRequestConfig): Promise<ResponseRaw<T>>
29
+ }
30
+
31
+ export type HttpInterceptor = (raw: ResponseRaw) => boolean
32
+
33
+ /**
34
+ * Request Config for request API
35
+ * 沿用 Axios 的部分配置
36
+ */
37
+ export type HttpRequestConfig<D = RequestData> = {
38
+ url: string,
39
+ method?: HttpMethod,
40
+ baseUrl?: string,
41
+ headers?: HeaderData,
42
+ data?: D,
43
+ }
44
+
45
+ /**
46
+ * Request data for http get & post method
47
+ */
48
+ export type RequestData = Record<string, any>
49
+
50
+ /**
51
+ * 接口请求返回的标准格式
52
+ */
53
+ export type ResponseRaw<T = ResponseData> = {
54
+ status: number,
55
+ message: string,
56
+ data: T
57
+ }
58
+
59
+ /**
60
+ * 拆箱之后前端拿到的数据
61
+ */
62
+ export type ResponseData = Record<string, any> | any[]
63
+
64
+ export type HttpInstance = {
65
+ request<T = ResponseData>(config: HttpRequestConfig): Promise<T>
66
+ get<T = ResponseData>(url: string, data?: RequestData): Promise<T>,
67
+ post<T = ResponseData>(url: string, data?: RequestData): Promise<T>,
68
+ }
69
+
70
+ /**
71
+ *
72
+ */
73
+ export type HttpTranslates = Record<string, HttpTranslate | undefined>
74
+ export type HttpTransforms = Record<string, HttpTransform | undefined>
75
+
76
+ /**
77
+ * 向 request header 加入参数
78
+ * 多数是 token
79
+ */
80
+ export type HeaderParams = Record<string, string>
81
+
82
+ export enum HttpMethod {
83
+ get = 'GET',
84
+ post = 'POST',
85
+ put = 'PUT',
86
+ delete = 'DELETE',
87
+ }
88
+
89
+ export enum HttpError {
90
+ auth = 'auth',
91
+ server = 'server'
92
+ }
93
+
94
+ export type HeaderData = Record<string, string>
95
+
96
+ /**
97
+ * 接口参数转换器
98
+ */
99
+ export type HttpTranslate = (data: RequestData) => RequestData
100
+
101
+ /**
102
+ * 接口数据转换器
103
+ */
104
+ export type HttpTransform = (data: ResponseData) => ResponseData
105
+
106
+ /**
107
+ * 接口设置
108
+ */
109
+ export type HttpEndpoint = {
110
+ path: string,
111
+ translate?: HttpTranslate,
112
+ transform?: HttpTransform,
113
+ }
114
+
115
+ /**
116
+ * 接口组
117
+ */
118
+ export type HttpEndpoints = {
119
+ [name: string]: HttpEndpoint
120
+ }
121
+
122
+ /**
123
+ * 分页参数
124
+ */
125
+ export type PagingParams = {
126
+ /**
127
+ * 页数
128
+ */
129
+ page: number,
130
+ /**
131
+ * 页数据条数
132
+ */
133
+ pageSize: number,
134
+ }
135
+
136
+ export type PagingData = {
137
+ /**
138
+ * 页总数
139
+ */
140
+ totalPages: number,
141
+ }
142
+
143
+ /**
144
+ * Wrapped with Paging Data
145
+ */
146
+ export type WithPaging<T = ResponseData> = {
147
+ [K in keyof PagingData]: PagingData[K];
148
+ } & {
149
+ data: T;
150
+ }
151
+
152
+ /**
153
+ * 分页设置
154
+ */
155
+ export type Paging = {
156
+ translate (params: PagingParams): any,
157
+ transform (resonse: any): PagingData,
158
158
  }
@@ -1,4 +1,4 @@
1
- export * from './weixin'
2
- export * from './components'
3
- export * from './composables'
1
+ export * from './weixin'
2
+ export * from './components'
3
+ export * from './composables'
4
4
  export * from './http'
@@ -1,38 +1,38 @@
1
- export type PaymentOptions = {}
2
-
3
- /**
4
- * 发起微信支付
5
- * @param options
6
- */
7
- export function requestPayment(json: any): Promise<boolean> {
8
- /** 时间戳从1970年1月1日00:00:00至今的秒数,即当前的时间 */
9
- // const timeStamp: string = '',
10
- // /** 随机字符串,长度为32个字符以下 */
11
- // nonceStr: string = '',
12
- // /** 统一下单接口返回的prepay_id参数值,提交格式如:prepay_id=* */
13
- // pack: string = '',
14
- // /** 签名算法,暂支持MD5 */
15
- // signType: string = 'MD5',
16
- // /** 签名,具体签名方案参见微信公众号支付帮助文档(https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=4_3&t=1474537654457); */
17
- // paySign: string = ''
18
- // /** 接口调用成功的回调函数 */
19
- // const success = (res: {}) => {},
20
- // /**接口调用失败的回调函数*/
21
- // fail = () => {},
22
- // /**接口调用结束的回调函数(调用成功、失败都会执行)*/
23
- // complete = () => {}
24
- return new Promise<boolean>((resolve, reject) => {
25
- const success = (res) => {
26
- resolve(true)
27
- }
28
- const fail = (res) => {
29
- console.log('wx.requestPayment FAIL:', res)
30
- resolve(false)
31
- }
32
- wx.requestPayment({
33
- ...json,
34
- success,
35
- fail
36
- })
37
- })
38
- }
1
+ export type PaymentOptions = {}
2
+
3
+ /**
4
+ * 发起微信支付
5
+ * @param options
6
+ */
7
+ export function requestPayment(json: any): Promise<boolean> {
8
+ /** 时间戳从1970年1月1日00:00:00至今的秒数,即当前的时间 */
9
+ // const timeStamp: string = '',
10
+ // /** 随机字符串,长度为32个字符以下 */
11
+ // nonceStr: string = '',
12
+ // /** 统一下单接口返回的prepay_id参数值,提交格式如:prepay_id=* */
13
+ // pack: string = '',
14
+ // /** 签名算法,暂支持MD5 */
15
+ // signType: string = 'MD5',
16
+ // /** 签名,具体签名方案参见微信公众号支付帮助文档(https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=4_3&t=1474537654457); */
17
+ // paySign: string = ''
18
+ // /** 接口调用成功的回调函数 */
19
+ // const success = (res: {}) => {},
20
+ // /**接口调用失败的回调函数*/
21
+ // fail = () => {},
22
+ // /**接口调用结束的回调函数(调用成功、失败都会执行)*/
23
+ // complete = () => {}
24
+ return new Promise<boolean>((resolve, reject) => {
25
+ const success = (res) => {
26
+ resolve(true)
27
+ }
28
+ const fail = (res) => {
29
+ console.log('wx.requestPayment FAIL:', res)
30
+ resolve(false)
31
+ }
32
+ wx.requestPayment({
33
+ ...json,
34
+ success,
35
+ fail
36
+ })
37
+ })
38
+ }
@@ -1,3 +1,3 @@
1
- .number {
2
- font-family: 'DIN alternate', 'Barlow Condensed', 'Roboto Condensed', sans-serif-condensed-light;
1
+ .number {
2
+ font-family: 'DIN alternate', 'Barlow Condensed', 'Roboto Condensed', sans-serif-condensed-light;
3
3
  }