@tongfun/tf-widget 0.1.6 → 0.1.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.browserslistrc +3 -3
- package/.editorconfig +5 -5
- package/.eslintrc.js +17 -17
- package/README.md +39 -8
- package/dist/css/chunk-9c7a8e06.920744ef.css +1 -0
- package/dist/css/chunk-vendors.de967301.css +1 -0
- package/dist/css/index.153bd82e.css +1 -0
- package/dist/fonts/element-icons.535877f5.woff +0 -0
- package/dist/fonts/element-icons.732389de.ttf +0 -0
- package/dist/js/chunk-9c7a8e06.ffff58b5.js +1 -0
- package/dist/js/chunk-vendors.45086d09.js +39 -0
- package/dist/js/index.52bcef0d.js +1 -0
- package/lib/css/1.920744ef.css +1 -0
- package/lib/tf-widget.common.1.js +387 -0
- package/lib/tf-widget.common.js +85007 -63712
- package/lib/tf-widget.css +1 -1
- package/lib/tf-widget.umd.1.js +387 -0
- package/lib/tf-widget.umd.js +85007 -63712
- package/lib/tf-widget.umd.min.1.js +1 -0
- package/lib/tf-widget.umd.min.js +10 -3
- package/package/t-data-list/index.js +6 -0
- package/package/t-data-list/main.vue +192 -0
- package/package/t-data-list/src/condition-input/basic.vue +31 -0
- package/package/t-data-list/src/condition-input/date.vue +106 -0
- package/package/t-data-list/src/condition-input/index.vue +100 -0
- package/package/t-data-list/src/condition-input/input.vue +31 -0
- package/package/t-data-list/src/condition-input/number.vue +115 -0
- package/package/t-data-list/src/condition-input/select.vue +86 -0
- package/package/t-data-list/src/js/fieldTypeEnum.js +10 -0
- package/package/t-data-list/src/js/operatorEnum.js +109 -0
- package/package/t-data-list/src/js/qureyParamsEnum.js +4 -0
- package/package/t-data-list/src/js/util.js +34 -0
- package/package/t-data-list/src/mixins/button-controll-mixin.js +77 -0
- package/package/t-data-list/src/pushdown/push-down.vue +158 -0
- package/package/t-data-list/src/t-list-search.vue +32 -0
- package/package/t-data-list/src/t-plan/condition-always-item.vue +143 -0
- package/package/t-data-list/src/t-plan/condition-mult-item.vue +222 -0
- package/package/t-data-list/src/t-plan/index.vue +190 -0
- package/package/t-data-list/src/t-plan/plan-content.vue +396 -0
- package/package/t-data-list/src/t-table/index.vue +120 -0
- package/package/t-data-list/src/t-table/table-group-item-edit.vue +238 -0
- package/package/t-data-list/src/t-table/table-group-item.vue +87 -0
- package/package/t-data-list/src/t-table/table-group.vue +179 -0
- package/package/t-data-list/src/t-table/table-records-header-popover.vue +250 -0
- package/package/t-data-list/src/t-table/table-records-selected.vue +159 -0
- package/package/t-data-list/src/t-table/table-records.vue +324 -0
- package/package/t-input/children/address.vue +101 -0
- package/package/t-input/children/basic-display.vue +41 -0
- package/package/t-input/children/basic.vue +251 -0
- package/package/t-input/children/date.vue +89 -0
- package/package/t-input/children/group-components/group-dialog.vue +350 -0
- package/package/t-input/children/group.vue +126 -0
- package/package/t-input/children/input.vue +72 -0
- package/package/t-input/children/number.vue +74 -0
- package/package/t-input/children/select.vue +89 -0
- package/package/t-input/children/tfile/fiile-enclosure.vue +233 -0
- package/package/t-input/children/tfile/file-img/comp.png +0 -0
- package/package/t-input/children/tfile/file-img/excel.png +0 -0
- package/package/t-input/children/tfile/file-img/img.png +0 -0
- package/package/t-input/children/tfile/file-img/pdf.png +0 -0
- package/package/t-input/children/tfile/file-img/word.png +0 -0
- package/package/t-input/index.js +7 -0
- package/package/t-input/index.vue +337 -0
- package/package/t-input/tInputCache.js +24 -0
- package/package/tf-layout/README.md +69 -0
- package/package/tf-layout/index.js +8 -0
- package/package/tf-layout/src/components/tf-labelbar.vue +376 -0
- package/package/tf-layout/src/components/tf-menu.vue +180 -0
- package/package/tf-layout/src/components/tf-right-menu.vue +89 -0
- package/package/tf-layout/src/components/tf-rotate-box.vue +50 -0
- package/package/tf-layout/src/tf-layout.vue +115 -0
- package/package/tf-widget/src/children/decimal.vue +15 -16
- package/package/tf-widget/src/children/integer.vue +15 -16
- package/package.json +4 -2
- package/postinstall.js +10 -10
- package/src/api/file-enclosure.js +26 -0
- package/src/api/push-down.js +19 -0
- package/src/api/tableV3.js +186 -0
- package/src/index.js +11 -3
- package/src/mixins/t-data-query-mixin.js +289 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
const typeEnum = {
|
|
2
|
+
/**
|
|
3
|
+
* 文本类型
|
|
4
|
+
*/
|
|
5
|
+
input: [
|
|
6
|
+
{ label: '等于', value: 'TEXT_EQUAL', strict: true },
|
|
7
|
+
{ label: '包含', value: 'TEXT_LIKE', isFrezz: true },
|
|
8
|
+
{ label: '不等于', value: 'TEXT_UNEQUAL' },
|
|
9
|
+
{ label: '不包含', value: 'TEXT_NOT_LIKE' }
|
|
10
|
+
],
|
|
11
|
+
|
|
12
|
+
// 基础资料类型
|
|
13
|
+
basic: [
|
|
14
|
+
{ label: '等于', value: 'BASIC_EQUAL', strict: true },
|
|
15
|
+
{ label: '包含', value: 'BASIC_LIKE', isFrezz: true },
|
|
16
|
+
{ label: '不等于', value: 'BASIC_UNEQUAL' },
|
|
17
|
+
{ label: '不包含', value: 'BASIC_NOT_LIKE' }
|
|
18
|
+
],
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* 时间类型
|
|
22
|
+
*/
|
|
23
|
+
// 短时间
|
|
24
|
+
date: [
|
|
25
|
+
{ label: '大于', value: 'TIME_MORE_SHORT' },
|
|
26
|
+
{ label: '小于', value: 'TIME_LESS_SHORT' },
|
|
27
|
+
{ label: '大于等于', value: 'TIME_MORE_EQ_SHORT' },
|
|
28
|
+
{ label: '小于等于', value: 'TIME_LESS_EQ_SHORT' },
|
|
29
|
+
{ label: '等于', value: 'TIME_EQUAL_SHORT' },
|
|
30
|
+
// { label: '在...中', value: 'TIME_EQUAL_SHORT_BETWEEN', range: true },
|
|
31
|
+
// 时间通用
|
|
32
|
+
{ label: '前天', value: 'TIME_BEFORE_YESTERDAY', over: true },
|
|
33
|
+
{ label: '昨天', value: 'TIME_YESTERDAY', over: true },
|
|
34
|
+
{ label: '今天', value: 'TIME_TODAY', over: true },
|
|
35
|
+
{ label: '明天', value: 'TIME_TOMORROW', over: true },
|
|
36
|
+
{ label: '后天', value: 'TIME_AFTER_TOMORROW', over: true },
|
|
37
|
+
{ label: '上周', value: 'TIME_LAST_WEEK', over: true },
|
|
38
|
+
{ label: '本周', value: 'TIME_WEEK', over: true },
|
|
39
|
+
{ label: '下周', value: 'TIME_NEXT_WEEK', over: true },
|
|
40
|
+
{ label: '本月', value: 'TIME_MONTH', over: true },
|
|
41
|
+
{ label: '上月', value: 'TIME_LAST_MONTH', over: true }
|
|
42
|
+
],
|
|
43
|
+
// 长时间
|
|
44
|
+
datetime: [
|
|
45
|
+
{ label: '大于', value: 'TIME_MORE_LONG' },
|
|
46
|
+
{ label: '大于等于', value: 'TIME_MORE_EQ_LONG' },
|
|
47
|
+
{ label: '等于', value: 'TIME_EQUAL_LONG' },
|
|
48
|
+
{ label: '小于等于', value: 'TIME_LESS_EQ_LONG' },
|
|
49
|
+
{ label: '小于', value: 'TIME_LESS' },
|
|
50
|
+
// { label: '在...中', value: 'TIME_EQUAL_BETWEEN', range: true },
|
|
51
|
+
// 时间通用
|
|
52
|
+
{ label: '前天', value: 'TIME_BEFORE_YESTERDAY', over: true },
|
|
53
|
+
{ label: '昨天', value: 'TIME_YESTERDAY', over: true },
|
|
54
|
+
{ label: '今天', value: 'TIME_TODAY', over: true },
|
|
55
|
+
{ label: '明天', value: 'TIME_TOMORROW', over: true },
|
|
56
|
+
{ label: '后天', value: 'TIME_AFTER_TOMORROW', over: true },
|
|
57
|
+
{ label: '上周', value: 'TIME_LAST_WEEK', over: true },
|
|
58
|
+
{ label: '本周', value: 'TIME_WEEK', over: true },
|
|
59
|
+
{ label: '下周', value: 'TIME_NEXT_WEEK', over: true },
|
|
60
|
+
{ label: '本月', value: 'TIME_MONTH', over: true },
|
|
61
|
+
{ label: '上月', value: 'TIME_LAST_MONTH', over: true }
|
|
62
|
+
],
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* 枚举类型
|
|
66
|
+
*
|
|
67
|
+
*/
|
|
68
|
+
enum: [
|
|
69
|
+
{ label: '等于', value: 'ENUM_EQUAL', strict: true },
|
|
70
|
+
{ label: '不等于', value: 'ENUM_UNEQUAL', isFrezz: true },
|
|
71
|
+
{ label: '在...中', value: 'ENUM_IN', multi: true },
|
|
72
|
+
{ label: '不在...中', value: 'ENUM_NOT_IN', multi: true }
|
|
73
|
+
],
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* 数字类型
|
|
77
|
+
*/
|
|
78
|
+
number: [
|
|
79
|
+
{ label: '大于', value: 'NUMBER_MORE' },
|
|
80
|
+
{ label: '大于等于', value: 'NUMBER_MORE_EQUAL' },
|
|
81
|
+
{ label: '等于', value: 'NUMBER_EQUAL', strict: true },
|
|
82
|
+
{ label: '不等于', value: 'NUMBER_NOT_EQUAL' },
|
|
83
|
+
{ label: '小于', value: 'NUMBER_LESS' },
|
|
84
|
+
{ label: '小于等于', value: 'NUMBER_LESS_EQUAL' },
|
|
85
|
+
{ label: '在...中', value: 'NUMBER_BETWEEN', range: true }
|
|
86
|
+
]
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* 所有的不需要输入值的选项的操作符
|
|
91
|
+
* @returns string[]
|
|
92
|
+
*/
|
|
93
|
+
export function getAllOverOperatorList () {
|
|
94
|
+
const overOptions = []
|
|
95
|
+
for (const key in typeEnum) {
|
|
96
|
+
for (const option of typeEnum[key]) {
|
|
97
|
+
option.over && !overOptions.find(item => item === option.value) && overOptions.push(option.value)
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return overOptions
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
export default function getOperatorOption (type) {
|
|
104
|
+
// todo: 优化一下判断次数???
|
|
105
|
+
if (type === 'decimal' || type === 'integer') {
|
|
106
|
+
type = 'number'
|
|
107
|
+
}
|
|
108
|
+
return typeEnum[type]
|
|
109
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import fieldType from './fieldTypeEnum'
|
|
2
|
+
import getOperatorOption from './operatorEnum'
|
|
3
|
+
/**
|
|
4
|
+
* 根据id找到该节点的父节点
|
|
5
|
+
*/
|
|
6
|
+
export function getParentId (tree, id) {
|
|
7
|
+
let resId = null
|
|
8
|
+
for (const child of tree.children) {
|
|
9
|
+
if (child.id === id) {
|
|
10
|
+
resId = tree.id
|
|
11
|
+
return resId
|
|
12
|
+
}
|
|
13
|
+
if (child.children) {
|
|
14
|
+
resId = getParentId(child, id)
|
|
15
|
+
if (resId) {
|
|
16
|
+
return resId
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return resId
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* 参数名称是根据后端的表头中的一个字段来确定
|
|
25
|
+
* 此函数,根据componentType找到前端自定义的枚举类型
|
|
26
|
+
* 然后根据类型找到其模糊搜索的操作类型
|
|
27
|
+
* 用于通用列表混入对象中的,搜索建议拼接高级条件,搜索范围条件限定拼接高级条件
|
|
28
|
+
*/
|
|
29
|
+
export function getOperator (componentValueType, isStrict) {
|
|
30
|
+
const type = fieldType[componentValueType]
|
|
31
|
+
const operatorList = getOperatorOption(type)
|
|
32
|
+
const operator = operatorList.find(item => item[isStrict ? 'strict' : 'isFrezz'])
|
|
33
|
+
return operator
|
|
34
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 按钮处理函数混入对象
|
|
3
|
+
* 为了避免将来按钮逐渐增多,导致查询页面代码庞大
|
|
4
|
+
* 顶部的所有按钮的处理函数都放入当前混入对象中
|
|
5
|
+
*/
|
|
6
|
+
import { del } from '@/api/tableV3.js'
|
|
7
|
+
|
|
8
|
+
export default {
|
|
9
|
+
methods: {
|
|
10
|
+
// 跳转到新增页面
|
|
11
|
+
insert () {
|
|
12
|
+
const randomStr = Math.random().toString(36).slice(8)
|
|
13
|
+
this.$router.replace(`${this.$route.path}/insert/${randomStr}`)
|
|
14
|
+
},
|
|
15
|
+
// 跳转到修改页面
|
|
16
|
+
update () {
|
|
17
|
+
if (this.selectedRows.length === 0) {
|
|
18
|
+
return this.$message.warning('请选择一条数据')
|
|
19
|
+
}
|
|
20
|
+
if (this.selectedRows.length > 1) {
|
|
21
|
+
return this.$message.warning('只允许选择一条数据')
|
|
22
|
+
}
|
|
23
|
+
const randomStr = Math.random().toString(36).slice(8)
|
|
24
|
+
this.$router.replace(`${this.$route.path}/update/${randomStr}/${this.ids[0]}`)
|
|
25
|
+
},
|
|
26
|
+
// 删除列表数据
|
|
27
|
+
del () {
|
|
28
|
+
if (this.ids.length === 0) {
|
|
29
|
+
this.$message.info('您还未选择数据')
|
|
30
|
+
return
|
|
31
|
+
}
|
|
32
|
+
this.$confirm('是否确定删除?', '提示', {
|
|
33
|
+
confirmButtonText: '确定',
|
|
34
|
+
cancelButtonText: '取消',
|
|
35
|
+
type: 'warning'
|
|
36
|
+
}).then(async () => {
|
|
37
|
+
const { code, msg } = await del({
|
|
38
|
+
target: this.target,
|
|
39
|
+
params: {
|
|
40
|
+
ids: this.ids.join(',')
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
if (code !== 0) {
|
|
44
|
+
return this.$message.error(msg)
|
|
45
|
+
}
|
|
46
|
+
this.$message.success('删除成功')
|
|
47
|
+
this.refresh()
|
|
48
|
+
})
|
|
49
|
+
},
|
|
50
|
+
// 打开下推的弹窗口
|
|
51
|
+
showPushDown () {
|
|
52
|
+
if (!this.ids.length) {
|
|
53
|
+
return this.$message.error('请先选择数据')
|
|
54
|
+
}
|
|
55
|
+
this.pushdownVisible = true
|
|
56
|
+
},
|
|
57
|
+
/**
|
|
58
|
+
*
|
|
59
|
+
* @param {*} clearTableSelect 刷新完毕后是否清空已选 默认不清空
|
|
60
|
+
* @param {*} clearCondition 是否清空所有条件进行刷新,默认保留当前条件(目前只有刷新按钮不保留条件)
|
|
61
|
+
*/
|
|
62
|
+
refresh (clearTableSelect = false, clearCondition = false) {
|
|
63
|
+
if (!clearTableSelect) {
|
|
64
|
+
this.syncData.tableSelectionClear = false
|
|
65
|
+
}
|
|
66
|
+
if (clearCondition) {
|
|
67
|
+
this.query.conditionAlwaysList = []
|
|
68
|
+
this.query.conditionGroup = null
|
|
69
|
+
this.query.conditionMultiList = []
|
|
70
|
+
this.query.conditionQuickList = []
|
|
71
|
+
this.query.pageNum = 1
|
|
72
|
+
this.query.pageSize = 200
|
|
73
|
+
}
|
|
74
|
+
this.getTableData(false, true)
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-dialog
|
|
3
|
+
title="下推"
|
|
4
|
+
:visible="visible"
|
|
5
|
+
width="35%"
|
|
6
|
+
@update:visible="$emit('update:visible',$event)"
|
|
7
|
+
@open="handleOpen"
|
|
8
|
+
>
|
|
9
|
+
<div class="header">
|
|
10
|
+
<i class="el-icon-refresh" @click="refreshMethod" />
|
|
11
|
+
</div>
|
|
12
|
+
<div class="table-info">
|
|
13
|
+
<ux-grid
|
|
14
|
+
ref="pushDownTable"
|
|
15
|
+
v-loading="tableLoading"
|
|
16
|
+
column-key
|
|
17
|
+
:data="tableData"
|
|
18
|
+
beautify-table
|
|
19
|
+
border
|
|
20
|
+
highlight-current-row
|
|
21
|
+
show-header-overflow
|
|
22
|
+
show-overflow="tooltip"
|
|
23
|
+
class="common-table"
|
|
24
|
+
:width-resize="true"
|
|
25
|
+
:checkbox-config="{highlight: true ,trigger: 'row'}"
|
|
26
|
+
@current-change="currentChange"
|
|
27
|
+
@selection-change="selectionChange"
|
|
28
|
+
>
|
|
29
|
+
<ux-table-column type="checkbox" fixed="left" align="center" width="60" />
|
|
30
|
+
<ux-table-column field="value" title="单据名称" align="center" resizable width="" />
|
|
31
|
+
<template slot="empty">
|
|
32
|
+
<SvgIcon icon-class="table-empty" style="width: 6vw;height: 6vh;margin-top: 3vh" />
|
|
33
|
+
<div style="font-size: 1.4vh;margin-bottom: 10.5vh">
|
|
34
|
+
暂无数据
|
|
35
|
+
</div>
|
|
36
|
+
</template>
|
|
37
|
+
</ux-grid>
|
|
38
|
+
</div>
|
|
39
|
+
<span slot="footer" class="dialog-footer">
|
|
40
|
+
<el-button class="common-header-button close" @click="$emit('update:visible',false)">取 消</el-button>
|
|
41
|
+
<el-button class="common-header-button" @click="dialogConfirm">确 定</el-button>
|
|
42
|
+
</span>
|
|
43
|
+
</el-dialog>
|
|
44
|
+
</template>
|
|
45
|
+
<script>
|
|
46
|
+
import { findBillExchangeRouterVO } from '@/api/push-down'
|
|
47
|
+
import { pushDownValid } from '@/api/tableV3'
|
|
48
|
+
export default {
|
|
49
|
+
components: {
|
|
50
|
+
|
|
51
|
+
},
|
|
52
|
+
props: {
|
|
53
|
+
visible: {
|
|
54
|
+
type: Boolean,
|
|
55
|
+
default: false
|
|
56
|
+
},
|
|
57
|
+
pushDownTableName: {
|
|
58
|
+
type: String,
|
|
59
|
+
default: null
|
|
60
|
+
},
|
|
61
|
+
parentSelectionData: {
|
|
62
|
+
type: Array,
|
|
63
|
+
default: () => []
|
|
64
|
+
},
|
|
65
|
+
needAuditFlag: {
|
|
66
|
+
type: Boolean,
|
|
67
|
+
default: false
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
data () {
|
|
71
|
+
return {
|
|
72
|
+
selectionData: [],
|
|
73
|
+
tableData: [],
|
|
74
|
+
tableLoading: false,
|
|
75
|
+
refreshMethod: null
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
created () {
|
|
79
|
+
this.refreshMethod = this.utils.debounce(this.getTableData)
|
|
80
|
+
},
|
|
81
|
+
methods: {
|
|
82
|
+
handleOpen () {
|
|
83
|
+
this.getTableData()
|
|
84
|
+
},
|
|
85
|
+
/**
|
|
86
|
+
* 获取下推单据列表
|
|
87
|
+
*/
|
|
88
|
+
getTableData () {
|
|
89
|
+
if (this.pushDownTableName) {
|
|
90
|
+
this.tableData = []
|
|
91
|
+
this.tableLoading = true
|
|
92
|
+
this.selectionData = []
|
|
93
|
+
const data = {
|
|
94
|
+
originTableName: this.pushDownTableName
|
|
95
|
+
}
|
|
96
|
+
findBillExchangeRouterVO(data).then(res => {
|
|
97
|
+
if (res.code === 0) {
|
|
98
|
+
this.tableData = res.data.filter(item => {
|
|
99
|
+
return item.value && item.routerName
|
|
100
|
+
})
|
|
101
|
+
} else {
|
|
102
|
+
this.$message.warning('获取数据失败,请稍后重试!')
|
|
103
|
+
}
|
|
104
|
+
this.tableLoading = false
|
|
105
|
+
}).catch(() => {
|
|
106
|
+
this.tableLoading = false
|
|
107
|
+
})
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
/**
|
|
111
|
+
* 表格当前行change事件
|
|
112
|
+
* @param row
|
|
113
|
+
*/
|
|
114
|
+
currentChange (row) {
|
|
115
|
+
this.$refs.pushDownTable.clearSelection()
|
|
116
|
+
this.$refs.pushDownTable.setCurrentRow(row)
|
|
117
|
+
},
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* 表格选择项change事件
|
|
121
|
+
*/
|
|
122
|
+
selectionChange (value) {
|
|
123
|
+
this.selectionData = value
|
|
124
|
+
},
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* 弹框确认事件
|
|
128
|
+
*/
|
|
129
|
+
async dialogConfirm () {
|
|
130
|
+
if (!this.selectionData.length) {
|
|
131
|
+
return this.$message.error('请选择目标单')
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// 校验是否满足下推条件
|
|
135
|
+
const name = this.selectionData[0].value
|
|
136
|
+
const ids = Array.from(new Set(this.parentSelectionData))
|
|
137
|
+
const res = await pushDownValid(name, ids)
|
|
138
|
+
if (res.code !== 0) {
|
|
139
|
+
return this.$message.error(res.msg)
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
this.$emit('update:visible', false)
|
|
143
|
+
const list = [...new Set(this.parentSelectionData)]
|
|
144
|
+
const data = {
|
|
145
|
+
pid: list.join(','),
|
|
146
|
+
pushDownName: this.selectionData[0].value
|
|
147
|
+
}
|
|
148
|
+
const randomNum = Math.floor(Math.random() * 1000000)
|
|
149
|
+
const routerName = this.selectionData[0].routerName
|
|
150
|
+
window.history.pushState({ ...data }, '', routerName + '/' + randomNum)
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
</script>
|
|
155
|
+
|
|
156
|
+
<style scoped>
|
|
157
|
+
|
|
158
|
+
</style>
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="t-list-search-wrapper">
|
|
3
|
+
<el-input
|
|
4
|
+
v-model="value"
|
|
5
|
+
prefix-icon="el-icon-search"
|
|
6
|
+
@keydown.enter.native="$emit('search',value)"
|
|
7
|
+
/>
|
|
8
|
+
</div>
|
|
9
|
+
</template>
|
|
10
|
+
<script>
|
|
11
|
+
export default {
|
|
12
|
+
data () {
|
|
13
|
+
return {
|
|
14
|
+
value: ''
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
}
|
|
19
|
+
</script>
|
|
20
|
+
|
|
21
|
+
<style lang="less" scoped>
|
|
22
|
+
.t-list-search-wrapper{
|
|
23
|
+
width:200px;
|
|
24
|
+
margin-right:12px;
|
|
25
|
+
::v-deep .el-input__inner {
|
|
26
|
+
border:none ;
|
|
27
|
+
border-radius: 0;
|
|
28
|
+
border-bottom: 1px solid #a7a1a1;
|
|
29
|
+
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
</style>
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="condition-always-item">
|
|
3
|
+
<div class="title">
|
|
4
|
+
<span>{{ data.title }}:</span>
|
|
5
|
+
</div>
|
|
6
|
+
|
|
7
|
+
<div class="values">
|
|
8
|
+
<div
|
|
9
|
+
v-for="item in conditonOptions"
|
|
10
|
+
:key="item.enumId"
|
|
11
|
+
:class="['value-item',isActive(item.enumId)? 'active':'']"
|
|
12
|
+
@click="handleClick(item)"
|
|
13
|
+
>
|
|
14
|
+
{{ item.name }}
|
|
15
|
+
</div>
|
|
16
|
+
</div>
|
|
17
|
+
|
|
18
|
+
<div class="swich-button">
|
|
19
|
+
<template v-if="singleSelect">
|
|
20
|
+
<el-button size="mini" type="primary" @click="switchToMulti">多选</el-button>
|
|
21
|
+
</template>
|
|
22
|
+
<template v-else>
|
|
23
|
+
<el-button size="mini" type="primary" @click="multiSelected">确定</el-button>
|
|
24
|
+
<el-button size="mini" type="danger" @click="switchToSingle">取消</el-button>
|
|
25
|
+
</template>
|
|
26
|
+
</div>
|
|
27
|
+
</div>
|
|
28
|
+
</template>
|
|
29
|
+
|
|
30
|
+
<script>
|
|
31
|
+
export default {
|
|
32
|
+
props: {
|
|
33
|
+
data: {
|
|
34
|
+
type: Object,
|
|
35
|
+
default: null
|
|
36
|
+
},
|
|
37
|
+
value: {
|
|
38
|
+
type: Array,
|
|
39
|
+
default: null
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
data () {
|
|
43
|
+
return {
|
|
44
|
+
multiSelectedCache: [],
|
|
45
|
+
singleSelect: true
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
computed: {
|
|
49
|
+
isActive () {
|
|
50
|
+
return function (value) {
|
|
51
|
+
if (this.singleSelect) {
|
|
52
|
+
return this.value.includes(value)
|
|
53
|
+
}
|
|
54
|
+
return this.multiSelectedCache.includes(value)
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
conditonOptions () {
|
|
58
|
+
if (this.singleSelect) {
|
|
59
|
+
return this.data.options
|
|
60
|
+
}
|
|
61
|
+
return this.data.options.filter(option => option.enumId !== '-1')
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
methods: {
|
|
65
|
+
handleClick (item) {
|
|
66
|
+
// 单选模式下
|
|
67
|
+
if (this.singleSelect) {
|
|
68
|
+
this.selected = [item.enumId]
|
|
69
|
+
return this.$emit('input', [item.enumId])
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// 多选模式下
|
|
73
|
+
if (this.multiSelectedCache.includes(item.enumId)) {
|
|
74
|
+
return this.multiSelectedCache.splice(this.multiSelectedCache.indexOf(item.enumId), 1)
|
|
75
|
+
}
|
|
76
|
+
this.multiSelectedCache.push(item.enumId)
|
|
77
|
+
},
|
|
78
|
+
// 切换到多选状态
|
|
79
|
+
switchToMulti () {
|
|
80
|
+
this.singleSelect = false
|
|
81
|
+
this.multiSelectedCache = []
|
|
82
|
+
this.multiSelectedCache.push(...this.value)
|
|
83
|
+
},
|
|
84
|
+
// 切换到单选状态
|
|
85
|
+
switchToSingle () {
|
|
86
|
+
this.singleSelect = true
|
|
87
|
+
this.multiSelectedCache = []
|
|
88
|
+
},
|
|
89
|
+
multiSelected () {
|
|
90
|
+
const index = this.multiSelectedCache.indexOf('-1')
|
|
91
|
+
index !== -1 && this.multiSelectedCache.splice(index, 1)
|
|
92
|
+
this.$emit('input', this.multiSelectedCache)
|
|
93
|
+
this.singleSelect = true
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
}
|
|
98
|
+
</script>
|
|
99
|
+
|
|
100
|
+
<style scoped lang='less'>
|
|
101
|
+
// 整体
|
|
102
|
+
.condition-always-item {
|
|
103
|
+
display:flex;
|
|
104
|
+
justify-content: space-between;
|
|
105
|
+
border-top:1px solid #dddfe6;
|
|
106
|
+
padding-top:5px;
|
|
107
|
+
// align-items:center;
|
|
108
|
+
|
|
109
|
+
.title {
|
|
110
|
+
margin-top:5px;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// 可选值wrapper
|
|
114
|
+
.values {
|
|
115
|
+
flex:1;
|
|
116
|
+
display:flex;
|
|
117
|
+
flex-wrap: wrap;
|
|
118
|
+
|
|
119
|
+
//可选值 item
|
|
120
|
+
.value-item {
|
|
121
|
+
cursor: pointer;
|
|
122
|
+
user-select: none;
|
|
123
|
+
border:1px #d5d5d9 solid;
|
|
124
|
+
color:#9999a1;
|
|
125
|
+
border-radius:3px;
|
|
126
|
+
padding:5px;
|
|
127
|
+
margin-left:10px;
|
|
128
|
+
margin-bottom:5px;
|
|
129
|
+
}
|
|
130
|
+
.active {
|
|
131
|
+
color:#075699;
|
|
132
|
+
border:1px solid #075699;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
.swich-button {
|
|
137
|
+
.el-button {
|
|
138
|
+
background-color: #075699;
|
|
139
|
+
border:none;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
</style>
|