提交 bacabf84 authored 作者: TaoJinlong's avatar TaoJinlong

Merge branch 'main' of https://github.com/dataease/dataease into main

...@@ -8,6 +8,7 @@ import io.dataease.controller.sys.request.DeptCreateRequest; ...@@ -8,6 +8,7 @@ import io.dataease.controller.sys.request.DeptCreateRequest;
import io.dataease.controller.sys.request.DeptDeleteRequest; import io.dataease.controller.sys.request.DeptDeleteRequest;
import io.dataease.controller.sys.request.DeptStatusRequest; import io.dataease.controller.sys.request.DeptStatusRequest;
import io.dataease.controller.sys.response.DeptNodeResponse; import io.dataease.controller.sys.response.DeptNodeResponse;
import io.dataease.controller.sys.response.DeptTreeNode;
import io.dataease.service.sys.DeptService; import io.dataease.service.sys.DeptService;
import io.swagger.annotations.Api; import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiOperation;
...@@ -82,4 +83,9 @@ public class SysDeptController extends ResultHolder { ...@@ -82,4 +83,9 @@ public class SysDeptController extends ResultHolder {
deptService.updateStatus(request); deptService.updateStatus(request);
} }
@PostMapping("/nodesByDeptId/{deptId}")
public List<DeptTreeNode> nodesByDeptId(@PathVariable("deptId") Long deptId){
return deptService.searchTree(deptId);
}
} }
package io.dataease.controller.sys.response;
import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class DeptTreeNode implements Serializable {
private Long id;
private String label;
private Boolean hasChildren;
private List<DeptTreeNode> children;
public List<DeptTreeNode> toList(){
List<DeptTreeNode> lists = new ArrayList<>();
lists.add(this);
return lists;
}
}
package io.dataease.datasource.provider; package io.dataease.datasource.provider;
import io.dataease.base.domain.DatasetTableField;
import io.dataease.base.domain.Datasource; import io.dataease.base.domain.Datasource;
import io.dataease.datasource.dto.TableFiled; import io.dataease.datasource.dto.TableFiled;
import io.dataease.datasource.request.DatasourceRequest; import io.dataease.datasource.request.DatasourceRequest;
...@@ -32,6 +33,6 @@ public abstract class DatasourceProvider { ...@@ -32,6 +33,6 @@ public abstract class DatasourceProvider {
abstract public List<String[]> fetchResult(ResultSet rs) throws Exception; abstract public List<String[]> fetchResult(ResultSet rs) throws Exception;
abstract public List<String> fetchResultField(ResultSet rs) throws Exception; abstract public List<TableFiled> fetchResultField(ResultSet rs) throws Exception;
} }
package io.dataease.datasource.provider; package io.dataease.datasource.provider;
import com.google.gson.Gson; import com.google.gson.Gson;
import io.dataease.base.domain.DatasetTableField;
import io.dataease.datasource.constants.DatasourceTypes; import io.dataease.datasource.constants.DatasourceTypes;
import io.dataease.datasource.dto.MysqlConfigrationDTO; import io.dataease.datasource.dto.MysqlConfigrationDTO;
import io.dataease.datasource.dto.SqlServerConfigration; import io.dataease.datasource.dto.SqlServerConfigration;
...@@ -90,12 +91,19 @@ public class JdbcProvider extends DatasourceProvider { ...@@ -90,12 +91,19 @@ public class JdbcProvider extends DatasourceProvider {
} }
@Override @Override
public List<String> fetchResultField(ResultSet rs) throws Exception { public List<TableFiled> fetchResultField(ResultSet rs) throws Exception {
List<String> fieldList = new ArrayList<>(); List<TableFiled> fieldList = new ArrayList<>();
ResultSetMetaData metaData = rs.getMetaData(); ResultSetMetaData metaData = rs.getMetaData();
int columnCount = metaData.getColumnCount(); int columnCount = metaData.getColumnCount();
for (int j = 0; j < columnCount; j++) { for (int j = 0; j < columnCount; j++) {
fieldList.add(metaData.getColumnName(j + 1)); String f = metaData.getColumnName(j + 1);
String l = StringUtils.isNotEmpty(metaData.getColumnLabel(j + 1)) ? metaData.getColumnLabel(j + 1) : f;
String t = metaData.getColumnTypeName(j + 1);
TableFiled field = new TableFiled();
field.setFieldName(l);
field.setRemarks(l);
field.setFieldType(t);
fieldList.add(field);
} }
return fieldList; return fieldList;
} }
......
...@@ -102,8 +102,13 @@ public class ChartViewService { ...@@ -102,8 +102,13 @@ public class ChartViewService {
DatasourceRequest datasourceRequest = new DatasourceRequest(); DatasourceRequest datasourceRequest = new DatasourceRequest();
datasourceRequest.setDatasource(ds); datasourceRequest.setDatasource(ds);
DataTableInfoDTO dataTableInfoDTO = new Gson().fromJson(table.getInfo(), DataTableInfoDTO.class); DataTableInfoDTO dataTableInfoDTO = new Gson().fromJson(table.getInfo(), DataTableInfoDTO.class);
datasourceRequest.setTable(dataTableInfoDTO.getTable()); if (StringUtils.equalsIgnoreCase(table.getType(), "db")) {
datasourceRequest.setQuery(getSQL(ds.getType(), dataTableInfoDTO.getTable(), xAxis, yAxis)); datasourceRequest.setTable(dataTableInfoDTO.getTable());
datasourceRequest.setQuery(getSQL(ds.getType(), dataTableInfoDTO.getTable(), xAxis, yAxis));
} else if (StringUtils.equalsIgnoreCase(table.getType(), "sql")) {
datasourceRequest.setQuery(getSQL(ds.getType(), " (" + dataTableInfoDTO.getSql() + ") AS tmp ", xAxis, yAxis));
}
List<String[]> data = datasourceProvider.getData(datasourceRequest); List<String[]> data = datasourceProvider.getData(datasourceRequest);
// todo 处理结果,目前做一个单系列图表,后期图表组件再扩展 // todo 处理结果,目前做一个单系列图表,后期图表组件再扩展
......
...@@ -54,8 +54,8 @@ public class DataSetTableService { ...@@ -54,8 +54,8 @@ public class DataSetTableService {
DataTableInfoDTO dataTableInfoDTO = new DataTableInfoDTO(); DataTableInfoDTO dataTableInfoDTO = new DataTableInfoDTO();
if (StringUtils.equalsIgnoreCase("db", datasetTable.getType())) { if (StringUtils.equalsIgnoreCase("db", datasetTable.getType())) {
dataTableInfoDTO.setTable(datasetTable.getName()); dataTableInfoDTO.setTable(datasetTable.getName());
datasetTable.setInfo(new Gson().toJson(dataTableInfoDTO));
} }
datasetTable.setInfo(new Gson().toJson(dataTableInfoDTO));
int insert = datasetTableMapper.insert(datasetTable); int insert = datasetTableMapper.insert(datasetTable);
// 添加表成功后,获取当前表字段和类型,抽象到dataease数据库 // 添加表成功后,获取当前表字段和类型,抽象到dataease数据库
if (insert == 1) { if (insert == 1) {
...@@ -143,15 +143,22 @@ public class DataSetTableService { ...@@ -143,15 +143,22 @@ public class DataSetTableService {
DatasourceProvider datasourceProvider = ProviderFactory.getProvider(ds.getType()); DatasourceProvider datasourceProvider = ProviderFactory.getProvider(ds.getType());
DatasourceRequest datasourceRequest = new DatasourceRequest(); DatasourceRequest datasourceRequest = new DatasourceRequest();
datasourceRequest.setDatasource(ds); datasourceRequest.setDatasource(ds);
String table = new Gson().fromJson(dataSetTableRequest.getInfo(), DataTableInfoDTO.class).getTable();
DatasetTableField datasetTableField = DatasetTableField.builder().build(); DatasetTableField datasetTableField = DatasetTableField.builder().build();
datasetTableField.setTableId(dataSetTableRequest.getId()); datasetTableField.setTableId(dataSetTableRequest.getId());
datasetTableField.setChecked(Boolean.TRUE); datasetTableField.setChecked(Boolean.TRUE);
List<DatasetTableField> fields = dataSetTableFieldsService.list(datasetTableField); List<DatasetTableField> fields = dataSetTableFieldsService.list(datasetTableField);
String[] fieldArray = fields.stream().map(DatasetTableField::getOriginName).toArray(String[]::new); String[] fieldArray = fields.stream().map(DatasetTableField::getOriginName).toArray(String[]::new);
datasourceRequest.setQuery(createQuerySQL(ds.getType(), table, fieldArray) + " LIMIT 0,10");// todo limit
DataTableInfoDTO dataTableInfoDTO = new Gson().fromJson(dataSetTableRequest.getInfo(), DataTableInfoDTO.class);
DatasetTable datasetTable = datasetTableMapper.selectByPrimaryKey(dataSetTableRequest.getId());
if (StringUtils.equalsIgnoreCase(datasetTable.getType(), "db")) {
String table = dataTableInfoDTO.getTable();
datasourceRequest.setQuery(createQuerySQL(ds.getType(), table, fieldArray) + " LIMIT 0,10");// todo limit
} else if (StringUtils.equalsIgnoreCase(datasetTable.getType(), "sql")) {
String sql = dataTableInfoDTO.getSql();
datasourceRequest.setQuery(createQuerySQL(ds.getType(), " (" + sql + ") AS tmp ", fieldArray));// todo 因为编辑可能取消某些字段展示,这里sql看看怎么处理
}
List<String[]> data = new ArrayList<>(); List<String[]> data = new ArrayList<>();
try { try {
...@@ -170,7 +177,6 @@ public class DataSetTableService { ...@@ -170,7 +177,6 @@ public class DataSetTableService {
}).collect(Collectors.toList()); }).collect(Collectors.toList());
} }
Map<String, Object> map = new HashMap<>(); Map<String, Object> map = new HashMap<>();
map.put("fields", fields); map.put("fields", fields);
map.put("data", jsonArray); map.put("data", jsonArray);
...@@ -187,14 +193,15 @@ public class DataSetTableService { ...@@ -187,14 +193,15 @@ public class DataSetTableService {
datasourceRequest.setQuery(sql); datasourceRequest.setQuery(sql);
ResultSet dataResultSet = datasourceProvider.getDataResultSet(datasourceRequest); ResultSet dataResultSet = datasourceProvider.getDataResultSet(datasourceRequest);
List<String[]> data = datasourceProvider.fetchResult(dataResultSet); List<String[]> data = datasourceProvider.fetchResult(dataResultSet);
List<String> fields = datasourceProvider.fetchResultField(dataResultSet); List<TableFiled> fields = datasourceProvider.fetchResultField(dataResultSet);
String[] fieldArray = fields.stream().map(TableFiled::getFieldName).toArray(String[]::new);
List<Map<String, Object>> jsonArray = new ArrayList<>(); List<Map<String, Object>> jsonArray = new ArrayList<>();
if (CollectionUtils.isNotEmpty(data)) { if (CollectionUtils.isNotEmpty(data)) {
jsonArray = data.stream().map(ele -> { jsonArray = data.stream().map(ele -> {
Map<String, Object> map = new HashMap<>(); Map<String, Object> map = new HashMap<>();
for (int i = 0; i < ele.length; i++) { for (int i = 0; i < ele.length; i++) {
map.put(fields.get(i), ele[i]); map.put(fieldArray[i], ele[i]);
} }
return map; return map;
}).collect(Collectors.toList()); }).collect(Collectors.toList());
...@@ -258,8 +265,19 @@ public class DataSetTableService { ...@@ -258,8 +265,19 @@ public class DataSetTableService {
Datasource ds = datasourceMapper.selectByPrimaryKey(datasetTable.getDataSourceId()); Datasource ds = datasourceMapper.selectByPrimaryKey(datasetTable.getDataSourceId());
DataSetTableRequest dataSetTableRequest = new DataSetTableRequest(); DataSetTableRequest dataSetTableRequest = new DataSetTableRequest();
BeanUtils.copyBean(dataSetTableRequest, datasetTable); BeanUtils.copyBean(dataSetTableRequest, datasetTable);
List<TableFiled> fields = getFields(dataSetTableRequest);
List<TableFiled> fields = new ArrayList<>();
long syncTime = System.currentTimeMillis(); long syncTime = System.currentTimeMillis();
if (StringUtils.equalsIgnoreCase(datasetTable.getType(), "db")) {
fields = getFields(dataSetTableRequest);
} else if (StringUtils.equalsIgnoreCase(datasetTable.getType(), "sql")) {
DatasourceProvider datasourceProvider = ProviderFactory.getProvider(ds.getType());
DatasourceRequest datasourceRequest = new DatasourceRequest();
datasourceRequest.setDatasource(ds);
datasourceRequest.setQuery(new Gson().fromJson(dataSetTableRequest.getInfo(), DataTableInfoDTO.class).getSql());
ResultSet dataResultSet = datasourceProvider.getDataResultSet(datasourceRequest);
fields = datasourceProvider.fetchResultField(dataResultSet);
}
if (CollectionUtils.isNotEmpty(fields)) { if (CollectionUtils.isNotEmpty(fields)) {
for (int i = 0; i < fields.size(); i++) { for (int i = 0; i < fields.size(); i++) {
TableFiled filed = fields.get(i); TableFiled filed = fields.get(i);
......
...@@ -8,10 +8,12 @@ import io.dataease.base.mapper.ext.query.GridExample; ...@@ -8,10 +8,12 @@ import io.dataease.base.mapper.ext.query.GridExample;
import io.dataease.commons.utils.BeanUtils; import io.dataease.commons.utils.BeanUtils;
import io.dataease.commons.utils.CommonBeanFactory; import io.dataease.commons.utils.CommonBeanFactory;
import io.dataease.controller.sys.base.BaseGridRequest; import io.dataease.controller.sys.base.BaseGridRequest;
import io.dataease.controller.sys.base.ConditionEntity;
import io.dataease.controller.sys.request.DeptCreateRequest; import io.dataease.controller.sys.request.DeptCreateRequest;
import io.dataease.controller.sys.request.DeptDeleteRequest; import io.dataease.controller.sys.request.DeptDeleteRequest;
import io.dataease.controller.sys.request.DeptStatusRequest; import io.dataease.controller.sys.request.DeptStatusRequest;
import io.dataease.controller.sys.request.SimpleTreeNode; import io.dataease.controller.sys.request.SimpleTreeNode;
import io.dataease.controller.sys.response.DeptTreeNode;
import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.ObjectUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
...@@ -139,6 +141,33 @@ public class DeptService { ...@@ -139,6 +141,33 @@ public class DeptService {
return sysDepts; return sysDepts;
} }
public List<DeptTreeNode> searchTree(Long deptId){
List<SysDept> roots = nodesByPid(0L);
if (deptId == DEPT_ROOT_PID) return roots.stream().map(this::format).collect(Collectors.toList());
SysDept sysDept = sysDeptMapper.selectByPrimaryKey(deptId);
if (roots.stream().anyMatch(node -> node.getDeptId() == deptId)) return roots.stream().map(this::format).collect(Collectors.toList());
SysDept current = sysDept;
DeptTreeNode currentNode = format(sysDept);
while (current.getPid() != DEPT_ROOT_PID){
SysDept parent = sysDeptMapper.selectByPrimaryKey(current.getPid()); //pid上有索引 所以效率不会太差
DeptTreeNode parentNode = format(parent);
parentNode.setChildren(currentNode.toList());
current = parent;
currentNode = parentNode;
}
DeptTreeNode targetRootNode = currentNode;
return roots.stream().map(node -> node.getDeptId() == targetRootNode.getId() ? targetRootNode : format(node)).collect(Collectors.toList());
}
private DeptTreeNode format(SysDept sysDept){
DeptTreeNode deptTreeNode = new DeptTreeNode();
deptTreeNode.setId(sysDept.getDeptId());
deptTreeNode.setLabel(sysDept.getName());
deptTreeNode.setHasChildren(sysDept.getSubCount() > 0);
return deptTreeNode;
}
private DeptService proxy(){ private DeptService proxy(){
return CommonBeanFactory.getBean(DeptService.class); return CommonBeanFactory.getBean(DeptService.class);
} }
......
...@@ -41,4 +41,11 @@ export function editDept(data) { ...@@ -41,4 +41,11 @@ export function editDept(data) {
}) })
} }
export default { addDept, delDept, editDept, getDeptTree, loadTable } export function treeByDeptId(deptId) {
return request({
url: '/api/dept/nodesByDeptId/' + deptId,
method: 'post'
})
}
export default { addDept, delDept, editDept, getDeptTree, loadTable, treeByDeptId }
<template>
<div class="complex-table">
<div v-if="$slots.header || header" class="complex-table__header">
<slot name="header">{{ header }}</slot>
</div>
<div v-if="$slots.toolbar || searchConfig" class="complex-table__toolbar">
<slot name="toolbar">
<fu-search-bar v-bind="searchConfig" @exec="search">
<slot name="buttons" />
<fu-table-column-select :columns="columns" />
</fu-search-bar>
</slot>
</div>
<div class="complex-table__body">
<slot />
<!-- <fu-table ref="table" v-bind="$attrs" :columns="columns" :local-key="localKey" v-on="$listeners">
<slot />
</fu-table> -->
</div>
<div v-if="$slots.pagination || paginationConfig" class="complex-table__pagination">
<slot name="pagination">
<fu-table-pagination
:current-page.sync="paginationConfig.currentPage"
:page-size.sync="paginationConfig.pageSize"
v-bind="paginationConfig"
@change="search"
/>
</slot>
</div>
</div>
</template>
<script>
export default {
name: 'TreeTable',
props: {
columns: {
type: Array,
default: () => []
},
// eslint-disable-next-line vue/require-default-prop
localKey: String, // 如果需要记住选择的列,则这里添加一个唯一的Key
// eslint-disable-next-line vue/require-default-prop
header: String,
// eslint-disable-next-line vue/require-default-prop
searchConfig: Object,
// eslint-disable-next-line vue/require-default-prop
paginationConfig: Object
},
data() {
return {
condition: {}
}
},
methods: {
search(condition, e) {
if (condition) {
this.condition = condition
}
this.$emit('search', this.condition, e)
}
}
}
</script>
<style lang="scss">
@import "~@/styles/mixin.scss";
@import "~@/styles/variables.scss";
.complex-table {
.complex-table__header {
@include flex-row(flex-start, center);
height: 60px;
font-size: 20px;
}
.complex-table__toolbar {
@include flex-row(flex-end, center);
}
.complex-table__pagination {
margin-top: 20px;
@include flex-row(flex-end);
}
}
</style>
...@@ -667,7 +667,8 @@ export default { ...@@ -667,7 +667,8 @@ export default {
required: '必填', required: '必填',
input_content: '请输入内容', input_content: '请输入内容',
add_sql_table: '添加SQL', add_sql_table: '添加SQL',
preview: '预览' preview: '预览',
pls_input_name: '请输入名称'
}, },
datasource: { datasource: {
create: '新建数据连接', create: '新建数据连接',
......
...@@ -42,7 +42,7 @@ ...@@ -42,7 +42,7 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
</el-row> </el-row>
<el-row style="overflow: auto;height: 600px;"> <el-row style="overflow: auto;height: 60vh;">
<el-checkbox-group v-model="checkTableList" size="small"> <el-checkbox-group v-model="checkTableList" size="small">
<el-checkbox <el-checkbox
v-for="t in tableData" v-for="t in tableData"
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
<el-button size="mini" @click="cancel"> <el-button size="mini" @click="cancel">
{{ $t('dataset.cancel') }} {{ $t('dataset.cancel') }}
</el-button> </el-button>
<el-button size="mini" type="primary"> <el-button size="mini" type="primary" @click="save">
{{ $t('dataset.confirm') }} {{ $t('dataset.confirm') }}
</el-button> </el-button>
</el-row> </el-row>
...@@ -60,15 +60,15 @@ ...@@ -60,15 +60,15 @@
ref="plxTable" ref="plxTable"
size="mini" size="mini"
style="width: 100%;" style="width: 100%;"
:height="500" :height="height"
:checkbox-config="{highlight: true}" :checkbox-config="{highlight: true}"
> >
<ux-table-column <ux-table-column
v-for="field in fields" v-for="field in fields"
:key="field" :key="field.fieldName"
min-width="200px" min-width="200px"
:field="field" :field="field.fieldName"
:title="field" :title="field.remarks"
:resizable="true" :resizable="true"
/> />
</ux-grid> </ux-grid>
...@@ -100,6 +100,10 @@ import 'codemirror/addon/dialog/dialog.css' ...@@ -100,6 +100,10 @@ import 'codemirror/addon/dialog/dialog.css'
import 'codemirror/addon/search/searchcursor.js' import 'codemirror/addon/search/searchcursor.js'
import 'codemirror/addon/search/search.js' import 'codemirror/addon/search/search.js'
import 'codemirror/keymap/emacs.js' import 'codemirror/keymap/emacs.js'
// 引入代码自动提示插件
import 'codemirror/addon/hint/show-hint.css'
import 'codemirror/addon/hint/sql-hint'
import 'codemirror/addon/hint/show-hint'
export default { export default {
name: 'AddSQL', name: 'AddSQL',
...@@ -123,13 +127,14 @@ export default { ...@@ -123,13 +127,14 @@ export default {
line: true, line: true,
mode: 'text/x-sql', mode: 'text/x-sql',
theme: 'solarized', theme: 'solarized',
hintOptions: { hintOptions: { // 自定义提示选项
completeSingle: true completeSingle: false // 当匹配只有一项的时候是否自动补全
} }
}, },
data: [], data: [],
fields: [], fields: [],
mode: '0' mode: '0',
height: 500
} }
}, },
computed: { computed: {
...@@ -139,7 +144,16 @@ export default { ...@@ -139,7 +144,16 @@ export default {
}, },
watch: {}, watch: {},
mounted() { mounted() {
window.onresize = () => {
return (() => {
this.height = window.innerHeight / 2
})()
}
this.height = window.innerHeight / 2
this.initDataSource() this.initDataSource()
this.$refs.myCm.codemirror.on('keypress', () => {
this.$refs.myCm.codemirror.showHint()
})
}, },
methods: { methods: {
initDataSource() { initDataSource() {
...@@ -169,6 +183,37 @@ export default { ...@@ -169,6 +183,37 @@ export default {
}) })
}, },
save() {
if (!this.dataSource || this.datasource === '') {
this.$message({
showClose: true,
message: this.$t('dataset.pls_slc_data_source'),
type: 'error'
})
return
}
if (!this.name || this.name === '') {
this.$message({
showClose: true,
message: this.$t('dataset.pls_input_name'),
type: 'error'
})
return
}
const table = {
name: this.name,
sceneId: this.param.id,
dataSourceId: this.dataSource,
type: 'sql',
mode: parseInt(this.mode),
info: '{"sql":"' + this.sql + '"}'
}
post('/dataset/table/update', table).then(response => {
this.$store.dispatch('dataset/setSceneData', new Date().getTime())
this.cancel()
})
},
cancel() { cancel() {
// this.dataReset() // this.dataReset()
this.$emit('switchComponent', { name: '' }) this.$emit('switchComponent', { name: '' })
......
<template> <template>
<el-col> <el-col>
<span>{{ table.name }}</span> <span>{{ table.name }}</span>
<el-table <ux-grid
ref="plxTable"
size="mini" size="mini"
:data="data" style="width: 100%;"
height="40vh" :height="height"
border :checkbox-config="{highlight: true}"
style="width: 100%;margin-top: 6px;"
> >
<el-table-column <ux-table-column
v-for="field in fields" v-for="field in fields"
:key="field.originName" :key="field.originName"
min-width="200px" min-width="200px"
:prop="field.originName" :field="field.originName"
:label="field.name" :title="field.name"
:resizable="true"
/> />
</el-table> </ux-grid>
</el-col> </el-col>
</template> </template>
...@@ -25,13 +26,16 @@ import { post } from '@/api/dataset/dataset' ...@@ -25,13 +26,16 @@ import { post } from '@/api/dataset/dataset'
export default { export default {
name: 'DatasetTableData', name: 'DatasetTableData',
props: { props: {
// eslint-disable-next-line vue/require-default-prop table: {
table: Object type: Object,
required: true
}
}, },
data() { data() {
return { return {
fields: [], fields: [],
data: [] data: [],
height: 500
} }
}, },
watch: { watch: {
...@@ -39,10 +43,14 @@ export default { ...@@ -39,10 +43,14 @@ export default {
this.initData() this.initData()
} }
}, },
created() {
this.initData()
},
mounted() { mounted() {
window.onresize = () => {
return (() => {
this.height = window.innerHeight / 3
})()
}
this.height = window.innerHeight / 3
this.initData()
}, },
methods: { methods: {
initData() { initData() {
...@@ -51,6 +59,8 @@ export default { ...@@ -51,6 +59,8 @@ export default {
post('/dataset/table/getPreviewData', this.table).then(response => { post('/dataset/table/getPreviewData', this.table).then(response => {
this.fields = response.data.fields this.fields = response.data.fields
this.data = response.data.data this.data = response.data.data
const datas = this.data
this.$refs.plxTable.reloadData(datas)
}) })
} }
}, },
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
ref="plxTable" ref="plxTable"
size="mini" size="mini"
style="width: 100%;" style="width: 100%;"
:height="500" :height="height"
:checkbox-config="{highlight: true}" :checkbox-config="{highlight: true}"
> >
<ux-table-column <ux-table-column
...@@ -23,12 +23,22 @@ ...@@ -23,12 +23,22 @@
export default { export default {
name: 'TabDataPreview', name: 'TabDataPreview',
props: { props: {
table: Object, table: {
fields: Array, type: Object,
data: Array required: true
},
fields: {
type: Array,
required: true
},
data: {
type: Array,
required: true
}
}, },
data() { data() {
return { return {
height: 500
} }
}, },
computed: { computed: {
...@@ -39,9 +49,13 @@ export default { ...@@ -39,9 +49,13 @@ export default {
this.$refs.plxTable.reloadData(datas) this.$refs.plxTable.reloadData(datas)
} }
}, },
created() {
},
mounted() { mounted() {
window.onresize = () => {
return (() => {
this.height = window.innerHeight / 2
})()
}
this.height = window.innerHeight / 2
}, },
activated() { activated() {
}, },
......
<template> <template>
<layout-content v-loading="$store.getters.loadingMap[$store.getters.currentPath]"> <layout-content v-loading="$store.getters.loadingMap[$store.getters.currentPath]">
<complex-table <!-- <complex-table
ref="table" ref="table"
:data="tableData" :data="tableData"
:lazy="isLazy" :lazy="isLazy"
...@@ -15,15 +15,31 @@ ...@@ -15,15 +15,31 @@
:default-expand-all="isTableExpand" :default-expand-all="isTableExpand"
row-key="deptId" row-key="deptId"
@search="search" @search="search"
> -->
<tree-table
:columns="columns"
:buttons="buttons"
:header="header"
:search-config="searchConfig"
@search="search"
> >
<template #buttons> <template #buttons>
<fu-table-button icon="el-icon-circle-plus-outline" :label="$t('organization.create')" @click="create" /> <fu-table-button v-permission="['dept:add']" icon="el-icon-circle-plus-outline" :label="$t('organization.create')" @click="create" />
</template> </template>
<el-table
<!-- <el-table-column type="selection" fix /> --> ref="table"
<el-table-column label="名称" prop="name" /> :data="tableData"
<el-table-column label="下属组织数" prop="subCount" /> lazy
<!-- <el-table-column label="状态" align="center" prop="enabled"> :load="loadExpandDatas"
style="width: 100%"
:tree-props="{children: 'children', hasChildren: 'hasChildren'}"
row-key="deptId"
>
<!-- <el-table-column type="selection" fix /> -->
<el-table-column label="名称" prop="name" />
<el-table-column label="下属组织数" prop="subCount" />
<!-- <el-table-column label="状态" align="center" prop="enabled">
<template slot-scope="scope"> <template slot-scope="scope">
<el-switch <el-switch
v-model="scope.row.enabled" v-model="scope.row.enabled"
...@@ -34,14 +50,16 @@ ...@@ -34,14 +50,16 @@
/> />
</template> </template>
</el-table-column> --> </el-table-column> -->
<el-table-column prop="createTime" label="创建日期"> <el-table-column prop="createTime" label="创建日期">
<template v-slot:default="scope"> <template v-slot:default="scope">
<span>{{ scope.row.createTime | timestampFormatDate }}</span> <span>{{ scope.row.createTime | timestampFormatDate }}</span>
</template> </template>
</el-table-column> </el-table-column>
<fu-table-operations :buttons="buttons" label="操作" fix /> <fu-table-operations :buttons="buttons" label="操作" fix />
</complex-table> </el-table>
</tree-table>
<!-- </complex-table> -->
<!-- add organization form --> <!-- add organization form -->
<el-dialog <el-dialog
...@@ -106,19 +124,19 @@ ...@@ -106,19 +124,19 @@
<script> <script>
import LayoutContent from '@/components/business/LayoutContent' import LayoutContent from '@/components/business/LayoutContent'
import ComplexTable from '@/components/business/complex-table' import TreeTable from '@/components/business/tree-table'
import Treeselect from '@riophae/vue-treeselect' import Treeselect from '@riophae/vue-treeselect'
import { formatCondition } from '@/utils/index' import { formatCondition } from '@/utils/index'
import '@riophae/vue-treeselect/dist/vue-treeselect.css' import '@riophae/vue-treeselect/dist/vue-treeselect.css'
import { LOAD_CHILDREN_OPTIONS, LOAD_ROOT_OPTIONS } from '@riophae/vue-treeselect' import { LOAD_CHILDREN_OPTIONS, LOAD_ROOT_OPTIONS } from '@riophae/vue-treeselect'
import { checkPermission } from '@/utils/permission'
import { getDeptTree, addDept, editDept, delDept, loadTable } from '@/api/system/dept' import { getDeptTree, addDept, editDept, delDept, loadTable } from '@/api/system/dept'
export default { export default {
name: 'MsOrganization', name: 'MsOrganization',
components: { components: {
LayoutContent, LayoutContent,
ComplexTable, TreeTable,
Treeselect Treeselect
}, },
data() { data() {
...@@ -155,9 +173,11 @@ export default { ...@@ -155,9 +173,11 @@ export default {
columns: [], columns: [],
buttons: [ buttons: [
{ {
label: this.$t('commons.edit'), icon: 'el-icon-edit', click: this.edit label: this.$t('commons.edit'), icon: 'el-icon-edit', click: this.edit,
show: checkPermission(['dept:edit'])
}, { }, {
label: this.$t('commons.delete'), icon: 'el-icon-delete', type: 'danger', click: this._handleDelete label: this.$t('commons.delete'), icon: 'el-icon-delete', type: 'danger', click: this._handleDelete,
show: checkPermission(['dept:del'])
} }
], ],
searchConfig: { searchConfig: {
...@@ -168,11 +188,7 @@ export default { ...@@ -168,11 +188,7 @@ export default {
] ]
}, },
paginationConfig: {
currentPage: 1,
pageSize: 10,
total: 0
},
defaultCondition: { defaultCondition: {
field: 'pid', field: 'pid',
operator: 'eq', operator: 'eq',
...@@ -271,7 +287,7 @@ export default { ...@@ -271,7 +287,7 @@ export default {
}, },
// 加载表格数据 // 加载表格数据
search(condition) { search(condition) {
this.setTableAttr() // this.setTableAttr()
this.tableData = [] this.tableData = []
let param = {} let param = {}
if (condition && condition.quick) { if (condition && condition.quick) {
...@@ -293,7 +309,7 @@ export default { ...@@ -293,7 +309,7 @@ export default {
if (condition && condition.quick) { if (condition && condition.quick) {
data = this.buildTree(data) data = this.buildTree(data)
this.setTableAttr(true) // this.setTableAttr(true)
} }
this.tableData = data this.tableData = data
this.depts = null this.depts = null
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
@search="search" @search="search"
> >
<template #buttons> <template #buttons>
<fu-table-button icon="el-icon-circle-plus-outline" :label="$t('user.create')" @click="create" /> <fu-table-button v-permission="['user:add']" icon="el-icon-circle-plus-outline" :label="$t('user.create')" @click="create" />
</template> </template>
<el-table-column type="selection" fix /> <el-table-column type="selection" fix />
...@@ -157,7 +157,7 @@ import '@riophae/vue-treeselect/dist/vue-treeselect.css' ...@@ -157,7 +157,7 @@ import '@riophae/vue-treeselect/dist/vue-treeselect.css'
import { userLists, addUser, editUser, delUser, editPassword, editStatus } from '@/api/system/user' import { userLists, addUser, editUser, delUser, editPassword, editStatus } from '@/api/system/user'
import { allRoles } from '@/api/system/role' import { allRoles } from '@/api/system/role'
import { getDeptTree } from '@/api/system/dept' import { getDeptTree, treeByDeptId } from '@/api/system/dept'
export default { export default {
...@@ -168,9 +168,11 @@ export default { ...@@ -168,9 +168,11 @@ export default {
columns: [], columns: [],
buttons: [ buttons: [
{ {
label: this.$t('commons.edit'), icon: 'el-icon-edit', click: this.edit label: this.$t('commons.edit'), icon: 'el-icon-edit', click: this.edit,
show: checkPermission(['user:edit'])
}, { }, {
label: this.$t('commons.delete'), icon: 'el-icon-delete', type: 'danger', click: this.del label: this.$t('commons.delete'), icon: 'el-icon-delete', type: 'danger', click: this.del,
show: checkPermission(['user:del'])
}, { }, {
label: this.$t('member.edit_password'), icon: 'el-icon-s-tools', type: 'danger', click: this.editPassword, label: this.$t('member.edit_password'), icon: 'el-icon-s-tools', type: 'danger', click: this.editPassword,
show: checkPermission(['user:editPwd']) show: checkPermission(['user:editPwd'])
...@@ -306,14 +308,20 @@ export default { ...@@ -306,14 +308,20 @@ export default {
}, },
create() { create() {
this.depts = null
this.formType = 'add' this.formType = 'add'
this.form = Object.assign({}, this.defaultForm) this.form = Object.assign({}, this.defaultForm)
this.dialogVisible = true this.dialogVisible = true
}, },
edit(row) { edit(row) {
this.depts = null
this.formType = 'modify' this.formType = 'modify'
this.dialogVisible = true this.dialogVisible = true
this.form = Object.assign({}, row) this.form = Object.assign({}, row)
if (this.form.deptId === 0) {
this.form.deptId = null
}
this.initDeptTree()
}, },
editPassword(row) { editPassword(row) {
this.editPasswordVisible = true this.editPasswordVisible = true
...@@ -364,6 +372,7 @@ export default { ...@@ -364,6 +372,7 @@ export default {
}) })
}, },
handleClose() { handleClose() {
this.depts = null
this.formType = 'add' this.formType = 'add'
this.form = {} this.form = {}
this.editPasswordVisible = false this.editPasswordVisible = false
...@@ -376,12 +385,30 @@ export default { ...@@ -376,12 +385,30 @@ export default {
this.$success(this.$t('commons.modify_success')) this.$success(this.$t('commons.modify_success'))
}) })
}, },
initDeptTree() {
treeByDeptId(this.form.deptId || 0).then(res => {
const results = res.data.map(node => {
if (node.hasChildren && !node.children) {
node.children = null
}
return node
})
this.depts = results
})
},
// 获取弹窗内部门数据 // 获取弹窗内部门数据
loadDepts({ action, parentNode, callback }) { loadDepts({ action, parentNode, callback }) {
if (action === LOAD_ROOT_OPTIONS) { if (action === LOAD_ROOT_OPTIONS && !this.form.deptId) {
const _self = this const _self = this
!this.depts && getDeptTree('0').then(res => { treeByDeptId(0).then(res => {
_self.depts = res.data.map(node => _self.normalizer(node)) const results = res.data.map(node => {
if (node.hasChildren && !node.children) {
node.children = null
}
return node
})
_self.depts = results
callback() callback()
}) })
} }
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论