功能变化: 通用components 更新
parent
0a05a97308
commit
9e10d1841f
|
@ -1,5 +1,8 @@
|
||||||
<template>
|
<template>
|
||||||
<el-tag :type="color">{{ currentValue }}</el-tag>
|
<div>
|
||||||
|
<el-tag v-if="currentValue" :type="color">{{ currentValue }}</el-tag>
|
||||||
|
<span v-else></span>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
// 行展示组件进阶版
|
// 行展示组件进阶版
|
||||||
|
|
|
@ -0,0 +1,100 @@
|
||||||
|
<!--
|
||||||
|
* @创建文件时间: 2021-11-09 15:41:29
|
||||||
|
* @Auther: 猿小天
|
||||||
|
* @最后修改人: 猿小天
|
||||||
|
* @最后修改时间: 2021-12-08 14:41:20
|
||||||
|
* 联系Qq:1638245306
|
||||||
|
* @文件介绍:
|
||||||
|
-->
|
||||||
|
# 表格选择框配置说明
|
||||||
|
|
||||||
|
## crud.js
|
||||||
|
```
|
||||||
|
{
|
||||||
|
title: '单选本地',
|
||||||
|
key: 'select1',
|
||||||
|
sortable: true,
|
||||||
|
search: {
|
||||||
|
disabled: true
|
||||||
|
},
|
||||||
|
type: 'table-selector',
|
||||||
|
dict: {
|
||||||
|
url: '/api/system/user/',
|
||||||
|
value: 'id', // 数据字典中value字段的属性名
|
||||||
|
label: 'name', // 数据字典中label字段的属性名
|
||||||
|
getData: (url, dict, { form, component }) => {
|
||||||
|
return request({ url: url, params: { page: 1, limit: 1 } }).then(ret => {
|
||||||
|
component._elProps.page = ret.data.page
|
||||||
|
component._elProps.limit = ret.data.limit
|
||||||
|
component._elProps.total = ret.data.total
|
||||||
|
return ret.data.data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
form: {
|
||||||
|
component: {
|
||||||
|
span: 12,
|
||||||
|
props: { multiple: true },
|
||||||
|
elProps: {
|
||||||
|
pagination: true,
|
||||||
|
columns: [
|
||||||
|
{
|
||||||
|
field: "name",
|
||||||
|
title: "名称",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: "username",
|
||||||
|
title: "账号",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: "role",
|
||||||
|
title: "角色Id",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: "dept",
|
||||||
|
title: "部门Id",
|
||||||
|
},
|
||||||
|
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## 配置说明
|
||||||
|
```
|
||||||
|
详细文档:
|
||||||
|
1.http://d2-crud-plus.docmirror.cn/d2-crud-plus/guide/dict.html
|
||||||
|
2.https://xuliangzhan_admin.gitee.io/vxe-table/#/grid/api
|
||||||
|
```
|
||||||
|
|
||||||
|
| Name | Description | Type | Required | Default |
|
||||||
|
| ---------- | ---------------- | ------- | -------- | -------------- |
|
||||||
|
| type | 字段所使用的组件 | String | true | table-selector |
|
||||||
|
| dict | 字典的配置 | Object | true | {} |
|
||||||
|
| multiple | 是否多选 | Boolean | false | false |
|
||||||
|
| pagination | 是否分页 | Boolean | false | false |
|
||||||
|
| columns | 表格的列配置 | Array | true | [] |
|
||||||
|
| field | 字段 | String | true | '' |
|
||||||
|
| title | 字段名称 | String | true | '' |
|
||||||
|
___
|
||||||
|
|
||||||
|
## events
|
||||||
|
| Name | Description | Params |
|
||||||
|
|------|-------------|--------|
|
||||||
|
| radioChange| 表格行单选的点击事件| row,rowIndex|
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
form:{
|
||||||
|
component:{
|
||||||
|
on: { //单选事件监听
|
||||||
|
radioChange({ event, scope }) {
|
||||||
|
scope.form.channel_number = event.row.channel_number
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
export default {
|
||||||
|
// 字段类型配置,注册之后即可在crud.js中使用了
|
||||||
|
'table-list-selector': {
|
||||||
|
// 表单组件配置
|
||||||
|
form: { component: { name: 'table-list-selector-input', props: { color: 'danger' } } },
|
||||||
|
// 行组件配置
|
||||||
|
component: { name: 'values-format', props: {} },
|
||||||
|
// 行展示时居中
|
||||||
|
align: 'center'
|
||||||
|
// 您还可以写更多默认配置
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
* @创建文件时间: 2021-08-02 23:56:15
|
||||||
|
* @Auther: 猿小天
|
||||||
|
* @最后修改人: 猿小天
|
||||||
|
* @最后修改时间: 2021-08-09 22:15:56
|
||||||
|
* 联系Qq:1638245306
|
||||||
|
* @文件介绍:
|
||||||
|
*/
|
||||||
|
import { d2CrudPlus } from 'd2-crud-plus'
|
||||||
|
import group from './group'
|
||||||
|
|
||||||
|
function install (Vue, options) {
|
||||||
|
Vue.component('table-list-selector-input', () => import('./table-list-selector'))
|
||||||
|
// Vue.component('d2p-row-format', () => import('./row'))
|
||||||
|
if (d2CrudPlus != null) {
|
||||||
|
// 注册字段类型`demo-extend`
|
||||||
|
d2CrudPlus.util.columnResolve.addTypes(group)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 导出install, 通过`vue.use(D2pDemoExtend)`安装后 ,`demo-extend` 就可以在`crud.js`中使用了
|
||||||
|
export default {
|
||||||
|
install
|
||||||
|
}
|
|
@ -0,0 +1,653 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<el-button-group>
|
||||||
|
<el-button size="mini" type="success" round @click="openDialog">添加</el-button>
|
||||||
|
</el-button-group>
|
||||||
|
<el-dialog
|
||||||
|
custom-class="d2p-tree-selector-dialog"
|
||||||
|
:title="dialogTitle"
|
||||||
|
:visible.sync="dialogVisible"
|
||||||
|
width="50%"
|
||||||
|
append-to-body
|
||||||
|
>
|
||||||
|
<div>
|
||||||
|
<div v-if="treeFilter" class="filter-bar" style="padding-bottom: 20px">
|
||||||
|
<el-input
|
||||||
|
prefix-icon="el-icon-search"
|
||||||
|
:placeholder="filterPlaceholder"
|
||||||
|
v-model="filterText"
|
||||||
|
size="small"
|
||||||
|
>
|
||||||
|
</el-input>
|
||||||
|
</div>
|
||||||
|
<vxe-grid
|
||||||
|
v-bind="_elProps"
|
||||||
|
:data="_options"
|
||||||
|
ref="elTree"
|
||||||
|
:auto-resize="true"
|
||||||
|
@radio-change="radioChange"
|
||||||
|
@checkbox-change="checkboxChange"
|
||||||
|
>
|
||||||
|
<template #pager>
|
||||||
|
<vxe-pager
|
||||||
|
v-if="pagination"
|
||||||
|
style="margin-top: 10px"
|
||||||
|
:layouts="[
|
||||||
|
'Sizes',
|
||||||
|
'PrevJump',
|
||||||
|
'PrevPage',
|
||||||
|
'Number',
|
||||||
|
'NextPage',
|
||||||
|
'NextJump',
|
||||||
|
'FullJump',
|
||||||
|
'Total',
|
||||||
|
]"
|
||||||
|
:current-page.sync="_elProps.page"
|
||||||
|
:page-size.sync="_elProps.limit"
|
||||||
|
:total.sync="_elProps.total"
|
||||||
|
@page-change="handlePageChange"
|
||||||
|
>
|
||||||
|
</vxe-pager>
|
||||||
|
</template>
|
||||||
|
</vxe-grid>
|
||||||
|
</div>
|
||||||
|
<span slot="footer" class="dialog-footer">
|
||||||
|
<el-button @click="dialogVisible = false">{{ cancelText }}</el-button>
|
||||||
|
<el-button type="primary" @click="selectSubmit">{{
|
||||||
|
confirmText
|
||||||
|
}}</el-button>
|
||||||
|
</span>
|
||||||
|
</el-dialog>
|
||||||
|
<el-table
|
||||||
|
:data="tableData"
|
||||||
|
style="width: 100%"
|
||||||
|
height="280"
|
||||||
|
align="center"
|
||||||
|
size="small">
|
||||||
|
<el-table-column
|
||||||
|
type="index"
|
||||||
|
width="40"
|
||||||
|
label="#">
|
||||||
|
</el-table-column>
|
||||||
|
<template v-for="(item,index) in gridOptions.columns">
|
||||||
|
<el-table-column
|
||||||
|
v-if="item.types && item.types=='img'"
|
||||||
|
:key="index"
|
||||||
|
:label="item.title"
|
||||||
|
width="120">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<img :src="scope.row.images" style='width: 30px' />
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column
|
||||||
|
v-else-if="item.types && item.types=='dict'"
|
||||||
|
:key="index"
|
||||||
|
:label="item.title"
|
||||||
|
width="120">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span v-for="(data,index) in item.dictData" :key="index">
|
||||||
|
<span v-if="data.value===scope.row[item.field]">{{data.label}}</span>
|
||||||
|
<span v-else></span>
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column
|
||||||
|
v-else
|
||||||
|
:key="index"
|
||||||
|
:prop="item.field"
|
||||||
|
:label="item.title"
|
||||||
|
width="120">
|
||||||
|
</el-table-column>
|
||||||
|
</template>
|
||||||
|
<el-table-column
|
||||||
|
label="操作"
|
||||||
|
fixed="right"
|
||||||
|
v-show="colButtons.show"
|
||||||
|
:width="colButtons.width">
|
||||||
|
<template slot-scope="scopes">
|
||||||
|
<el-button style="padding: 0" :disabled="item.disabled?item.disabled({...scopes,tableData}):false" type="text"
|
||||||
|
size="small" :circle="item.circle?item.circle:false" v-for="(item,index) in colButtons.btns"
|
||||||
|
:icon="item.icon?item.icon:''" :key="index" @click="item.click({...scopes,tableData})">
|
||||||
|
{{ item.text }}
|
||||||
|
</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import lodash from 'lodash'
|
||||||
|
import { d2CrudPlus } from 'd2-crud-plus'
|
||||||
|
import { request } from '@/api/service'
|
||||||
|
import XEUtils from 'xe-utils'
|
||||||
|
// 表格选择组件
|
||||||
|
export default {
|
||||||
|
name: 'table-list-selector-input',
|
||||||
|
mixins: [d2CrudPlus.input, d2CrudPlus.inputDict],
|
||||||
|
props: {
|
||||||
|
// 值
|
||||||
|
value: {
|
||||||
|
type: [Number, String, Boolean, Array, Object]
|
||||||
|
},
|
||||||
|
// 过滤,value中的nodes过滤方法 参数为nodes
|
||||||
|
filter: {
|
||||||
|
type: Function,
|
||||||
|
require: false
|
||||||
|
},
|
||||||
|
// 过滤的placeholder
|
||||||
|
filterPlaceholder: {
|
||||||
|
type: String,
|
||||||
|
default: '输入关键字进行过滤'
|
||||||
|
},
|
||||||
|
placeholder: {
|
||||||
|
type: String,
|
||||||
|
default: '请选择'
|
||||||
|
},
|
||||||
|
dialogTitle: {
|
||||||
|
type: String,
|
||||||
|
default: '选择'
|
||||||
|
},
|
||||||
|
cancelText: {
|
||||||
|
type: String,
|
||||||
|
default: '取消'
|
||||||
|
},
|
||||||
|
confirmText: {
|
||||||
|
type: String,
|
||||||
|
default: '确定'
|
||||||
|
},
|
||||||
|
// 树形组件节点过滤,可以配置elProps.filterNodeMethod ,覆盖默认的过滤方法
|
||||||
|
treeFilter: {
|
||||||
|
type: Boolean,
|
||||||
|
require: false,
|
||||||
|
default: true
|
||||||
|
},
|
||||||
|
// 是否多选,传入false为单选
|
||||||
|
multiple: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
// 是否忽略选中节点的子节点
|
||||||
|
ignoreFullCheckedChildren: {
|
||||||
|
type: Boolean,
|
||||||
|
default: true
|
||||||
|
},
|
||||||
|
// 是否只返回叶子节点
|
||||||
|
leafOnly: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
// 是否包含半选节点
|
||||||
|
includeHalfChecked: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
},
|
||||||
|
// 弹框表的配置
|
||||||
|
elProps: {
|
||||||
|
type: Object
|
||||||
|
},
|
||||||
|
// 显示表的操作按钮配置
|
||||||
|
colButtons: {
|
||||||
|
type: Object,
|
||||||
|
default () {
|
||||||
|
return {
|
||||||
|
width: 150,
|
||||||
|
show: true,
|
||||||
|
btn: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* 是否可以清除
|
||||||
|
*/
|
||||||
|
clearable: {
|
||||||
|
type: Boolean,
|
||||||
|
default: true
|
||||||
|
},
|
||||||
|
// 数据字典配置
|
||||||
|
dict: {
|
||||||
|
type: Object,
|
||||||
|
require: false
|
||||||
|
},
|
||||||
|
// 是否开启分页
|
||||||
|
pagination: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
currentValue: undefined,
|
||||||
|
collapseTags: false,
|
||||||
|
selected: [],
|
||||||
|
dialogVisible: false,
|
||||||
|
filterText: undefined,
|
||||||
|
requestUrl: null,
|
||||||
|
gridOptions: undefined,
|
||||||
|
tableData: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
created () {
|
||||||
|
// if (this.dict) {
|
||||||
|
// this.dict = d2CrudPlus.util.dict.mergeDefault(this.dict, true)
|
||||||
|
// }
|
||||||
|
// this.initData()
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
_elProps () {
|
||||||
|
const defaultElProps = {
|
||||||
|
// showCheckbox: this.multiple,
|
||||||
|
highlightCurrent: !this.multiple,
|
||||||
|
props: {},
|
||||||
|
columns: [],
|
||||||
|
border: true,
|
||||||
|
resizable: true
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.dict != null) {
|
||||||
|
if (this.dict.label != null) {
|
||||||
|
defaultElProps.props.label = this.dict.label
|
||||||
|
}
|
||||||
|
if (this.dict.value != null) {
|
||||||
|
defaultElProps.props.value = this.dict.value
|
||||||
|
}
|
||||||
|
if (this.dict.children != null) {
|
||||||
|
defaultElProps.props.children = this.dict.children
|
||||||
|
}
|
||||||
|
// 加上树形的配置
|
||||||
|
if (this.dict.isTree) {
|
||||||
|
defaultElProps.treeConfig = this.elProps.treeConfig
|
||||||
|
}
|
||||||
|
}
|
||||||
|
defaultElProps.nodeKey = defaultElProps.props.value
|
||||||
|
lodash.merge(defaultElProps, this.elProps)
|
||||||
|
|
||||||
|
// 对显示列表增加操作列
|
||||||
|
const gridProps = JSON.parse(JSON.stringify(defaultElProps))
|
||||||
|
// gridProps.columns = [...gridProps.columns,{ title: '操作', width: this.colButtons.width, slots: { default: 'operate' } }]
|
||||||
|
// eslint-disable-next-line vue/no-side-effects-in-computed-properties
|
||||||
|
this.gridOptions = gridProps
|
||||||
|
|
||||||
|
if (this.multiple) {
|
||||||
|
defaultElProps.checkboxConfig = this.elProps.checkboxConfig
|
||||||
|
? this.elProps.checkboxConfig
|
||||||
|
: {}
|
||||||
|
defaultElProps.columns = [
|
||||||
|
{
|
||||||
|
type: 'checkbox',
|
||||||
|
width: 60
|
||||||
|
},
|
||||||
|
...defaultElProps.columns
|
||||||
|
]
|
||||||
|
} else {
|
||||||
|
defaultElProps.radioConfig = this.elProps
|
||||||
|
? this.elProps.radioConfig
|
||||||
|
: {}
|
||||||
|
defaultElProps.columns = [
|
||||||
|
{
|
||||||
|
type: 'radio',
|
||||||
|
width: 60
|
||||||
|
},
|
||||||
|
...defaultElProps.columns
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
return defaultElProps
|
||||||
|
},
|
||||||
|
collapseTagSize () {
|
||||||
|
return ['small', 'mini'].indexOf(this.selectSize) > -1 ? 'mini' : 'small'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
filterText (val) {
|
||||||
|
// this.$refs.elTree.filter(val);
|
||||||
|
this.searchTableData()
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
// initData () {
|
||||||
|
// d2CrudPlus.util.dict.get(this.dict).then(ret => {
|
||||||
|
// this.$set(this, 'data', ret)
|
||||||
|
// this.setValue(this.value)
|
||||||
|
// })
|
||||||
|
// },
|
||||||
|
onDictLoaded () {
|
||||||
|
// log.danger("onDictLoaded", this.dict, this.value);
|
||||||
|
// this.setValue(this.value)
|
||||||
|
this.tableData = this.value
|
||||||
|
},
|
||||||
|
setValue (value) {
|
||||||
|
// log.danger("setValue:", this.currentValue, this.value, this._options);
|
||||||
|
if (this.currentValue === this.value) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
let arrValue = value
|
||||||
|
if (value == null) {
|
||||||
|
this.selected = []
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(arrValue instanceof Array)) {
|
||||||
|
arrValue = [arrValue]
|
||||||
|
}
|
||||||
|
if (this.dict && this.dict.getNodes) {
|
||||||
|
// log.danger("getNodes:", arrValue);
|
||||||
|
this.dict.getNodes(arrValue).then((nodes) => {
|
||||||
|
this.selectedNodes(nodes, value)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
const nodes = []
|
||||||
|
if (this._options == null || this._options.length === 0) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
for (const item of arrValue) {
|
||||||
|
const data = this._options
|
||||||
|
const node = d2CrudPlus.util.dict.getByValue(item, data, this.dict)
|
||||||
|
if (node != null) {
|
||||||
|
nodes.push(node)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.selectedNodes(nodes, value)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
selectedNodes (nodes, value) {
|
||||||
|
const selected = []
|
||||||
|
for (const node of nodes) {
|
||||||
|
node.id = node[this.dict.value]
|
||||||
|
selected.push(node)
|
||||||
|
}
|
||||||
|
// log.danger("selected:", selected);
|
||||||
|
this.$set(this, 'selected', selected)
|
||||||
|
this.resetInputHeight()
|
||||||
|
},
|
||||||
|
handleCheckChange (event) {
|
||||||
|
this.$emit('check-change', event)
|
||||||
|
},
|
||||||
|
handleCurrentChange (event) {
|
||||||
|
this.$emit('current-change', event)
|
||||||
|
},
|
||||||
|
// 打开选择框
|
||||||
|
openDialog () {
|
||||||
|
const that = this
|
||||||
|
if (this.disabled) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
this.dialogVisible = true
|
||||||
|
setTimeout(() => {
|
||||||
|
if (that._options.length > 0) {
|
||||||
|
that._options.map(
|
||||||
|
(item) => item[that._elProps.props.value]
|
||||||
|
)
|
||||||
|
// ids.forEach((id) => {
|
||||||
|
// console.log(111, id)
|
||||||
|
// const current = that.$refs.elTree.store.nodesMap[id]
|
||||||
|
// console.log(22, current)
|
||||||
|
// if (current != null) {
|
||||||
|
// this.doExpandParent(current)
|
||||||
|
// }
|
||||||
|
// })
|
||||||
|
|
||||||
|
// this.$nextTick(() => {
|
||||||
|
// if (that.multiple) {
|
||||||
|
// // this.$refs.elTree.setCheckedKeys(ids, this.leafOnly);
|
||||||
|
// that.$refs.elTree.setCheckboxRow(that.tableData, true)
|
||||||
|
// } else if (ids.length > 0) {
|
||||||
|
// // this.$refs.elTree.setCurrentKey(ids[0]);
|
||||||
|
// that.$refs.elTree.setRadioRow(that.tableData[0], true)
|
||||||
|
// }
|
||||||
|
// })
|
||||||
|
}
|
||||||
|
}, 1)
|
||||||
|
},
|
||||||
|
doExpandParent (node) {
|
||||||
|
if (node.parent != null) {
|
||||||
|
this.doExpandParent(node.parent)
|
||||||
|
}
|
||||||
|
node.expanded = true
|
||||||
|
},
|
||||||
|
// 处理value,是否为原生value还是自定义value
|
||||||
|
getValueKey (item) {
|
||||||
|
if (this._elProps.props.value != null) {
|
||||||
|
return item[this._elProps.props.value]
|
||||||
|
} else {
|
||||||
|
return item.value
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 处理label,是否为原生label还是自定义label
|
||||||
|
getValueLabel (item) {
|
||||||
|
if (this._elProps.props.label != null) {
|
||||||
|
return item[this._elProps.props.label]
|
||||||
|
} else {
|
||||||
|
return item.label
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 处理children,是否为原生children还是自定义children
|
||||||
|
getValueChildren (item) {
|
||||||
|
let children = 'children'
|
||||||
|
if (this._elProps.props.children != null) {
|
||||||
|
children = this._elProps.props.children
|
||||||
|
}
|
||||||
|
return item[children]
|
||||||
|
},
|
||||||
|
// 确定按钮事件
|
||||||
|
selectSubmit () {
|
||||||
|
const that = this
|
||||||
|
const nodes = this.refreshSelected()
|
||||||
|
if (that.tableData === undefined) {
|
||||||
|
that.tableData = nodes
|
||||||
|
} else {
|
||||||
|
that.tableData = this.tableData.concat(nodes) // 为显示表格赋值
|
||||||
|
}
|
||||||
|
this.tableData = XEUtils.uniq(this.tableData) // 将数组去重
|
||||||
|
that.dialogVisible = false
|
||||||
|
that.doValueInputChanged(this.tableData)
|
||||||
|
},
|
||||||
|
// 将值传出去
|
||||||
|
doValueInputChanged (nodes) {
|
||||||
|
// let values = this.formatValue(nodes)
|
||||||
|
let values = nodes
|
||||||
|
this.resetInputHeight()
|
||||||
|
if (!this.multiple) {
|
||||||
|
values = values && values.length > 0 ? values[0] : undefined
|
||||||
|
}
|
||||||
|
this.currentValue = values
|
||||||
|
if (this.dispatch) {
|
||||||
|
this.dispatch('ElFormItem', 'el.form.blur')
|
||||||
|
}
|
||||||
|
this.$emit('input', values)
|
||||||
|
},
|
||||||
|
itemClosed (item) {
|
||||||
|
const newNodes = lodash.without(this.selected, item)
|
||||||
|
// console.log("new value", item, newNodes);
|
||||||
|
this.$set(this, 'selected', newNodes)
|
||||||
|
this.doValueInputChanged(newNodes)
|
||||||
|
},
|
||||||
|
// 获取选中的行数据
|
||||||
|
refreshSelected () {
|
||||||
|
let nodes = null
|
||||||
|
if (this.multiple) {
|
||||||
|
nodes = this.$refs.elTree.getCheckboxRecords()
|
||||||
|
} else {
|
||||||
|
const node = this.$refs.elTree.getRadioRecord()
|
||||||
|
if (node == null) {
|
||||||
|
nodes = []
|
||||||
|
} else {
|
||||||
|
nodes = [node]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.ignoreFullCheckedChildren) {
|
||||||
|
nodes = this.filterFullCheckedChildren(nodes)
|
||||||
|
}
|
||||||
|
if (this.filter != null) {
|
||||||
|
nodes = this.filter(nodes)
|
||||||
|
}
|
||||||
|
// log.danger("selected", this.selected);
|
||||||
|
this.$set(this, 'selected', nodes)
|
||||||
|
return nodes
|
||||||
|
},
|
||||||
|
resetInputHeight () {
|
||||||
|
if (this.collapseTags && !this.filterable) return
|
||||||
|
this.$nextTick(() => {
|
||||||
|
if (!this.$refs.reference) return
|
||||||
|
const inputChildNodes = this.$refs.reference.$el.childNodes
|
||||||
|
const input = [].filter.call(
|
||||||
|
inputChildNodes,
|
||||||
|
(item) => item.tagName === 'INPUT'
|
||||||
|
)[0]
|
||||||
|
const tags = this.$refs.tags
|
||||||
|
const sizeInMap = this.initialInputHeight || 40
|
||||||
|
const height =
|
||||||
|
this.selected.length === 0
|
||||||
|
? sizeInMap + 'px'
|
||||||
|
: Math.max(
|
||||||
|
tags
|
||||||
|
? tags.clientHeight + (tags.clientHeight > sizeInMap ? 6 : 0)
|
||||||
|
: 0,
|
||||||
|
sizeInMap
|
||||||
|
) + 'px'
|
||||||
|
input.style.height = height
|
||||||
|
if (this.visible && this.emptyText !== false) {
|
||||||
|
this.broadcast('ElSelectDropdown', 'updatePopper')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
// 过滤叶子节点
|
||||||
|
filterFullCheckedChildren (nodes) {
|
||||||
|
const ignored = new Set()
|
||||||
|
for (const item of nodes) {
|
||||||
|
const children = this.getValueChildren(item)
|
||||||
|
if (children != null) {
|
||||||
|
for (const child of children) {
|
||||||
|
ignored.add(this.getValueKey(child))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const values = []
|
||||||
|
for (const item of nodes) {
|
||||||
|
const key = this.getValueKey(item)
|
||||||
|
if (!ignored.has(key)) {
|
||||||
|
values.push(item)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return values
|
||||||
|
},
|
||||||
|
formatValue (nodes) {
|
||||||
|
const values = []
|
||||||
|
for (const item of nodes) {
|
||||||
|
values.push(this.getValueKey(item))
|
||||||
|
}
|
||||||
|
return values
|
||||||
|
},
|
||||||
|
filterNode (value, data) {
|
||||||
|
if (!value) return true
|
||||||
|
return this.getValueLabel(data).indexOf(value) !== -1
|
||||||
|
},
|
||||||
|
onChange (value) {
|
||||||
|
this.$emit('change', value)
|
||||||
|
|
||||||
|
if (this.dispatch) {
|
||||||
|
this.dispatch('ElFormItem', 'el.form.blur')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 分页事件
|
||||||
|
handlePageChange ({
|
||||||
|
currentPage,
|
||||||
|
pageSize
|
||||||
|
}) {
|
||||||
|
const that = this
|
||||||
|
that._elProps.page = currentPage
|
||||||
|
that._elProps.limit = pageSize
|
||||||
|
that.searchTableData()
|
||||||
|
},
|
||||||
|
// 获取数据事件
|
||||||
|
searchTableData () {
|
||||||
|
const that = this
|
||||||
|
let params
|
||||||
|
|
||||||
|
if (that.pagination) {
|
||||||
|
params = {
|
||||||
|
page: that._elProps.page,
|
||||||
|
limit: that._elProps.limit,
|
||||||
|
search: that.filterText
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
params = {
|
||||||
|
search: that.filterText
|
||||||
|
}
|
||||||
|
}
|
||||||
|
let url
|
||||||
|
if (typeof that.dict.url === 'function') {
|
||||||
|
const form = that.d2CrudContext.getForm()
|
||||||
|
url = that.dict.url(that.dict, { form })
|
||||||
|
} else {
|
||||||
|
url = that.dict.url
|
||||||
|
}
|
||||||
|
request({
|
||||||
|
url: url,
|
||||||
|
params: params
|
||||||
|
}).then((ret) => {
|
||||||
|
const { data } = ret
|
||||||
|
that._elProps.page = data.page
|
||||||
|
that._elProps.limit = data.limit
|
||||||
|
that._elProps.total = data.total
|
||||||
|
that.$set(that, 'dictOptions', data.data)
|
||||||
|
})
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* 表格单选事件
|
||||||
|
*/
|
||||||
|
radioChange ({ checked, row, rowIndex, $rowIndex, column, columnIndex, $columnIndex, $event }) {
|
||||||
|
this.$emit('radioChange', {
|
||||||
|
row,
|
||||||
|
rowIndex
|
||||||
|
})
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* 表格多选事件
|
||||||
|
*/
|
||||||
|
checkboxChange ({ checked, row, rowIndex, $rowIndex, column, columnIndex, $columnIndex, $event }) {
|
||||||
|
this.$emit('checkboxChange', {
|
||||||
|
checked, row, rowIndex, $rowIndex, column, columnIndex, $columnIndex, $event
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
|
||||||
|
.d2p-tree-selector {
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
.el-cascader {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.is-disabled .el-tag__close.el-icon-close {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.d2p-tree-selector-dialog {
|
||||||
|
&.el-dialog {
|
||||||
|
max-height: 80vh;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
|
||||||
|
.el-dialog__body {
|
||||||
|
flex: 1;
|
||||||
|
overflow-y: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.el-dialog__header {
|
||||||
|
padding: 20px 20px 20px;
|
||||||
|
border-bottom: 1px solid #eee;
|
||||||
|
}
|
||||||
|
|
||||||
|
.el-dialog__footer {
|
||||||
|
padding: 10px 20px 10px;
|
||||||
|
border-top: 1px solid #eee;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
|
@ -70,3 +70,23 @@
|
||||||
| columns | 表格的列配置 | Array | true | [] |
|
| columns | 表格的列配置 | Array | true | [] |
|
||||||
| field | 字段 | String | true | '' |
|
| field | 字段 | String | true | '' |
|
||||||
| title | 字段名称 | String | true | '' |
|
| title | 字段名称 | String | true | '' |
|
||||||
|
___
|
||||||
|
|
||||||
|
## events
|
||||||
|
| Name | Description | Params |
|
||||||
|
|------|-------------|--------|
|
||||||
|
| radioChange| 表格行单选的点击事件| row,rowIndex|
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
form:{
|
||||||
|
component:{
|
||||||
|
on: { //单选事件监听
|
||||||
|
radioChange({ event, scope }) {
|
||||||
|
scope.form.channel_number = event.row.channel_number
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
|
|
@ -201,6 +201,7 @@ export default {
|
||||||
// this.dict = d2CrudPlus.util.dict.mergeDefault(this.dict, true)
|
// this.dict = d2CrudPlus.util.dict.mergeDefault(this.dict, true)
|
||||||
// }
|
// }
|
||||||
// this.initData()
|
// this.initData()
|
||||||
|
// console.log(this)
|
||||||
this.searchTableData()
|
this.searchTableData()
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
@ -337,7 +338,6 @@ export default {
|
||||||
that.$nextTick(() => {
|
that.$nextTick(() => {
|
||||||
const refs = Object.assign({}, that.$refs)
|
const refs = Object.assign({}, that.$refs)
|
||||||
const { elTree } = refs
|
const { elTree } = refs
|
||||||
console.log(elTree)
|
|
||||||
if (that.multiple) {
|
if (that.multiple) {
|
||||||
elTree.setCheckboxRow(that.selected, true)
|
elTree.setCheckboxRow(that.selected, true)
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue