DictDetail.vue 11 KB
<template>
  <el-container>
    <el-header style="height: 30px">
      <div class="search-container">
        <div class="search-item">
          <span class="search-label">字典编码</span>
          <el-input
            size="medium"
            v-model="inputLabel"
            :disabled="true"
            style="width: 200px"
          >
          </el-input>
        </div>
        <div class="search-item">
          <span class="search-label">字典名称</span>
          <el-input
            v-model="inputDictName"
            :disabled="true"
            style="width: 200px; margin-right: 20px"
          >
          </el-input>
        </div>
      </div>
    </el-header>

    <el-main>
      <div>
        <el-card shadow="never">
          <div style="text-align: right">
            <el-button
              type="primary"
              size="small"
              icon="el-icon-search"
              @click="handleSearchDetail"
            >
              查询
            </el-button>
            <el-button
              type="success"
              size="small"
              icon="el-icon-plus"
              @click="handleAdd"
            >
              新增
            </el-button>
            <el-button
              type="danger"
              size="small"
              icon="el-icon-delete"
              @click="handleBatchDelete"
            >
              删除
            </el-button>
          </div>
        </el-card>
      </div>
      <el-dialog
        title="新增字典明细"
        :visible.sync="dialogFormVisible"
        width="30%"
        center
      >
        <el-form :model="form" label-width="80px">
          <el-row>
            <el-col :span="12">
              <el-form-item label="字典名称">
                <el-input
                  v-model="form.dictName"
                  :disabled="true"
                  autocomplete="off"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item label="字典编码">
                <el-input
                  v-model="form.label"
                  :disabled="true"
                  autocomplete="off"
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-form-item label="明细编码">
            <el-input v-model="form.value" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="明细名称">
            <el-input v-model="form.detailName" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="值">
            <el-input v-model="form.value" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="排序">
            <el-input v-model="form.sort" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="备注">
            <el-input v-model="form.remark" autocomplete="off"></el-input>
          </el-form-item>
        </el-form>
        <span slot="footer" class="dialog-footer">
          <el-button @click="dialogFormVisible = false">取 消</el-button>
          <el-button type="primary" @click="handleAddData">确 定</el-button>
        </span>
      </el-dialog>
      <el-dialog
        title="编辑字典明细"
        :visible.sync="EditdialogFormVisible"
        width="30%"
        center
      >
        <el-form :model="Editform" label-width="80px">
          <el-form-item label="字典名称">
            <el-input v-model="Editform.dictName" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="字典编码">
            <el-input v-model="Editform.label" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="实际值">
            <el-input v-model="Editform.value" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="备注">
            <el-input v-model="Editform.remark" autocomplete="off"></el-input>
          </el-form-item>
        </el-form>
        <span slot="footer" class="dialog-footer">
          <el-button @click="EditdialogFormVisible = false">取 消</el-button>
          <el-button
            type="primary"
            :loading="editLoading"
            @click="handleEditData"
            >确 定</el-button
          >
        </span>
      </el-dialog>
      <div class="dict-detail-container">
        <!-- 字典明细内容 -->
        <el-table
          :data="dictDetailList"
          max-height="540"
          style="width: 100%"
          @selection-change="handleSelectionChange"
        >
          <el-table-column type="selection" width="55"> </el-table-column>
          <el-table-column prop="dictId" label="id"></el-table-column>
          <el-table-column prop="code" label="字典编码"></el-table-column>
          <el-table-column prop="name" label="字典名称"></el-table-column>
          <el-table-column prop="code" label="明细编码"></el-table-column>
          <el-table-column prop="value" label="明细名称"></el-table-column>
          <el-table-column prop="name" label="值"></el-table-column>
          <el-table-column prop="sort" label="排序"></el-table-column>
          <el-table-column prop="remark" label="备注"></el-table-column>
          <el-table-column prop="created" label="创建时间"></el-table-column>
          <el-table-column prop="createdBy" label="创建人"></el-table-column>
          <el-table-column prop="updated" label="更新时间"></el-table-column>
          <el-table-column prop="updatedBy" label="更新人"></el-table-column>

          <el-table-column label="操作">
            <template slot-scope="scope">
              <el-button
                v-if="scope.row.id"
                type="text"
                @click="handleEdit(scope.row)"
                >编辑</el-button
              >
            </template>
          </el-table-column>
        </el-table>
      </div>
    </el-main>
  </el-container>
</template>

<script>
import {
  GetDictDetails,
  AddDictDetail,
  EditDictDetail,
  DeleteDictDetails,
} from "@/api/systemManage/dict";

