From 9057e04efad1b7d61c77a72e5c37a504d0aee935 Mon Sep 17 00:00:00 2001
From: doum <doum>
Date: 星期五, 26 九月 2025 09:24:03 +0800
Subject: [PATCH] H5静态化

---
 admin/src/components/system/user/OperaUserWindow.vue |   71 ++++++++++++++++++++---------------
 1 files changed, 40 insertions(+), 31 deletions(-)

diff --git a/admin/src/components/system/user/OperaUserWindow.vue b/admin/src/components/system/user/OperaUserWindow.vue
index 8fe9643..c5da65d 100644
--- a/admin/src/components/system/user/OperaUserWindow.vue
+++ b/admin/src/components/system/user/OperaUserWindow.vue
@@ -7,7 +7,7 @@
     @confirm="confirm"
   >
     <el-form :model="form" ref="form" :rules="rules">
-      <el-form-item label="鐢ㄦ埛鍚�" prop="username" required v-if="form.id ==null">
+      <el-form-item label="鐢ㄦ埛鍚�" prop="username" required>
         <el-input v-model="form.username" placeholder="璇疯緭鍏ョ敤鎴峰悕" v-trim maxlength="50"/>
       </el-form-item>
       <el-form-item label="濮撳悕" prop="realname" required>
@@ -19,30 +19,24 @@
           <el-radio label="0">濂�</el-radio>
         </el-radio-group>
       </el-form-item>
-<!--      <el-form-item label="澶村儚" prop="avatar" required>-->
-<!--        <el-radio-group v-model="form.avatar" class="form-item-avatar">-->
-<!--          <el-radio label="/avatar/man.png" border><img src="/avatar/man.png" alt=""></el-radio>-->
-<!--          <el-radio label="/avatar/woman.png" border><img src="/avatar/woman.png" alt=""></el-radio>-->
-<!--        </el-radio-group>-->
-<!--      </el-form-item>-->
-<!--      <el-form-item v-if="form.id == null" label="鍒濆瀵嗙爜" prop="password" required>-->
-<!--        <el-input v-model="form.password" type="password" placeholder="璇疯緭鍏ュ垵濮嬪瘑鐮�" maxlength="30" show-password/>-->
-<!--      </el-form-item>-->
-<!--            <el-form-item label="鎵�灞為儴闂�" prop="departmentId" required>-->
-<!--        <DepartmentSelect v-model="form.departmentId" placeholder="璇烽�夋嫨鐢ㄦ埛鎵�灞為儴闂�" :inline="false" clearable/>-->
-<!--      </el-form-item>-->
-<!--      <el-form-item label="宀椾綅" prop="positionId">-->
-<!--        <PositionSelect v-model="form.positionIds" placeholder="璇烽�夋嫨鐢ㄦ埛鎵�鍦ㄥ矖浣�" :inline="false" :multiple="true" clearable/>-->
-<!--      </el-form-item>-->
+      <el-form-item label="澶村儚" prop="avatar" required>
+        <el-radio-group v-model="form.avatar" class="form-item-avatar">
+          <el-radio label="avatar/man.png" border><img src="@/assets/avatar/man.png" alt=""></el-radio>
+          <el-radio label="avatar/woman.png" border><img src="@/assets/avatar/woman.png" alt=""></el-radio>
+        </el-radio-group>
+      </el-form-item>
+      <el-form-item v-if="form.id == null" label="鍒濆瀵嗙爜" prop="password" required>
+        <el-input v-model="form.password" type="password" placeholder="璇疯緭鍏ュ垵濮嬪瘑鐮�" maxlength="30" show-password/>
+      </el-form-item>
       <el-form-item label="宸ュ彿" prop="empNo">
         <el-input v-model="form.empNo" placeholder="璇疯緭鍏ュ伐鍙�" v-trim maxlength="50"/>
       </el-form-item>
       <el-form-item label="鎵嬫満鍙风爜" prop="mobile">
         <el-input v-model="form.mobile" placeholder="璇疯緭鍏ユ墜鏈哄彿鐮�" v-trim maxlength="11"/>
       </el-form-item>
