Browse Source

feat: [系统管理] 权限设置

lkf
memorylkf 2 months ago
parent
commit
64d39048b0
5 changed files with 106 additions and 91 deletions
  1. +3
    -1
      src/views/business/template/list.vue
  2. +1
    -1
      src/views/system/dept/index.vue
  3. +45
    -41
      src/views/system/dict/data.vue
  4. +54
    -45
      src/views/system/dict/index.vue
  5. +3
    -3
      src/views/system/role/index.vue

+ 3
- 1
src/views/business/template/list.vue View File

@ -62,7 +62,7 @@
<el-table-column :label="$t('form.operate')" fixed="right" align="center" width="100">
<template slot-scope="scope">
<el-button type="text" @click="edit(scope.row)">{{ $t('page.system.template.bj') }}</el-button>
<el-button type="text" @click="bdpz(scope.row)">{{ $t('page.system.template.detail') }}</el-button>
<el-button type="text" @click="bdpz(scope.row)" v-hasPermi="['business:template:detail']">{{ $t('page.system.template.detail') }}</el-button>
</template>
</el-table-column>
</el-table>
@ -264,6 +264,8 @@ export default {
});
},
bdpz(row) {
this.saveSimpleLog({name:row.name+'('+row.showSn+')',nameEn:row.name+'('+row.showSn+')',jcmc:'模板详情',jcmcEn:'Function Detail'})
this.tableDialog.title = '表单配置'
this.tableDialog.sn=row.sn
this.tableDialog.visible=true

+ 1
- 1
src/views/system/dept/index.vue View File

@ -106,7 +106,7 @@
v-hasPermi="['system:dept:remove']"
>{{$t('page.system.dept.delete')}}</el-button>
<el-button
v-hasPermi="['system:dept:detail']"
type="text"
@click="handleUpdate(scope.row,true)"
>{{$t('page.system.dept.detail')}}</el-button>

+ 45
- 41
src/views/system/dict/data.vue View File

@ -11,15 +11,15 @@
/>
</el-select>
</el-form-item>
<el-form-item label="字典标签" prop="dictLabel">
<el-form-item label="标签" prop="dictLabel">
<el-input
v-model="queryParams.dictLabel"
placeholder="请输入字典标签"
placeholder="请输入"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="status">
<!-- <el-form-item label="状态" prop="status">
<el-select v-model="queryParams.status" placeholder="数据状态" clearable>
<el-option
v-for="dict in dict.type.sys_normal_disable"
@ -28,9 +28,9 @@
:value="dict.value"
/>
</el-select>
</el-form-item>
</el-form-item> -->
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">查询</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
@ -43,10 +43,10 @@
icon="el-icon-plus"
@click="handleAdd"
v-hasPermi="['system:dict:add']"
v-hasPermi="['system:dict:add','system:dict:edit']"
>新增</el-button>
</el-col>
<el-col :span="1.5">
<!-- <el-col :span="1.5">
<el-button
type="success"
plain
@ -77,7 +77,7 @@
@click="handleExport"
v-hasPermi="['system:dict:export']"
>导出</el-button>
</el-col>
</el-col> -->
<el-col :span="1.5">
<el-button
type="warning"
@ -91,43 +91,49 @@
</el-row>
<el-table v-loading="loading" :data="dataList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="字典编码" align="center" prop="dictCode" />
<el-table-column label="字典标签" align="center" prop="dictLabel">
<!-- <el-table-column type="selection" width="55" align="center" /> -->
<!-- <el-table-column label="字典编码" align="center" prop="dictCode" /> -->
<el-table-column label="标签" align="center" prop="dictLabel">
<template slot-scope="scope">
<span v-if="(scope.row.listClass == '' || scope.row.listClass == 'default') && (scope.row.cssClass == '' || scope.row.cssClass == null)">{{ scope.row.dictLabel }}</span>
<el-tag v-else :type="scope.row.listClass == 'primary' ? '' : scope.row.listClass" :class="scope.row.cssClass">{{ scope.row.dictLabel }}</el-tag>
</template>
</el-table-column>
<el-table-column label="字典键值" align="center" prop="dictValue" />
<el-table-column label="字典排序" align="center" prop="dictSort" />
<el-table-column label="状态" align="center" prop="status">
<el-table-column label="键值" align="center" prop="dictValue" />
<el-table-column label="排序" align="center" prop="dictSort" />
<!-- <el-table-column label="状态" align="center" prop="status">
<template slot-scope="scope">
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
</template>
</el-table-column>
</el-table-column> -->
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" />
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
<!-- <el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span>
</template>
</el-table-column>
</el-table-column> -->
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
@click="handleUpdate(scope.row,false)"
v-hasPermi="['system:dict:edit']"
>修改</el-button>
>编辑</el-button>
<el-button
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['system:dict:remove']"
>删除</el-button>
<el-button
type="text"
@click="handleUpdate(scope.row,true)"
v-hasPermi="['system:dict:query']"
>详情</el-button>
</template>
</el-table-column>
</el-table>
@ -146,19 +152,19 @@
<el-form-item label="字典类型">
<el-input v-model="form.dictType" :disabled="true" />
</el-form-item>
<el-form-item label="数据标签" prop="dictLabel">
<el-input v-model="form.dictLabel" placeholder="请输入数据标签" />
<el-form-item label="标签" prop="dictLabel">
<el-input v-model="form.dictLabel" placeholder="请输入数据标签" :readonly="readonly" />
</el-form-item>
<el-form-item label="数据键值" prop="dictValue">
<el-input v-model="form.dictValue" placeholder="请输入数据键值" />
<el-form-item label="键值" prop="dictValue">
<el-input v-model="form.dictValue" placeholder="请输入数据键值" :readonly="readonly" />
</el-form-item>
<el-form-item label="样式属性" prop="cssClass">
<!-- <el-form-item label="样式属性" prop="cssClass">
<el-input v-model="form.cssClass" placeholder="请输入样式属性" />
</el-form-item> -->
<el-form-item label="排序" prop="dictSort">
<el-input-number v-model="form.dictSort" controls-position="right" :min="0" :disabled="readonly" />
</el-form-item>
<el-form-item label="显示排序" prop="dictSort">
<el-input-number v-model="form.dictSort" controls-position="right" :min="0" />
</el-form-item>
<el-form-item label="回显样式" prop="listClass">
<!-- <el-form-item label="回显样式" prop="listClass">
<el-select v-model="form.listClass">
<el-option
v-for="item in listClassOptions"
@ -176,12 +182,12 @@
:label="dict.value"
>{{dict.label}}</el-radio>
</el-radio-group>
</el-form-item>
</el-form-item> -->
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" :readonly="readonly"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<div slot="footer" class="dialog-footer" v-if="!readonly">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
@ -260,13 +266,13 @@ export default {
//
rules: {
dictLabel: [
{ required: true, message: "数据标签不能为空", trigger: "blur" }
{ required: true, message: "标签不能为空", trigger: "blur" }
],
dictValue: [
{ required: true, message: "数据键值不能为空", trigger: "blur" }
{ required: true, message: "键值不能为空", trigger: "blur" }
],
dictSort: [
{ required: true, message: "数据顺序不能为空", trigger: "blur" }
{ required: true, message: "顺序不能为空", trigger: "blur" }
]
}
}
@ -349,13 +355,14 @@ export default {
this.multiple = !selection.length
},
/** 修改按钮操作 */
handleUpdate(row) {
handleUpdate(row,readonly) {
this.readonly = readonly
this.reset()
const dictCode = row.dictCode || this.ids
getData(dictCode).then(response => {
this.form = response.data
this.open = true
this.title = "修改字典数据"
this.title = (readonly?'':'编辑')+"字典数据"
})
},
/** 提交按钮 */
@ -365,14 +372,12 @@ export default {
if (this.form.dictCode != undefined) {
updateData(this.form).then(response => {
this.$store.dispatch('dict/removeDict', this.queryParams.dictType)
this.$modal.msgSuccess("修改成功")
this.open = false
this.getList()
})
} else {
addData(this.form).then(response => {
this.$store.dispatch('dict/removeDict', this.queryParams.dictType)
this.$modal.msgSuccess("新增成功")
this.open = false
this.getList()
})
@ -387,7 +392,6 @@ export default {
return delData(dictCodes)
}).then(() => {
this.getList()
this.$modal.msgSuccess("删除成功")
this.$store.dispatch('dict/removeDict', this.queryParams.dictType)
}).catch(() => {})
},

+ 54
- 45
src/views/system/dict/index.vue View File

@ -1,28 +1,28 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="字典名称" prop="dictName">
<el-form-item label="名称" prop="dictName">
<el-input
v-model="queryParams.dictName"
placeholder="请输入字典名称"
placeholder="请输入"
clearable
style="width: 240px"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="字典类型" prop="dictType">
<el-form-item label="类型" prop="dictType">
<el-input
v-model="queryParams.dictType"
placeholder="请输入字典类型"
placeholder="请输入"
clearable
style="width: 240px"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="status">
<!-- <el-form-item label="状态" prop="status">
<el-select
v-model="queryParams.status"
placeholder="字典状态"
placeholder="请选择"
clearable
style="width: 240px"
>
@ -33,8 +33,8 @@
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="创建时间">
</el-form-item> -->
<!-- <el-form-item label="创建时间">
<el-date-picker
v-model="dateRange"
style="width: 240px"
@ -44,9 +44,9 @@
start-placeholder="开始日期"
end-placeholder="结束日期"
></el-date-picker>
</el-form-item>
</el-form-item> -->
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">查询</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
@ -62,7 +62,7 @@
v-hasPermi="['system:dict:add']"
>新增</el-button>
</el-col>
<el-col :span="1.5">
<!-- <el-col :span="1.5">
<el-button
type="success"
plain
@ -93,7 +93,7 @@
@click="handleExport"
v-hasPermi="['system:dict:export']"
>导出</el-button>
</el-col>
</el-col> -->
<el-col :span="1.5">
<el-button
type="danger"
@ -101,50 +101,55 @@
icon="el-icon-refresh"
@click="handleRefreshCache"
v-hasPermi="['system:dict:remove']"
v-hasPermi="['system:dict:refresh']"
>刷新缓存</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
<!-- <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> -->
</el-row>
<el-table v-loading="loading" :data="typeList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="字典编号" align="center" prop="dictId" />
<el-table-column label="字典名称" align="center" prop="dictName" :show-overflow-tooltip="true" />
<el-table-column label="字典类型" align="center" :show-overflow-tooltip="true">
<!-- <el-table-column type="selection" width="55" align="center" /> -->
<!-- <el-table-column label="字典编号" align="center" prop="dictId" /> -->
<el-table-column label="名称" align="center" prop="dictName" :show-overflow-tooltip="true" />
<el-table-column label="类型" align="center" :show-overflow-tooltip="true">
<template slot-scope="scope">
<router-link :to="'/system/dict-data/index/' + scope.row.dictId" class="link-type">
<router-link v-if="checkPermi(['system:dict:query','system:dict:edit'])" :to="'/system/dict-data/index/' + scope.row.dictId" class="link-type">
<span>{{ scope.row.dictType }}</span>
</router-link>
<span v-else>{{scope.row.dictType}}</span>
</template>
</el-table-column>
<el-table-column label="状态" align="center" prop="status">
<!-- <el-table-column label="状态" align="center" prop="status">
<template slot-scope="scope">
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
</template>
</el-table-column>
</el-table-column> -->
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" />
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
<!-- <el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span>
</template>
</el-table-column>
</el-table-column> -->
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
@click="handleUpdate(scope.row,false)"
v-hasPermi="['system:dict:edit']"
>修改</el-button>
>编辑</el-button>
<el-button
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['system:dict:remove']"
>删除</el-button>
<el-button
type="text"
@click="handleUpdate(scope.row,true)"
v-hasPermi="['system:dict:query']"
>详情</el-button>
</template>
</el-table-column>
</el-table>
@ -160,26 +165,26 @@
<!-- 添加或修改参数配置对话框 -->
<el-dialog :close-on-click-modal="false" :close-on-press-escape="false" :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="字典名称" prop="dictName">
<el-input v-model="form.dictName" placeholder="请输入字典名称" />
<el-form-item label="名称" prop="dictName">
<el-input v-model="form.dictName" placeholder="请输入" :readonly="readonly" />
</el-form-item>
<el-form-item label="字典类型" prop="dictType">
<el-input v-model="form.dictType" placeholder="请输入字典类型" />
<el-form-item label="类型" prop="dictType">
<el-input v-model="form.dictType" placeholder="请输入" :readonly="readonly" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<!-- <el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status" :disabled="readonly">
<el-radio
v-for="dict in dict.type.sys_normal_disable"
:key="dict.value"
:label="dict.value"
>{{dict.label}}</el-radio>
</el-radio-group>
</el-form-item>
</el-form-item> -->
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" :readonly="readonly"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<div slot="footer" class="dialog-footer" v-if="!readonly">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
@ -189,6 +194,7 @@
<script>
import { listType, getType, delType, addType, updateType, refreshCache } from "@/api/system/dict/type"
import { checkPermi } from "@/utils/permission";
export default {
name: "Dict",
@ -228,18 +234,21 @@ export default {
//
rules: {
dictName: [
{ required: true, message: "字典名称不能为空", trigger: "blur" }
{ required: true, message: "名称不能为空", trigger: "blur" }
],
dictType: [
{ required: true, message: "字典类型不能为空", trigger: "blur" }
{ required: true, message: "类型不能为空", trigger: "blur" }
]
}
},
readonly:false,
}
},
created() {
this.getList()
},
methods: {
checkPermi,
/** 查询字典类型列表 */
getList() {
this.loading = true
@ -290,13 +299,17 @@ export default {
this.multiple = !selection.length
},
/** 修改按钮操作 */
handleUpdate(row) {
handleUpdate(row,readonly) {
this.readonly = readonly
if(readonly){
this.saveSimpleLog({name:row.dictName,nameEn:row.dictName,jcmc:'字典详情',jcmcEn:'Dict Detail'})
}
this.reset()
const dictId = row.dictId || this.ids
getType(dictId).then(response => {
this.form = response.data
this.open = true
this.title = "修改字典类型"
this.title = (readonly?'':'编辑')+"字典类型"
})
},
/** 提交按钮 */
@ -305,13 +318,11 @@ export default {
if (valid) {
if (this.form.dictId != undefined) {
updateType(this.form).then(response => {
this.$modal.msgSuccess("修改成功")
this.open = false
this.getList()
})
} else {
addType(this.form).then(response => {
this.$modal.msgSuccess("新增成功")
this.open = false
this.getList()
})
@ -326,7 +337,6 @@ export default {
return delType(dictIds)
}).then(() => {
this.getList()
this.$modal.msgSuccess("删除成功")
}).catch(() => {})
},
/** 导出按钮操作 */
@ -338,7 +348,6 @@ export default {
/** 刷新缓存按钮操作 */
handleRefreshCache() {
refreshCache().then(() => {
this.$modal.msgSuccess("刷新成功")
this.$store.dispatch('dict/cleanDict')
})
}

+ 3
- 3
src/views/system/role/index.vue View File

@ -134,7 +134,7 @@
type="text"
@click="handleStatusChange(scope.row)"
v-hasPermi="['system:role:edit']"
v-hasPermi="['system:role:enable']"
v-if="scope.row.status==='0'"
>{{$t('page.system.role.disable')}}</el-button>
@ -142,7 +142,7 @@
type="text"
@click="handleStatusChange(scope.row)"
v-hasPermi="['system:role:edit']"
v-hasPermi="['system:role:enable']"
v-if="scope.row.status==='1'"
>{{$t('page.system.role.enable')}}</el-button>
@ -154,7 +154,7 @@
>{{$t('page.system.role.allocate')}}</el-button>
<el-button
v-hasPermi="['system:role:detail']"
type="text"
@click="handleUpdate(scope.row,true)"
>{{$t('page.system.role.detail')}}</el-button>

Loading…
Cancel
Save