371 lines
13 KiB
Java
Raw Normal View History

2019-02-25 15:58:05 +08:00
<template>
<a-card :bordered="false">
<!-- 查询区域 -->
<div class="table-page-search-wrapper">
<a-form layout="inline" @keyup.enter.native="searchQuery">
2019-02-25 15:58:05 +08:00
<a-row :gutter="24">
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="用户名">
<j-input placeholder="请输入名称模糊查询" v-model="queryParam.name"></j-input>
2019-02-25 15:58:05 +08:00
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
2019-02-25 15:58:05 +08:00
<a-form-item label="年龄">
<!-- <a-input placeholder="请输入名称查询" v-model="queryParam.age"></a-input>-->
<a-input placeholder="最小年龄" type="ge" v-model="queryParam.age_begin" style="width:calc(50% - 15px);"></a-input>
<span class="group-query-strig">~</span>
<a-input placeholder="最大年龄" type="le" v-model="queryParam.age_end" style="width:calc(50% - 15px);"></a-input>
2019-02-25 15:58:05 +08:00
</a-form-item>
</a-col>
2019-04-14 16:20:04 +08:00
<template v-if="toggleSearchStatus">
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="生日">
<a-range-picker v-model="queryParam.birthdayRange"
format="YYYY-MM-DD"
:placeholder="['开始时间', '结束时间']"
@change="onBirthdayChange" />
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="性别">
<j-dict-select-tag v-model="queryParam.sex" placeholder="请选择性别" dictCode="sex"/>
2019-04-14 16:20:04 +08:00
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="选择用户">
<j-dict-select-tag v-model="queryParam.id" placeholder="请选择用户" dictCode="demo,name,id"/>
2019-04-14 16:20:04 +08:00
</a-form-item>
</a-col>
</template>
<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
<a-col :xl="6" :lg="7" :md="8" :sm="24">
2019-02-25 15:58:05 +08:00
<a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
<a @click="handleToggleSearch" style="margin-left: 8px">
{{ toggleSearchStatus ? '收起' : '展开' }}
<a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
</a>
2019-04-14 16:20:04 +08:00
</a-col>
</span>
2019-02-25 15:58:05 +08:00
</a-row>
</a-form>
</div>
<!-- 操作按钮区域 -->
<div class="table-operator">
2019-02-25 15:58:05 +08:00
<a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
<a-button type="primary" icon="plus" @click="jump">创建单据</a-button>
<a-button type="primary" icon="plus" @click="onetomany">一对多</a-button>
<a-button type="primary" icon="download" @click="handleExportXls('单表示例')">导出</a-button>
<a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
2019-04-14 16:20:04 +08:00
<a-button type="primary" icon="import">导入</a-button>
</a-upload>
<!-- 高级查询区域 -->
<j-super-query :fieldList="fieldList" ref="superQueryModal" @handleSuperQuery="handleSuperQuery"></j-super-query>
2019-02-25 15:58:05 +08:00
<a-dropdown v-if="selectedRowKeys.length > 0">
<a-menu slot="overlay">
<a-menu-item key="1" @click="batchDel">
<a-icon type="delete"/>
删除
</a-menu-item>
</a-menu>
<a-button style="margin-left: 8px"> 批量操作
<a-icon type="down"/>
</a-button>
</a-dropdown>
</div>
<!-- table区域-begin -->
<div>
<div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
<i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{
selectedRowKeys.length }}</a>
<a style="margin-left: 24px" @click="onClearSelected">清空</a>
2019-07-05 15:38:38 +08:00
<span style="float:right;">
<a @click="loadData()"><a-icon type="sync" />刷新</a>
<a-divider type="vertical" />
<a-popover title="自定义列" trigger="click" placement="leftBottom">
<template slot="content">
<a-checkbox-group @change="onColSettingsChange" v-model="settingColumns" :defaultValue="settingColumns">
<a-row style="width: 400px">
2019-07-05 15:38:38 +08:00
<template v-for="(item,index) in defColumns">
<template v-if="item.key!='rowIndex'&& item.dataIndex!='action'">
<a-col :span="12"><a-checkbox :value="item.dataIndex"><j-ellipsis :value="item.title" :length="10"></j-ellipsis></a-checkbox></a-col>
2019-07-05 15:38:38 +08:00
</template>
</template>
</a-row>
</a-checkbox-group>
</template>
<a><a-icon type="setting" />设置</a>
2019-07-05 15:38:38 +08:00
</a-popover>
</span>
2019-02-25 15:58:05 +08:00
</div>
<a-table
ref="table"
size="middle"
bordered
rowKey="id"
:columns="columns"
:dataSource="dataSource"
:pagination="ipagination"
:loading="loading"
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
@change="handleTableChange">
2019-07-05 15:38:38 +08:00
<div slot="filterDropdown">
<a-card>
<a-checkbox-group @change="onColSettingsChange" v-model="settingColumns" :defaultValue="settingColumns">
<a-row style="width: 400px">
2019-07-05 15:38:38 +08:00
<template v-for="(item,index) in defColumns">
<template v-if="item.key!='rowIndex'&& item.dataIndex!='action'">
<a-col :span="12"><a-checkbox :value="item.dataIndex"><j-ellipsis :value="item.title" :length="10"></j-ellipsis></a-checkbox></a-col>
2019-07-05 15:38:38 +08:00
</template>
</template>
</a-row>
</a-checkbox-group>
</a-card>
</div>
<a-icon slot="filterIcon" type='setting' :style="{ fontSize:'16px',color: '#108ee9' }" />
2019-02-25 15:58:05 +08:00
<span slot="action" slot-scope="text, record">
<a @click="handleEdit(record)">编辑</a>
<a-divider type="vertical"/>
<a-dropdown>
<a class="ant-dropdown-link">更多 <a-icon type="down"/></a>
<a-menu slot="overlay">
<a-menu-item>
<a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
<a>删除</a>
</a-popconfirm>
</a-menu-item>
</a-menu>
</a-dropdown>
</span>
</a-table>
</div>
<!-- table区域-end -->
<!-- 表单区域 -->
2019-04-14 16:20:04 +08:00
<jeecgDemo-modal ref="modalForm" @ok="modalFormOk"></jeecgDemo-modal>
2019-02-25 15:58:05 +08:00
<!-- 一对多表单区域 -->
<JeecgDemoTabsModal ref="jeecgDemoTabsModal" @ok="modalFormOk"></JeecgDemoTabsModal>
</a-card>
</template>
<script>
import JeecgDemoModal from './modules/JeecgDemoModal'
2019-04-14 16:20:04 +08:00
import JSuperQuery from '@/components/jeecg/JSuperQuery.vue';
import JInput from '@/components/jeecg/JInput.vue';
2019-02-25 15:58:05 +08:00
import JeecgDemoTabsModal from './modules/JeecgDemoTabsModal'
import {initDictOptions, filterDictText,filterDictTextByCache} from '@/components/dict/JDictSelectUtil'
2019-04-14 16:20:04 +08:00
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
2019-07-05 15:38:38 +08:00
import Vue from 'vue'
import { filterObj } from '@/utils/util';
2019-02-25 15:58:05 +08:00
2019-04-14 16:20:04 +08:00
//高级查询modal需要参数
const superQueryFieldList=[
{
type: "string",
value: "name",
text: "用户名"
}, {
type: "int",
value: "age",
text: "年龄"
}, {
type: "date",
value: "birthday",
text: "生日"
}
]
2019-02-25 15:58:05 +08:00
export default {
name: "JeecgDemoList",
2019-04-14 16:20:04 +08:00
mixins:[JeecgListMixin],
2019-02-25 15:58:05 +08:00
components: {
JeecgDemoModal,
2019-04-14 16:20:04 +08:00
JSuperQuery,
2019-02-25 15:58:05 +08:00
JeecgDemoTabsModal,
JInput
2019-02-25 15:58:05 +08:00
},
data() {
return {
description: '单表示例列表',
2019-02-25 15:58:05 +08:00
//字典数组缓存
sexDictOptions: [],
2019-04-14 16:20:04 +08:00
importExcelUrl:`${window._CONFIG['domianURL']}/test/jeecgDemo/importExcel`,
2019-07-05 15:38:38 +08:00
//表头
columns:[],
//列设置
settingColumns:[],
//列定义
defColumns: [
2019-02-25 15:58:05 +08:00
{
title: '#',
dataIndex: '',
key: 'rowIndex',
width: 60,
align: "center",
customRender: function (t, r, index) {
return parseInt(index) + 1;
}
},
{
title: '姓名',
align: "center",
dataIndex: 'name'
},
{
title: '关键词',
align: "center",
dataIndex: 'keyWord'
},
{
title: '打卡时间',
align: "center",
dataIndex: 'punchTime'
},
{
title: '性别',
align: "center",
dataIndex: 'sex',
2019-04-14 16:20:04 +08:00
customRender: (text) => {
2019-02-25 15:58:05 +08:00
//字典值替换通用方法
return filterDictTextByCache('sex', text);
2019-02-25 15:58:05 +08:00
}
},
{
title: '年龄',
align: "center",
dataIndex: 'age'
},
{
title: '生日',
align: "center",
dataIndex: 'birthday'
},
{
title: '邮箱',
align: "center",
dataIndex: 'email'
},
{
title: '个人简介',
align: "center",
dataIndex: 'content'
},
{
title: '操作',
dataIndex: 'action',
align: "center",
2019-07-05 15:38:38 +08:00
scopedSlots: {
filterDropdown: 'filterDropdown',
filterIcon: 'filterIcon',
customRender: 'action'},
2019-02-25 15:58:05 +08:00
}
],
url: {
list: "/test/jeecgDemo/list",
delete: "/test/jeecgDemo/delete",
deleteBatch: "/test/jeecgDemo/deleteBatch",
exportXlsUrl: "/test/jeecgDemo/exportXls"
2019-02-25 15:58:05 +08:00
},
2019-04-14 16:20:04 +08:00
fieldList:superQueryFieldList
2019-02-25 15:58:05 +08:00
}
},
methods: {
getQueryParams(){
2019-12-25 13:25:10 +08:00
//高级查询器
let sqp = {}
if(this.superQueryParams){
sqp['superQueryParams']=encodeURI(this.superQueryParams)
sqp['superQueryMatchType'] = this.superQueryMatchType
2019-12-25 13:25:10 +08:00
}
var param = Object.assign(sqp, this.queryParam, this.isorter ,this.filters);
param.field = this.getQueryField();
param.pageNo = this.ipagination.current;
param.pageSize = this.ipagination.pageSize;
delete param.birthdayRange; //范围参数不传递后台
return filterObj(param);
},
2019-02-25 15:58:05 +08:00
initDictConfig() {
2019-04-14 16:20:04 +08:00
console.log("--我才是真的方法!--")
2019-02-25 15:58:05 +08:00
//初始化字典 - 性别
initDictOptions('sex').then((res) => {
if (res.success) {
this.sexDictOptions = res.result;
}
});
},
2019-04-14 16:20:04 +08:00
onetomany: function () {
2019-02-25 15:58:05 +08:00
this.$refs.jeecgDemoTabsModal.add();
this.$refs.jeecgDemoTabsModal.title = "编辑";
},
//跳转单据页面
jump() {
this.$router.push({path: '/jeecg/helloworld'})
2019-07-05 15:38:38 +08:00
},
onBirthdayChange: function (value, dateString) {
console.log(dateString[0],dateString[1]);
this.queryParam.birthday_begin=dateString[0];
this.queryParam.birthday_end=dateString[1];
},
2019-07-05 15:38:38 +08:00
//列设置更改事件
onColSettingsChange (checkedValues) {
var key = this.$route.name+":colsettings";
Vue.ls.set(key, checkedValues, 7 * 24 * 60 * 60 * 1000)
this.settingColumns = checkedValues;
const cols = this.defColumns.filter(item => {
if(item.key =='rowIndex'|| item.dataIndex=='action'){
return true
}
if (this.settingColumns.includes(item.dataIndex)) {
return true
}
return false
})
this.columns = cols;
},
initColumns(){
//权限过滤(列权限控制时打开,修改第二个参数为授权码前缀)
//this.defColumns = colAuthFilter(this.defColumns,'testdemo:');
var key = this.$route.name+":colsettings";
let colSettings= Vue.ls.get(key);
if(colSettings==null||colSettings==undefined){
let allSettingColumns = [];
this.defColumns.forEach(function (item,i,array ) {
allSettingColumns.push(item.dataIndex);
})
this.settingColumns = allSettingColumns;
this.columns = this.defColumns;
}else{
this.settingColumns = colSettings;
const cols = this.defColumns.filter(item => {
if(item.key =='rowIndex'|| item.dataIndex=='action'){
return true;
}
if (colSettings.includes(item.dataIndex)) {
return true;
}
return false;
})
this.columns = cols;
}
2019-02-25 15:58:05 +08:00
}
2019-07-05 15:38:38 +08:00
},
created() {
this.initColumns();
},
2019-02-25 15:58:05 +08:00
}
</script>
2019-02-25 19:50:57 +08:00
<style scoped>
@import '~@assets/less/common.less';
2019-02-25 15:58:05 +08:00
</style>