123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- <template>
- <div class="menushome">
- <el-card class="box-card">
- <div slot="header" class="clearfix">
- <span>菜单管理</span>
- <el-button style="float: right; padding: 3px 0" type="text" @click="addmenus">添加菜单</el-button>
- </div>
- <div class="main">
- <filterList ref="filterList" :tableData="menusList" :filed="filed" @edit="filtereEdit" @delete="filterDelete" @query="filterQuery" :total="Total"></filterList>
- </div>
- </el-card>
- <dialogAndDrawer :width="'35%'" :title="title" :visibleSync="visibleSync" v-if="visibleSync" @close="visibleSync = false">
- <template v-slot:windowMain>
- <formData ref="formData" :filed="formfiled" :data="formdata" :rules="formrules" @save="formSave">
- <template v-slot:ext="{ formdata }">
- <!-- 地址 -->
- <el-form-item prop="url" v-if="formdata && formdata.type == '0'" label="地址">
- <el-input v-model="formdata['url']" placeholder="请输入地址"></el-input>
- </el-form-item>
- <!-- 栏目 -->
- <el-form-item prop="column" v-if="formdata && formdata.type == '1'" label="栏目">
- <el-select multiple v-model="formdata['column']" placeholder="请选择栏目">
- <el-option v-for="i in columnList" :key="i.code" :label="i.name" :value="i.code">
- </el-option>
- </el-select>
- </el-form-item>
- <!-- 单页 -->
- <el-form-item prop="pages" v-if="formdata && formdata.type == '2'" label="单页">
- <el-select v-model="formdata['pages']" placeholder="请选择单页">
- <el-option v-for="i in pagesList" :key="i._id" :label="i.title" :value="i._id">
- </el-option>
- </el-select>
- </el-form-item>
- </template>
- </formData>
- </template>
- </dialogAndDrawer>
- </div>
- </template>
- <script>
- import filterList from '@components/filterList/index.vue';
- import dialogAndDrawer from '@components/dialogAndDrawer.vue';
- import formData from '@components/formData/index.vue';
- import { mapState, mapActions } from 'vuex';
- export default {
- components: {
- filterList,
- dialogAndDrawer,
- formData
- },
- data() {
- return {
- title: '',
- visibleSync: false,
- filed: [
- { name: 'name', label: '名称', filter: true },
- { name: 'code', label: '编码', filter: true }
- ],
- formdata: {},
- formfiled: [
- { name: 'name', label: '名称' },
- { name: 'code', label: '编码' },
- { name: 'date', label: '时间', formater: 'date:datetime' },
- { name: 'type', label: '类型', formater: 'dict:imgNewsType' }
- ],
- formrules: {
- name: [
- { required: true, message: '请输入名称', trigger: 'blur' }
- ],
- code: [
- { required: true, message: '请输入编码', trigger: 'blur' }
- ],
- date: [
- { required: true, message: '请输入时间', trigger: 'blur' }
- ],
- type: [
- { required: true, message: '请输入类型', trigger: 'blur' }
- ],
- url: [
- { required: true, message: '请输入类型', trigger: 'blur' }
- ],
- column: [
- { required: true, message: '请输入类型', trigger: 'chage' }
- ],
- pages: [
- { required: true, message: '请输入类型', trigger: 'chage' }
- ]
- }
- };
- },
- computed: {
- ...mapState(['menusList', 'Total', 'typeList', 'columnList', 'pagesList'])
- },
- async mounted() {
- await this.filterQuery();
- await this.codeQuery();
- await this.columnQuery();
- await this.pagesQuery();
- },
- methods: {
- ...mapActions(['menusQuery', 'menusCreate', 'menusUpdate', 'menusDelete', 'menusQuery', 'codeQuery', 'columnQuery', 'pagesQuery']),
- // 添加
- addmenus () {
- this.formdata = {};
- this.title = '添加菜单';
- this.visibleSync = true;
- },
- // 修改
- async filtereEdit (e) {
- this.formdata = e;
- this.title = '修改菜单';
- this.visibleSync = true;
- },
- // 删除
- async filterDelete (e) {
- const res = await this.menusDelete({ id: e?._id });
- this.$resChange(res, '删除成功');
- this.filterQuery();
- },
- // 查询
- async filterQuery ({ filter = {}, paging = { page: 0, size: 10 } } = {}) {
- await this.menusQuery({ filter, paging });
- },
- // 表单保存
- async formSave (e) {
- if (e.isRevise && e?.isRevise == false) {
- this.$message.warning('未作修改');
- return;
- }
- this.$delete(e, 'isRevise');
- let res, msg;
- // 修改
- if (e._id) {
- res = await this.menusUpdate(e);
- msg = '菜单修改成功';
- } else {
- res = await this.menusCreate(e);
- msg = '菜单添加成功';
- }
- this.filterQuery();
- this.$resChange(res, msg);
- this.visibleSync = false;
- }
- }
- };
- </script>
- <style lang="scss">
- .menushome {
- width: 100%;
- height: 100%;
- display: flex;
- .box-card {
- width: 100%;
- height: 100%;
- .el-card__body {
- height: 100%;
- }
- }
- }
- </style>
|