@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.
- package/.eslintrc.mjs +7 -7
- package/COMPONENT_USAGE.md +1523 -1523
- package/PROJECT_DOCS.md +142 -142
- package/README.md +187 -187
- package/babel.config.js +12 -12
- package/dist/appkit.css +63 -15
- package/dist/index.js +881 -259
- package/package.json +79 -79
- package/project.config.json +15 -15
- package/project.tt.json +13 -13
- package/rollup.config.mjs +78 -78
- package/src/Appkit.ts +72 -72
- package/src/balance/api/endpoints.ts +133 -133
- package/src/balance/api/index.ts +118 -118
- package/src/balance/components/AccountView.vue +770 -770
- package/src/balance/components/BalanceCard.vue +210 -210
- package/src/balance/components/BalanceReminder.vue +84 -84
- package/src/balance/components/ConsumptionFilter.vue +218 -218
- package/src/balance/components/ConsumptionRules.vue +68 -68
- package/src/balance/components/DateFilter.vue +259 -259
- package/src/balance/components/DateRange.vue +111 -111
- package/src/balance/components/ListFilter.vue +62 -62
- package/src/balance/components/ListFilterPicker.vue +191 -191
- package/src/balance/components/PromoterCard.vue +308 -307
- package/src/balance/components/SecondBalance.vue +77 -77
- package/src/balance/components/Tip.vue +45 -45
- package/src/balance/components/index.ts +8 -8
- package/src/balance/types.ts +99 -99
- package/src/components/bt-cropper/index.vue +730 -730
- package/src/components/bt-cropper/utils/calcCropper.js +42 -42
- package/src/components/bt-cropper/utils/calcImagePosition.js +23 -23
- package/src/components/bt-cropper/utils/calcImageSize.js +37 -37
- package/src/components/bt-cropper/utils/calcPointDistance.js +12 -12
- package/src/components/bt-cropper/utils/calcRightAndBottom.js +7 -7
- package/src/components/bt-cropper/utils/ratio.js +3 -3
- package/src/components/bt-cropper/utils/tools.js +25 -25
- package/src/components/dd-area/index.vue +225 -225
- package/src/components/dd-icon/doc.md +21 -21
- package/src/components/dd-icon/index.vue +23 -23
- package/src/components/dd-notice-bar/index.vue +78 -78
- package/src/components/dd-search/doc.md +34 -34
- package/src/components/dd-search/index.vue +168 -168
- package/src/components/dd-selector/index.vue +124 -124
- package/src/components/dd-skeleton/doc.md +19 -19
- package/src/components/dd-skeleton/index.vue +36 -36
- package/src/global.ts +6 -6
- package/src/index.ts +101 -101
- package/src/main.scss +1 -1
- package/src/notice/api/endpoints.ts +54 -54
- package/src/notice/api/index.ts +121 -121
- package/src/notice/components/NoticeBanner.vue +247 -247
- package/src/notice/components/NoticeEntry.vue +99 -99
- package/src/notice/components/NoticeList.vue +311 -311
- package/src/notice/components/NoticeList2.vue +401 -400
- package/src/notice/components/NoticePopup.vue +163 -163
- package/src/notice/components/index.ts +6 -6
- package/src/notice/components/useCommonList.ts +87 -86
- package/src/notice/components/useNotice.ts +35 -35
- package/src/notice/index.ts +1 -1
- package/src/notice/types.ts +25 -25
- package/src/payment/api/config.ts +7 -7
- package/src/payment/api/endpoints.ts +98 -96
- package/src/payment/api/index.ts +108 -107
- package/src/payment/components/AmountPicker.vue +90 -90
- package/src/payment/components/RechargeResult.vue +68 -69
- package/src/payment/components/RechargeView.vue +195 -191
- package/src/payment/components/RightsPicker.vue +105 -105
- package/src/payment/components/TradeView.vue +573 -363
- package/src/payment/components/UserAgreement.vue +234 -234
- package/src/payment/components/index.ts +22 -22
- package/src/payment/index.ts +5 -5
- package/src/payment/services/index.ts +16 -16
- package/src/payment/services/invoke-recharge.ts +25 -25
- package/src/payment/services/request-payment.ts +132 -130
- package/src/payment/types.ts +34 -33
- package/src/register/components/SelfRegistration.vue +233 -233
- package/src/register/components/index.ts +2 -2
- package/src/scenarios/components/SharePoster.vue +364 -364
- package/src/scenarios/components/index.ts +2 -2
- package/src/scenarios/components/poster-paste.vue +93 -93
- package/src/scenarios/components/share-poster.md +273 -273
- package/src/shared/components/AppDrawer.vue +53 -53
- package/src/shared/components/AppVerify.vue +137 -128
- package/src/shared/components/DeviceVersion.vue +78 -78
- package/src/shared/components/EmptyView.vue +33 -33
- package/src/shared/components/OcrBank.vue +202 -0
- package/src/shared/components/OcrBusinessLicense.vue +120 -137
- package/src/shared/components/OcrIcon.vue +267 -229
- package/src/shared/components/OcrInvoice.vue +322 -0
- package/src/shared/components/PageHeader.vue +84 -84
- package/src/shared/components/index.ts +10 -8
- package/src/shared/composables/index.ts +10 -9
- package/src/shared/composables/useAmount.ts +46 -46
- package/src/shared/composables/useCompress.ts +64 -0
- package/src/shared/composables/useCountdown.ts +46 -46
- package/src/shared/composables/useCrypto.ts +76 -76
- package/src/shared/composables/useDeviceEnv.ts +26 -26
- package/src/shared/composables/useDragBox.ts +97 -97
- package/src/shared/composables/useEncode.ts +43 -43
- package/src/shared/composables/useLogger.ts +144 -144
- package/src/shared/composables/useSafeArea.ts +46 -46
- package/src/shared/composables/useTabbar.ts +24 -24
- package/src/shared/composables/useUpload.ts +106 -61
- package/src/shared/composables/useValidator.ts +32 -32
- package/src/shared/composables/useWxAuth.ts +48 -48
- package/src/shared/http/Http.ts +149 -148
- package/src/shared/http/index.ts +1 -1
- package/src/shared/http/types.ts +163 -163
- package/src/shared/index.ts +9 -9
- package/src/shared/tracking/directives/index.ts +40 -40
- package/src/shared/tracking/examples/page-tracking-template.vue +27 -27
- package/src/shared/tracking/tracking-sdk.ts +0 -1
- package/src/shared/weixin/index.ts +9 -9
- package/src/shared/weixin/jssdk.ts +104 -103
- package/src/shared/weixin/payment.ts +38 -38
- package/src/styles/vars.scss +3 -3
- package/src/user/api/endpoints.ts +17 -17
- package/src/user/api/index.ts +123 -123
- package/src/user/components/LoginSetting.vue +114 -114
- package/src/user/components/UserAuth.vue +218 -218
- package/src/user/components/UserBinding.vue +277 -277
- package/src/user/components/UserBindingSuccess.vue +80 -80
- package/src/user/components/UserEntry.vue +139 -139
- package/src/user/components/UserFeedback.vue +428 -427
- package/src/user/components/UserFeedbackEntry.vue +175 -175
- package/src/user/components/UserHeadCrop.vue +65 -65
- package/src/user/components/UserInfo.vue +711 -709
- package/src/user/components/UserResourceEmpty.vue +75 -75
- package/src/user/components/index.ts +23 -23
- package/src/user/index.ts +1 -1
- package/src/utils/utils.ts +33 -33
- package/tsconfig.json +30 -30
- package/types/global.d.ts +24 -22
- package/types/vue.d.ts +10 -10
- 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
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
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
|
+
}
|