@uxda/appkit 4.3.1 → 4.3.3

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 (131) hide show
  1. package/.eslintrc.mjs +7 -7
  2. package/COMPONENT_USAGE.md +1523 -0
  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 +48 -3
  7. package/dist/assets/asset-DcH8Kg-2 +1 -0
  8. package/dist/index.js +147 -78
  9. package/package.json +79 -82
  10. package/project.config.json +15 -15
  11. package/project.tt.json +13 -13
  12. package/rollup.config.mjs +78 -78
  13. package/src/Appkit.ts +72 -72
  14. package/src/balance/api/endpoints.ts +133 -133
  15. package/src/balance/api/index.ts +118 -118
  16. package/src/balance/components/AccountView.vue +770 -770
  17. package/src/balance/components/BalanceCard.vue +210 -210
  18. package/src/balance/components/BalanceReminder.vue +84 -84
  19. package/src/balance/components/ConsumptionFilter.vue +218 -218
  20. package/src/balance/components/ConsumptionRules.vue +68 -68
  21. package/src/balance/components/DateFilter.vue +259 -259
  22. package/src/balance/components/DateRange.vue +111 -111
  23. package/src/balance/components/ListFilter.vue +62 -62
  24. package/src/balance/components/ListFilterPicker.vue +191 -191
  25. package/src/balance/components/PromoterCard.vue +307 -307
  26. package/src/balance/components/SecondBalance.vue +77 -77
  27. package/src/balance/components/Tip.vue +45 -45
  28. package/src/balance/components/index.ts +8 -8
  29. package/src/balance/types.ts +99 -99
  30. package/src/components/bt-cropper/index.vue +730 -730
  31. package/src/components/bt-cropper/utils/calcCropper.js +42 -42
  32. package/src/components/bt-cropper/utils/calcImagePosition.js +23 -23
  33. package/src/components/bt-cropper/utils/calcImageSize.js +37 -37
  34. package/src/components/bt-cropper/utils/calcPointDistance.js +12 -12
  35. package/src/components/bt-cropper/utils/calcRightAndBottom.js +7 -7
  36. package/src/components/bt-cropper/utils/ratio.js +3 -3
  37. package/src/components/bt-cropper/utils/tools.js +25 -25
  38. package/src/components/dd-area/index.vue +225 -225
  39. package/src/components/dd-icon/doc.md +21 -21
  40. package/src/components/dd-icon/index.vue +23 -23
  41. package/src/components/dd-notice-bar/index.vue +78 -78
  42. package/src/components/dd-search/doc.md +34 -34
  43. package/src/components/dd-search/index.vue +168 -168
  44. package/src/components/dd-selector/index.vue +124 -124
  45. package/src/components/dd-skeleton/doc.md +19 -19
  46. package/src/components/dd-skeleton/index.vue +36 -36
  47. package/src/global.ts +6 -6
  48. package/src/index.ts +101 -101
  49. package/src/main.scss +1 -1
  50. package/src/notice/api/endpoints.ts +54 -54
  51. package/src/notice/api/index.ts +121 -121
  52. package/src/notice/components/NoticeBanner.vue +247 -247
  53. package/src/notice/components/NoticeEntry.vue +99 -99
  54. package/src/notice/components/NoticeList.vue +311 -311
  55. package/src/notice/components/NoticeList2.vue +398 -240
  56. package/src/notice/components/NoticePopup.vue +163 -163
  57. package/src/notice/components/index.ts +6 -6
  58. package/src/notice/components/useCommonList.ts +86 -86
  59. package/src/notice/components/useNotice.ts +35 -35
  60. package/src/notice/index.ts +1 -1
  61. package/src/notice/types.ts +25 -25
  62. package/src/payment/api/config.ts +7 -7
  63. package/src/payment/api/endpoints.ts +96 -96
  64. package/src/payment/api/index.ts +107 -107
  65. package/src/payment/components/AmountPicker.vue +90 -90
  66. package/src/payment/components/RechargeResult.vue +69 -69
  67. package/src/payment/components/RechargeView.vue +191 -191
  68. package/src/payment/components/RightsPicker.vue +105 -105
  69. package/src/payment/components/TradeView.vue +363 -363
  70. package/src/payment/components/UserAgreement.vue +234 -234
  71. package/src/payment/components/index.ts +22 -22
  72. package/src/payment/index.ts +5 -5
  73. package/src/payment/services/index.ts +16 -16
  74. package/src/payment/services/invoke-recharge.ts +25 -25
  75. package/src/payment/services/request-payment.ts +130 -130
  76. package/src/payment/types.ts +33 -33
  77. package/src/register/components/SelfRegistration.vue +233 -233
  78. package/src/register/components/index.ts +2 -2
  79. package/src/scenarios/components/SharePoster.vue +364 -364
  80. package/src/scenarios/components/index.ts +2 -2
  81. package/src/scenarios/components/poster-paste.vue +93 -93
  82. package/src/scenarios/components/share-poster.md +273 -273
  83. package/src/shared/components/AppDrawer.vue +53 -53
  84. package/src/shared/components/AppVerify.vue +128 -128
  85. package/src/shared/components/DeviceVersion.vue +78 -78
  86. package/src/shared/components/EmptyView.vue +33 -33
  87. package/src/shared/components/OcrBusinessLicense.vue +137 -137
  88. package/src/shared/components/OcrIcon.vue +229 -229
  89. package/src/shared/components/PageHeader.vue +84 -84
  90. package/src/shared/components/index.ts +8 -8
  91. package/src/shared/composables/index.ts +9 -9
  92. package/src/shared/composables/useAmount.ts +46 -46
  93. package/src/shared/composables/useCountdown.ts +46 -46
  94. package/src/shared/composables/useCrypto.ts +76 -76
  95. package/src/shared/composables/useDeviceEnv.ts +26 -26
  96. package/src/shared/composables/useDragBox.ts +97 -97
  97. package/src/shared/composables/useEncode.ts +43 -43
  98. package/src/shared/composables/useLogger.ts +144 -144
  99. package/src/shared/composables/useSafeArea.ts +46 -46
  100. package/src/shared/composables/useTabbar.ts +24 -24
  101. package/src/shared/composables/useUpload.ts +61 -61
  102. package/src/shared/composables/useValidator.ts +32 -32
  103. package/src/shared/composables/useWxAuth.ts +48 -48
  104. package/src/shared/http/Http.ts +148 -148
  105. package/src/shared/http/index.ts +1 -1
  106. package/src/shared/http/types.ts +163 -163
  107. package/src/shared/index.ts +9 -9
  108. package/src/shared/tracking/directives/index.ts +40 -40
  109. package/src/shared/tracking/examples/page-tracking-template.vue +27 -27
  110. package/src/shared/weixin/index.ts +9 -9
  111. package/src/shared/weixin/jssdk.ts +103 -103
  112. package/src/shared/weixin/payment.ts +38 -38
  113. package/src/styles/vars.scss +3 -3
  114. package/src/user/api/endpoints.ts +17 -17
  115. package/src/user/api/index.ts +123 -123
  116. package/src/user/components/LoginSetting.vue +114 -114
  117. package/src/user/components/UserAuth.vue +218 -218
  118. package/src/user/components/UserBinding.vue +277 -277
  119. package/src/user/components/UserBindingSuccess.vue +80 -80
  120. package/src/user/components/UserEntry.vue +139 -139
  121. package/src/user/components/UserFeedback.vue +427 -427
  122. package/src/user/components/UserFeedbackEntry.vue +175 -175
  123. package/src/user/components/UserHeadCrop.vue +65 -65
  124. package/src/user/components/UserInfo.vue +709 -709
  125. package/src/user/components/UserResourceEmpty.vue +75 -75
  126. package/src/user/components/index.ts +23 -23
  127. package/src/user/index.ts +1 -1
  128. package/src/utils/utils.ts +33 -33
  129. package/tsconfig.json +30 -30
  130. package/types/global.d.ts +22 -22
  131. package/types/vue.d.ts +10 -10
@@ -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'
@@ -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,22 +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
- }
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
+ }