@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,229 +1,267 @@
1
- <template>
2
- <div class="ocr-icon" :class="[disabled ? 'disabled' : '']" v-track-click="'身份证识别-点击'" @click="onPhotograph">
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 } from '@uxda/nutshell/taro'
15
- import { useAppKitOptions } from '../../Appkit'
16
- import { ref } from 'vue';
17
-
18
- const appKitOptions = useAppKitOptions()
19
-
20
- const emits = defineEmits(['complete'])
21
-
22
- type OcrIconProps = {
23
- disabled?: boolean,
24
- side?: 'face' | 'back',
25
- class?: string
26
- }
27
-
28
- const props = withDefaults(defineProps<OcrIconProps>(), {
29
- disabled: false,
30
- side: 'face',
31
- class: ''
32
- })
33
-
34
- type OcrResultType = {
35
- faceInfo: {
36
- name: string
37
- certNo: string
38
- address: string
39
- }
40
- backInfo: {
41
- startDate: string
42
- endDate: string
43
- }
44
- fileUploadVO: {
45
- fileKey: string
46
- fileUrl: string
47
- objectNo: string
48
- thumbnailUrl?: string
49
- }
50
- }
51
-
52
- async function taroImgCompress(src: string, quality = 80) {
53
- if (Taro.getEnv() === 'WEB') {
54
- return src;
55
- } else {
56
- return new Promise((resolve, reject) => {
57
- Taro.compressImage({
58
- src: src,
59
- quality: quality,
60
- success: (res) => {
61
- resolve(res)
62
- },
63
- fail: (res) => {
64
- reject(res)
65
- },
66
- })
67
- })
68
- }
69
- }
70
-
71
- function getCompressQuality(size: number) {
72
- let quality = 100
73
- const curSize = size / (1024 * 1024)
74
- if (curSize > 6) {
75
- quality = quality - ((curSize - 6) / curSize) * 100
76
- }
77
- return quality
78
- }
79
-
80
- function allTrim(str: string) {
81
- return str.replace(/\s+/g, '')
82
- }
83
-
84
- async function onUploadFile(csRes: any) {
85
- let result: OcrResultType | null = null
86
- try {
87
- console.log('===上传', csRes)
88
- let { path, size, tempFilePath } = csRes.tempFiles[0]
89
- let filePath
90
- if (Taro.getEnv() !== 'WEB') {
91
- const compressImg: any = (await taroImgCompress(path || tempFilePath, getCompressQuality(size))) || {}
92
- filePath = compressImg.tempFilePath || path
93
- } else {
94
- filePath = path || tempFilePath
95
- }
96
-
97
- console.log(filePath, 'filePath')
98
- showLoading({ title: '身份证识别中..' })
99
-
100
- const session = appKitOptions.token()
101
- const baseUrl = appKitOptions.baseUrl()
102
- const upRes: any = await uploadFile({
103
- url: baseUrl + '/hkapprove/ocr/idcard',
104
- filePath,
105
- name: 'file',
106
- formData: {
107
- objectNo: `min${Date.now()}`,
108
- side: props.side,
109
- },
110
- header: {
111
- token: session || '',
112
- },
113
- })
114
- hideLoading()
115
-
116
- const res = JSON.parse(upRes.data)
117
- if (res.code === '200') {
118
- const faceInfo = res.result.faceInfo || {}
119
- const backInfo = res.result.backInfo || {}
120
- result = {
121
- faceInfo: {
122
- name: allTrim(faceInfo.name || ''),
123
- certNo: allTrim(faceInfo.num || ''),
124
- address: allTrim(faceInfo.address || ''),
125
- },
126
- backInfo: {
127
- startDate: backInfo?.startDate || '',
128
- endDate: backInfo?.endDate || ''
129
- },
130
- fileUploadVO: res.result.fileUploadVO || {},
131
- }
132
- console.log('===识别', result)
133
- if (props.side === 'face' && !result.faceInfo.name && !result.faceInfo.certNo) {
134
- showToast({ title: '识别失败,请重试', icon: 'none' })
135
- }
136
- if (props.side === 'back' && !result.backInfo?.startDate && !result.backInfo?.endDate) {
137
- showToast({ title: '识别失败,请重试', icon: 'none' })
138
- }
139
- } else {
140
- showToast({
141
- title: res.msg,
142
- icon: 'error',
143
- })
144
- }
145
- } catch (err) {
146
- hideLoading()
147
- console.log(err)
148
- }
149
- emits('complete', result)
150
- }
151
-
152
-
153
- // 上传图片操作面板
154
- const activeSheetVisible = ref(false)
155
- const actionSheetMenus = [
156
- {
157
- name: '拍摄',
158
- type: 'camera',
159
- },
160
- {
161
- name: '从相册选择',
162
- type: 'album',
163
- },
164
- {
165
- name: '从聊天会话选择',
166
- type: 'message',
167
- },
168
- ]
169
- if (Taro.getEnv() === 'WEB') {
170
- actionSheetMenus.pop()
171
- }
172
-
173
- // 选择图像上传
174
- async function chooseImages(item: any) {
175
- if (['camera', 'album'].includes(item.type)) {
176
- const csRes = await chooseMedia({
177
- count: 1,
178
- sourceType: [item.type], // "camera" | "album"
179
- maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
180
- })
181
-
182
- onUploadFile(csRes)
183
- } else {
184
- const csRes = await chooseMessageFile({
185
- count: 1,
186
- type: 'image',
187
- })
188
-
189
- onUploadFile(csRes)
190
- }
191
- }
192
-
193
- async function onPhotograph() {
194
- if (props.disabled) return
195
-
196
- if (Taro.getEnv() === 'WEB') {
197
- const csRes = await chooseMedia({
198
- count: 1,
199
- sourceType: ['album'], // "camera" | "album"
200
- maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
201
- })
202
-
203
- onUploadFile(csRes)
204
- return
205
- }
206
-
207
- activeSheetVisible.value = true
208
- }
209
- </script>
210
-
211
- <style lang="scss">
212
- .ocr-icon {
213
- width: 24px;
214
- height: 24px;
215
- display: inline-flex;
216
- align-items: center;
217
-
218
- .ns-icon {
219
- width: 24px;
220
- height: 24px;
221
- }
222
-
223
- &.disabled {
224
- .ns-icon {
225
- filter: brightness(1.5) grayscale(1);
226
- }
227
- }
228
- }
229
- </style>
1
+ <template>
2
+ <div class="ocr-icon" :class="[disabled ? 'disabled' : '', className]" 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
+ side?: 'face' | 'back',
29
+ className?: string
30
+ uploadUrl?: string
31
+ customUpload?: Function
32
+ hasUploadVo?: boolean
33
+ customClick?: boolean
34
+ }
35
+ type FileType = {
36
+ "downloadUrl": string,
37
+ "fileId": string,
38
+ "fileName": string,
39
+ "fileSize": number,
40
+ "fileSuffix": string,
41
+ "fileType": string,
42
+ "originalUrl": string
43
+ }
44
+
45
+ const props = withDefaults(defineProps<OcrProps>(), {
46
+ disabled: false,
47
+ side: 'face',
48
+ className: '',
49
+ hasUploadVo: true,
50
+ customClick: false,
51
+ uploadUrl: '/saas-base/file/uploadPublic',
52
+ })
53
+
54
+ type OcrResultType = {
55
+ faceInfo: {
56
+ name: string
57
+ certNo: string
58
+ address: string
59
+ }
60
+ backInfo: {
61
+ startDate: string
62
+ endDate: string
63
+ }
64
+ fileUploadVO: {
65
+ fileKey: string
66
+ fileUrl: string
67
+ objectNo: string
68
+ thumbnailUrl?: string
69
+ }
70
+ }
71
+
72
+ function allTrim(str: string) {
73
+ return str.replace(/\s+/g, '')
74
+ }
75
+
76
+ async function onUploadFile(csRes: any) {
77
+ let result: OcrResultType | null = null
78
+ try {
79
+ let { path, size, tempFilePath } = csRes.tempFiles[0]
80
+ const compressImg: any = (await compressImage(path || tempFilePath, getCompressQuality(size))) || {}
81
+ const filePath = compressImg.tempFilePath || path
82
+
83
+ if (props.customUpload) {
84
+ props.customUpload(filePath)
85
+ return
86
+ }
87
+
88
+ showLoading({ title: '身份证识别中..', mask: true })
89
+
90
+ const session = appKitOptions.token()
91
+ const baseUrl = appKitOptions.baseUrl()
92
+ const upRes: any = await uploadFile({
93
+ url: `${baseUrl}${!props.hasUploadVo ? props.uploadUrl : '/hkapprove/ocr/idcard'}`,
94
+ filePath,
95
+ name: 'file',
96
+ formData: {
97
+ objectNo: `min${Date.now()}`,
98
+ side: props.side,
99
+ appCode: appKitOptions.app(),
100
+ },
101
+ header: {
102
+ token: session || '',
103
+ },
104
+ })
105
+
106
+ const res = JSON.parse(upRes.data)
107
+ if (res.code === '200') {
108
+ if (props.hasUploadVo) {
109
+ hideLoading()
110
+ const faceInfo = res.result.faceInfo || {}
111
+ const backInfo = res.result.backInfo || {}
112
+ result = {
113
+ faceInfo: {
114
+ name: allTrim(faceInfo.name || ''),
115
+ certNo: allTrim(faceInfo.num || ''),
116
+ address: allTrim(faceInfo.address || ''),
117
+ },
118
+ backInfo: {
119
+ startDate: backInfo?.startDate || '',
120
+ endDate: backInfo?.endDate || ''
121
+ },
122
+ fileUploadVO: res.result.fileUploadVO || {},
123
+ }
124
+ if (props.side === 'face' && !result.faceInfo.name && !result.faceInfo.certNo) {
125
+ showToast({ title: '识别失败,请重试', icon: 'none' })
126
+ }
127
+ if (props.side === 'back' && !result.backInfo?.startDate && !result.backInfo?.endDate) {
128
+ showToast({ title: '识别失败,请重试', icon: 'none' })
129
+ }
130
+ } else {
131
+ await getOcrInfo(res.result)
132
+ }
133
+ } else {
134
+ hideLoading()
135
+ showToast({
136
+ title: res.msg,
137
+ icon: 'error',
138
+ })
139
+ }
140
+ } catch (err) {
141
+ hideLoading()
142
+ console.log(err)
143
+ }
144
+
145
+ props.hasUploadVo && (result?.faceInfo.name || result?.backInfo.startDate) && emits('complete', result)
146
+ }
147
+
148
+ // 根据证件路径获取证件信息
149
+ async function getOcrInfo(file: string | FileType) {
150
+ try {
151
+ const res: any = await $http.get('/hkbase/common/idCard', {
152
+ fileUrl: typeof file === 'string' ? file : file.originalUrl,
153
+ side: props.side,
154
+ })
155
+ hideLoading()
156
+
157
+ if ((props.side === 'face' && !res?.name) || (props.side === 'back' && !res?.signDate)) {
158
+ $n.dialog({
159
+ title: '识别失败',
160
+ message: `您上传的图片可能不够清晰或与当前功能不符,请重新上传一张清晰、完整的图片。谢谢!`,
161
+ okText: '我知道了',
162
+ cancelText: '',
163
+ })
164
+ return
165
+ }
166
+
167
+ emits('complete', {
168
+ faceInfo: {
169
+ name: allTrim(res?.name || ''),
170
+ certNo: allTrim(res?.cardNumber || ''),
171
+ address: allTrim(res?.address || ''),
172
+ },
173
+ backInfo: {
174
+ startDate: res?.expireDate || '',
175
+ endDate: res?.signDate || ''
176
+ },
177
+ fileUploadVO: {
178
+ fileUrl: typeof file === 'string' ? file : file.originalUrl,
179
+ fileKey: typeof file === 'string' ? file : file.fileId,
180
+ },
181
+ })
182
+ } catch (err) {
183
+ hideLoading()
184
+ }
185
+ }
186
+
187
+ // 上传图片操作面板
188
+ const activeSheetVisible = ref(false)
189
+ const actionSheetMenus = [
190
+ {
191
+ name: '拍摄',
192
+ type: 'camera',
193
+ },
194
+ {
195
+ name: '从相册选择',
196
+ type: 'album',
197
+ },
198
+ {
199
+ name: '从聊天会话选择',
200
+ type: 'message',
201
+ },
202
+ ]
203
+ if (Taro.getEnv() === 'WEB') {
204
+ actionSheetMenus.pop()
205
+ }
206
+
207
+ // 选择图像上传
208
+ async function chooseImages(item: any) {
209
+ if (['camera', 'album'].includes(item.type)) {
210
+ const csRes = await chooseMedia({
211
+ count: 1,
212
+ sourceType: [item.type], // "camera" | "album"
213
+ maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
214
+ })
215
+
216
+ onUploadFile(csRes)
217
+ } else {
218
+ const csRes = await chooseMessageFile({
219
+ count: 1,
220
+ type: 'image',
221
+ })
222
+
223
+ onUploadFile(csRes)
224
+ }
225
+ }
226
+
227
+ async function onUpload() {
228
+ if (props.disabled) return
229
+
230
+ if (Taro.getEnv() === 'WEB') {
231
+ const csRes = await chooseMedia({
232
+ count: 1,
233
+ sourceType: ['album'], // "camera" | "album"
234
+ maxDuration: 60, // 使用duration属性判断是图片还是视频,图片没有该属性
235
+ })
236
+
237
+ onUploadFile(csRes)
238
+ return
239
+ }
240
+
241
+ activeSheetVisible.value = true
242
+ }
243
+
244
+ defineExpose({
245
+ onUpload
246
+ })
247
+ </script>
248
+
249
+ <style lang="scss">
250
+ .ocr-icon {
251
+ width: 24px;
252
+ height: 24px;
253
+ display: inline-flex;
254
+ align-items: center;
255
+
256
+ .ns-icon {
257
+ width: 24px;
258
+ height: 24px;
259
+ }
260
+
261
+ &.disabled {
262
+ .ns-icon {
263
+ filter: brightness(1.5) grayscale(1);
264
+ }
265
+ }
266
+ }
267
+ </style>