From fa4c36d0848b047b853dcea33f1b995a8b9067da Mon Sep 17 00:00:00 2001
From: doum <doum>
Date: 星期五, 19 九月 2025 17:47:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 admin/src/components/system/user/RoleConfigWindow.vue |  123 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 123 insertions(+), 0 deletions(-)

diff --git a/admin/src/components/system/user/RoleConfigWindow.vue b/admin/src/components/system/user/RoleConfigWindow.vue
new file mode 100644
index 0000000..96cf087
--- /dev/null
+++ b/admin/src/components/system/user/RoleConfigWindow.vue
@@ -0,0 +1,123 @@
+<template>
+  <GlobalWindow
+    :visible.sync="visible"
+    :confirm-working="isWorking"
+    width="582px"
+    title="閰嶇疆鐢ㄦ埛瑙掕壊"
+    @confirm="confirm"
+  >
+    <p class="tip" v-if="user != null">涓虹敤鎴� <em>{{user.realname}}</em> 閰嶇疆瑙掕壊</p>
+    <el-transfer
+      v-model="selectedIds"
+      :titles="['鏈巿鏉冭鑹�', '宸叉巿鏉冭鑹�']"
+      :props="{
+        key: 'id',
+        label: 'name'
+      }"
+      :data="roles">
+    </el-transfer>
+  </GlobalWindow>
+</template>
+
+<script>
+import BasePage from '@/components/base/BasePage'
+import GlobalWindow from '@/components/common/GlobalWindow'
+import { createUserRole } from '@/api/system/user'
+import { fetchAll as fetchAllRoles } from '@/api/system/role'
+export default {
+  name: 'RoleConfigWindow',
+  extends: BasePage,
+  components: { GlobalWindow },
+  data () {
+    return {
+      visible: false,
+      isWorking: false,
+      // 鐢ㄦ埛
+      user: null,
+      // 瑙掕壊鍒楄〃
+      roles: null,
+      // 宸查�変腑鐨勮鑹睮D
+      selectedIds: []
+    }
+  },
+  methods: {
+    /**
+     * 鎵撳紑绐楀彛
+     *
+     * @param user 鐩爣鐢ㄦ埛
+     */
+    open (user) {
+      fetchAllRoles()
+        .then(records => {
+          this.roles = records
+          this.user = user
+          // 濡傛灉涓哄浐瀹氱敤鎴凤紝鍒欏浐瀹氳鑹蹭笉鍙洿鏀�
+          if (this.user.fixed) {
+            for (const role of this.roles) {
+              if (role.fixed) {
+                role.disabled = true
+              }
+            }
+          }
+          // 濡傛灉褰撳墠鐢ㄦ埛涓洪潪瓒呯骇绠$悊鍛樼敤鎴凤紝鍒欎笉鍏佽鎺堟潈瓒呯骇绠$悊鍛樿鑹�
+          if (!this.isAdmin) {
+            for (const role of this.roles) {
+              if (role.code === this.adminCode) {
+                role.disabled = true
+              }
+            }
+          }
+          this.selectedIds = this.user.roles.map(r => r.id)
+          this.visible = true
+        })
+        .catch(e => {
+          this.$tip.apiFailed(e)
+        })
+    },
+    /**
+     * 纭閫夋嫨瑙掕壊
+     */
+    confirm () {
+      if (this.isWorking) {
+        return
+      }
+      this.isWorking = true
+      createUserRole({
+        userId: this.user.id,
+        roleIds: this.selectedIds
+      })
+        .then(() => {
+          this.visible = false
+          this.$emit('success')
+          setTimeout(() => {
+            this.$dialog.attentionConfirm('瑙掕壊閰嶇疆鎴愬姛锛岀敤鎴烽渶閲嶆柊鐧诲綍鍚庣敓鏁�').then(() => {})
+          }, 300)
+        })
+        .catch(e => {
+          this.$tip.apiFailed(e)
+        })
+        .finally(() => {
+          this.isWorking = false
+        })
+    },
+    // 鍏抽棴
+    close () {
+      this.$emit('update:visible', false)
+    }
+  }
+}
+</script>
+
+<style scoped lang="scss">
+@import "@/assets/style/variables.scss";
+// 瑙掕壊閰嶇疆
+.global-window {
+  .tip {
+    em {
+      font-style: normal;
+      color: $primary-color;
+      font-weight: bold;
+    }
+  }
+}
+</style>

--
Gitblit v1.9.3