@uxda/appkit 4.1.62 → 4.2.0

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 (117) hide show
  1. package/.eslintrc.mjs +7 -7
  2. package/README.md +187 -187
  3. package/babel.config.js +12 -12
  4. package/dist/appkit.css +6 -8
  5. package/dist/index.js +49 -19
  6. package/package.json +79 -77
  7. package/project.config.json +15 -15
  8. package/project.tt.json +13 -13
  9. package/rollup.config.mjs +67 -56
  10. package/src/Appkit.ts +66 -66
  11. package/src/balance/api/endpoints.ts +133 -133
  12. package/src/balance/api/index.ts +106 -106
  13. package/src/balance/components/AccountView.vue +750 -749
  14. package/src/balance/components/BalanceCard.vue +215 -215
  15. package/src/balance/components/BalanceReminder.vue +85 -85
  16. package/src/balance/components/ConsumptionFilter.vue +218 -218
  17. package/src/balance/components/ConsumptionRules.vue +68 -68
  18. package/src/balance/components/DateFilter.vue +250 -250
  19. package/src/balance/components/DateRange.vue +80 -80
  20. package/src/balance/components/ListFilter.vue +62 -62
  21. package/src/balance/components/ListFilterPicker.vue +191 -191
  22. package/src/balance/components/PromoterCard.vue +237 -237
  23. package/src/balance/components/SecondBalance.vue +71 -71
  24. package/src/balance/components/Tip.vue +45 -45
  25. package/src/balance/components/index.ts +8 -8
  26. package/src/balance/types.ts +97 -97
  27. package/src/components/bt-cropper/index.vue +774 -774
  28. package/src/components/bt-cropper/utils/calcCropper.js +42 -42
  29. package/src/components/bt-cropper/utils/calcImagePosition.js +23 -23
  30. package/src/components/bt-cropper/utils/calcImageSize.js +37 -37
  31. package/src/components/bt-cropper/utils/calcPointDistance.js +12 -12
  32. package/src/components/bt-cropper/utils/calcRightAndBottom.js +7 -7
  33. package/src/components/bt-cropper/utils/ratio.js +3 -3
  34. package/src/components/bt-cropper/utils/tools.js +25 -25
  35. package/src/components/dd-area/index.vue +225 -225
  36. package/src/components/dd-icon/doc.md +21 -21
  37. package/src/components/dd-icon/index.vue +23 -23
  38. package/src/components/dd-notice-bar/index.vue +78 -78
  39. package/src/components/dd-search/doc.md +34 -34
  40. package/src/components/dd-search/index.vue +168 -168
  41. package/src/components/dd-selector/index.vue +124 -124
  42. package/src/components/dd-skeleton/doc.md +19 -19
  43. package/src/components/dd-skeleton/index.vue +36 -36
  44. package/src/global.ts +6 -6
  45. package/src/index.ts +89 -89
  46. package/src/main.scss +1 -1
  47. package/src/notice/api/endpoints.ts +17 -17
  48. package/src/notice/api/index.ts +106 -106
  49. package/src/notice/components/NoticeBanner.vue +243 -243
  50. package/src/notice/components/NoticeEntry.vue +99 -99
  51. package/src/notice/components/NoticeList.vue +315 -315
  52. package/src/notice/components/NoticePopup.vue +162 -162
  53. package/src/notice/components/index.ts +5 -5
  54. package/src/notice/components/useCommonList.ts +86 -86
  55. package/src/notice/components/useNotice.ts +35 -35
  56. package/src/notice/index.ts +1 -1
  57. package/src/notice/types.ts +25 -25
  58. package/src/payment/api/config.ts +7 -7
  59. package/src/payment/api/endpoints.ts +103 -103
  60. package/src/payment/api/index.ts +100 -100
  61. package/src/payment/components/AmountPicker.vue +90 -90
  62. package/src/payment/components/RechargeResult.vue +69 -69
  63. package/src/payment/components/RechargeView.vue +155 -155
  64. package/src/payment/components/RightsPicker.vue +105 -105
  65. package/src/payment/components/TradeView.vue +317 -317
  66. package/src/payment/components/UserAgreement.vue +234 -234
  67. package/src/payment/components/index.ts +22 -22
  68. package/src/payment/index.ts +5 -5
  69. package/src/payment/services/index.ts +16 -16
  70. package/src/payment/services/invoke-recharge.ts +25 -25
  71. package/src/payment/services/request-payment.ts +58 -58
  72. package/src/payment/types.ts +28 -28
  73. package/src/register/components/SelfRegistration.vue +233 -233
  74. package/src/register/components/index.ts +2 -2
  75. package/src/shared/components/AppDrawer.vue +54 -58
  76. package/src/shared/components/AppVerify.vue +128 -128
  77. package/src/shared/components/DeviceVersion.vue +68 -68
  78. package/src/shared/components/EmptyView.vue +33 -33
  79. package/src/shared/components/OcrBusinessLicense.vue +130 -130
  80. package/src/shared/components/OcrIcon.vue +202 -202
  81. package/src/shared/components/PageHeader.vue +79 -79
  82. package/src/shared/components/index.ts +8 -8
  83. package/src/shared/composables/index.ts +8 -8
  84. package/src/shared/composables/useAmount.ts +46 -46
  85. package/src/shared/composables/useCountdown.ts +46 -46
  86. package/src/shared/composables/useCrypto.ts +76 -76
  87. package/src/shared/composables/useDragBox.ts +97 -97
  88. package/src/shared/composables/useEncode.ts +43 -43
  89. package/src/shared/composables/useLogger.ts +123 -123
  90. package/src/shared/composables/useSafeArea.ts +46 -46
  91. package/src/shared/composables/useTabbar.ts +24 -24
  92. package/src/shared/composables/useUpload.ts +54 -54
  93. package/src/shared/composables/useValidator.ts +32 -31
  94. package/src/shared/http/Http.ts +136 -136
  95. package/src/shared/http/index.ts +1 -1
  96. package/src/shared/http/types.ts +157 -157
  97. package/src/shared/index.ts +3 -3
  98. package/src/shared/weixin/payment.ts +38 -38
  99. package/src/styles/vars.scss +3 -3
  100. package/src/user/api/endpoints.ts +17 -17
  101. package/src/user/api/index.ts +111 -111
  102. package/src/user/components/LoginSetting.vue +114 -114
  103. package/src/user/components/UserAuth.vue +238 -216
  104. package/src/user/components/UserBinding.vue +307 -307
  105. package/src/user/components/UserBindingSuccess.vue +80 -80
  106. package/src/user/components/UserEntry.vue +133 -133
  107. package/src/user/components/UserFeedback.vue +431 -431
  108. package/src/user/components/UserFeedbackEntry.vue +192 -192
  109. package/src/user/components/UserHeadCrop.vue +65 -65
  110. package/src/user/components/UserInfo.vue +732 -723
  111. package/src/user/components/UserResourceEmpty.vue +75 -75
  112. package/src/user/components/index.ts +23 -23
  113. package/src/user/index.ts +1 -1
  114. package/tsconfig.json +30 -30
  115. package/types/global.d.ts +21 -21
  116. package/types/vue.d.ts +10 -10
  117. package/dist/assets/asset-3B_CoPto +0 -1
