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 |  181 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 181 insertions(+), 0 deletions(-)

diff --git a/admin/src/components/system/user/OperaUserWindow.vue b/admin/src/components/system/user/OperaUserWindow.vue
new file mode 100644
index 0000000..c5da65d
--- /dev/null
+++ b/admin/src/components/system/user/OperaUserWindow.vue
@@ -0,0 +1,181 @@
+<template>
+  <!-- 鏂板缓/淇敼 -->
+  <GlobalWindow
+    :title="title"
+    :visible.sync="visible"
+    :confirm-working="isWorking"
+    @confirm="confirm"
+  >
+    <el-form :model="form" ref="form" :rules="rules">
+      <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>
+        <el-input v-model="form.realname" placeholder="璇疯緭鍏ュ鍚�" v-trim maxlength="50"/>
+      </el-form-item>
+      <el-form-item label="鎬у埆" prop="sex" required>
+        <el-radio-group v-model="form.sex">
+          <el-radio label="1">鐢�</el-radio>
+          <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="@/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="birthday">
+        <el-date-picker v-model="form.birthday" value-format="yyyy-MM-dd" placeholder="璇烽�夋嫨鐢ㄦ埛鐢熸棩"/>
+      </el-form-item>
+    </el-form>
+  </GlobalWindow>
+</template>
+
+<script>
+import BaseOpera from '@/components/base/BaseOpera'
+import GlobalWindow from '@/components/common/GlobalWindow'
+import { checkMobile, checkEmail } from '@/utils/form'
+
+export default {
+  name: 'OperaUserWindow',
+  extends: BaseOpera,
+  components: { GlobalWindow },
+  data () {
+    return {
+      // 琛ㄥ崟鏁版嵁
+      form: {
+        id: null,
+        username: '', // 鐢ㄦ埛鍚�
+        realname: '', // 濮撳悕
+        empNo: '', // 宸ュ彿
+        avatar: '/avatar/man.png', // 澶村儚
+        password: '', // 瀵嗙爜
+        mobile: '', // 鎵嬫満鍙风爜
+        email: '', // 閭
+        sex: '1', // 鎬у埆
+        birthday: '' // 鐢熸棩
+      },
+      // 楠岃瘉瑙勫垯
+      rules: {
+        username: [
+          { required: true, message: '璇疯緭鍏ョ敤鎴峰悕' }
+        ],
+        realname: [
+          { required: true, message: '璇疯緭鍏ュ鍚�' }
+        ],
+        password: [
+          { required: true, message: '璇疯緭鍏ュ瘑鐮�', trigger: 'blur' },
+          { validator: this.validatePassword, trigger: 'blur' }
+        ],
+        avatar: [
+          { required: true, message: '璇烽�夋嫨鐢ㄦ埛澶村儚' }
+        ],
+        sex: [
+          { required: true, message: '璇烽�夋嫨鐢ㄦ埛鎬у埆' }
+        ],
+        mobile: [
+          { validator: checkMobile }
+        ],
+        email: [
+          { validator: checkEmail }
+        ]
+      }
+    }
+  },
+  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() // 楠岃瘉閫氳繃
+        }
+      }
+    },
+    /**
+     * 鎵撳紑绐楀彛
+     *
+     * @param title 绐楀彛鏍囬
+     * @param target 琛屽璞★紙浠呯紪杈戦渶璇ュ弬鏁帮級
+     */
+    open (title, target) {
+      this.title = title
+      this.visible = true
+      // 鏂板缓
+      if (target == null) {
+        this.$nextTick(() => {
+          this.$refs.form.resetFields()
+          this.form.id = null
+          this.form.departmentId = null
+          this.form.positionIds = []
+        })
+        return
+      }
+      // 缂栬緫
+      this.$nextTick(() => {
+        for (const key in this.form) {
+          this.form[key] = target[key]
+        }
+        this.form.departmentId = target.department == null ? null : target.department.id
+        this.form.positionIds = target.positions == null ? [] : target.positions.map(p => p.id)
+      })
+    }
+  },
+  created () {
+    this.config({
+      api: '/system/user'
+    })
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.global-window {
+  /deep/ .el-date-editor {
+    width: 100%;
+  }
+  // 琛ㄥ崟澶村儚澶勭悊
+  /deep/ .form-item-avatar {
+    .el-radio.is-bordered {
+      height: auto;
+      padding: 6px;
+      margin: 0 10px 0 0;
+      .el-radio__input {
+        display: none;
+      }
+      .el-radio__label {
+        padding: 0;
+        width: 48px;
+        display: block;
+        img {
+          width: 100%;
+        }
+      }
+    }
+  }
+}
+</style>

--
Gitblit v1.9.3