|
@@ -1,82 +1,60 @@
|
|
<template>
|
|
<template>
|
|
<a-card :bordered="false">
|
|
<a-card :bordered="false">
|
|
- <a-row v-show="visible" :gutter="20">
|
|
|
|
- <a-col :span="6">
|
|
|
|
- <a-tree
|
|
|
|
- @expand="onExpand"
|
|
|
|
- :expandedKeys="expandedKeys"
|
|
|
|
- :autoExpandParent="autoExpandParent"
|
|
|
|
- @select="onSelect"
|
|
|
|
- :selectedKeys="selectedKeys"
|
|
|
|
- :treeData="treeData"
|
|
|
|
- :replaceFields="{
|
|
|
|
- children:'children', title:'title', key:'value'
|
|
|
|
- }"
|
|
|
|
- />
|
|
|
|
- </a-col>
|
|
|
|
- <a-col :span="18">
|
|
|
|
- <div class="table-page-search-wrapper" @keyup.enter="handleEnter">
|
|
|
|
- <a-form layout="inline">
|
|
|
|
- <a-row :gutter="48" >
|
|
|
|
- <a-col :md="6" :sm="24">
|
|
|
|
- <a-form-item label="模板名称">
|
|
|
|
- <a-input v-model="queryParam.name" placeholder="请输入模板名称"/>
|
|
|
|
- </a-form-item>
|
|
|
|
- </a-col>
|
|
|
|
- <a-col :md="6 || 24" :sm="24" >
|
|
|
|
- <span class="table-page-search-submitButtons">
|
|
|
|
- <a-button type="primary" @click="$refs.table.refresh(true)">查询</a-button>
|
|
|
|
- <a-button style="margin-left: 8px" @click="resetSearchForm">重置</a-button>
|
|
|
|
- </span>
|
|
|
|
- </a-col>
|
|
|
|
- </a-row>
|
|
|
|
- </a-form>
|
|
|
|
- </div>
|
|
|
|
-
|
|
|
|
- <div class="table-operator" style="margin-bottom: 8px;">
|
|
|
|
- <a-row>
|
|
|
|
- <a-col :md="16">
|
|
|
|
- <a-button type="primary" icon="plus" @click="handleAdd()">新增</a-button>
|
|
|
|
- <a-dropdown v-action:edit v-if="selectedRowKeys.length > 0 ">
|
|
|
|
- <a-menu slot="overlay">
|
|
|
|
- <a-popconfirm title="是否要删除所选数据?" @confirm="batchDelete()">
|
|
|
|
- <a-menu-item key="1"><a-icon type="delete" /><a>删除</a></a-menu-item>
|
|
|
|
- </a-popconfirm>
|
|
|
|
- </a-menu>
|
|
|
|
- <a-button style="margin-left: 8px">
|
|
|
|
- 批量操作 <a-icon type="down" />
|
|
|
|
- </a-button>
|
|
|
|
- </a-dropdown>
|
|
|
|
|
|
+ <div v-show="visible">
|
|
|
|
+ <div class="table-page-search-wrapper" @keyup.enter="handleEnter">
|
|
|
|
+ <a-form layout="inline">
|
|
|
|
+ <a-row :gutter="48">
|
|
|
|
+ <a-col :md="6" :sm="24">
|
|
|
|
+ <a-form-item label="模板名称">
|
|
|
|
+ <a-input v-model="queryParam.name" placeholder="请输入模板名称" />
|
|
|
|
+ </a-form-item>
|
|
|
|
+ </a-col>
|
|
|
|
+ <a-col :md="6" :sm="24">
|
|
|
|
+ <a-form-item label="所属部门">
|
|
|
|
+ <a-tree-select v-model="queryParam.deptId" style="width: 100%" :dropdown-style="{ maxHeight: '400px', overflow: 'auto' }" :tree-data="treeData" placeholder="请选择" tree-default-expand-all>
|
|
|
|
+ </a-tree-select>
|
|
|
|
+ </a-form-item>
|
|
|
|
+ </a-col>
|
|
|
|
+ <a-col :md="6 || 24" :sm="24">
|
|
|
|
+ <span class="table-page-search-submitButtons">
|
|
|
|
+ <a-button type="primary" @click="$refs.table.refresh(true)">查询</a-button>
|
|
|
|
+ <a-button style="margin-left: 8px" @click="resetSearchForm">重置</a-button>
|
|
|
|
+ </span>
|
|
</a-col>
|
|
</a-col>
|
|
</a-row>
|
|
</a-row>
|
|
- </div>
|
|
|
|
|
|
+ </a-form>
|
|
|
|
+ </div>
|
|
|
|
|
|
- <s-table
|
|
|
|
- ref="table"
|
|
|
|
- size="default"
|
|
|
|
- rowKey="id"
|
|
|
|
- :columns="columns"
|
|
|
|
- :data="loadData"
|
|
|
|
- showPagination="auto"
|
|
|
|
- >
|
|
|
|
- <span slot="action" slot-scope="record">
|
|
|
|
- <template>
|
|
|
|
- <a @click="handleView(record)">查看</a>
|
|
|
|
- <operation-button
|
|
|
|
- @click="handleEdit(record)"
|
|
|
|
- >修改</operation-button>
|
|
|
|
- <operation-button
|
|
|
|
- v-if="$auth('custom-form-del')"
|
|
|
|
- :type="2"
|
|
|
|
- title="是否要删除该条数据?"
|
|
|
|
- @confirm="batchDelete(record.id)">删除</operation-button>
|
|
|
|
- </template>
|
|
|
|
- </span>
|
|
|
|
- </s-table>
|
|
|
|
- </a-col>
|
|
|
|
- </a-row>
|
|
|
|
- <base-form ref="baseModal" @ok="handleOk"/>
|
|
|
|
- <detail ref="detailModal" @ok="handleOk"/>
|
|
|
|
|
|
+ <div class="table-operator" style="margin-bottom: 8px;">
|
|
|
|
+ <a-row>
|
|
|
|
+ <a-col :md="16">
|
|
|
|
+ <a-button type="primary" icon="plus" @click="handleAdd()">新增</a-button>
|
|
|
|
+ <a-dropdown v-action:edit v-if="selectedRowKeys.length > 0 ">
|
|
|
|
+ <a-menu slot="overlay">
|
|
|
|
+ <a-popconfirm title="是否要删除所选数据?" @confirm="batchDelete()">
|
|
|
|
+ <a-menu-item key="1"><a-icon type="delete" /><a>删除</a></a-menu-item>
|
|
|
|
+ </a-popconfirm>
|
|
|
|
+ </a-menu>
|
|
|
|
+ <a-button style="margin-left: 8px">
|
|
|
|
+ 批量操作 <a-icon type="down" />
|
|
|
|
+ </a-button>
|
|
|
|
+ </a-dropdown>
|
|
|
|
+ </a-col>
|
|
|
|
+ </a-row>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <s-table ref="table" size="default" rowKey="id" :columns="columns" :data="loadData" showPagination="auto">
|
|
|
|
+ <span slot="action" slot-scope="record">
|
|
|
|
+ <template>
|
|
|
|
+ <a @click="handleView(record)">查看</a>
|
|
|
|
+ <operation-button @click="handleEdit(record)">修改</operation-button>
|
|
|
|
+ <operation-button v-if="$auth('custom-form-del')" :type="2" title="是否要删除该条数据?" @confirm="batchDelete(record.id)">删除</operation-button>
|
|
|
|
+ </template>
|
|
|
|
+ </span>
|
|
|
|
+ </s-table>
|
|
|
|
+ </div>
|
|
|
|
+ <base-form ref="baseModal" @ok="handleOk" />
|
|
|
|
+ <detail ref="detailModal" @ok="handleOk" />
|
|
</a-card>
|
|
</a-card>
|
|
</template>
|
|
</template>
|
|
|
|
|
|
@@ -92,61 +70,59 @@ export default {
|
|
STable,
|
|
STable,
|
|
Ellipsis,
|
|
Ellipsis,
|
|
BaseForm,
|
|
BaseForm,
|
|
- Detail
|
|
|
|
|
|
+ Detail,
|
|
},
|
|
},
|
|
- data () {
|
|
|
|
|
|
+ data() {
|
|
return {
|
|
return {
|
|
- advanced: false,
|
|
|
|
visible: true,
|
|
visible: true,
|
|
treeData: [],
|
|
treeData: [],
|
|
- expandedKeys: [],
|
|
|
|
- autoExpandParent: true,
|
|
|
|
// 查询参数
|
|
// 查询参数
|
|
- queryParam: {
|
|
|
|
- },
|
|
|
|
|
|
+ queryParam: {},
|
|
// 表头
|
|
// 表头
|
|
columns: [
|
|
columns: [
|
|
{
|
|
{
|
|
title: '序号',
|
|
title: '序号',
|
|
dataIndex: 'index',
|
|
dataIndex: 'index',
|
|
customRender: (text, record, index) => {
|
|
customRender: (text, record, index) => {
|
|
- return `${(this.$refs.table.localPagination.current - 1) * this.$refs.table.localPagination.pageSize + index + 1}`
|
|
|
|
- }
|
|
|
|
|
|
+ return `${
|
|
|
|
+ (this.$refs.table.localPagination.current - 1) * this.$refs.table.localPagination.pageSize + index + 1
|
|
|
|
+ }`
|
|
|
|
+ },
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '表单名称',
|
|
title: '表单名称',
|
|
- dataIndex: 'name'
|
|
|
|
|
|
+ dataIndex: 'name',
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '表单类型',
|
|
title: '表单类型',
|
|
dataIndex: 'type',
|
|
dataIndex: 'type',
|
|
customRender: (text, record, index) => {
|
|
customRender: (text, record, index) => {
|
|
return this.BaseTool.Table.getMapText(this.typeMap, text)
|
|
return this.BaseTool.Table.getMapText(this.typeMap, text)
|
|
- }
|
|
|
|
|
|
+ },
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '模板分类',
|
|
title: '模板分类',
|
|
dataIndex: 'category',
|
|
dataIndex: 'category',
|
|
customRender: (text, record, index) => {
|
|
customRender: (text, record, index) => {
|
|
return this.BaseTool.Table.getMapText(this.categoryMap, text)
|
|
return this.BaseTool.Table.getMapText(this.categoryMap, text)
|
|
- }
|
|
|
|
|
|
+ },
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '备注',
|
|
title: '备注',
|
|
- dataIndex: 'remark'
|
|
|
|
|
|
+ dataIndex: 'remark',
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '创建人',
|
|
title: '创建人',
|
|
- dataIndex: 'createdUserName'
|
|
|
|
|
|
+ dataIndex: 'createdUserName',
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '创建时间',
|
|
title: '创建时间',
|
|
- dataIndex: 'createdTime'
|
|
|
|
|
|
+ dataIndex: 'createdTime',
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '状态',
|
|
title: '状态',
|
|
fixed: 'right',
|
|
fixed: 'right',
|
|
- dataIndex: 'status'
|
|
|
|
|
|
+ dataIndex: 'status',
|
|
},
|
|
},
|
|
{
|
|
{
|
|
title: '操作',
|
|
title: '操作',
|
|
@@ -154,75 +130,93 @@ export default {
|
|
width: '200px',
|
|
width: '200px',
|
|
fixed: 'right',
|
|
fixed: 'right',
|
|
align: 'center',
|
|
align: 'center',
|
|
- scopedSlots: { customRender: 'action' }
|
|
|
|
- }
|
|
|
|
|
|
+ scopedSlots: { customRender: 'action' },
|
|
|
|
+ },
|
|
],
|
|
],
|
|
// 下拉框map
|
|
// 下拉框map
|
|
// 加载数据方法 必须为 Promise 对象
|
|
// 加载数据方法 必须为 Promise 对象
|
|
- loadData: parameter => {
|
|
|
|
|
|
+ loadData: (parameter) => {
|
|
parameter = {
|
|
parameter = {
|
|
...parameter,
|
|
...parameter,
|
|
...this.queryParam,
|
|
...this.queryParam,
|
|
dataScope: {
|
|
dataScope: {
|
|
sortBy: 'desc',
|
|
sortBy: 'desc',
|
|
- sortName: 'created_time'
|
|
|
|
- }
|
|
|
|
|
|
+ sortName: 'created_time',
|
|
|
|
+ },
|
|
}
|
|
}
|
|
- return getCustomFormPage(Object.assign(parameter, this.queryParam))
|
|
|
|
- .then(res => {
|
|
|
|
- return res.data
|
|
|
|
- })
|
|
|
|
|
|
+ return getCustomFormPage(Object.assign(parameter, this.queryParam)).then((res) => {
|
|
|
|
+ return res.data
|
|
|
|
+ })
|
|
},
|
|
},
|
|
selectedRowKeys: [],
|
|
selectedRowKeys: [],
|
|
selectedRows: [],
|
|
selectedRows: [],
|
|
- selectedKeys: [],
|
|
|
|
options: {
|
|
options: {
|
|
- alert: { show: true, clear: () => { this.selectedRowKeys = [] } },
|
|
|
|
|
|
+ alert: {
|
|
|
|
+ show: true,
|
|
|
|
+ clear: () => {
|
|
|
|
+ this.selectedRowKeys = []
|
|
|
|
+ },
|
|
|
|
+ },
|
|
rowSelection: {
|
|
rowSelection: {
|
|
selectedRowKeys: this.selectedRowKeys,
|
|
selectedRowKeys: this.selectedRowKeys,
|
|
- onChange: this.onSelectChange
|
|
|
|
- }
|
|
|
|
|
|
+ onChange: this.onSelectChange,
|
|
|
|
+ },
|
|
},
|
|
},
|
|
optionAlertShow: false,
|
|
optionAlertShow: false,
|
|
categoryMap: {},
|
|
categoryMap: {},
|
|
- typeMap: {}
|
|
|
|
|
|
+ typeMap: {},
|
|
}
|
|
}
|
|
},
|
|
},
|
|
- created () {
|
|
|
|
|
|
+ created() {
|
|
// 下拉框map
|
|
// 下拉框map
|
|
this.typeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CUSTOM_FORM_TYPE)
|
|
this.typeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CUSTOM_FORM_TYPE)
|
|
this.categoryMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CATEGORY_TYPE)
|
|
this.categoryMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.CATEGORY_TYPE)
|
|
this.tableOption()
|
|
this.tableOption()
|
|
- getCustomTree().then(res => {
|
|
|
|
- this.treeData = res.data
|
|
|
|
|
|
+ getCustomTree().then((res) => {
|
|
|
|
+ this.treeData = this.setTree(res.data)
|
|
})
|
|
})
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
- tableOption () {
|
|
|
|
|
|
+ tableOption() {
|
|
if (!this.optionAlertShow) {
|
|
if (!this.optionAlertShow) {
|
|
this.options = {
|
|
this.options = {
|
|
- alert: { show: true, clear: () => { this.selectedRowKeys = [] } },
|
|
|
|
|
|
+ alert: {
|
|
|
|
+ show: true,
|
|
|
|
+ clear: () => {
|
|
|
|
+ this.selectedRowKeys = []
|
|
|
|
+ },
|
|
|
|
+ },
|
|
rowSelection: {
|
|
rowSelection: {
|
|
selectedRowKeys: this.selectedRowKeys,
|
|
selectedRowKeys: this.selectedRowKeys,
|
|
onChange: this.onSelectChange,
|
|
onChange: this.onSelectChange,
|
|
- getCheckboxProps: record => ({
|
|
|
|
|
|
+ getCheckboxProps: (record) => ({
|
|
props: {
|
|
props: {
|
|
disabled: false,
|
|
disabled: false,
|
|
- name: record.id
|
|
|
|
- }
|
|
|
|
- })
|
|
|
|
- }
|
|
|
|
|
|
+ name: record.id,
|
|
|
|
+ },
|
|
|
|
+ }),
|
|
|
|
+ },
|
|
}
|
|
}
|
|
this.optionAlertShow = true
|
|
this.optionAlertShow = true
|
|
} else {
|
|
} else {
|
|
this.options = {
|
|
this.options = {
|
|
alert: false,
|
|
alert: false,
|
|
- rowSelection: null
|
|
|
|
|
|
+ rowSelection: null,
|
|
}
|
|
}
|
|
this.optionAlertShow = false
|
|
this.optionAlertShow = false
|
|
}
|
|
}
|
|
},
|
|
},
|
|
- batchDelete (id) {
|
|
|
|
|
|
+ setTree(list) {
|
|
|
|
+ return list.map((item) => {
|
|
|
|
+ return {
|
|
|
|
+ title: item.title,
|
|
|
|
+ key: item.id,
|
|
|
|
+ value: item.id,
|
|
|
|
+ children: item.children ? this.setTree(item.children) : [],
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ batchDelete(id) {
|
|
let ids = []
|
|
let ids = []
|
|
if (this.BaseTool.String.isBlank(id)) {
|
|
if (this.BaseTool.String.isBlank(id)) {
|
|
const length = this.selectedRows.length
|
|
const length = this.selectedRows.length
|
|
@@ -230,66 +224,50 @@ export default {
|
|
this.$message.info('请选择要删除的记录')
|
|
this.$message.info('请选择要删除的记录')
|
|
return
|
|
return
|
|
}
|
|
}
|
|
- ids = this.selectedRows.map(item => item.id)
|
|
|
|
|
|
+ ids = this.selectedRows.map((item) => item.id)
|
|
} else {
|
|
} else {
|
|
ids = [id]
|
|
ids = [id]
|
|
}
|
|
}
|
|
- deleteCustomForms(ids).then(res => {
|
|
|
|
|
|
+ deleteCustomForms(ids).then((res) => {
|
|
this.$message.info('删除成功')
|
|
this.$message.info('删除成功')
|
|
this.handleOk()
|
|
this.handleOk()
|
|
this.$refs.table.clearSelected()
|
|
this.$refs.table.clearSelected()
|
|
})
|
|
})
|
|
},
|
|
},
|
|
- handleAdd () {
|
|
|
|
|
|
+ handleAdd() {
|
|
this.visible = false
|
|
this.visible = false
|
|
const modal = this.$refs.baseModal
|
|
const modal = this.$refs.baseModal
|
|
modal.base()
|
|
modal.base()
|
|
},
|
|
},
|
|
- handleEdit (record) {
|
|
|
|
|
|
+ handleEdit(record) {
|
|
this.visible = false
|
|
this.visible = false
|
|
- fetchCustomForm({ id: record.id }).then(res => {
|
|
|
|
|
|
+ fetchCustomForm({ id: record.id }).then((res) => {
|
|
const modal = this.$refs.baseModal
|
|
const modal = this.$refs.baseModal
|
|
modal.base(res.data)
|
|
modal.base(res.data)
|
|
})
|
|
})
|
|
},
|
|
},
|
|
- handleView (record) {
|
|
|
|
|
|
+ handleView(record) {
|
|
this.visible = false
|
|
this.visible = false
|
|
- fetchCustomForm({ id: record.id }).then(res => {
|
|
|
|
|
|
+ fetchCustomForm({ id: record.id }).then((res) => {
|
|
const modal = this.$refs.detailModal
|
|
const modal = this.$refs.detailModal
|
|
modal.base(res.data)
|
|
modal.base(res.data)
|
|
})
|
|
})
|
|
},
|
|
},
|
|
- handleOk (values) {
|
|
|
|
|
|
+ handleOk(values) {
|
|
this.visible = true
|
|
this.visible = true
|
|
this.$refs.table.refresh()
|
|
this.$refs.table.refresh()
|
|
},
|
|
},
|
|
- onSelectChange (selectedRowKeys, selectedRows) {
|
|
|
|
|
|
+ onSelectChange(selectedRowKeys, selectedRows) {
|
|
this.selectedRowKeys = selectedRowKeys
|
|
this.selectedRowKeys = selectedRowKeys
|
|
this.selectedRows = selectedRows
|
|
this.selectedRows = selectedRows
|
|
},
|
|
},
|
|
- resetSearchForm () {
|
|
|
|
- this.queryParam = {
|
|
|
|
- }
|
|
|
|
|
|
+ resetSearchForm() {
|
|
|
|
+ this.queryParam = {}
|
|
this.$refs.table.refresh(true)
|
|
this.$refs.table.refresh(true)
|
|
},
|
|
},
|
|
- onSelect: function (selectedKeys, info) {
|
|
|
|
- this.selectedKeys = selectedKeys
|
|
|
|
- if (selectedKeys.length > 0) {
|
|
|
|
- this.queryParam.deptId = selectedKeys[0]
|
|
|
|
- this.rightSelectDept = info.node.dataRef.item
|
|
|
|
- } else {
|
|
|
|
- this.queryParam.deptId = ''
|
|
|
|
- this.rightSelectDept = {}
|
|
|
|
- }
|
|
|
|
|
|
+ handleEnter() {
|
|
this.$refs.table.refresh(true)
|
|
this.$refs.table.refresh(true)
|
|
},
|
|
},
|
|
- onExpand (expandedKeys) {
|
|
|
|
- this.expandedKeys = expandedKeys
|
|
|
|
- this.autoExpandParent = false
|
|
|
|
- },
|
|
|
|
- handleEnter () {
|
|
|
|
- this.$refs.table.refresh(true)
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
|
|
+ },
|
|
}
|
|
}
|
|
</script>
|
|
</script>
|