@uxda/appkit 4.3.8 → 4.3.12

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 (135) hide show
  1. package/.eslintrc.mjs +7 -7
  2. package/COMPONENT_USAGE.md +1523 -1523
  3. package/PROJECT_DOCS.md +142 -142
  4. package/README.md +187 -187
  5. package/babel.config.js +12 -12
  6. package/dist/appkit.css +63 -15
  7. package/dist/index.js +881 -259
  8. package/package.json +79 -79
  9. package/project.config.json +15 -15
  10. package/project.tt.json +13 -13
  11. package/rollup.config.mjs +78 -78
  12. package/src/Appkit.ts +72 -72
  13. package/src/balance/api/endpoints.ts +133 -133
  14. package/src/balance/api/index.ts +118 -118
  15. package/src/balance/components/AccountView.vue +770 -770
  16. package/src/balance/components/BalanceCard.vue +210 -210
  17. package/src/balance/components/BalanceReminder.vue +84 -84
  18. package/src/balance/components/ConsumptionFilter.vue +218 -218
  19. package/src/balance/components/ConsumptionRules.vue +68 -68
  20. package/src/balance/components/DateFilter.vue +259 -259
  21. package/src/balance/components/DateRange.vue +111 -111
  22. package/src/balance/components/ListFilter.vue +62 -62
  23. package/src/balance/components/ListFilterPicker.vue +191 -191
  24. package/src/balance/components/PromoterCard.vue +308 -307
  25. package/src/balance/components/SecondBalance.vue +77 -77
  26. package/src/balance/components/Tip.vue +45 -45
  27. package/src/balance/components/index.ts +8 -8
  28. package/src/balance/types.ts +99 -99
  29. package/src/components/bt-cropper/index.vue +730 -730
  30. package/src/components/bt-cropper/utils/calcCropper.js +42 -42
  31. package/src/components/bt-cropper/utils/calcImagePosition.js +23 -23
  32. package/src/components/bt-cropper/utils/calcImageSize.js +37 -37
  33. package/src/components/bt-cropper/utils/calcPointDistance.js +12 -12
  34. package/src/components/bt-cropper/utils/calcRightAndBottom.js +7 -7
  35. package/src/components/bt-cropper/utils/ratio.js +3 -3
  36. package/src/components/bt-cropper/utils/tools.js +25 -25
  37. package/src/components/dd-area/index.vue +225 -225
  38. package/src/components/dd-icon/doc.md +21 -21
  39. package/src/components/dd-icon/index.vue +23 -23
  40. package/src/components/dd-notice-bar/index.vue +78 -78
  41. package/src/components/dd-search/doc.md +34 -34
  42. package/src/components/dd-search/index.vue +168 -168
  43. package/src/components/dd-selector/index.vue +124 -124
  44. package/src/components/dd-skeleton/doc.md +19 -19
  45. package/src/components/dd-skeleton/index.vue +36 -36
  46. package/src/global.ts +6 -6
  47. package/src/index.ts +101 -101
  48. package/src/main.scss +1 -1
  49. package/src/notice/api/endpoints.ts +54 -54
  50. package/src/notice/api/index.ts +121 -121
  51. package/src/notice/components/NoticeBanner.vue +247 -247
  52. package/src/notice/components/NoticeEntry.vue +99 -99
  53. package/src/notice/components/NoticeList.vue +311 -311
  54. package/src/notice/components/NoticeList2.vue +401 -400
  55. package/src/notice/components/NoticePopup.vue +163 -163
  56. package/src/notice/components/index.ts +6 -6
  57. package/src/notice/components/useCommonList.ts +87 -86
  58. package/src/notice/components/useNotice.ts +35 -35
  59. package/src/notice/index.ts +1 -1
  60. package/src/notice/types.ts +25 -25
  61. package/src/payment/api/config.ts +7 -7
  62. package/src/payment/api/endpoints.ts +98 -96
  63. package/src/payment/api/index.ts +108 -107
  64. package/src/payment/components/AmountPicker.vue +90 -90
  65. package/src/payment/components/RechargeResult.vue +68 -69
  66. package/src/payment/components/RechargeView.vue +195 -191
  67. package/src/payment/components/RightsPicker.vue +105 -105
  68. package/src/payment/components/TradeView.vue +573 -363
  69. package/src/payment/components/UserAgreement.vue +234 -234
  70. package/src/payment/components/index.ts +22 -22
  71. package/src/payment/index.ts +5 -5
  72. package/src/payment/services/index.ts +16 -16
  73. package/src/payment/services/invoke-recharge.ts +25 -25
  74. package/src/payment/services/request-payment.ts +132 -130
  75. package/src/payment/types.ts +34 -33
  76. package/src/register/components/SelfRegistration.vue +233 -233
  77. package/src/register/components/index.ts +2 -2
  78. package/src/scenarios/components/SharePoster.vue +364 -364
  79. package/src/scenarios/components/index.ts +2 -2
  80. package/src/scenarios/components/poster-paste.vue +93 -93
  81. package/src/scenarios/components/share-poster.md +273 -273
  82. package/src/shared/components/AppDrawer.vue +53 -53
  83. package/src/shared/components/AppVerify.vue +137 -128
  84. package/src/shared/components/DeviceVersion.vue +78 -78
  85. package/src/shared/components/EmptyView.vue +33 -33
  86. package/src/shared/components/OcrBank.vue +202 -0
  87. package/src/shared/components/OcrBusinessLicense.vue +120 -137
  88. package/src/shared/components/OcrIcon.vue +267 -229
  89. package/src/shared/components/OcrInvoice.vue +322 -0
  90. package/src/shared/components/PageHeader.vue +84 -84
  91. package/src/shared/components/index.ts +10 -8
  92. package/src/shared/composables/index.ts +10 -9
  93. package/src/shared/composables/useAmount.ts +46 -46
  94. package/src/shared/composables/useCompress.ts +64 -0
  95. package/src/shared/composables/useCountdown.ts +46 -46
  96. package/src/shared/composables/useCrypto.ts +76 -76
  97. package/src/shared/composables/useDeviceEnv.ts +26 -26
  98. package/src/shared/composables/useDragBox.ts +97 -97
  99. package/src/shared/composables/useEncode.ts +43 -43
  100. package/src/shared/composables/useLogger.ts +144 -144
  101. package/src/shared/composables/useSafeArea.ts +46 -46
  102. package/src/shared/composables/useTabbar.ts +24 -24
  103. package/src/shared/composables/useUpload.ts +106 -61
  104. package/src/shared/composables/useValidator.ts +32 -32
  105. package/src/shared/composables/useWxAuth.ts +48 -48
  106. package/src/shared/http/Http.ts +149 -148
  107. package/src/shared/http/index.ts +1 -1
  108. package/src/shared/http/types.ts +163 -163
  109. package/src/shared/index.ts +9 -9
  110. package/src/shared/tracking/directives/index.ts +40 -40
  111. package/src/shared/tracking/examples/page-tracking-template.vue +27 -27
  112. package/src/shared/tracking/tracking-sdk.ts +0 -1
  113. package/src/shared/weixin/index.ts +9 -9
  114. package/src/shared/weixin/jssdk.ts +104 -103
  115. package/src/shared/weixin/payment.ts +38 -38
  116. package/src/styles/vars.scss +3 -3
  117. package/src/user/api/endpoints.ts +17 -17
  118. package/src/user/api/index.ts +123 -123
  119. package/src/user/components/LoginSetting.vue +114 -114
  120. package/src/user/components/UserAuth.vue +218 -218
  121. package/src/user/components/UserBinding.vue +277 -277
  122. package/src/user/components/UserBindingSuccess.vue +80 -80
  123. package/src/user/components/UserEntry.vue +139 -139
  124. package/src/user/components/UserFeedback.vue +428 -427
  125. package/src/user/components/UserFeedbackEntry.vue +175 -175
  126. package/src/user/components/UserHeadCrop.vue +65 -65
  127. package/src/user/components/UserInfo.vue +711 -709
  128. package/src/user/components/UserResourceEmpty.vue +75 -75
  129. package/src/user/components/index.ts +23 -23
  130. package/src/user/index.ts +1 -1
  131. package/src/utils/utils.ts +33 -33
  132. package/tsconfig.json +30 -30
  133. package/types/global.d.ts +24 -22
  134. package/types/vue.d.ts +10 -10
  135. package/dist/assets/asset-DcH8Kg-2 +0 -1
