@uxda/appkit 4.3.8 → 4.3.11

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 -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 +3 -48
  7. package/dist/index.js +84 -152
  8. package/package.json +82 -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 +307 -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 +240 -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 +86 -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 +96 -96
  63. package/src/payment/api/index.ts +107 -107
  64. package/src/payment/components/AmountPicker.vue +90 -90
  65. package/src/payment/components/RechargeResult.vue +69 -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 +365 -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 +130 -130
  75. package/src/payment/types.ts +33 -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 +128 -128
  84. package/src/shared/components/DeviceVersion.vue +78 -78
  85. package/src/shared/components/EmptyView.vue +33 -33
  86. package/src/shared/components/OcrBusinessLicense.vue +137 -137
  87. package/src/shared/components/OcrIcon.vue +229 -229
  88. package/src/shared/components/PageHeader.vue +84 -84
  89. package/src/shared/components/index.ts +8 -8
  90. package/src/shared/composables/index.ts +9 -9
  91. package/src/shared/composables/useAmount.ts +46 -46
  92. package/src/shared/composables/useCountdown.ts +46 -46
  93. package/src/shared/composables/useCrypto.ts +76 -76
  94. package/src/shared/composables/useDeviceEnv.ts +26 -26
  95. package/src/shared/composables/useDragBox.ts +97 -97
  96. package/src/shared/composables/useEncode.ts +43 -43
  97. package/src/shared/composables/useLogger.ts +144 -144
  98. package/src/shared/composables/useSafeArea.ts +46 -46
  99. package/src/shared/composables/useTabbar.ts +24 -24
  100. package/src/shared/composables/useUpload.ts +61 -61
  101. package/src/shared/composables/useValidator.ts +32 -32
  102. package/src/shared/composables/useWxAuth.ts +48 -48
  103. package/src/shared/http/Http.ts +148 -148
  104. package/src/shared/http/index.ts +1 -1
  105. package/src/shared/http/types.ts +163 -163
  106. package/src/shared/index.ts +9 -9
  107. package/src/shared/tracking/directives/index.ts +40 -40
  108. package/src/shared/tracking/examples/page-tracking-template.vue +27 -27
  109. package/src/shared/weixin/index.ts +9 -9
  110. package/src/shared/weixin/jssdk.ts +103 -103
  111. package/src/shared/weixin/payment.ts +38 -38
  112. package/src/styles/vars.scss +3 -3
  113. package/src/user/api/endpoints.ts +17 -17
  114. package/src/user/api/index.ts +123 -123
  115. package/src/user/components/LoginSetting.vue +114 -114
  116. package/src/user/components/UserAuth.vue +218 -218
  117. package/src/user/components/UserBinding.vue +277 -277
  118. package/src/user/components/UserBindingSuccess.vue +80 -80
  119. package/src/user/components/UserEntry.vue +139 -139
  120. package/src/user/components/UserFeedback.vue +427 -427
  121. package/src/user/components/UserFeedbackEntry.vue +175 -175
  122. package/src/user/components/UserHeadCrop.vue +65 -65
  123. package/src/user/components/UserInfo.vue +709 -709
  124. package/src/user/components/UserResourceEmpty.vue +75 -75
  125. package/src/user/components/index.ts +23 -23
  126. package/src/user/index.ts +1 -1
  127. package/src/utils/utils.ts +33 -33
  128. package/tsconfig.json +30 -30
  129. package/types/global.d.ts +22 -22
  130. package/types/vue.d.ts +10 -10
  131. package/dist/assets/asset-DcH8Kg-2 +0 -1
