@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,112 +1,112 @@
1
- <template>
2
- <div class="date-range" v-track-click="'日期范围-点击'" @click="openDateRangePicker">
3
- <div class="text">{{ dateRangeDisplay }}</div>
4
- <img style="margin-top: -2px" class="time-icon"
5
- src="https://cdn.ddjf.com/static/images/bpms-workBench/clound-bean-down.png" />
6
- </div>
7
-
8
- <nut-popup position="bottom" :style="{ height: '40%' }" round :close-on-click-overlay="true"
9
- v-model:visible="datePickerOpen">
10
- <date-filter :from="model.from" :to="model.to" @reset="onDateReset" @complete="onDateFilterComplete" />
11
- </nut-popup>
12
- </template>
13
-
14
- <script lang="ts" setup>
15
- import { computed, PropType, ref, watch } from 'vue'
16
- import { useNutshell } from '@uxda/nutshell/taro'
17
- import DateFilter from './DateFilter.vue'
18
- import dayjs from 'dayjs'
19
-
20
- const $n = useNutshell()
21
-
22
- export type DateRangeModel = {
23
- from: string,
24
- to: string
25
- }
26
-
27
- const model = defineModel({
28
- type: Object as PropType<DateRangeModel>,
29
- required: false,
30
- default: {
31
- from: dayjs().add(-1, 'M').format('YYYY-MM-DD'),
32
- to: dayjs().format('YYYY-MM-DD')
33
- }
34
- })
35
-
36
- // 时间筛选
37
- const datePickerOpen = ref<boolean>(false)
38
- function openDateRangePicker() {
39
- datePickerOpen.value = true
40
- }
41
- const onDateFilterComplete = (value) => {
42
- model.value = {
43
- from: value.from,
44
- to: value.to
45
- }
46
- datePickerOpen.value = false
47
- emit('complete', model.value)
48
- }
49
- function onDateReset() {
50
- model.value = {
51
- from: dayjs().add(-1, 'M').format('YYYY-MM-DD'),
52
- to: dayjs().format('YYYY-MM-DD')
53
- }
54
- datePickerOpen.value = false
55
- }
56
-
57
- const emit = defineEmits(['complete', 'reset'])
58
-
59
- // const openDateRangePicker = () => {
60
- // $n.sheet({
61
- // component: DateFilter,
62
- // class: 'ns-sheet-reset date-filter-sheet',
63
- // props: {
64
- // from: model.value.from,
65
- // to: model.value.to,
66
- // onReset() {
67
- // model.value.from = dayjs().add(-1, 'M').format('YYYY-MM-DD')
68
- // model.value.to = dayjs().format('YYYY-MM-DD')
69
- // }
70
- // },
71
- // modal: true, // 不允许点击 overlay 关闭弹窗
72
- // mask: true,
73
- // onComplete(result: any) {
74
- // model.value = {
75
- // from: result.from,
76
- // to: result.to
77
- // }
78
- // },
79
- // })
80
- // }
81
-
82
- const dateRangeDisplay = computed(() => {
83
- let startTime = (model.value.from || '').replace(/-/g, '.').substring(2)
84
- let endTime = (model.value.to || '').replace(/-/g, '.').substring(2)
85
- return startTime + '-' + endTime
86
- })
87
-
88
- </script>
89
-
90
- <style lang="scss">
91
- .date-range {
92
- height: 22px;
93
- padding-right: 5px;
94
- flex: 1;
95
- display: flex;
96
- align-items: center;
97
- justify-content: flex-end;
98
-
99
- .text {
100
- width: fit-content;
101
- white-space: nowrap;
102
- }
103
-
104
- .time-icon {
105
- display: block;
106
- font-size: 0;
107
- width: 12px;
108
- height: 12px;
109
- margin-left: 4px;
110
- }
111
- }
1
+ <template>
2
+ <div class="date-range" v-track-click="'日期范围-点击'" @click="openDateRangePicker">
3
+ <div class="text">{{ dateRangeDisplay }}</div>
4
+ <img style="margin-top: -2px" class="time-icon"
5
+ src="https://cdn.ddjf.com/static/images/bpms-workBench/clound-bean-down.png" />
6
+ </div>
7
+
8
+ <nut-popup position="bottom" :style="{ height: '40%' }" round :close-on-click-overlay="true"
9
+ v-model:visible="datePickerOpen">
10
+ <date-filter :from="model.from" :to="model.to" @reset="onDateReset" @complete="onDateFilterComplete" />
11
+ </nut-popup>
12
+ </template>
13
+
14
+ <script lang="ts" setup>
15
+ import { computed, PropType, ref, watch } from 'vue'
16
+ import { useNutshell } from '@uxda/nutshell/taro'
17
+ import DateFilter from './DateFilter.vue'
18
+ import dayjs from 'dayjs'
19
+
20
+ const $n = useNutshell()
21
+
22
+ export type DateRangeModel = {
23
+ from: string,
24
+ to: string
25
+ }
26
+
27
+ const model = defineModel({
28
+ type: Object as PropType<DateRangeModel>,
29
+ required: false,
30
+ default: {
31
+ from: dayjs().add(-1, 'M').format('YYYY-MM-DD'),
32
+ to: dayjs().format('YYYY-MM-DD')
33
+ }
34
+ })
35
+
36
+ // 时间筛选
37
+ const datePickerOpen = ref<boolean>(false)
38
+ function openDateRangePicker() {
39
+ datePickerOpen.value = true
40
+ }
41
+ const onDateFilterComplete = (value) => {
42
+ model.value = {
43
+ from: value.from,
44
+ to: value.to
45
+ }
46
+ datePickerOpen.value = false
47
+ emit('complete', model.value)
48
+ }
49
+ function onDateReset() {
50
+ model.value = {
51
+ from: dayjs().add(-1, 'M').format('YYYY-MM-DD'),
52
+ to: dayjs().format('YYYY-MM-DD')
53
+ }
54
+ datePickerOpen.value = false
55
+ }
56
+
57
+ const emit = defineEmits(['complete', 'reset'])
58
+
59
+ // const openDateRangePicker = () => {
60
+ // $n.sheet({
61
+ // component: DateFilter,
62
+ // class: 'ns-sheet-reset date-filter-sheet',
63
+ // props: {
64
+ // from: model.value.from,
65
+ // to: model.value.to,
66
+ // onReset() {
67
+ // model.value.from = dayjs().add(-1, 'M').format('YYYY-MM-DD')
68
+ // model.value.to = dayjs().format('YYYY-MM-DD')
69
+ // }
70
+ // },
71
+ // modal: true, // 不允许点击 overlay 关闭弹窗
72
+ // mask: true,
73
+ // onComplete(result: any) {
74
+ // model.value = {
75
+ // from: result.from,
76
+ // to: result.to
77
+ // }
78
+ // },
79
+ // })
80
+ // }
81
+
82
+ const dateRangeDisplay = computed(() => {
83
+ let startTime = (model.value.from || '').replace(/-/g, '.').substring(2)
84
+ let endTime = (model.value.to || '').replace(/-/g, '.').substring(2)
85
+ return startTime + '-' + endTime
86
+ })
87
+
88
+ </script>
89
+
90
+ <style lang="scss">
91
+ .date-range {
92
+ height: 22px;
93
+ padding-right: 5px;
94
+ flex: 1;
95
+ display: flex;
96
+ align-items: center;
97
+ justify-content: flex-end;
98
+
99
+ .text {
100
+ width: fit-content;
101
+ white-space: nowrap;
102
+ }
103
+
104
+ .time-icon {
105
+ display: block;
106
+ font-size: 0;
107
+ width: 12px;
108
+ height: 12px;
109
+ margin-left: 4px;
110
+ }
111
+ }
112
112
  </style>
