Blame view

src/views/basePrincipalResponsibility/index.vue 8.48 KB
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
1
2
  <template>
    <div class="item-box common-info-box">
3662215e   monkeyhouyi   有害清单,应用详情
3
      <div class="item-title">制度性文件</div>
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
4
5
6
7
8
      <div class="item-body">
        <div class="NCC-common-layout">
          <div class="NCC-common-layout-center">
            <el-row class="NCC-common-search-box" :gutter="16">
              <el-form @submit.native.prevent size="mini">
ff36c85d   monkeyhouyi   1
9
                <el-col :span="6">
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
10
                  <el-form-item label="">
ff36c85d   monkeyhouyi   1
11
                    <el-input v-model="query.fileName" placeholder="请输入文件名" clearable/>
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
12
13
                  </el-form-item>
                </el-col>
ff36c85d   monkeyhouyi   1
14
                <el-col :span="6">
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
15
                  <el-form-item label="">
f0d64cc9   monkeyhouyi   优化
16
17
18
19
                    <el-select v-model="query.fileType" placeholder="请选择文件类型" clearable>
                      <el-option v-for="(item, index) in fileTypeOptions" :key="index" :label="item.fullName" :value="item.id" />
                    </el-select>
                    <!-- <el-input v-model="query.fileType" placeholder="请输入文件类型" clearable/> -->
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
20
21
22
23
                  </el-form-item>
                </el-col>
                <el-col :span="4">
                  <el-form-item>
ff36c85d   monkeyhouyi   1
24
                    <el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button>
7180000e   monkeyhouyi   优化
25
                    <el-button icon="el-icon-refresh-right" @click="reset()">重置</el-button>
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
26
27
28
29
                  </el-form-item>
                </el-col>
              </el-form>
              <div class="NCC-common-search-box-right">
ff36c85d   monkeyhouyi   1
30
31
                <el-button type="success" icon="el-icon-plus" @click="addOrUpdateHandle()" size="mini" >新增</el-button>
                <!-- <el-button type="primary" icon="el-icon-download" size="mini" @click="exportData()">导出</el-button> -->
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
32
33
34
              </div>
            </el-row>
            <div class="NCC-common-layout-main NCC-flex-main">
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
35
              <NCC-table v-loading="listLoading" :data="list">
ff36c85d   monkeyhouyi   1
36
                <!-- <el-table-column prop="id" label="主键" align="left" show-overflow-tooltip/> -->
6c8bfe23   monkeyhouyi   时间过滤器
37
                <el-table-column prop="fileName" label="文件名" align="left" show-overflow-tooltip width="600"/>
4614132f   monkeyhouyi   列表查询,案件处理
38
                <el-table-column label="文件类型" prop="fileType" align="left" show-overflow-tooltip>
ff36c85d   monkeyhouyi   1
39
                  <template slot-scope="scope">{{ scope.row.fileType | dynamicText(fileTypeOptions) }}</template>
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
40
                </el-table-column>
6c8bfe23   monkeyhouyi   时间过滤器
41
                <el-table-column prop="timeTakingEffect" label="生效时间" align="left" show-overflow-tooltip :formatter="ncc.tableDateFormatDay"/>
cbd5265d   monkeyhouyi   优化
42
                <!-- <el-table-column prop="content" label="具体内容" align="left" show-overflow-tooltip/> -->
ff36c85d   monkeyhouyi   1
43
                <!-- <el-table-column prop="creatorUserId" label="创建用户" align="left" show-overflow-tooltip/> -->
6c8bfe23   monkeyhouyi   时间过滤器
44
                <el-table-column prop="creatorTime" label="创建时间" :formatter="ncc.tableDateFormatDay" align="left" show-overflow-tooltip/>
ff36c85d   monkeyhouyi   1
45
46
                <!-- <el-table-column prop="lastModifyUserId" label="修改用户" show-overflow-tooltip align="left"/> -->
                <!-- <el-table-column prop="lastModifyTime" :formatter="ncc.tableDateFormat" label="修改时间" align="left" show-overflow-tooltip/> -->
cbd5265d   monkeyhouyi   优化
47
                <el-table-column label="操作" fixed="right" width="150">
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
48
                  <template slot-scope="scope">
bc4f2fcb   monkeyhouyi   1
49
50
                    <!-- <el-button type="text" @click="addOrUpdateHandle(scope.row.id, true)" >详情</el-button> -->
                    <el-button type="text" @click="toDetail(scope.row.id, true)" >详情</el-button>
ff36c85d   monkeyhouyi   1
51
52
                    <el-button type="text" @click="addOrUpdateHandle(scope.row.id)" >编辑</el-button>
                    <el-button type="text" @click="handleDel(scope.row.id)" class="NCC-table-delBtn" >删除</el-button>
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
53
54
55
56
57
58
59
60
61
62
63
64
                  </template>
                </el-table-column>
              </NCC-table>
              <pagination
                :total="total"
                :page.sync="listQuery.currentPage"
                :limit.sync="listQuery.pageSize"
                @pagination="initData"
              />
            </div>
          </div>
          <NCC-Form v-if="formVisible" ref="NCCForm" @refresh="refresh" />
bc4f2fcb   monkeyhouyi   1
65
          <Detail v-if="DetailVisible" ref="Detail"  />
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
66
67
68
69
70
71
72
73
74
75
76
77
78
          <ExportBox
            v-if="exportBoxVisible"
            ref="ExportBox"
            @download="download"
          />
        </div>
      </div>
    </div>
  </template>
  <script>
  import request from "@/utils/request";
  import { getDictionaryDataSelector } from "@/api/systemData/dictionary";
  import NCCForm from "./Form";
bc4f2fcb   monkeyhouyi   1
79
  import Detail from "./Detail.vue";
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
80
81
82
  import ExportBox from "./ExportBox";
  import { previewDataInterface } from "@/api/systemData/dataInterface";
  export default {
bc4f2fcb   monkeyhouyi   1
83
    components: { NCCForm, ExportBox, Detail },
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
    data() {
      return {
        query: {
          fileName: undefined,
          fileType: undefined,
        },
        list: [],
        listLoading: false,
        multipleSelection: [],
        total: 0,
        listQuery: {
          currentPage: 1,
          pageSize: 20,
          sort: "desc",
          sidx: "",
        },
        formVisible: false,
        exportBoxVisible: false,
        columnList: [
          { prop: "id", label: "主键" },
          { prop: "fileName", label: "文件名" },
          { prop: "fileType", label: "文件类型" },
          { prop: "timeTakingEffect", label: "生效时间" },
          { prop: "content", label: "具体内容" },
          { prop: "creatorUserId", label: "创建用户" },
          { prop: "creatorTime", label: "创建时间" },
          { prop: "lastModifyUserId", label: "修改用户" },
          { prop: "lastModifyTime", label: "修改时间" },
        ],
        fileTypeOptions: [],
bc4f2fcb   monkeyhouyi   1
114
        DetailVisible: false,
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
115
116
117
118
      };
    },
    computed: {},
    created() {
4614132f   monkeyhouyi   列表查询,案件处理
119
120
      this.initData();
      this.getfileTypeOptions();
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
121
122
    },
    methods: {
f0d64cc9   monkeyhouyi   优化
123
124
125
      async getfileTypeOptions() {
        let res = await getDictionaryDataSelector('577087166203561221');
  			this.fileTypeOptions = [...res.data.list, { fullName: '其他', id: '0' }];
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
126
127
      },
      initData() {
bae8b004   monkeyhouyi   1
128
        this.list = [];
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
        this.listLoading = true;
        let _query = {
          ...this.listQuery,
          ...this.query,
        };
        let query = {};
        for (let key in _query) {
          if (Array.isArray(_query[key])) {
            query[key] = _query[key].join();
          } else {
            query[key] = _query[key];
          }
        }
        request({
          url: `/Extend/BasePrincipalResponsibility`,
          method: "GET",
218a9837   monkeyhouyi   运营主体优化
145
          params: query,
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
146
147
148
149
150
151
        }).then((res) => {
          this.list = res.data.list;
          this.total = res.data.pagination.total;
          this.listLoading = false;
        });
      },
bc4f2fcb   monkeyhouyi   1
152
153
154
155
156
157
      toDetail(id, isDetail) {
        this.DetailVisible = true;
        this.$nextTick(() => {
          this.$refs.Detail.init(id, isDetail);
        });
      },
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
      handleDel(id) {
        this.$confirm("此操作将永久删除该数据, 是否继续?", "提示", {
          type: "warning",
        })
          .then(() => {
            request({
              url: `/Extend/BasePrincipalResponsibility/${id}`,
              method: "DELETE",
            }).then((res) => {
              this.$message({
                type: "success",
                message: res.msg,
                onClose: () => {
                  this.initData();
                },
              });
            });
          })
          .catch(() => {});
      },
      addOrUpdateHandle(id, isDetail) {
        this.formVisible = true;
        this.$nextTick(() => {
          this.$refs.NCCForm.init(id, isDetail);
        });
      },
      exportData() {
        this.exportBoxVisible = true;
        this.$nextTick(() => {
          this.$refs.ExportBox.init(this.columnList);
        });
      },
      download(data) {
        let query = { ...data, ...this.listQuery, ...this.query };
        request({
          url: `/Extend/BasePrincipalResponsibility/Actions/Export`,
          method: "GET",
          data: query,
        }).then((res) => {
          if (!res.data.url) return;
          window.location.href = this.define.comUrl + res.data.url;
          this.$refs.ExportBox.visible = false;
          this.exportBoxVisible = false;
        });
      },
      search() {
        this.listQuery = {
          currentPage: 1,
          pageSize: 20,
          sort: "desc",
          sidx: "",
        };
        this.initData();
      },
      refresh(isrRefresh) {
        this.formVisible = false;
        if (isrRefresh) this.reset();
      },
      reset() {
        for (let key in this.query) {
          this.query[key] = undefined;
        }
        this.listQuery = {
          currentPage: 1,
          pageSize: 20,
          sort: "desc",
          sidx: "",
        };
        this.initData();
      },
    },
  };
  </script>
  <style scoped lang="scss">
  .common-info-box {
    :deep(.el-table__body-wrapper.is-scrolling-none) {
      height: calc(100% - 47px);
      overflow-y: scroll;
    }
4424f41c   monkeyhouyi   网信执法、清单管理静态页面
237
238
  }
  </style>