@@ -1,215 +1,215 @@
1
- <template>
2
- <div class="account-card">
3
- <div class="card">
4
- <div class="card-row">
5
- <div class="card-row-left">
6
- <div class="bean-box">
7
- <div class="bean-icon-box">
8
- <img class="bean-icon" src="https://cdn.ddjf.com/static/images/bpms-workBench/gold-bean.png" />
9
- </div>
10
- <span class="baan-name">云豆</span>
11
- </div>
12
- <div class="bean-nums number">{{ formatAmount(balance.total || 0) }}</div>
13
- </div>
14
- <div class="card-row-right">
15
- <div class="account-info-entry" @click="gotoDetail">
16
- <div class="account-info-name">账户明细</div>
17
- <div class="account-info-icon">
18
- <img class="icon"
19
- src="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMzAiIHZpZXdCb3g9IjAgMCAzMCAzMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTE1IDI3LjVDMjEuOTAzNiAyNy41IDI3LjUgMjEuOTAzNiAyNy41IDE1QzI3LjUgOC4wOTY0NCAyMS45MDM2IDIuNSAxNSAyLjVDOC4wOTY0NCAyLjUgMi41IDguMDk2NDQgMi41IDE1QzIuNSAyMS45MDM2IDguMDk2NDQgMjcuNSAxNSAyNy41WiIgZmlsbD0iIzM1MzUzNSIgc3Ryb2tlPSIjMzUzNTM1IiBzdHJva2Utd2lkdGg9IjIuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTEgMTUuMTU2MkgxOS4zMTI1IiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjEuODQ3MjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTUuMTU2NyAxMUwxOS4zMTMgMTUuMTU2MkwxNS4xNTY3IDE5LjMxMjUiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iMS44NDcyMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+Cjwvc3ZnPgo=" />
20
- </div>
21
- </div>
22
- </div>
23
- </div>
24
- <!-- <div class="line"></div>
25
- <div class="card-row">
26
- <div class="card-row-left desc">权益使用时自动扣减云豆</div>
27
- <div class="card-row-right">
28
- <div class="pay" @click="gotoRecharge">
29
- <div>充值</div>
30
- <img
31
- class="pay-icon"
32
- src="https://cdn.ddjf.com/static/images/bpms-workBench/bean-right.png"
33
- />
34
- </div>
35
- </div>
36
- </div> -->
37
- </div>
38
- </div>
39
- </template>
40
-
41
- <script setup lang="ts">
42
- import { ref } from 'vue'
43
- import { endpoints, useHttp } from '../api'
44
- import { Balance } from '../types'
45
- import { useDidShow } from '@tarojs/taro'
46
- import { useAmount } from '../../shared/composables/useAmount'
47
-
48
- type BalanceCardProps = {
49
- app: string
50
- }
51
- const props = withDefaults(defineProps<BalanceCardProps>(), {
52
- app: '',
53
- })
54
-
55
- const { formatAmount } = useAmount()
56
- const balance = ref<Balance>({
57
- total: 0,
58
- privileges: [],
59
- })
60
-
61
- const gotoRecharge = () => {
62
- emit('recharge')
63
- }
64
-
65
- async function loadBalance() {
66
- const $http = useHttp()
67
- $http
68
- .get<Balance>(endpoints.获取余额明细, {
69
- app: props.app,
70
- })
71
- .then((data) => {
72
- // balance.value = data
73
- balance.value.total = data.total || (data.commonAccount as number)
74
- })
75
- }
76
-
77
- const emit = defineEmits([
78
- /**
79
- * 跳账户详情
80
- */
81
- 'drill',
82
- /**
83
- * 跳充值页
84
- */
85
- 'recharge',
86
- ])
87
-
88
- function gotoDetail() {
89
- emit('drill')
90
- }
91
-
92
- useDidShow(() => {
93
- loadBalance()
94
- })
95
-
96
- defineExpose({
97
- reload: loadBalance,
98
- })
99
- </script>
100
-
101
- <style lang="scss">
102
- .account-card {
103
- .card {
104
- background: linear-gradient(90deg, #FFEBC1 0%, #FFB875 100%);
105
- border-radius: 10px;
106
- padding: 14px 20px;
107
- margin: 0;
108
-
109
- .card-row {
110
- display: flex;
111
- justify-content: space-between;
112
- align-items: center;
113
-
114
- .card-row-left {
115
- display: flex;
116
- flex-direction: column;
117
-
118
- .bean-box {
119
- display: flex;
120
- align-items: center;
121
-
122
- .bean-icon-box {
123
- width: 20px;
124
- height: 20px;
125
- margin-right: 8px;
126
-
127
- .bean-icon {
128
- display: block;
129
- font-size: 0;
130
- width: 100%;
131
- height: 100%;
132
- }
133
- }
134
-
135
- .baan-name {
136
- color: #375264;
137
- font-size: 16px;
138
- }
139
- }
140
-
141
- .bean-nums {
142
- color: #353535;
143
- line-height: 25px;
144
- font-weight: bold;
145
- font-size: 20px;
146
- margin-top: 3px;
147
- }
148
- }
149
-
150
- .desc {
151
- font-size: 10px;
152
- color: #ccc;
153
- line-height: 14px;
154
- }
155
- }
156
-
157
- .line {
158
- margin: 6px 0px 8px 0px;
159
- height: 0.5px;
160
- background: rgb(195, 195, 195);
161
- opacity: 0.2;
162
- }
163
-
164
- .card-row-right {
165
- .pay {
166
- padding: 0 8px;
167
- line-height: 18px;
168
- color: #ffd6a5;
169
- border: 1px solid #ffd6a5;
170
- border-radius: 9px;
171
- font-size: 12px;
172
- display: flex;
173
- align-items: center;
174
-
175
- .pay-icon {
176
- display: block;
177
- font-size: 0;
178
- width: 3.5px;
179
- height: 6px;
180
- margin-left: 6px;
181
- }
182
- }
183
-
184
- .account-info-entry {
185
- display: flex;
186
- align-items: center;
187
- padding: 0 10px;
188
- height: 28px;
189
- line-height: 28px;
190
- border-radius: 14px;
191
- background: rgba(255, 255, 255, 0.8);
192
-
193
- .account-info-name {
194
- color: #353535;
195
- font-size: 13px;
196
- font-weight: 500;
197
- margin-right: 8px;
198
- }
199
-
200
- .account-info-icon {
201
- width: 15px;
202
- height: 15px;
203
-
204
- .icon {
205
- display: block;
206
- font-size: 0;
207
- width: 100%;
208
- height: 100%;
209
- }
210
- }
211
- }
212
- }
213
- }
214
- }
215
- </style>
1
+ <template>
2
+ <div class="account-card">
3
+ <div class="card">
4
+ <div class="card-row">
5
+ <div class="card-row-left">
6
+ <div class="bean-box">
7
+ <div class="bean-icon-box">
8
+ <img class="bean-icon" src="https://cdn.ddjf.com/static/images/bpms-workBench/gold-bean.png" />
9
+ </div>
10
+ <span class="baan-name">云豆</span>
11
+ </div>
12
+ <div class="bean-nums number">{{ formatAmount(balance.total || 0) }}</div>
13
+ </div>
14
+ <div class="card-row-right">
15
+ <div class="account-info-entry" @click="gotoDetail">
16
+ <div class="account-info-name">账户明细</div>
17
+ <div class="account-info-icon">
18
+ <img class="icon"
19
+ src="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAiIGhlaWdodD0iMzAiIHZpZXdCb3g9IjAgMCAzMCAzMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTE1IDI3LjVDMjEuOTAzNiAyNy41IDI3LjUgMjEuOTAzNiAyNy41IDE1QzI3LjUgOC4wOTY0NCAyMS45MDM2IDIuNSAxNSAyLjVDOC4wOTY0NCAyLjUgMi41IDguMDk2NDQgMi41IDE1QzIuNSAyMS45MDM2IDguMDk2NDQgMjcuNSAxNSAyNy41WiIgZmlsbD0iIzM1MzUzNSIgc3Ryb2tlPSIjMzUzNTM1IiBzdHJva2Utd2lkdGg9IjIuNSIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTEgMTUuMTU2MkgxOS4zMTI1IiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjEuODQ3MjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPgo8cGF0aCBkPSJNMTUuMTU2NyAxMUwxOS4zMTMgMTUuMTU2MkwxNS4xNTY3IDE5LjMxMjUiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iMS44NDcyMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+Cjwvc3ZnPgo=" />
20
+ </div>
21
+ </div>
22
+ </div>
23
+ </div>
24
+ <!-- <div class="line"></div>
25
+ <div class="card-row">
26
+ <div class="card-row-left desc">权益使用时自动扣减云豆</div>
27
+ <div class="card-row-right">
28
+ <div class="pay" @click="gotoRecharge">
29
+ <div>充值</div>
30
+ <img
31
+ class="pay-icon"
32
+ src="https://cdn.ddjf.com/static/images/bpms-workBench/bean-right.png"
33
+ />
34
+ </div>
35
+ </div>
36
+ </div> -->
37
+ </div>
38
+ </div>
39
+ </template>
40
+
41
+ <script setup lang="ts">
42
+ import { ref } from 'vue'
43
+ import { endpoints, useHttp } from '../api'
44
+ import { Balance } from '../types'
45
+ import { useDidShow } from '@tarojs/taro'
46
+ import { useAmount } from '../../shared/composables/useAmount'
47
+
48
+ type BalanceCardProps = {
49
+ app: string
50
+ }
51
+ const props = withDefaults(defineProps<BalanceCardProps>(), {
52
+ app: '',
53
+ })
54
+
55
+ const { formatAmount } = useAmount()
56
+ const balance = ref<Balance>({
57
+ total: 0,
58
+ privileges: [],
59
+ })
60
+
61
+ const gotoRecharge = () => {
62
+ emit('recharge')
63
+ }
64
+
65
+ async function loadBalance() {
66
+ const $http = useHttp()
67
+ $http
68
+ .get<Balance>(endpoints.获取余额明细, {
69
+ app: props.app,
70
+ })
71
+ .then((data) => {
72
+ // balance.value = data
73
+ balance.value.total = data.total || (data.commonAccount as number)
74
+ })
75
+ }
76
+
77
+ const emit = defineEmits([
78
+ /**
79
+ * 跳账户详情
80
+ */
81
+ 'drill',
82
+ /**
83
+ * 跳充值页
84
+ */
85
+ 'recharge',
86
+ ])
87
+
88
+ function gotoDetail() {
89
+ emit('drill')
90
+ }
91
+
92
+ useDidShow(() => {
93
+ loadBalance()
94
+ })
95
+
96
+ defineExpose({
97
+ reload: loadBalance,
98
+ })
99
+ </script>
100
+
101
+ <style lang="scss">
102
+ .account-card {
103
+ .card {
104
+ background: linear-gradient(90deg, #FFEBC1 0%, #FFB875 100%);
105
+ border-radius: 10px;
106
+ padding: 14px 20px;
107
+ margin: 0;
108
+
109
+ .card-row {
110
+ display: flex;
111
+ justify-content: space-between;
112
+ align-items: center;
113
+
114
+ .card-row-left {
115
+ display: flex;
116
+ flex-direction: column;
117
+
118
+ .bean-box {
119
+ display: flex;
120
+ align-items: center;
121
+
122
+ .bean-icon-box {
123
+ width: 20px;
124
+ height: 20px;
125
+ margin-right: 8px;
126
+
127
+ .bean-icon {
128
+ display: block;
129
+ font-size: 0;
130
+ width: 100%;
131
+ height: 100%;
132
+ }
133
+ }
134
+
135
+ .baan-name {
136
+ color: #375264;
137
+ font-size: 16px;
138
+ }
139
+ }
140
+
141
+ .bean-nums {
142
+ color: #353535;
143
+ line-height: 25px;
144
+ font-weight: bold;
145
+ font-size: 20px;
146
+ margin-top: 3px;
147
+ }
148
+ }
149
+
150
+ .desc {
151
+ font-size: 10px;
152
+ color: #ccc;
153
+ line-height: 14px;
154
+ }
155
+ }
156
+
157
+ .line {
158
+ margin: 6px 0px 8px 0px;
159
+ height: 0.5px;
160
+ background: rgb(195, 195, 195);
161
+ opacity: 0.2;
162
+ }
163
+
164
+ .card-row-right {
165
+ .pay {
166
+ padding: 0 8px;
167
+ line-height: 18px;
168
+ color: #ffd6a5;
169
+ border: 1px solid #ffd6a5;
170
+ border-radius: 9px;
171
+ font-size: 12px;
172
+ display: flex;
173
+ align-items: center;
174
+
175
+ .pay-icon {
176
+ display: block;
177
+ font-size: 0;
178
+ width: 3.5px;
179
+ height: 6px;
180
+ margin-left: 6px;
181
+ }
182
+ }
183
+
184
+ .account-info-entry {
185
+ display: flex;
186
+ align-items: center;
187
+ padding: 0 10px;
188
+ height: 28px;
189
+ line-height: 28px;
190
+ border-radius: 14px;
191
+ background: rgba(255, 255, 255, 0.8);
192
+
193
+ .account-info-name {
194
+ color: #353535;
195
+ font-size: 13px;
196
+ font-weight: 500;
197
+ margin-right: 8px;
198
+ }
199
+
200
+ .account-info-icon {
201
+ width: 15px;
202
+ height: 15px;
203
+
204
+ .icon {
205
+ display: block;
206
+ font-size: 0;
207
+ width: 100%;
208
+ height: 100%;
209
+ }
210
+ }
211
+ }
212
+ }
213
+ }
214
+ }
215
+ </style>
@@ -1,85 +1,85 @@
1
- <template>
2
- <nut-popup
3
- pop-class="balance-reminder-popup"
4
- round
5
- teleport="#app"
6
- :visible="modelValue"
7
- :close-on-click-overlay="false">
8
- <div class="balance-reminder">
9
- <div class="body">
10
- <h2>操作失败</h2>
11
- <p>您的账户可用余额不足,请充值后再进行查询</p>
12
- </div>
13
- <div class="footer">
14
- <div class="col">
15
- <nut-button
16
- class="cancel-button"
17
- @click="emit('update:modelValue', false)"
18
- block>取消</nut-button>
19
- </div>
20
- <div class="col">
21
- <nut-button block
22
- class="recharge-button"
23
- @click="emit('recharge')">{{buttonText}}</nut-button>
24
- </div>
25
- </div>
26
- </div>
27
- </nut-popup>
28
- </template>
29
-
30
- <script setup lang="ts">
31
- interface BalanceReminderProps {
32
- modelValue: boolean
33
- buttonText?: string
34
- }
35
-
36
- const emit = defineEmits(['recharge', 'update:modelValue'])
37
-
38
- withDefaults(
39
- defineProps<BalanceReminderProps>(), {
40
- modelValue: () => false,
41
- buttonText: '去充值'
42
- }
43
- )
44
- </script>
45
-
46
- <style lang="scss">
47
- .balance-reminder-popup {
48
- width: 90%;
49
- }
50
- .balance-reminder {
51
- --primary-button-background: linear-gradient(135deg, #098C9D 0%, #66BF97 100%);
52
- h2 {
53
- font-size: 16px;
54
- font-weight: bold;
55
- margin-bottom: 14px;
56
- }
57
- .body {
58
- height: 120px;
59
- box-sizing: border-box;
60
- display: flex;
61
- flex-direction: column;
62
- align-items: center;
63
- justify-content: center;
64
- padding: 20px 10px 10px 10px;
65
- font-size: 14px;
66
- text-align: center;
67
- color: #666;
68
- }
69
- .footer {
70
- display: flex;
71
- flex-direction: row;
72
- justify-content: stretch;
73
- align-items: center;
74
- padding: 10px 20px 20px 20px;
75
- .col {
76
- flex-grow: 1;
77
- padding: 6px;
78
- }
79
- .recharge-button {
80
- color: #fff;
81
- background: var(--primary-button-background);
82
- }
83
- }
84
- }
85
- </style>
1
+ <template>
2
+ <nut-popup
3
+ pop-class="balance-reminder-popup"
4
+ round
5
+ teleport="#app"
6
+ :visible="modelValue"
7
+ :close-on-click-overlay="false">
8
+ <div class="balance-reminder">
9
+ <div class="body">
10
+ <h2>操作失败</h2>
11
+ <p>您的账户可用余额不足,请充值后再进行查询</p>
12
+ </div>
13
+ <div class="footer">
14
+ <div class="col">
15
+ <nut-button
16
+ class="cancel-button"
17
+ @click="emit('update:modelValue', false)"
18
+ block>取消</nut-button>
19
+ </div>
20
+ <div class="col">
21
+ <nut-button block
22
+ class="recharge-button"
23
+ @click="emit('recharge')">{{buttonText}}</nut-button>
24
+ </div>
25
+ </div>
26
+ </div>
27
+ </nut-popup>
28
+ </template>
29
+
30
+ <script setup lang="ts">
31
+ interface BalanceReminderProps {
32
+ modelValue: boolean
33
+ buttonText?: string
34
+ }
35
+
36
+ const emit = defineEmits(['recharge', 'update:modelValue'])
37
+
38
+ withDefaults(
39
+ defineProps<BalanceReminderProps>(), {
40
+ modelValue: () => false,
41
+ buttonText: '去充值'
42
+ }
43
+ )
44
+ </script>
45
+
46
+ <style lang="scss">
47
+ .balance-reminder-popup {
48
+ width: 90%;
49
+ }
50
+ .balance-reminder {
51
+ --primary-button-background: linear-gradient(135deg, #098C9D 0%, #66BF97 100%);
52
+ h2 {
53
+ font-size: 16px;
54
+ font-weight: bold;
55
+ margin-bottom: 14px;
56
+ }
57
+ .body {
58
+ height: 120px;
59
+ box-sizing: border-box;
60
+ display: flex;
61
+ flex-direction: column;
62
+ align-items: center;
63
+ justify-content: center;
64
+ padding: 20px 10px 10px 10px;
65
+ font-size: 14px;
66
+ text-align: center;
67
+ color: #666;
68
+ }
69
+ .footer {
70
+ display: flex;
71
+ flex-direction: row;
72
+ justify-content: stretch;
73
+ align-items: center;
74
+ padding: 10px 20px 20px 20px;
75
+ .col {
76
+ flex-grow: 1;
77
+ padding: 6px;
78
+ }
79
+ .recharge-button {
80
+ color: #fff;
81
+ background: var(--primary-button-background);
82
+ }
83
+ }
84
+ }
85
+ </style>