功能变化: 更新组件

pull/103/head
李强 2023-06-18 20:41:45 +08:00
parent 7659cc67dd
commit 227e1393a4
9 changed files with 157 additions and 121 deletions

View File

@ -29,8 +29,8 @@ function webSocketOnError (e) {
*/
function webSocketOnMessage (e) {
const data = JSON.parse(e.data)
const { refresh_unread, systemConfig } = data
if (refresh_unread) {
const { refreshUnread, systemConfig } = data
if (refreshUnread) {
// 更新消息通知条数
store.dispatch('d2admin/messagecenter/setUnread')
}

View File

@ -4,7 +4,7 @@ import d2Container from './d2-container'
import tableProgress from './table-progress/lib/table-progress.vue'
import cardSelect from '@/components/card-select/index'
import selectorTable from '@/components/selector-table/index'
import m2mValuesPopover from '@/components/m2m-values-popover/index'
import valuesPopover from '@/components/values-popover/index'
// 注意 有些组件使用异步加载会有影响
Vue.component('d2-container', d2Container)
Vue.component('d2-icon', () => import('./d2-icon'))
@ -18,4 +18,4 @@ Vue.component('dvaHtml2pdf', () => import('./dvaHtml2pdf/index.vue'))
Vue.component('table-progress', tableProgress)
Vue.use(selectorTable)
Vue.use(cardSelect)
Vue.use(m2mValuesPopover)
Vue.use(valuesPopover)

View File

@ -1,105 +0,0 @@
<!-- 多对多value值展示组件 -->
<template>
<div>
<el-popover
placement="right"
width="400"
trigger="hover"
v-if="value.length > 0"
@show="showEvents">
<el-descriptions class="margin-top" :column="1" size="mini" border>
<!-- <template slot="extra">-->
<!-- <el-button type="primary" size="mini" disabled>上一页</el-button>-->
<!-- <el-button type="primary" size="mini" disabled>下一页</el-button>-->
<!-- </template>-->
<el-descriptions-item v-for="(item,index) in data" :key="index">
<template slot="label">
<i class="el-icon-user"></i>
{{ elProps.label }}
</template>
{{ item[dict.label] }}
</el-descriptions-item>
</el-descriptions>
<el-button type="primary" plain size="mini" slot="reference"><span> {{ value.length }} {{elProps.unit}}</span>
</el-button>
</el-popover>
<el-button v-else type="primary" plain size="mini" slot="reference"><span> {{ value.length }} {{elProps.unit}}</span>
</el-button>
</div>
</template>
<script>
import { d2CrudPlus } from 'd2-crud-plus'
import { request } from '@/api/service'
export default {
name: 'm2m-values-popover',
model: {
prop: 'value',
event: ['change', 'input']
},
mixins: [d2CrudPlus.input, d2CrudPlus.inputDict],
props: {
//
value: {
type: [String, Number, Array],
required: false,
default: ''
},
//
dict: {
type: Object,
require: true
},
//
elProps: {
type: Object,
require: false,
default () {
return {
type: 'text', // test/tree
rowKey: 'users',
label: '标题',
unit: '个'
}
}
}
},
data () {
return {
data: []
}
},
value: {
handler (value, oldVal) {
this.showEvents()
},
deep: true
},
computed: {
_elProps () {
return this.elProps
}
},
mounted () {
},
methods: {
showEvents () {
if (!this.data[0]) {
this.getData()
}
},
getData () {
const params = {}
params[this.dict.value] = this.value
params.query = `{${this.dict.value},${this.dict.label}}`
request({ url: this.dict.url, params: params }).then(ret => {
this.data = ret.data.data || ret.data
})
}
}
}
</script>
<style scoped>
</style>

View File

@ -6,10 +6,23 @@
trigger="click"
@show="visibleChange">
<div class="option">
<el-input style="margin-bottom: 10px" v-model="search" clearable placeholder="请输入关键词" @change="getDict"
<el-row>
<el-col :span="21">
<el-input
style="margin-bottom: 10px"
v-model="search"
clearable
size="small"
placeholder="请输入关键词"
@change="getDict"
@clear="getDict">
<el-button style="width: 100px" slot="append" icon="el-icon-search"></el-button>
</el-input>
</el-col>
<el-col :span="3" style="padding-left: 10px;padding-right: 10px;">
<el-button type="primary" round size="mini" style="padding: 10px;" @click="onClear"></el-button>
</el-col>
</el-row>
<el-table
ref="tableRef"
:data="tableData"
@ -57,7 +70,7 @@
</el-tag>
</div>
</div>
<el-input v-else placeholder="请选择" slot:reference :disabled="disabled"></el-input>
<el-input v-else placeholder="请选择" slot:reference clearable :disabled="disabled"></el-input>
</div>
</el-popover>
</div>

View File

@ -2,7 +2,7 @@ import { d2CrudPlus } from 'd2-crud-plus'
import group from './group'
function install (Vue, options) {
Vue.component('m2m-values-popover', () => import('./m2m-values-popover'))
Vue.component('values-popover', () => import('./values-popover'))
if (d2CrudPlus != null) {
// 注册字段类型`demo-extend`
d2CrudPlus.util.columnResolve.addTypes(group)

View File

@ -0,0 +1,131 @@
<!-- value值展示组件 -->
<template>
<div>
<div v-if="elProps.type === 'list'">
<el-popover
placement="right"
width="300"
trigger="hover"
v-if="value.length > 0"
@show="showEvents"
@hide="show=false">
<el-descriptions class="margin-top" :column="1" size="mini" border>
<el-descriptions-item v-for="(item,index) in data" :key="index">
<template slot="label">
<i class="el-icon-user"></i>
{{ elProps.label }}
</template>
{{ item[dict.label] }}
</el-descriptions-item>
</el-descriptions>
<el-button type="primary" plain size="mini" slot="reference"><span> {{ value.length }} {{ elProps.unit }}</span>
</el-button>
</el-popover>
<el-button v-else type="primary" plain size="mini" slot="reference"><span> {{
value.length
}} {{ elProps.unit }}</span>
</el-button>
</div>
<div v-else-if="elProps.type === 'ueditor'">
<el-popover
placement="right"
width="400"
trigger="hover"
v-if="value.length > 0"
popper-class="userprjtreepop"
@show="showEvents"
@hide="show=false">
<div v-html="value" v-if="show"></div>
<el-button type="primary" plain size="mini" slot="reference"><span>预览</span>
</el-button>
</el-popover>
<el-button v-else type="primary" plain size="mini" slot="reference"><span>预览</span>
</el-button>
</div>
</div>
</template>
<script>
import { d2CrudPlus } from 'd2-crud-plus'
import { request } from '@/api/service'
export default {
name: 'valuesPopover',
model: {
prop: 'value',
event: ['change', 'input']
},
mixins: [d2CrudPlus.input, d2CrudPlus.inputDict],
props: {
//
value: {
type: [String, Number, Array],
required: false,
default: ''
},
//
dict: {
type: Object,
require: true
},
//
elProps: {
type: Object,
require: false,
default () {
return {
type: 'text', // test/tree/list/ueditor
rowKey: 'users',
label: '标题',
unit: '个'
}
}
}
},
data () {
return {
data: [],
show: false
}
},
value: {
handler (value, oldVal) {
this.showEvents()
},
deep: true
},
computed: {
_elProps () {
return this.elProps
}
},
mounted () {
},
methods: {
showEvents () {
this.show = true
if (this.elProps.type === 'list') {
if (!this.data[0]) {
this.getListData()
}
}
},
getListData () {
const params = {}
params[this.dict.value] = this.value
params.query = `{${this.dict.value},${this.dict.label}}`
request({ url: this.dict.url, params: params }).then(ret => {
this.data = ret.data.data || ret.data
})
}
}
}
</script>
<style >
.userprjtreepop{
width: 80%;
overflow-x: auto;
max-height: 80%;
overflow-y: auto;
}
</style>

View File

@ -1,6 +1,4 @@
import { request } from '@/api/service'
import { urlPrefix } from '@/views/system/messageCenter/api'
export default {
namespaced: true,
state: {

View File

@ -331,7 +331,7 @@ export default {
const form = JSON.parse(JSON.stringify(this.form))
const keys = Object.keys(form)
const values = Object.values(form)
let submitForm = Object.assign([],this.formList)
const submitForm = Object.assign([], this.formList)
for (const index in this.formList) {
const item = this.formList[index]
// eslint-disable-next-line camelcase
@ -397,14 +397,13 @@ export default {
const { tableData } = $table.getTableData()
const tableLength = tableData.length
if (tableLength === 0) {
const { row } = $table.insert()
$table.insert()
} else {
const errMap = await $table.validate().catch(errMap => errMap)
if (errMap) {
this.$message.error('校验不通过!')
} else {
const { row } = $table.insert()
$table.insert()
}
}
},