-<!--      <el-form-item label="閭" prop="email">-->
-<!--        <el-input v-model="form.email" placeholder="璇疯緭鍏ラ偖绠�" v-trim maxlength="200"/>-->
-<!--      </el-form-item>-->
+      <el-form-item label="閭" prop="email">
+        <el-input v-model="form.email" placeholder="璇疯緭鍏ラ偖绠�" v-trim maxlength="200"/>
+      </el-form-item>
       <el-form-item label="鐢熸棩" prop="birthday">
         <el-date-picker v-model="form.birthday" value-format="yyyy-MM-dd" placeholder="璇烽�夋嫨鐢ㄦ埛鐢熸棩"/>
       </el-form-item>
@@ -53,14 +47,12 @@
 <script>
 import BaseOpera from '@/components/base/BaseOpera'
 import GlobalWindow from '@/components/common/GlobalWindow'
-import DepartmentSelect from '@/components/common/DepartmentSelect'
-import PositionSelect from '@/components/common/PositionSelect'
 import { checkMobile, checkEmail } from '@/utils/form'
 
 export default {
   name: 'OperaUserWindow',
   extends: BaseOpera,
-  components: { PositionSelect, DepartmentSelect, GlobalWindow },
+  components: { GlobalWindow },
   data () {
     return {
       // 琛ㄥ崟鏁版嵁
@@ -69,8 +61,6 @@
         username: '', // 鐢ㄦ埛鍚�
         realname: '', // 濮撳悕
         empNo: '', // 宸ュ彿
-        departmentId: null, //  鎵�灞為儴闂↖D
-        positionIds: [], //  鎵�灞炲矖浣岻D闆�
         avatar: '/avatar/man.png', // 澶村儚
         password: '', // 瀵嗙爜
         mobile: '', // 鎵嬫満鍙风爜
@@ -87,10 +77,8 @@
           { required: true, message: '璇疯緭鍏ュ鍚�' }
         ],
         password: [
-          { required: true, message: '璇疯緭鍏ュ瘑鐮�' }
-        ],
-        departmentId: [
-          { required: true, message: '璇烽�夋嫨閮ㄩ棬' }
+          { required: true, message: '璇疯緭鍏ュ瘑鐮�', trigger: 'blur' },
+          { validator: this.validatePassword, trigger: 'blur' }
         ],
         avatar: [
           { required: true, message: '璇烽�夋嫨鐢ㄦ埛澶村儚' }
@@ -108,9 +96,31 @@
     }
   },
   methods: {
+    validatePassword (rule, value, callback) {
+      if (!value) {
+        callback(new Error('璇疯緭鍏ュ瘑鐮�'))
+      } else {
+        const lengthValid = /^.{6,20}$/.test(value)
+        const hasLetter = /[a-zA-Z]/.test(value)
+        const hasNumber = /[0-9]/.test(value)
+        const hasSpecial = /[!@#$%^&*(),.?":{}|<>]/.test(value)
+
+        const typesCount = [hasLetter, hasNumber, hasSpecial].filter(Boolean).length
+
+        if (!lengthValid) {
+          callback(new Error('瀵嗙爜闀垮害闇�涓�6鍒�20涓瓧绗�'))
+        } else if (typesCount < 2) {
+          callback(new Error('瀵嗙爜闇�鍖呭惈瀛楁瘝銆佹暟瀛楀強鐗规畩瀛楃涓殑鑷冲皯涓ょ'))
+        } else {
+          callback() // 楠岃瘉閫氳繃
+        }
+      }
+    },
     /**
-     * @title 绐楀彛鏍囬
-     * @target 缂栬緫鐨勭敤鎴峰璞�
+     * 鎵撳紑绐楀彛
+     *
+     * @param title 绐楀彛鏍囬
+     * @param target 琛屽璞★紙浠呯紪杈戦渶璇ュ弬鏁帮級
      */
     open (title, target) {
       this.title = title
@@ -122,7 +132,6 @@
           this.form.id = null
           this.form.departmentId = null
           this.form.positionIds = []
-          this.form.username=null
         })
         return
       }

--
Gitblit v1.9.3