Ver Fonte

弹框ui优化,实名认证校验

cc0011 há 6 dias atrás
pai
commit
4db5f70e6a
3 ficheiros alterados com 174 adições e 31 exclusões
  1. 69 15
      src/views/Mention.vue
  2. 67 14
      src/views/Share.vue
  3. 38 2
      src/views/Signin.vue

+ 69 - 15
src/views/Mention.vue

@@ -87,12 +87,25 @@
         <button class="dialog-btn auth-btn" @click="goToAuth">去认证</button>
       </div>
     </div>
+
+    <!-- 通用提示弹窗 -->
+    <div v-if="showTipsDialog" class="custom-dialog-mask">
+      <div class="custom-dialog tips-dialog">
+        <div class="dialog-close" @click="showTipsDialog = false">
+          <i class="close-icon"></i>
+        </div>
+        <div class="dialog-title">温馨提示</div>
+        <div class="dialog-content">{{ tipsMessage }}</div>
+        <button class="dialog-btn tips-btn" @click="showTipsDialog = false">确定</button>
+      </div>
+    </div>
   </div>
 </template>
 
 <script>
 import { getUserInfo } from '@/api/home';
 import { withdrawCoin } from '@/api/profile';
+
 export default {
   name: 'Mention',
   data() {
@@ -102,28 +115,46 @@ export default {
       password: '',
       showPassword: false,
       type: '',
-      showAuthDialog: false
+      showAuthDialog: false,
+      showTipsDialog: false,
+      tipsMessage: ''
     }
   },
   computed: {
     minWithdrawAmount() {
       switch(this.type) {
-        case '1':
+        case '1':  // coins
           return 10000;
-        case '2':
+        case '2':  // money
           return 10000;
+        case '3':  // txbt
+          return 20;
+        case '4':  // dyxz
+          return 20;
+        case '5':  // dayred
+          return 20;
+        case '6':  // guquan
+          return 20;
         default:
           return 20;
       }
     },
     availableBalance() {
       switch(this.type) {
-        case '1':
+        case '1':  
           return this.userInfo.coins || 0;
         case '2':
+          return this.userInfo.txbt|| 0;
+        case '3': 
+          return this.userInfo.dyxz || 0;
+        case '4':  
+          return this.userInfo.dayred || 0;
+        case '5':  
           return this.userInfo.money || 0;
+        case '6':  
+          return this.userInfo.guquan || 0;
         default:
-          return this.userInfo.dayred || 0;
+          return 0;
       }
     }
   },
@@ -146,23 +177,27 @@ export default {
     togglePassword() {
       this.showPassword = !this.showPassword;
     },
+    showTips(message) {
+      this.tipsMessage = message;
+      this.showTipsDialog = true;
+    },
     async handleWithdraw() {
       // 检查实名认证
-      if (this.userInfo.if_real === 0) {
-        this.showAuthDialog = true;
-        return;
-      }
+      // if (this.userInfo.if_real === 0) {
+      //   this.showAuthDialog = true;
+      //   return;
+      // }
 
       if (!this.amount) {
-        alert('请输入提现金额');
+        this.showTips('请输入提现金额');
         return;
       }
       if (this.amount < this.minWithdrawAmount) {
-        alert(`提现金额不能小于${this.minWithdrawAmount}元`);
+        this.showTips(`提现金额不能小于${this.minWithdrawAmount}元`);
         return;
       }
       if (!this.password) {
-        alert('请输入登录密码');
+        this.showTips('请输入登录密码');
         return;
       }
 
@@ -176,14 +211,14 @@ export default {
         let res = await withdrawCoin(params);
         
         if(res.code == 1){
-          alert('提现申请已提交')
+          this.showTips('提现申请已提交');
         }else{
-          alert(res.msg)
+          this.showTips(res.msg);
         }
         await this.getUserInfo();
       } catch (error) {
         console.error('提现失败:', error);
-        alert('提现失败,请重试');
+        this.showTips('提现失败,请重试');
       }
     },
     goToAuth() {
@@ -431,4 +466,23 @@ export default {
 .dialog-close .close-icon::after {
   transform: rotate(-45deg);
 }
+
+.tips-dialog {
+  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
+}
+
+.tips-btn {
+  background: #ed4b39;
+}
+
+.tips-btn:hover {
+  background: #d43b2a;
+}
+
+.dialog-title {
+  font-size: 18px;
+  font-weight: 500;
+  margin-bottom: 12px;
+  color: #333;
+}
 </style> 

+ 67 - 14
src/views/Share.vue

@@ -80,6 +80,42 @@
         <button class="dialog-btn auth-btn" @click="goToAuth">去认证</button>
       </div>
     </div>
+
+    <!-- 二维码保存成功提示弹窗 -->
+    <div v-if="showQrSavedDialog" class="custom-dialog-mask">
+      <div class="custom-dialog success-dialog">
+        <div class="dialog-close" @click="showQrSavedDialog = false">
+          <i class="close-icon"></i>
+        </div>
+        <div class="dialog-icon">
+          <svg t="1710400631664" class="success-icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4266">
+            <path d="M512 512m-448 0a448 448 0 1 0 896 0 448 448 0 1 0-896 0Z" fill="#52C41A" p-id="4267"></path>
+            <path d="M466.7 679.8c-8.5 0-16.6-3.4-22.6-9.4l-181-181.1c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l158.4 158.4 249.7-249.6c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L489.3 670.4c-6 6-14.1 9.4-22.6 9.4z" fill="#FFFFFF" p-id="4268"></path>
+          </svg>
+        </div>
+        <div class="dialog-title success-title">保存成功</div>
+        <div class="dialog-content">二维码已成功保存到本地</div>
+        <button class="dialog-btn success-btn" @click="showQrSavedDialog = false">确定</button>
+      </div>
+    </div>
+
+    <!-- 链接复制成功提示弹窗 -->
+    <div v-if="showLinkCopiedDialog" class="custom-dialog-mask">
+      <div class="custom-dialog success-dialog">
+        <div class="dialog-close" @click="showLinkCopiedDialog = false">
+          <i class="close-icon"></i>
+        </div>
+        <div class="dialog-icon">
+          <svg t="1710400631664" class="success-icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4266">
+            <path d="M512 512m-448 0a448 448 0 1 0 896 0 448 448 0 1 0-896 0Z" fill="#52C41A" p-id="4267"></path>
+            <path d="M466.7 679.8c-8.5 0-16.6-3.4-22.6-9.4l-181-181.1c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l158.4 158.4 249.7-249.6c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L489.3 670.4c-6 6-14.1 9.4-22.6 9.4z" fill="#FFFFFF" p-id="4268"></path>
+          </svg>
+        </div>
+        <div class="dialog-title success-title">复制成功</div>
+        <div class="dialog-content">邀请链接已成功复制到剪贴板</div>
+        <button class="dialog-btn success-btn" @click="showLinkCopiedDialog = false">确定</button>
+      </div>
+    </div>
   </div>
 </template>
 
@@ -102,7 +138,9 @@ export default {
         { people: 100, money: 168, coins: 1200 },
         { people: 200, money: 268, coins: 2000 }
       ],
-      showAuthDialog: false
+      showAuthDialog: false,
+      showQrSavedDialog: false,
+      showLinkCopiedDialog: false
     }
   },
   computed: {
@@ -150,11 +188,6 @@ export default {
       }
     },
     saveQRCode() {
-      // 检查实名认证状态
-      if (this.userInfo.if_real === 0) {
-        this.showAuthDialog = true;
-        return;
-      }
 
       // Create a temporary link to download the QR code
       const link = document.createElement('a');
@@ -163,15 +196,9 @@ export default {
       document.body.appendChild(link);
       link.click();
       document.body.removeChild(link);
-      alert('二维码已保存');
+      this.showQrSavedDialog = true;
     },
     copyLink() {
-      // 检查实名认证状态
-      if (this.userInfo.if_real === 0) {
-        this.showAuthDialog = true;
-        return;
-      }
-
       // Copy link to clipboard
       const textarea = document.createElement('textarea');
       textarea.value = this.inviteLink;
@@ -179,7 +206,7 @@ export default {
       textarea.select();
       document.execCommand('copy');
       document.body.removeChild(textarea);
-      alert('链接已复制到剪贴板');
+      this.showLinkCopiedDialog = true;
     },
     async claimReward(task) {
       // 检查实名认证状态
@@ -543,4 +570,30 @@ export default {
     transform: scale(1);
   }
 }
+
+/* 成功提示弹窗样式 */
+.success-dialog {
+  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
+}
+
+.success-icon {
+  width: 100%;
+  height: 100%;
+}
+
+.success-title {
+  color: #52C41A;
+}
+
+.success-btn {
+  background: #52C41A;
+}
+
+.success-btn:hover {
+  background: #73d13d;
+}
+
+.success-btn:active {
+  transform: scale(0.98);
+}
 </style> 

+ 38 - 2
src/views/Signin.vue

@@ -112,6 +112,23 @@
         <button class="dialog-btn auth-btn" @click="goToAuth">去认证</button>
       </div>
     </div>
+
+    <!-- 错误提示弹窗 -->
+    <div v-if="showErrorDialog" class="custom-dialog-mask">
+      <div class="custom-dialog error-dialog">
+        <div class="dialog-close" @click="showErrorDialog = false">
+          <i class="close-icon"></i>
+        </div>
+        <div class="dialog-icon">
+          <svg viewBox="64 64 896 896" data-icon="close-circle" width="60px" height="60px" fill="#ff4d4f" aria-hidden="true">
+            <path d="M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm165.4 618.2l-66-.3L512 563.4l-99.3 118.4-66.1.3c-4.4 0-8-3.5-8-8 0-1.9.7-3.7 1.9-5.2l130.1-155L340.5 359a8.32 8.32 0 01-1.9-5.2c0-4.4 3.6-8 8-8l66.1.3L512 464.6l99.3-118.4 66-.3c4.4 0 8 3.5 8 8 0 1.9-.7 3.7-1.9 5.2L553.5 514l130 155c1.2 1.5 1.9 3.3 1.9 5.2 0 4.4-3.6 8-8 8z"></path>
+          </svg>
+        </div>
+        <div class="dialog-title error-title">签到失败</div>
+        <div class="dialog-content">{{ errorMessage }}</div>
+        <button class="dialog-btn error-btn" @click="showErrorDialog = false">确定</button>
+      </div>
+    </div>
   </div>
 </template>
 
@@ -128,7 +145,9 @@ export default {
       dailyCoins: 10,
       showSuccessDialog: false,
       showAlreadySignedDialog: false,
-      showAuthDialog: false
+      showAuthDialog: false,
+      showErrorDialog: false,
+      errorMessage: ''
     }
   },
   computed: {
@@ -176,7 +195,8 @@ export default {
         await this.getUserInfo();
       } catch (error) {
         console.error('签到失败:', error);
-        alert('签到失败,请重试');
+        this.errorMessage = '签到失败,请重试';
+        this.showErrorDialog = true;
       }
     },
     goToAuth() {
@@ -510,4 +530,20 @@ export default {
 .dialog-close .close-icon::after {
   transform: rotate(-45deg);
 }
+
+.error-title {
+  color: #ff4d4f;
+}
+
+.error-btn {
+  background: #ff4d4f;
+}
+
+.error-btn:hover {
+  background: #ff7875;
+}
+
+.error-dialog {
+  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
+}
 </style>