@@ -1,63 +1,63 @@
1
- <template>
2
- <div class="list-filter" v-track-click="'筛选-点击'" @click="openPicker">
3
- <span class="text">筛选</span>
4
- <img class="icon" src="https://cdn.ddjf.com/static/images/bpms-workBench/clound-bean-select-icon.png" />
5
- </div>
6
- </template>
7
-
8
- <script lang="ts" setup>
9
- import { computed, PropType, reactive } from 'vue'
10
- import { useNutshell } from '@uxda/nutshell/taro'
11
- import ListFilterPicker from './ListFilterPicker.vue'
12
-
13
- const $n = useNutshell()
14
-
15
- export type ListFilterValue = {
16
- type: string,
17
- }
18
-
19
- const model = defineModel({
20
- type: Object as PropType<ListFilterValue>,
21
- default: {
22
- type: ''
23
- },
24
- required: false,
25
- })
26
-
27
- const emit = defineEmits<{
28
- (e: 'update:modelValue', v: ListFilterValue): void,
29
- (e: 'change'): void,
30
- }>()
31
-
32
- const openPicker = () => {
33
- $n.sheet({
34
- component: ListFilterPicker,
35
- class: 'ns-sheet-reset list-filter-sheet',
36
- props: {
37
- modelValue: model,
38
- onComplete: (result) => {
39
- emit('update:modelValue', {
40
- type: result[0]
41
- })
42
- }
43
- }
44
- })
45
- }
46
- </script>
47
-
48
- <style lang="scss">
49
- .list-filter {
50
- display: flex;
51
- align-items: center;
52
- height: 22px;
53
- padding-left: 5px;
54
-
55
- .icon {
56
- display: block;
57
- font-size: 0;
58
- width: 12px;
59
- height: 12px;
60
- margin-left: 4px;
61
- }
62
- }
1
+ <template>
2
+ <div class="list-filter" v-track-click="'筛选-点击'" @click="openPicker">
3
+ <span class="text">筛选</span>
4
+ <img class="icon" src="https://cdn.ddjf.com/static/images/bpms-workBench/clound-bean-select-icon.png" />
5
+ </div>
6
+ </template>
7
+
8
+ <script lang="ts" setup>
9
+ import { computed, PropType, reactive } from 'vue'
10
+ import { useNutshell } from '@uxda/nutshell/taro'
11
+ import ListFilterPicker from './ListFilterPicker.vue'
12
+
13
+ const $n = useNutshell()
14
+
15
+ export type ListFilterValue = {
16
+ type: string,
17
+ }
18
+
19
+ const model = defineModel({
20
+ type: Object as PropType<ListFilterValue>,
21
+ default: {
22
+ type: ''
23
+ },
24
+ required: false,
25
+ })
26
+
27
+ const emit = defineEmits<{
28
+ (e: 'update:modelValue', v: ListFilterValue): void,
29
+ (e: 'change'): void,
30
+ }>()
31
+
32
+ const openPicker = () => {
33
+ $n.sheet({
34
+ component: ListFilterPicker,
35
+ class: 'ns-sheet-reset list-filter-sheet',
36
+ props: {
37
+ modelValue: model,
38
+ onComplete: (result) => {
39
+ emit('update:modelValue', {
40
+ type: result[0]
41
+ })
42
+ }
43
+ }
44
+ })
45
+ }
46
+ </script>
47
+
48
+ <style lang="scss">
49
+ .list-filter {
50
+ display: flex;
51
+ align-items: center;
52
+ height: 22px;
53
+ padding-left: 5px;
54
+
55
+ .icon {
56
+ display: block;
57
+ font-size: 0;
58
+ width: 12px;
59
+ height: 12px;
60
+ margin-left: 4px;
61
+ }
62
+ }
63
63
  </style>