@@ -1,144 +1,144 @@
1
- /**
2
- * 记录阿里日志
3
- * 生产: https://sls.console.aliyun.com/lognext/project/ddyk-prod/logsearch/ddjf-internet-web
4
- */
5
- import qs from 'qs'
6
- import { useAppKitOptions } from '../../Appkit'
7
- import Taro, { getSystemInfoSync, request } from '@tarojs/taro'
8
-
9
- interface LogType {
10
- projectName?: string
11
- logStore?: string
12
- topic?: string
13
- APIVersion?: string
14
- baseUrl?: string
15
- alislsURL?: string
16
- systemInfo?: string
17
- enable?: boolean
18
- }
19
-
20
- const defaultLogOptions: LogType = {
21
- projectName: 'ddyk-dev',
22
- logStore: 'ddjf-internet-web',
23
- topic: 'appkit',
24
- enable: true,
25
- }
26
-
27
- // 使用时间戳生成唯一标识
28
- export function generateUniqueId(pre?: string) {
29
- return `${pre ? pre + '-' : ''}${Date.now().toString(16)}-${Math.random().toString(36).substr(2)}`
30
- }
31
-
32
- export function useLogger(options?: LogType) {
33
- const appkitOptions = useAppKitOptions()
34
- const url = appkitOptions.baseUrl()
35
-
36
- if (Taro.getEnv() === 'WEB') {
37
- if (location.origin.includes('ytech.ddjf.com')) {
38
- defaultLogOptions.projectName = 'ddyk-prod'
39
- }
40
- } else {
41
- if (url.includes('ytech.ddjf.com')) {
42
- defaultLogOptions.projectName = 'ddyk-prod'
43
- }
44
- }
45
-
46
- if (options) {
47
- options = Object.assign(defaultLogOptions, options)
48
- } else {
49
- options = defaultLogOptions
50
- }
51
-
52
- const projectName = options.projectName
53
- const logStore = options.logStore
54
- const topic = options.topic || ''
55
- const APIVersion = '0.6.0'
56
- const baseUrl = `https://${projectName}.cn-shenzhen.log.aliyuncs.com/logstores/${logStore}/track?APIVersion=${APIVersion}`
57
- const alislsURL = topic ? `${baseUrl}&__topic__=${topic}` : baseUrl
58
- const enable = options.enable === undefined ? true : options.enable
59
-
60
- const { miniProgram } =
61
- Taro.getEnv() === 'WEAPP' ? Taro.getAccountInfoSync() : { miniProgram: { version: '' } }
62
- const systemInfo =
63
- JSON.stringify({
64
- ...getSystemInfoSync(),
65
- appVersion: miniProgram?.version,
66
- }) || '未知'
67
-
68
- function send(params: Record<string, any>) {
69
- if (!enable) return
70
-
71
- params.systemInfo = systemInfo
72
- const token = appkitOptions.tempToken() || appkitOptions.token()
73
- if (token) {
74
- params.userInfo = token
75
- }
76
- if (params.msg && !params.send) {
77
- params.send = params.msg
78
- }
79
- if (params.send) {
80
- params.send = params.send.slice(0, 1024)
81
- }
82
- if (params.receive) {
83
- params.receive = params.receive.slice(0, 1024)
84
- }
85
- if (params.duration) {
86
- params.duration = params.duration
87
- }
88
-
89
- // 记录页面栈信息
90
- const pages = Taro.getCurrentPages()
91
- const currentPage = pages?.[pages.length - 1]
92
- const lastPage = pages?.[pages.length - 2]
93
- const taroParams = currentPage.$taroParams
94
- if (taroParams) {
95
- delete taroParams.stamp
96
- delete taroParams.$taroTimestamp
97
- }
98
- const laseTaroParams = lastPage?.$taroParams
99
- if (laseTaroParams) {
100
- delete laseTaroParams.stamp
101
- delete laseTaroParams.$taroTimestamp
102
- }
103
- params.pages = JSON.stringify({
104
- current: `${currentPage?.route}?${qs.stringify(taroParams)}`,
105
- last: lastPage
106
- ? `${lastPage?.route}?${qs.stringify(laseTaroParams)}`
107
- : '',
108
- }).slice(0, 1024)
109
-
110
- console.log(params)
111
-
112
- const tmpStr = Object.keys(params)
113
- .map((key) => `${key}=${encodeURIComponent(params[key])}`)
114
- .join('&')
115
- const url = `${alislsURL}&${tmpStr}`
116
- request({ url })
117
- }
118
-
119
- function info(params: any) {
120
- if (!enable) return
121
- send({
122
- send: params.send ?? '',
123
- receive: params.receive ?? '',
124
- duration: params.duration ?? '',
125
- traceId: params.traceId as string,
126
- level: 'info',
127
- })
128
- }
129
-
130
- function error(params: any) {
131
- if (!enable) return
132
- send({
133
- send: params.send ?? '',
134
- receive: params.receive ?? '',
135
- traceId: params.traceId as string,
136
- level: 'error',
137
- })
138
- }
139
-
140
- return {
141
- info,
142
- error,
143
- }
144
- }
1
+ /**
2
+ * 记录阿里日志
3
+ * 生产: https://sls.console.aliyun.com/lognext/project/ddyk-prod/logsearch/ddjf-internet-web
4
+ */
5
+ import qs from 'qs'
6
+ import { useAppKitOptions } from '../../Appkit'
7
+ import Taro, { getSystemInfoSync, request } from '@tarojs/taro'
8
+
9
+ interface LogType {
10
+ projectName?: string
11
+ logStore?: string
12
+ topic?: string
13
+ APIVersion?: string
14
+ baseUrl?: string
15
+ alislsURL?: string
16
+ systemInfo?: string
17
+ enable?: boolean
18
+ }
19
+
20
+ const defaultLogOptions: LogType = {
21
+ projectName: 'ddyk-dev',
22
+ logStore: 'ddjf-internet-web',
23
+ topic: 'appkit',
24
+ enable: true,
25
+ }
26
+
27
+ // 使用时间戳生成唯一标识
28
+ export function generateUniqueId(pre?: string) {
29
+ return `${pre ? pre + '-' : ''}${Date.now().toString(16)}-${Math.random().toString(36).substr(2)}`
30
+ }
31
+
32
+ export function useLogger(options?: LogType) {
33
+ const appkitOptions = useAppKitOptions()
34
+ const url = appkitOptions.baseUrl()
35
+
36
+ if (Taro.getEnv() === 'WEB') {
37
+ if (location.origin.includes('ytech.ddjf.com')) {
38
+ defaultLogOptions.projectName = 'ddyk-prod'
39
+ }
40
+ } else {
41
+ if (url.includes('ytech.ddjf.com')) {
42
+ defaultLogOptions.projectName = 'ddyk-prod'
43
+ }
44
+ }
45
+
46
+ if (options) {
47
+ options = Object.assign(defaultLogOptions, options)
48
+ } else {
49
+ options = defaultLogOptions
50
+ }
51
+
52
+ const projectName = options.projectName
53
+ const logStore = options.logStore
54
+ const topic = options.topic || ''
55
+ const APIVersion = '0.6.0'
56
+ const baseUrl = `https://${projectName}.cn-shenzhen.log.aliyuncs.com/logstores/${logStore}/track?APIVersion=${APIVersion}`
57
+ const alislsURL = topic ? `${baseUrl}&__topic__=${topic}` : baseUrl
58
+ const enable = options.enable === undefined ? true : options.enable
59
+
60
+ const { miniProgram } =
61
+ Taro.getEnv() === 'WEAPP' ? Taro.getAccountInfoSync() : { miniProgram: { version: '' } }
62
+ const systemInfo =
63
+ JSON.stringify({
64
+ ...getSystemInfoSync(),
65
+ appVersion: miniProgram?.version,
66
+ }) || '未知'
67
+
68
+ function send(params: Record<string, any>) {
69
+ if (!enable) return
70
+
71
+ params.systemInfo = systemInfo
72
+ const token = appkitOptions.tempToken() || appkitOptions.token()
73
+ if (token) {
74
+ params.userInfo = token
75
+ }
76
+ if (params.msg && !params.send) {
77
+ params.send = params.msg
78
+ }
79
+ if (params.send) {
80
+ params.send = params.send.slice(0, 1024)
81
+ }
82
+ if (params.receive) {
83
+ params.receive = params.receive.slice(0, 1024)
84
+ }
85
+ if (params.duration) {
86
+ params.duration = params.duration
87
+ }
88
+
89
+ // 记录页面栈信息
90
+ const pages = Taro.getCurrentPages()
91
+ const currentPage = pages?.[pages.length - 1]
92
+ const lastPage = pages?.[pages.length - 2]
93
+ const taroParams = currentPage.$taroParams
94
+ if (taroParams) {
95
+ delete taroParams.stamp
96
+ delete taroParams.$taroTimestamp
97
+ }
98
+ const laseTaroParams = lastPage?.$taroParams
99
+ if (laseTaroParams) {
100
+ delete laseTaroParams.stamp
101
+ delete laseTaroParams.$taroTimestamp
102
+ }
103
+ params.pages = JSON.stringify({
104
+ current: `${currentPage?.route}?${qs.stringify(taroParams)}`,
105
+ last: lastPage
106
+ ? `${lastPage?.route}?${qs.stringify(laseTaroParams)}`
107
+ : '',
108
+ }).slice(0, 1024)
109
+
110
+ console.log(params)
111
+
112
+ const tmpStr = Object.keys(params)
113
+ .map((key) => `${key}=${encodeURIComponent(params[key])}`)
114
+ .join('&')
115
+ const url = `${alislsURL}&${tmpStr}`
116
+ request({ url })
117
+ }
118
+
119
+ function info(params: any) {
120
+ if (!enable) return
121
+ send({
122
+ send: params.send ?? '',
123
+ receive: params.receive ?? '',
124
+ duration: params.duration ?? '',
125
+ traceId: params.traceId as string,
126
+ level: 'info',
127
+ })
128
+ }
129
+
130
+ function error(params: any) {
131
+ if (!enable) return
132
+ send({
133
+ send: params.send ?? '',
134
+ receive: params.receive ?? '',
135
+ traceId: params.traceId as string,
136
+ level: 'error',
137
+ })
138
+ }
139
+
140
+ return {
141
+ info,
142
+ error,
143
+ }
144
+ }
@@ -1,46 +1,46 @@
1
- import Taro, { getSystemInfoSync, getMenuButtonBoundingClientRect } from '@tarojs/taro'
2
- /**
3
- * 屏幕安全区域
4
- */
5
- export type SafeArea = {
6
- /**
7
- * 状态条高度
8
- */
9
- status: number
10
- /**
11
- * 导航条区域(胶囊)
12
- */
13
- nav: number
14
- /**
15
- * 屏幕底部范围
16
- */
17
- bottom: number
18
- menuRect: any
19
- }
20
-
21
- /**
22
- * 获取屏幕安全区域
23
- * 从系统 API 获取
24
- * @returns
25
- */
26
- export function useSafeArea(): SafeArea {
27
- const systemInfo = getSystemInfoSync(),
28
- capsule = Taro.getEnv() === 'WEAPP' ? getMenuButtonBoundingClientRect() : { top: 0, height: 0 }
29
- /**
30
- * 状态条高度
31
- */
32
- const status = systemInfo.statusBarHeight || 0,
33
- /**
34
- * 据说是胶囊上下间距
35
- */
36
- gap = capsule.top - status,
37
- nav = capsule.height + gap * 2,
38
- safeAreaBottom = (systemInfo.safeArea || {}).bottom || 0,
39
- bottom = systemInfo.screenHeight - safeAreaBottom
40
- return {
41
- status,
42
- nav,
43
- bottom,
44
- menuRect: capsule,
45
- }
46
- }
1
+ import Taro, { getSystemInfoSync, getMenuButtonBoundingClientRect } from '@tarojs/taro'
2
+ /**
3
+ * 屏幕安全区域
4
+ */
5
+ export type SafeArea = {
6
+ /**
7
+ * 状态条高度
8
+ */
9
+ status: number
10
+ /**
11
+ * 导航条区域(胶囊)
12
+ */
13
+ nav: number
14
+ /**
15
+ * 屏幕底部范围
16
+ */
17
+ bottom: number
18
+ menuRect: any
19
+ }
20
+
21
+ /**
22
+ * 获取屏幕安全区域
23
+ * 从系统 API 获取
24
+ * @returns
25
+ */
26
+ export function useSafeArea(): SafeArea {
27
+ const systemInfo = getSystemInfoSync(),
28
+ capsule = Taro.getEnv() === 'WEAPP' ? getMenuButtonBoundingClientRect() : { top: 0, height: 0 }
29
+ /**
30
+ * 状态条高度
31
+ */
32
+ const status = systemInfo.statusBarHeight || 0,
33
+ /**
34
+ * 据说是胶囊上下间距
35
+ */
36
+ gap = capsule.top - status,
37
+ nav = capsule.height + gap * 2,
38
+ safeAreaBottom = (systemInfo.safeArea || {}).bottom || 0,
39
+ bottom = systemInfo.screenHeight - safeAreaBottom
40
+ return {
41
+ status,
42
+ nav,
43
+ bottom,
44
+ menuRect: capsule,
45
+ }
46
+ }
@@ -1,24 +1,24 @@
1
- import { ref } from 'vue'
2
-
3
- const tab = ref<string>(''),
4
- changeCallback = ref<(value: string) => void>(
5
- (value: string) => {
6
- console.log('ORIGINAL changeCallback===', value)
7
- }
8
- )
9
-
10
- const setTab = (value: string) => {
11
- tab.value = value
12
- changeCallback.value(value)
13
- }
14
-
15
- const onTabChange = (callback: (value: string) => void) => {
16
- changeCallback.value = callback
17
- }
18
-
19
- export function useTabbar () {
20
- return {
21
- onTabChange,
22
- setTab
23
- }
24
- }
1
+ import { ref } from 'vue'
2
+
3
+ const tab = ref<string>(''),
4
+ changeCallback = ref<(value: string) => void>(
5
+ (value: string) => {
6
+ console.log('ORIGINAL changeCallback===', value)
7
+ }
8
+ )
9
+
10
+ const setTab = (value: string) => {
11
+ tab.value = value
12
+ changeCallback.value(value)
13
+ }
14
+
15
+ const onTabChange = (callback: (value: string) => void) => {
16
+ changeCallback.value = callback
17
+ }
18
+
19
+ export function useTabbar () {
20
+ return {
21
+ onTabChange,
22
+ setTab
23
+ }
24
+ }
@@ -1,61 +1,106 @@
1
- import Taro, { uploadFile } from '@tarojs/taro'
2
- import { Media } from '@uxda/nutshell/taro'
3
- import { useAppKitOptions } from '../../Appkit'
4
-
5
- export type UploadConfig = {
6
- baseUrl: string
7
- name?: string
8
- headers?: Record<string, string>
9
- }
10
-
11
- const mappings: { [x: string]: keyof Media } = {
12
- downloadUrl: 'thrumb',
13
- fileId: 'id',
14
- fileName: 'name',
15
- fileSize: 'size',
16
- fileSuffix: 'ext',
17
- fileType: 'type',
18
- originalUrl: 'url',
19
- }
20
-
21
- const transformFields = (row: any) => {
22
- return Object.fromEntries(Object.entries(row).map(([k, v]) => [mappings[k] || k, v]))
23
- }
24
-
25
- type UploadFunction = (url: string, file: Media) => Promise<Media>
26
-
27
- export const useUpload = (config: UploadConfig) => {
28
- const appkitOptions = useAppKitOptions()
29
-
30
- const upload: UploadFunction = (url: string, file: Media) => {
31
- return new Promise<Media>((resolve, reject) => {
32
- uploadFile({
33
- url: config.baseUrl + url,
34
- filePath: file.path!,
35
- name: 'file',
36
- formData: {
37
- objectNo: `min${Date.now()}`,
38
- },
39
- header: {
40
- ...config.headers,
41
- token: appkitOptions.tempToken() || appkitOptions.token(),
42
- },
43
- success: (rsp: any) => {
44
- const { data } = rsp
45
- try {
46
- const response = JSON.parse(data)
47
- console.log('===response', response)
48
- resolve(transformFields(response.result))
49
- } catch (e) {
50
- reject({
51
- message: '文件上传异常',
52
- })
53
- }
54
- },
55
- })
56
- })
57
- }
58
- return {
59
- upload,
60
- }
61
- }
1
+ import Taro from "@tarojs/taro";
2
+
3
+ /**
4
+ * 使用 canvas 压缩图片(Web 端)
5
+ */
6
+ export const compressImageWithCanvas = (
7
+ src: string,
8
+ quality: number
9
+ ): Promise<string> => {
10
+ return new Promise((resolve, reject) => {
11
+ const img = new Image();
12
+ img.crossOrigin = "anonymous";
13
+
14
+ img.onload = () => {
15
+ try {
16
+ const canvas = document.createElement("canvas");
17
+ const ctx = canvas.getContext("2d");
18
+
19
+ if (!ctx) {
20
+ reject(new Error("无法获取 canvas 上下文"));
21
+ return;
22
+ }
23
+
24
+ // 设置画布尺寸(可以根据需要限制最大尺寸)
25
+ const maxWidth = 850;
26
+ const maxHeight = 850;
27
+ let width = img.width;
28
+ let height = img.height;
29
+
30
+ // 计算压缩后的尺寸
31
+ if (width > maxWidth || height > maxHeight) {
32
+ const ratio = Math.min(maxWidth / width, maxHeight / height);
33
+ width = width * ratio;
34
+ height = height * ratio;
35
+ }
36
+
37
+ canvas.width = width;
38
+ canvas.height = height;
39
+
40
+ // 绘制图片到 canvas
41
+ ctx.drawImage(img, 0, 0, width, height);
42
+
43
+ // 转换为 blob
44
+ canvas.toBlob(
45
+ (blob) => {
46
+ if (!blob) {
47
+ reject(new Error("图片压缩失败"));
48
+ return;
49
+ }
50
+ // 创建 blob URL
51
+ const compressedUrl = URL.createObjectURL(blob);
52
+ resolve(compressedUrl);
53
+ },
54
+ "image/jpeg",
55
+ quality / 100
56
+ );
57
+ } catch (error) {
58
+ reject(error);
59
+ }
60
+ };
61
+
62
+ img.onerror = () => {
63
+ reject(new Error("图片加载失败"));
64
+ };
65
+
66
+ img.src = src;
67
+ });
68
+ };
69
+
70
+ // 压缩图片
71
+ export async function compressImage(src: string, quality = 80) {
72
+ if (Taro.getEnv() === "WEB") {
73
+ try {
74
+ const compressedUrl = await compressImageWithCanvas(src, quality);
75
+ // 返回格式与小程序端一致,包含 tempFilePath 属性
76
+ return { tempFilePath: compressedUrl };
77
+ } catch (error) {
78
+ console.error("图片压缩失败:", error);
79
+ // 压缩失败时返回原图
80
+ return { tempFilePath: src };
81
+ }
82
+ } else {
83
+ return new Promise((resolve, reject) => {
84
+ Taro.compressImage({
85
+ src: src,
86
+ quality: quality,
87
+ success: (res) => {
88
+ resolve(res);
89
+ },
90
+ fail: (res) => {
91
+ reject(res);
92
+ },
93
+ });
94
+ });
95
+ }
96
+ }
97
+
98
+ // 获取压缩质量
99
+ export function getCompressQuality(size: number) {
100
+ let quality = 100;
101
+ const curSize = size / (1024 * 1024);
102
+ if (curSize > 6) {
103
+ quality = quality - ((curSize - 6) / curSize) * 100;
104
+ }
105
+ return quality;
106
+ }
@@ -1,32 +1,32 @@
1
- /**
2
- * 通用表单校验器
3
- */
4
- import isMobilePhone from 'validator/es/lib/isMobilePhone'
5
- import isIdentityCard from 'validator/es/lib/isIdentityCard'
6
-
7
- export function useValidator() {
8
- // 身份证号码校验
9
- function certNoValidator(value: string) {
10
- if (!value) {
11
- return '请输入身份证号'
12
- } else if (!isIdentityCard(value, 'zh-CN')) {
13
- return '请输入正确的身份证号码'
14
- }
15
- return false
16
- }
17
-
18
- // 电话号码校验
19
- function phoneValidator(value: string) {
20
- if (!value) {
21
- return '请输入手机号码'
22
- } else if (!isMobilePhone(value, 'zh-CN')) {
23
- return '请输入正确的手机号'
24
- }
25
- return false
26
- }
27
-
28
- return {
29
- certNoValidator,
30
- phoneValidator,
31
- }
32
- }
1
+ /**
2
+ * 通用表单校验器
3
+ */
4
+ import isMobilePhone from 'validator/es/lib/isMobilePhone'
5
+ import isIdentityCard from 'validator/es/lib/isIdentityCard'
6
+
7
+ export function useValidator() {
8
+ // 身份证号码校验
9
+ function certNoValidator(value: string) {
10
+ if (!value) {
11
+ return '请输入身份证号'
12
+ } else if (!isIdentityCard(value, 'zh-CN')) {
13
+ return '请输入正确的身份证号码'
14
+ }
15
+ return false
16
+ }
17
+
18
+ // 电话号码校验
19
+ function phoneValidator(value: string) {
20
+ if (!value) {
21
+ return '请输入手机号码'
22
+ } else if (!isMobilePhone(value, 'zh-CN')) {
23
+ return '请输入正确的手机号'
24
+ }
25
+ return false
26
+ }
27
+
28
+ return {
29
+ certNoValidator,
30
+ phoneValidator,
31
+ }
32
+ }