export default {
  name: "DictDetail",
  props: {
    dictCode: String,
    dictName: String,
    // 添加新的 prop 用于监听主页面状态
    isMainPageActive: {
      type: Boolean,
      default: false,
    },
  },
  data() {
    return {
      dictDetailList: [],
      inputDictName: "",
      inputLabel: "",
      selectedItems: [],
      dialogFormVisible: false,
      form: {
        dictName: "",
        label: "",
        value: "",
        detailName: "",
        sort: "",
        remark: "",
      },
      EditdialogFormVisible: false,
      Editform: {
        dictName: "",
        label: "",
        value: "",
        remark: "",
      },
      editLoading: false,
    };
  },
  created() {},

  watch: {
    dictCode: {
      handler(newCode) {
        this.inputLabel = newCode;
        this.checkAndSearch();
      },
      immediate: true,
    },
    dictName: {
      handler(newName) {
        this.inputDictName = newName;
        this.checkAndSearch();
      },
      immediate: true,
    },
    isMainPageActive(newVal) {
      if (newVal) {
        this.clearDetailValues();
      }
    },
  },
  methods: {
    checkAndSearch() {
      if (this.inputDictName && this.inputLabel) {
        this.handleSearchDetail();
      }
    },

    fuzhi() {
      this.inputDictName = this.dictName;
      this.inputLabel = this.dictCode;
    },

    clearDetailValues() {
      this.inputDictName = "";
      this.inputLabel = "";
      this.dictDetailList = [];
      this.selectedItems = [];
      this.dialogFormVisible = false;
      this.EditdialogFormVisible = false;
      this.form = {
        dictName: "",
        label: "",
        value: "",
        detailName: "",
        sort: "",
        remark: "",
      };
      this.Editform = {
        dictName: "",
        label: "",
        value: "",
        remark: "",
      };
    },
    handleSelectionChange(val) {
      this.selectedItems = val;
    },
    handleEdit(row) {
      this.EditdialogFormVisible = true;
      this.Editform = { ...row };
    },
    handleEditData() {
      this.editLoading = true;
      EditDictDetail(this.Editform).then((res) => {
        if (res.code === "Success") {
          this.$message.success("数据修改成功");
          this.EditdialogFormVisible = false;
          this.editLoading = false;
          this.handleSearchDetail();
        } else {
          this.$message.error(res.message);
        }
      });
    },
    handleSearchDetail() {
      const requestData = {
        dictId: 0,
        name: this.inputDictName,
        code: this.inputLabel,
      };
      GetDictDetails(requestData).then((res) => {
        if (res.code === "Success" && res.data) {
          this.dictDetailList = res.data.data || res.data;
        }
      });
    },
    handleAdd() {
      this.dialogFormVisible = true;
      this.form = {
        dictName: this.inputDictName,
        label: this.inputLabel,
        value: "",
        detailName: "",
        sort: "",
        remark: "",
      };
    },
    handleAddData() {
      if (!this.form.dictName) {
        this.$message.error("字典编码不能为空");
        return;
      }
      if (!this.form.label) {
        this.$message.error("字典名称不能为空");
        return;
      }
      const requestdetailData = {
        Code: this.form.value,
        Name: this.form.detailName,
        Value: this.form.value,
        Sort: this.form.sort,
        Remark: this.form.remark,
        DictCode: this.form.label,
        DictName: this.form.dictName,
      };
      AddDictDetail(requestdetailData).then((res) => {
        if (res.code === "Success") {
          this.$message.success("新增成功");
          this.dialogFormVisible = false;
          this.handleSearchDetail();
        } else {
          this.$message.error(res.message);
        }
      });
    },
    handleBatchDelete() {
      if (this.selectedItems.length === 0) {
        this.$alert("请至少选择一条数据", "提示", {
          confirmButtonText: "确定",
        });
        return;
      }

      this.$confirm("确定要删除选中的数据吗?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          const list = this.selectedItems;
          DeleteDictDetails(list).then((res) => {
            if (res.code === "Success") {
              this.$message.success("删除成功");
              this.handleSearchDetail();
            }
          });
        })
        .catch(() => {
          this.$message.info("已取消删除");
        });
    },
  },
};
</script>

<style lang="scss" scoped>
::v-deep.el-table thead {
  color: #101010;
  font-weight: 600;
}
.app-container {
  padding: 16px;
}
.search-container {
  display: flex;
  align-items: center;
  .search-item {
    display: flex;
    align-items: center;
    margin-right: 20px;
    .search-label {
      margin-right: 10px;
      white-space: nowrap;
    }
  }
}
</style>