@@ -1,259 +1,259 @@
1
- <template>
2
- <div class="appkit-date-filter">
3
- <div class="date-filter-header">日期选择</div>
4
- <div class="content">
5
- <div class="title">自定义</div>
6
- <div class="time">
7
- <div class="item" :class="focused === 'from' ? 'current' : ''" @click="switchDateInput('from')">
8
- {{ formatDate(result.from) }}
9
- </div>
10
- <div class="line">-</div>
11
- <div class="item" :class="focused === 'to' ? 'current' : ''" @click="switchDateInput('to')">
12
- {{ formatDate(result.to) }}
13
- </div>
14
- </div>
15
- </div>
16
- <div class="buttons spa-between">
17
- <div class="btn" @click="reset">重置</div>
18
- <div class="btn confirm" v-track-click="'日期选择-确定'" @click="onOkClick">确定</div>
19
- </div>
20
- <div class="bottom"></div>
21
- <nut-popup v-model:visible="datePickerOpen" class="appkit-date-filter-picker-popup" position="bottom"
22
- overlay-class="appkit-date-filter-picker-overlay">
23
- <nut-date-picker v-model="focusedDate" :min-date="minDate" :max-date="maxDate" :is-show-chinese="false"
24
- :three-dimensional="false" @cancel="onDatePickerCancel" @confirm="onDatePickerComplete" />
25
- </nut-popup>
26
- </div>
27
- </template>
28
-
29
- <script lang="ts" setup>
30
- import { reactive, ref, watch } from 'vue'
31
- import { usePopup } from '@uxda/nutshell/taro'
32
-
33
- type DateFilterProps = {
34
- from: string
35
- to: string
36
- }
37
-
38
- const props = defineProps<DateFilterProps>()
39
-
40
- const emit = defineEmits(['complete', 'reset']),
41
- state = usePopup()
42
-
43
-
44
- /**
45
- * 日期范围结果
46
- */
47
- const result = reactive<DateFilterProps>({ ...props })
48
-
49
- watch(
50
- () => `${props.from}${props.to}`,
51
- () => {
52
- result.from = props.from
53
- result.to = props.to
54
- }
55
- )
56
-
57
-
58
- /**
59
- * 目前激活的日期输入框
60
- */
61
- const focused = ref<string>('from')
62
- const focusedDate = ref<any>(props.from)
63
-
64
- const minDate = ref<any>()
65
- const maxDate = ref<Date>(new Date())
66
- const datePickerOpen = ref<boolean>(false)
67
-
68
- if (state) {
69
- state.beforeClose = () => {
70
- datePickerOpen.value = false
71
- return true
72
- }
73
- }
74
-
75
- /**
76
- * 日期重置
77
- */
78
- function reset() {
79
- emit('reset')
80
- }
81
-
82
- /**
83
- * 确认,提交新时间
84
- */
85
- function onOkClick() {
86
- emit('complete', result)
87
- }
88
-
89
- function formatDate(date: string) {
90
- const [year, month, day] = date.split('-')
91
- return year + '年' + month + '月' + day + '日'
92
- }
93
-
94
- function onDatePickerComplete({ selectedValue, selectedOptions }) {
95
- let time = selectedOptions.map((val: any) => val.text).join('-')
96
- if (focused.value === 'from') {
97
- // 如果选择的时间比结束时间大,结束时间改为开始时间
98
- result.from = new Date(time) > new Date(result.to) ? result.to : time
99
- } else {
100
- result.to = time
101
- }
102
- datePickerOpen.value = false
103
- if (state) {
104
- state.couldClose = true
105
- }
106
- }
107
-
108
- function onDatePickerCancel() {
109
- datePickerOpen.value = false
110
- if (state) {
111
- state.couldClose = true
112
- }
113
- }
114
-
115
- /**
116
- * 切换时间逻辑:初始化时有时间,默认聚焦开始时间
117
- * 当选择开始时间大于结束时间,结束时间改为开始时间
118
- * 时间选择器都要小于当前时间,结束时间的时间选择器要以开始时间为最小值,
119
- */
120
- function switchDateInput(shift: string) {
121
- // 要设置一下结束时间的起始值 开始时间往前倒5年
122
- if (shift === 'from') {
123
- let time = result.from.split('-').map(Number)
124
- minDate.value = new Date(time[0] - 5, 1, 1)
125
- } else {
126
- let time = result.from.split('-').map(Number)
127
- minDate.value = new Date(time[0], time[1] - 1, time[2])
128
- }
129
- focusedDate.value = new Date(result[shift])
130
- focused.value = shift
131
- datePickerOpen.value = true
132
- // 不允许浮窗关闭
133
- if (state) {
134
- state.couldClose = false
135
- }
136
- }
137
- </script>
138
-
139
- <style lang="scss">
140
- .appkit-date-filter {
141
- height: 100%;
142
- display: flex;
143
- flex-direction: column;
144
- width: 100%;
145
- position: relative;
146
-
147
- .date-filter-header {
148
- text-align: center;
149
- height: 44px;
150
- line-height: 44px;
151
- color: #353535;
152
- font-size: 17px;
153
- background-color: #f5f5f5;
154
- }
155
-
156
- .content {
157
- flex: 1;
158
- margin: 15px;
159
- overflow-y: scroll;
160
- color: #353535;
161
- font-size: 13px;
162
-
163
- .title {
164
- opacity: 0.6;
165
- line-height: 18px;
166
- }
167
-
168
- .info {
169
- display: grid;
170
- grid-template-columns: 1fr 1fr 1fr;
171
- grid-gap: 10px;
172
- margin: 10px 0;
173
-
174
- .item {
175
- height: 30px;
176
- line-height: 30px;
177
- border: 1px solid #ccc;
178
- border-radius: 6px;
179
- text-align: center;
180
- }
181
-
182
- .current {
183
- border: 1px solid;
184
- border-image-source: linear-gradient(180deg,
185
- rgba(239, 208, 130, 0.8) 0%,
186
- rgba(255, 185, 120, 0.8) 100%);
187
- background: linear-gradient(180deg,
188
- rgba(239, 208, 130, 0.8) 0%,
189
- rgba(255, 185, 120, 0.8) 100%),
190
- linear-gradient(180deg, #fff7e3 0%, #fefde6 100%);
191
- }
192
- }
193
- }
194
-
195
- .buttons {
196
- margin: 32px 15px 0 15px;
197
- display: flex;
198
- justify-content: space-between;
199
- align-items: center;
200
-
201
- .btn {
202
- flex: 1;
203
- height: 40px;
204
- line-height: 40px;
205
- text-align: center;
206
- border: 1px solid #ccc;
207
- box-sizing: border-box;
208
- color: #666;
209
- font-size: 16px;
210
- border-radius: 6px;
211
- }
212
-
213
- .confirm {
214
- margin-left: 11px;
215
- color: #fff;
216
- border: none;
217
- background: #017FFF;
218
- }
219
- }
220
-
221
- .time {
222
- display: flex;
223
- justify-content: flex-start;
224
- align-items: center;
225
- margin: 10px 0 30px 0;
226
-
227
- .line {
228
- margin: 0 8px;
229
- }
230
-
231
- .item {
232
- height: 30px;
233
- line-height: 30px;
234
- padding: 0 15px;
235
- font-size: 13px;
236
- color: #353535;
237
- border: 1px solid transparent;
238
- box-sizing: border-box;
239
- background: rgba(#f5f5f5, 0.8);
240
- border-radius: 6px;
241
- }
242
-
243
- .current {
244
- border: 1px solid #353535;
245
- }
246
- }
247
-
248
- .bottom {
249
- height: 32px;
250
- background: #fff;
251
- }
252
- }
253
-
254
- .nut-overlay {
255
- &.date-filter-picker-overlay {
256
- height: 100vh;
257
- }
258
- }
259
- </style>
1
+ <template>
2
+ <div class="appkit-date-filter">
3
+ <div class="date-filter-header">日期选择</div>
4
+ <div class="content">
5
+ <div class="title">自定义</div>
6
+ <div class="time">
7
+ <div class="item" :class="focused === 'from' ? 'current' : ''" @click="switchDateInput('from')">
8
+ {{ formatDate(result.from) }}
9
+ </div>
10
+ <div class="line">-</div>
11
+ <div class="item" :class="focused === 'to' ? 'current' : ''" @click="switchDateInput('to')">
12
+ {{ formatDate(result.to) }}
13
+ </div>
14
+ </div>
15
+ </div>
16
+ <div class="buttons spa-between">
17
+ <div class="btn" @click="reset">重置</div>
18
+ <div class="btn confirm" v-track-click="'日期选择-确定'" @click="onOkClick">确定</div>
19
+ </div>
20
+ <div class="bottom"></div>
21
+ <nut-popup v-model:visible="datePickerOpen" class="appkit-date-filter-picker-popup" position="bottom"
22
+ overlay-class="appkit-date-filter-picker-overlay">
23
+ <nut-date-picker v-model="focusedDate" :min-date="minDate" :max-date="maxDate" :is-show-chinese="false"
24
+ :three-dimensional="false" @cancel="onDatePickerCancel" @confirm="onDatePickerComplete" />
25
+ </nut-popup>
26
+ </div>
27
+ </template>
28
+
29
+ <script lang="ts" setup>
30
+ import { reactive, ref, watch } from 'vue'
31
+ import { usePopup } from '@uxda/nutshell/taro'
32
+
33
+ type DateFilterProps = {
34
+ from: string
35
+ to: string
36
+ }
37
+
38
+ const props = defineProps<DateFilterProps>()
39
+
40
+ const emit = defineEmits(['complete', 'reset']),
41
+ state = usePopup()
42
+
43
+
44
+ /**
45
+ * 日期范围结果
46
+ */
47
+ const result = reactive<DateFilterProps>({ ...props })
48
+
49
+ watch(
50
+ () => `${props.from}${props.to}`,
51
+ () => {
52
+ result.from = props.from
53
+ result.to = props.to
54
+ }
55
+ )
56
+
57
+
58
+ /**
59
+ * 目前激活的日期输入框
60
+ */
61
+ const focused = ref<string>('from')
62
+ const focusedDate = ref<any>(props.from)
63
+
64
+ const minDate = ref<any>()
65
+ const maxDate = ref<Date>(new Date())
66
+ const datePickerOpen = ref<boolean>(false)
67
+
68
+ if (state) {
69
+ state.beforeClose = () => {
70
+ datePickerOpen.value = false
71
+ return true
72
+ }
73
+ }
74
+
75
+ /**
76
+ * 日期重置
77
+ */
78
+ function reset() {
79
+ emit('reset')
80
+ }
81
+
82
+ /**
83
+ * 确认,提交新时间
84
+ */
85
+ function onOkClick() {
86
+ emit('complete', result)
87
+ }
88
+
89
+ function formatDate(date: string) {
90
+ const [year, month, day] = date.split('-')
91
+ return year + '年' + month + '月' + day + '日'
92
+ }
93
+
94
+ function onDatePickerComplete({ selectedValue, selectedOptions }) {
95
+ let time = selectedOptions.map((val: any) => val.text).join('-')
96
+ if (focused.value === 'from') {
97
+ // 如果选择的时间比结束时间大,结束时间改为开始时间
98
+ result.from = new Date(time) > new Date(result.to) ? result.to : time
99
+ } else {
100
+ result.to = time
101
+ }
102
+ datePickerOpen.value = false
103
+ if (state) {
104
+ state.couldClose = true
105
+ }
106
+ }
107
+
108
+ function onDatePickerCancel() {
109
+ datePickerOpen.value = false
110
+ if (state) {
111
+ state.couldClose = true
112
+ }
113
+ }
114
+
115
+ /**
116
+ * 切换时间逻辑:初始化时有时间,默认聚焦开始时间
117
+ * 当选择开始时间大于结束时间,结束时间改为开始时间
118
+ * 时间选择器都要小于当前时间,结束时间的时间选择器要以开始时间为最小值,
119
+ */
120
+ function switchDateInput(shift: string) {
121
+ // 要设置一下结束时间的起始值 开始时间往前倒5年
122
+ if (shift === 'from') {
123
+ let time = result.from.split('-').map(Number)
124
+ minDate.value = new Date(time[0] - 5, 1, 1)
125
+ } else {
126
+ let time = result.from.split('-').map(Number)
127
+ minDate.value = new Date(time[0], time[1] - 1, time[2])
128
+ }
129
+ focusedDate.value = new Date(result[shift])
130
+ focused.value = shift
131
+ datePickerOpen.value = true
132
+ // 不允许浮窗关闭
133
+ if (state) {
134
+ state.couldClose = false
135
+ }
136
+ }
137
+ </script>
138
+
139
+ <style lang="scss">
140
+ .appkit-date-filter {
141
+ height: 100%;
142
+ display: flex;
143
+ flex-direction: column;
144
+ width: 100%;
145
+ position: relative;
146
+
147
+ .date-filter-header {
148
+ text-align: center;
149
+ height: 44px;
150
+ line-height: 44px;
151
+ color: #353535;
152
+ font-size: 17px;
153
+ background-color: #f5f5f5;
154
+ }
155
+
156
+ .content {
157
+ flex: 1;
158
+ margin: 15px;
159
+ overflow-y: scroll;
160
+ color: #353535;
161
+ font-size: 13px;
162
+
163
+ .title {
164
+ opacity: 0.6;
165
+ line-height: 18px;
166
+ }
167
+
168
+ .info {
169
+ display: grid;
170
+ grid-template-columns: 1fr 1fr 1fr;
171
+ grid-gap: 10px;
172
+ margin: 10px 0;
173
+
174
+ .item {
175
+ height: 30px;
176
+ line-height: 30px;
177
+ border: 1px solid #ccc;
178
+ border-radius: 6px;
179
+ text-align: center;
180
+ }
181
+
182
+ .current {
183
+ border: 1px solid;
184
+ border-image-source: linear-gradient(180deg,
185
+ rgba(239, 208, 130, 0.8) 0%,
186
+ rgba(255, 185, 120, 0.8) 100%);
187
+ background: linear-gradient(180deg,
188
+ rgba(239, 208, 130, 0.8) 0%,
189
+ rgba(255, 185, 120, 0.8) 100%),
190
+ linear-gradient(180deg, #fff7e3 0%, #fefde6 100%);
191
+ }
192
+ }
193
+ }
194
+
195
+ .buttons {
196
+ margin: 32px 15px 0 15px;
197
+ display: flex;
198
+ justify-content: space-between;
199
+ align-items: center;
200
+
201
+ .btn {
202
+ flex: 1;
203
+ height: 40px;
204
+ line-height: 40px;
205
+ text-align: center;
206
+ border: 1px solid #ccc;
207
+ box-sizing: border-box;
208
+ color: #666;
209
+ font-size: 16px;
210
+ border-radius: 6px;
211
+ }
212
+
213
+ .confirm {
214
+ margin-left: 11px;
215
+ color: #fff;
216
+ border: none;
217
+ background: #017FFF;
218
+ }
219
+ }
220
+
221
+ .time {
222
+ display: flex;
223
+ justify-content: flex-start;
224
+ align-items: center;
225
+ margin: 10px 0 30px 0;
226
+
227
+ .line {
228
+ margin: 0 8px;
229
+ }
230
+
231
+ .item {
232
+ height: 30px;
233
+ line-height: 30px;
234
+ padding: 0 15px;
235
+ font-size: 13px;
236
+ color: #353535;
237
+ border: 1px solid transparent;
238
+ box-sizing: border-box;
239
+ background: rgba(#f5f5f5, 0.8);
240
+ border-radius: 6px;
241
+ }
242
+
243
+ .current {
244
+ border: 1px solid #353535;
245
+ }
246
+ }
247
+
248
+ .bottom {
249
+ height: 32px;
250
+ background: #fff;
251
+ }
252
+ }
253
+
254
+ .nut-overlay {
255
+ &.date-filter-picker-overlay {
256
+ height: 100vh;
257
+ }
258
+ }
259
+ </style>