@uxda/appkit 4.3.6 → 4.3.8
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 +15 -63
- package/dist/assets/asset-DcH8Kg-2 +1 -0
- package/dist/index.js +259 -806
- 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 +307 -308
- 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 +400 -399
- package/src/notice/components/NoticePopup.vue +163 -163
- package/src/notice/components/index.ts +6 -6
- package/src/notice/components/useCommonList.ts +86 -87
- 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 +96 -98
- package/src/payment/api/index.ts +107 -108
- package/src/payment/components/AmountPicker.vue +90 -90
- package/src/payment/components/RechargeResult.vue +69 -68
- package/src/payment/components/RechargeView.vue +191 -191
- package/src/payment/components/RightsPicker.vue +105 -105
- package/src/payment/components/TradeView.vue +363 -571
- 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 +130 -132
- package/src/payment/types.ts +33 -34
- 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 +128 -137
- package/src/shared/components/DeviceVersion.vue +78 -78
- package/src/shared/components/EmptyView.vue +33 -33
- package/src/shared/components/OcrBusinessLicense.vue +137 -120
- package/src/shared/components/OcrIcon.vue +229 -267
- package/src/shared/components/PageHeader.vue +84 -84
- package/src/shared/components/index.ts +8 -10
- package/src/shared/composables/index.ts +9 -10
- package/src/shared/composables/useAmount.ts +46 -46
- 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 +61 -106
- package/src/shared/composables/useValidator.ts +32 -32
- package/src/shared/composables/useWxAuth.ts +48 -48
- package/src/shared/http/Http.ts +148 -149
- 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 +1 -0
- package/src/shared/weixin/index.ts +9 -9
- package/src/shared/weixin/jssdk.ts +103 -104
- 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 +427 -428
- package/src/user/components/UserFeedbackEntry.vue +175 -175
- package/src/user/components/UserHeadCrop.vue +65 -65
- package/src/user/components/UserInfo.vue +709 -711
- 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 +22 -24
- package/types/vue.d.ts +10 -10
- package/src/shared/components/OcrBank.vue +0 -202
- package/src/shared/components/OcrInvoice.vue +0 -218
- package/src/shared/composables/useCompress.ts +0 -64
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="user-resource-empty" :style="style" v-if="show">
|
|
3
|
-
<img
|
|
4
|
-
class="user-resource-empty-img"
|
|
5
|
-
src="https://cdn.ddjf.com/static/images/nutshell/empty-permission.png"
|
|
6
|
-
/>
|
|
7
|
-
<div class="user-resource-empty-text">
|
|
8
|
-
应用已于{{ dayjs(appInfo.endTime).format('YYYY年MM月DD日') }}到期,如需继续使用,
|
|
9
|
-
请联系大道客户总监进行续费
|
|
10
|
-
</div>
|
|
11
|
-
</div>
|
|
12
|
-
</template>
|
|
13
|
-
|
|
14
|
-
<script lang="ts" setup>
|
|
15
|
-
import { computed } from 'vue'
|
|
16
|
-
import { useSafeArea } from '../../shared/composables'
|
|
17
|
-
import dayjs from 'dayjs'
|
|
18
|
-
|
|
19
|
-
const props = withDefaults(
|
|
20
|
-
defineProps<{
|
|
21
|
-
appInfo: any
|
|
22
|
-
withTabbar?: boolean
|
|
23
|
-
withNavbar?: boolean
|
|
24
|
-
show?: boolean
|
|
25
|
-
}>(),
|
|
26
|
-
{
|
|
27
|
-
appInfo: {},
|
|
28
|
-
withTabbar: false,
|
|
29
|
-
withNavbar: false,
|
|
30
|
-
show: true,
|
|
31
|
-
}
|
|
32
|
-
)
|
|
33
|
-
|
|
34
|
-
const safeArea = useSafeArea()
|
|
35
|
-
|
|
36
|
-
const style = computed(() => {
|
|
37
|
-
let str = ''
|
|
38
|
-
if (props.withTabbar) {
|
|
39
|
-
str += `bottom: ${safeArea.menuRect.bottom + 5}px;`
|
|
40
|
-
}
|
|
41
|
-
if (props.withNavbar) {
|
|
42
|
-
str += `top: ${safeArea.nav + safeArea.status + 5}px;`
|
|
43
|
-
}
|
|
44
|
-
return str
|
|
45
|
-
})
|
|
46
|
-
</script>
|
|
47
|
-
|
|
48
|
-
<style lang="scss">
|
|
49
|
-
.user-resource-empty {
|
|
50
|
-
position: fixed;
|
|
51
|
-
z-index: 4;
|
|
52
|
-
left: 12px;
|
|
53
|
-
top: 10px;
|
|
54
|
-
bottom: 10px;
|
|
55
|
-
align-items: center;
|
|
56
|
-
width: calc(100% - 24px);
|
|
57
|
-
background: #ffffff;
|
|
58
|
-
border-radius: 5px;
|
|
59
|
-
display: flex;
|
|
60
|
-
flex-direction: column;
|
|
61
|
-
&-img {
|
|
62
|
-
margin-top: 50%;
|
|
63
|
-
height: 111px;
|
|
64
|
-
width: 198px;
|
|
65
|
-
}
|
|
66
|
-
&-text {
|
|
67
|
-
margin-top: 10px;
|
|
68
|
-
color: #353535;
|
|
69
|
-
opacity: 0.4;
|
|
70
|
-
font-size: 12px;
|
|
71
|
-
padding: 0 30px;
|
|
72
|
-
text-align: center;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="user-resource-empty" :style="style" v-if="show">
|
|
3
|
+
<img
|
|
4
|
+
class="user-resource-empty-img"
|
|
5
|
+
src="https://cdn.ddjf.com/static/images/nutshell/empty-permission.png"
|
|
6
|
+
/>
|
|
7
|
+
<div class="user-resource-empty-text">
|
|
8
|
+
应用已于{{ dayjs(appInfo.endTime).format('YYYY年MM月DD日') }}到期,如需继续使用,
|
|
9
|
+
请联系大道客户总监进行续费
|
|
10
|
+
</div>
|
|
11
|
+
</div>
|
|
12
|
+
</template>
|
|
13
|
+
|
|
14
|
+
<script lang="ts" setup>
|
|
15
|
+
import { computed } from 'vue'
|
|
16
|
+
import { useSafeArea } from '../../shared/composables'
|
|
17
|
+
import dayjs from 'dayjs'
|
|
18
|
+
|
|
19
|
+
const props = withDefaults(
|
|
20
|
+
defineProps<{
|
|
21
|
+
appInfo: any
|
|
22
|
+
withTabbar?: boolean
|
|
23
|
+
withNavbar?: boolean
|
|
24
|
+
show?: boolean
|
|
25
|
+
}>(),
|
|
26
|
+
{
|
|
27
|
+
appInfo: {},
|
|
28
|
+
withTabbar: false,
|
|
29
|
+
withNavbar: false,
|
|
30
|
+
show: true,
|
|
31
|
+
}
|
|
32
|
+
)
|
|
33
|
+
|
|
34
|
+
const safeArea = useSafeArea()
|
|
35
|
+
|
|
36
|
+
const style = computed(() => {
|
|
37
|
+
let str = ''
|
|
38
|
+
if (props.withTabbar) {
|
|
39
|
+
str += `bottom: ${safeArea.menuRect.bottom + 5}px;`
|
|
40
|
+
}
|
|
41
|
+
if (props.withNavbar) {
|
|
42
|
+
str += `top: ${safeArea.nav + safeArea.status + 5}px;`
|
|
43
|
+
}
|
|
44
|
+
return str
|
|
45
|
+
})
|
|
46
|
+
</script>
|
|
47
|
+
|
|
48
|
+
<style lang="scss">
|
|
49
|
+
.user-resource-empty {
|
|
50
|
+
position: fixed;
|
|
51
|
+
z-index: 4;
|
|
52
|
+
left: 12px;
|
|
53
|
+
top: 10px;
|
|
54
|
+
bottom: 10px;
|
|
55
|
+
align-items: center;
|
|
56
|
+
width: calc(100% - 24px);
|
|
57
|
+
background: #ffffff;
|
|
58
|
+
border-radius: 5px;
|
|
59
|
+
display: flex;
|
|
60
|
+
flex-direction: column;
|
|
61
|
+
&-img {
|
|
62
|
+
margin-top: 50%;
|
|
63
|
+
height: 111px;
|
|
64
|
+
width: 198px;
|
|
65
|
+
}
|
|
66
|
+
&-text {
|
|
67
|
+
margin-top: 10px;
|
|
68
|
+
color: #353535;
|
|
69
|
+
opacity: 0.4;
|
|
70
|
+
font-size: 12px;
|
|
71
|
+
padding: 0 30px;
|
|
72
|
+
text-align: center;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
</style>
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import UserEntry from './UserEntry.vue'
|
|
2
|
-
import UserInfo from './UserInfo.vue'
|
|
3
|
-
import UserBinding from './UserBinding.vue'
|
|
4
|
-
import UserBindingSuccess from './UserBindingSuccess.vue'
|
|
5
|
-
import UserHeadCrop from './UserHeadCrop.vue'
|
|
6
|
-
import UserFeedback from './UserFeedback.vue'
|
|
7
|
-
import UserFeedbackEntry from './UserFeedbackEntry.vue'
|
|
8
|
-
import LoginSetting from './LoginSetting.vue'
|
|
9
|
-
import UserResourceEmpty from './UserResourceEmpty.vue'
|
|
10
|
-
import UserAuth from './UserAuth.vue'
|
|
11
|
-
|
|
12
|
-
export {
|
|
13
|
-
UserEntry,
|
|
14
|
-
UserInfo,
|
|
15
|
-
UserBinding,
|
|
16
|
-
UserBindingSuccess,
|
|
17
|
-
UserHeadCrop,
|
|
18
|
-
UserFeedback,
|
|
19
|
-
UserFeedbackEntry,
|
|
20
|
-
LoginSetting,
|
|
21
|
-
UserResourceEmpty,
|
|
22
|
-
UserAuth,
|
|
23
|
-
}
|
|
1
|
+
import UserEntry from './UserEntry.vue'
|
|
2
|
+
import UserInfo from './UserInfo.vue'
|
|
3
|
+
import UserBinding from './UserBinding.vue'
|
|
4
|
+
import UserBindingSuccess from './UserBindingSuccess.vue'
|
|
5
|
+
import UserHeadCrop from './UserHeadCrop.vue'
|
|
6
|
+
import UserFeedback from './UserFeedback.vue'
|
|
7
|
+
import UserFeedbackEntry from './UserFeedbackEntry.vue'
|
|
8
|
+
import LoginSetting from './LoginSetting.vue'
|
|
9
|
+
import UserResourceEmpty from './UserResourceEmpty.vue'
|
|
10
|
+
import UserAuth from './UserAuth.vue'
|
|
11
|
+
|
|
12
|
+
export {
|
|
13
|
+
UserEntry,
|
|
14
|
+
UserInfo,
|
|
15
|
+
UserBinding,
|
|
16
|
+
UserBindingSuccess,
|
|
17
|
+
UserHeadCrop,
|
|
18
|
+
UserFeedback,
|
|
19
|
+
UserFeedbackEntry,
|
|
20
|
+
LoginSetting,
|
|
21
|
+
UserResourceEmpty,
|
|
22
|
+
UserAuth,
|
|
23
|
+
}
|
package/src/user/index.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './components'
|
|
1
|
+
export * from './components'
|
package/src/utils/utils.ts
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import Taro from "@tarojs/taro"
|
|
2
|
-
import dsBridge from 'dsbridge'
|
|
3
|
-
|
|
4
|
-
// 工具函数:DataURL转Blob
|
|
5
|
-
export function dataURItoBlob(dataURI) {
|
|
6
|
-
const byteString = atob(dataURI.split(',')[1])
|
|
7
|
-
const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]
|
|
8
|
-
const ab = new ArrayBuffer(byteString.length)
|
|
9
|
-
const ia = new Uint8Array(ab)
|
|
10
|
-
for (let i = 0; i < byteString.length; i++) {
|
|
11
|
-
ia[i] = byteString.charCodeAt(i)
|
|
12
|
-
}
|
|
13
|
-
return new Blob([ab], { type: mimeString })
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
// 是否H5页面
|
|
17
|
-
export function isWeb() {
|
|
18
|
-
const env = process.env.TARO_ENV || ''
|
|
19
|
-
return env === 'h5' || Taro.getEnv() === 'WEB'
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
// 使用时间戳生成唯一标识
|
|
24
|
-
export function generateUniqueId(pre?: string, delimiter = '-') {
|
|
25
|
-
return `${pre ? pre + delimiter : ''}${Date.now().toString(16)}${delimiter}${Math.random()
|
|
26
|
-
.toString(36)
|
|
27
|
-
.substr(2)}`
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// 是否是App环境
|
|
31
|
-
export function isApp() {
|
|
32
|
-
return dsBridge.hasNativeMethod('openWebPage')
|
|
33
|
-
}
|
|
1
|
+
import Taro from "@tarojs/taro"
|
|
2
|
+
import dsBridge from 'dsbridge'
|
|
3
|
+
|
|
4
|
+
// 工具函数:DataURL转Blob
|
|
5
|
+
export function dataURItoBlob(dataURI) {
|
|
6
|
+
const byteString = atob(dataURI.split(',')[1])
|
|
7
|
+
const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]
|
|
8
|
+
const ab = new ArrayBuffer(byteString.length)
|
|
9
|
+
const ia = new Uint8Array(ab)
|
|
10
|
+
for (let i = 0; i < byteString.length; i++) {
|
|
11
|
+
ia[i] = byteString.charCodeAt(i)
|
|
12
|
+
}
|
|
13
|
+
return new Blob([ab], { type: mimeString })
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// 是否H5页面
|
|
17
|
+
export function isWeb() {
|
|
18
|
+
const env = process.env.TARO_ENV || ''
|
|
19
|
+
return env === 'h5' || Taro.getEnv() === 'WEB'
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
// 使用时间戳生成唯一标识
|
|
24
|
+
export function generateUniqueId(pre?: string, delimiter = '-') {
|
|
25
|
+
return `${pre ? pre + delimiter : ''}${Date.now().toString(16)}${delimiter}${Math.random()
|
|
26
|
+
.toString(36)
|
|
27
|
+
.substr(2)}`
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// 是否是App环境
|
|
31
|
+
export function isApp() {
|
|
32
|
+
return dsBridge.hasNativeMethod('openWebPage')
|
|
33
|
+
}
|
package/tsconfig.json
CHANGED
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"module": "commonjs",
|
|
4
|
-
"removeComments": false,
|
|
5
|
-
"preserveConstEnums": true,
|
|
6
|
-
"moduleResolution": "node",
|
|
7
|
-
"experimentalDecorators": true,
|
|
8
|
-
"noImplicitAny": false,
|
|
9
|
-
"allowSyntheticDefaultImports": true,
|
|
10
|
-
"outDir": "dist",
|
|
11
|
-
"noUnusedLocals": true,
|
|
12
|
-
"noUnusedParameters": true,
|
|
13
|
-
"strictNullChecks": true,
|
|
14
|
-
"sourceMap": true,
|
|
15
|
-
"baseUrl": ".",
|
|
16
|
-
"rootDir": ".",
|
|
17
|
-
"jsx": "preserve",
|
|
18
|
-
"allowJs": true,
|
|
19
|
-
"resolveJsonModule": true,
|
|
20
|
-
"skipLibCheck": true,
|
|
21
|
-
"typeRoots": [
|
|
22
|
-
"node_modules/@types"
|
|
23
|
-
]
|
|
24
|
-
},
|
|
25
|
-
"include": [
|
|
26
|
-
"./src/",
|
|
27
|
-
"./types",
|
|
28
|
-
],
|
|
29
|
-
"compileOnSave": false
|
|
30
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"module": "commonjs",
|
|
4
|
+
"removeComments": false,
|
|
5
|
+
"preserveConstEnums": true,
|
|
6
|
+
"moduleResolution": "node",
|
|
7
|
+
"experimentalDecorators": true,
|
|
8
|
+
"noImplicitAny": false,
|
|
9
|
+
"allowSyntheticDefaultImports": true,
|
|
10
|
+
"outDir": "dist",
|
|
11
|
+
"noUnusedLocals": true,
|
|
12
|
+
"noUnusedParameters": true,
|
|
13
|
+
"strictNullChecks": true,
|
|
14
|
+
"sourceMap": true,
|
|
15
|
+
"baseUrl": ".",
|
|
16
|
+
"rootDir": ".",
|
|
17
|
+
"jsx": "preserve",
|
|
18
|
+
"allowJs": true,
|
|
19
|
+
"resolveJsonModule": true,
|
|
20
|
+
"skipLibCheck": true,
|
|
21
|
+
"typeRoots": [
|
|
22
|
+
"node_modules/@types"
|
|
23
|
+
]
|
|
24
|
+
},
|
|
25
|
+
"include": [
|
|
26
|
+
"./src/",
|
|
27
|
+
"./types",
|
|
28
|
+
],
|
|
29
|
+
"compileOnSave": false
|
|
30
|
+
}
|
package/types/global.d.ts
CHANGED
|
@@ -1,24 +1,22 @@
|
|
|
1
|
-
/// <reference types="@tarojs/taro" />
|
|
2
|
-
|
|
3
|
-
declare module '*.png'
|
|
4
|
-
declare module '*.gif'
|
|
5
|
-
declare module '*.jpg'
|
|
6
|
-
declare module '*.jpeg'
|
|
7
|
-
declare module '*.svg'
|
|
8
|
-
declare module '*.css'
|
|
9
|
-
declare module '*.less'
|
|
10
|
-
declare module '*.scss'
|
|
11
|
-
declare module '*.sass'
|
|
12
|
-
declare module '*.styl'
|
|
13
|
-
|
|
14
|
-
declare namespace NodeJS {
|
|
15
|
-
interface ProcessEnv {
|
|
16
|
-
TARO_ENV: 'weapp' | 'swan' | 'alipay' | 'h5' | 'rn' | 'tt' | 'quickapp' | 'qq' | 'jd'
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
declare module '@tarojs/components' {
|
|
21
|
-
export * from '@tarojs/components/types/index.vue3'
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
declare module '@uxda/nutshell/taro'
|
|
1
|
+
/// <reference types="@tarojs/taro" />
|
|
2
|
+
|
|
3
|
+
declare module '*.png'
|
|
4
|
+
declare module '*.gif'
|
|
5
|
+
declare module '*.jpg'
|
|
6
|
+
declare module '*.jpeg'
|
|
7
|
+
declare module '*.svg'
|
|
8
|
+
declare module '*.css'
|
|
9
|
+
declare module '*.less'
|
|
10
|
+
declare module '*.scss'
|
|
11
|
+
declare module '*.sass'
|
|
12
|
+
declare module '*.styl'
|
|
13
|
+
|
|
14
|
+
declare namespace NodeJS {
|
|
15
|
+
interface ProcessEnv {
|
|
16
|
+
TARO_ENV: 'weapp' | 'swan' | 'alipay' | 'h5' | 'rn' | 'tt' | 'quickapp' | 'qq' | 'jd'
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
declare module '@tarojs/components' {
|
|
21
|
+
export * from '@tarojs/components/types/index.vue3'
|
|
22
|
+
}
|
package/types/vue.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
export {}
|
|
2
|
-
|
|
3
|
-
declare module 'vue' {
|
|
4
|
-
export interface GlobalComponents extends JSX.IntrinsicElements {
|
|
5
|
-
/** Note: Vue 在 runtime 中将 JSX.IntrinsicElements 通过 index signature 重复声明标签
|
|
6
|
-
* 这会导致插件无法正常跳转类型,可以手动覆盖声明标签活得更好的体验,参考如下:
|
|
7
|
-
* 'scroll-view': JSX.IntrinsicElements['scroll-view']
|
|
8
|
-
*/
|
|
9
|
-
}
|
|
10
|
-
}
|
|
1
|
+
export {}
|
|
2
|
+
|
|
3
|
+
declare module 'vue' {
|
|
4
|
+
export interface GlobalComponents extends JSX.IntrinsicElements {
|
|
5
|
+
/** Note: Vue 在 runtime 中将 JSX.IntrinsicElements 通过 index signature 重复声明标签
|
|
6
|
+
* 这会导致插件无法正常跳转类型,可以手动覆盖声明标签活得更好的体验,参考如下:
|
|
7
|
+
* 'scroll-view': JSX.IntrinsicElements['scroll-view']
|
|
8
|
+
*/
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="ocr-bank" :class="[disabled ? 'disabled' : '']" v-track-click="'银行卡识别-点击'" @click="!customClick ? onUpload() : null">
|
|
3
|
-
<slot name="icon">
|
|
4
|
-
<ns-icon name="https://cdn.ddjf.com/static/images/beidouxing/ocr-icon.png" />
|
|
5
|
-
</slot>
|
|
6
|
-
</div>
|
|
7
|
-
|
|
8
|
-
<nut-action-sheet v-model:visible="activeSheetVisible" :menu-items="actionSheetMenus" @choose="chooseImages"
|
|
9
|
-
cancel-txt="取消" />
|
|
10
|
-
</template>
|
|
11
|
-
|
|
12
|
-
<script lang="ts" setup>
|
|
13
|
-
import Taro, { showToast, showLoading, hideLoading, chooseMedia, chooseMessageFile, uploadFile } from '@tarojs/taro'
|
|
14
|
-
import { NsIcon, useNutshell } from '@uxda/nutshell/taro'
|
|
15
|
-
import { useAppKitOptions } from '../../Appkit'
|
|
16
|
-
import { ref } from 'vue';
|
|
17
|
-
import { useHttp } from '../../balance/api'
|
|
18
|
-
import { compressImage, getCompressQuality } from '../composables/useUpload'
|
|
19
|
-
|
|
20
|
-
const appKitOptions = useAppKitOptions()
|
|
21
|
-
const $http = useHttp(),
|
|
22
|
-
$n = useNutshell()
|
|
23
|
-
|
|
24
|
-
const emits = defineEmits(['complete'])
|
|
25
|
-
|
|
26
|
-
type OcrProps = {
|
|
27
|
-
disabled?: boolean,
|
|
28
|
-
class?: string
|
|
29
|
-
uploadUrl?: string
|
|
30
|
-
customClick?: boolean
|
|
31
|
-
}
|
|
32
|
-
type FileType = {
|
|
33
|
-
"downloadUrl": string,
|
|
34
|
-
"fileId": string,
|
|
35
|
-
"fileName": string,
|
|
36
|
-
"fileSize": number,
|
|
37
|
-
"fileSuffix": string,
|
|
38
|
-
"fileType": string,
|
|
39
|
-
"originalUrl": string
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
const props = withDefaults(defineProps<OcrProps>(), {
|
|
43
|
-
disabled: false,
|
|
44
|
-
class: '',
|
|
45
|
-
uploadUrl: '/hkbase/file/uploadFile',
|
|
46
|
-
customClick: false
|
|
47
|
-
})
|
|
48
|
-
|
|
49
|
-
type BankCardType = {
|
|
50
|
-
bankCardNumber: string
|
|
51
|
-
bankCardType: string
|
|
52
|
-
bankName: string
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
async function onUploadFile(csRes: any) {
|
|
56
|
-
try {
|
|
57
|
-
let { path, size, tempFilePath } = csRes.tempFiles[0]
|
|
58
|
-
const compressImg: any = (await compressImage(path || tempFilePath, getCompressQuality(size))) || {}
|
|
59
|
-
const filePath = compressImg.tempFilePath || path
|
|
60
|
-
|
|
61
|
-
showLoading({ title: '银行卡识别中..', mask: true })
|
|
62
|
-
|
|
63
|
-
const session = appKitOptions.token()
|
|
64
|
-
const baseUrl = appKitOptions.baseUrl()
|
|
65
|
-
const upRes: any = await uploadFile({
|
|
66
|
-
url: baseUrl + props.uploadUrl,
|
|
67
|
-
filePath,
|
|
68
|
-
name: 'file',
|
|
69
|
-
formData: {
|
|
70
|
-
objectNo: `min${Date.now()}`,
|
|
71
|
-
appCode: appKitOptions.app(),
|
|
72
|
-
},
|
|
73
|
-
header: {
|
|
74
|
-
token: session || '',
|
|
75
|
-
},
|
|
76
|
-
})
|
|
77
|
-
|
|
78
|
-
const res = JSON.parse(upRes.data)
|
|
79
|
-
if (res.code === '200') {
|
|
80
|
-
await getBankCardInfo(res.result)
|
|
81
|
-
} else {
|
|
82
|
-
hideLoading()
|
|
83
|
-
showToast({
|
|
84
|
-
title: res.msg,
|
|
85
|
-
icon: 'error',
|
|
86
|
-
})
|
|
87
|
-
}
|
|
88
|
-
} catch (err) {
|
|
89
|
-
hideLoading()
|
|
90
|
-
console.log(err)
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
// 根据银行卡路径获取银行卡信息
|
|
95
|
-
async function getBankCardInfo(file: string | FileType) {
|
|
96
|
-
try {
|
|
97
|
-
const res: BankCardType = await $http.get('/hkbase/common/bankCard', {
|
|
98
|
-
fileUrl: typeof file === 'string' ? file : file.originalUrl,
|
|
99
|
-
})
|
|
100
|
-
hideLoading()
|
|
101
|
-
|
|
102
|
-
if (res && !res.bankCardNumber) {
|
|
103
|
-
$n.dialog({
|
|
104
|
-
title: '识别失败',
|
|
105
|
-
message: `您上传的图片可能不够清晰或与当前功能不符,请重新上传一张清晰、完整的图片。谢谢!`,
|
|
106
|
-
okText: '我知道了',
|
|
107
|
-
cancelText: '',
|
|
108
|
-
})
|
|
109
|
-
return
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
emits('complete', {
|
|
113
|
-
...res,
|
|
114
|
-
fileUrl: typeof file === 'string' ? file : file.originalUrl,
|
|
115
|
-
fileKey: typeof file === 'string' ? file : file.fileId,
|
|
116
|
-
})
|
|
117
|
-
} catch (err) {
|
|
118
|
-
hideLoading()
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// 上传图片操作面板
|
|
123
|
-
const activeSheetVisible = ref(false)
|
|
124
|
-
const actionSheetMenus = [
|
|
125
|
-
{
|
|
126
|
-
name: '拍摄',
|
|
127
|
-
type: 'camera',
|
|
128
|
-
},
|
|
129
|
-
{
|
|
130
|
-
name: '从相册选择',
|
|
131
|
-
type: 'album',
|
|
132
|
-
},
|
|
133
|
-
{
|
|
134
|
-
name: '从聊天会话选择',
|
|
135
|
-
type: 'message',
|
|
136
|
-
},
|
|
137
|
-
]
|
|
138
|
-
if (Taro.getEnv() === 'WEB') {
|
|
139
|
-
actionSheetMenus.pop()
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
// 选择图像上传
|
|
143
|
-
async function chooseImages(item: any) {
|
|
144
|
-
if (['camera', 'album'].includes(item.type)) {
|
|
145
|
-
const csRes = await chooseMedia({
|
|
146
|
-
count: 1,
|
|
147
|
-
sourceType: [item.type], // "camera" | "album"
|
|
148
|
-
maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
|
|
149
|
-
})
|
|
150
|
-
|
|
151
|
-
onUploadFile(csRes)
|
|
152
|
-
} else {
|
|
153
|
-
const csRes = await chooseMessageFile({
|
|
154
|
-
count: 1,
|
|
155
|
-
type: 'image',
|
|
156
|
-
})
|
|
157
|
-
|
|
158
|
-
onUploadFile(csRes)
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
async function onUpload() {
|
|
163
|
-
if (props.disabled) return
|
|
164
|
-
|
|
165
|
-
if (Taro.getEnv() === 'WEB') {
|
|
166
|
-
const csRes = await chooseMedia({
|
|
167
|
-
count: 1,
|
|
168
|
-
sourceType: ['album'], // "camera" | "album"
|
|
169
|
-
maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
|
|
170
|
-
})
|
|
171
|
-
|
|
172
|
-
onUploadFile(csRes)
|
|
173
|
-
return
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
activeSheetVisible.value = true
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
defineExpose({
|
|
180
|
-
onUpload
|
|
181
|
-
})
|
|
182
|
-
</script>
|
|
183
|
-
|
|
184
|
-
<style lang="scss">
|
|
185
|
-
.ocr-bank {
|
|
186
|
-
width: 24px;
|
|
187
|
-
height: 24px;
|
|
188
|
-
display: inline-flex;
|
|
189
|
-
align-items: center;
|
|
190
|
-
|
|
191
|
-
.ns-icon {
|
|
192
|
-
width: 24px;
|
|
193
|
-
height: 24px;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
&.disabled {
|
|
197
|
-
.ns-icon {
|
|
198
|
-
filter: brightness(1.5) grayscale(1);
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
</style>
|