75c32d5f
梁灏
rebuild Tree
|
1
|
<template>
|
eae3e936
Aresn
Tree support tran...
|
2
|
<collapse-transition>
|
75c32d5f
梁灏
rebuild Tree
|
3
4
5
6
7
8
|
<ul :class="classes" v-show="visible">
<li>
<span :class="arrowClasses" @click="handleExpand">
<Icon type="arrow-right-b"></Icon>
</span>
<Checkbox
|
eae3e936
Aresn
Tree support tran...
|
9
10
11
12
13
|
v-if="showCheckbox"
:value="data.checked"
:indeterminate="indeterminate"
:disabled="data.disabled || data.disableCheckbox"
@click.native.prevent="handleCheck"></Checkbox>
|
75c32d5f
梁灏
rebuild Tree
|
14
15
|
<span :class="titleClasses" v-html="data.title" @click="handleSelect"></span>
<Tree-node
|
eae3e936
Aresn
Tree support tran...
|
16
17
18
19
20
21
|
v-for="item in data.children"
:key="item"
:data="item"
:visible="data.expand"
:multiple="multiple"
:show-checkbox="showCheckbox">
|
75c32d5f
梁灏
rebuild Tree
|
22
23
24
|
</Tree-node>
</li>
</ul>
|
eae3e936
Aresn
Tree support tran...
|
25
|
</collapse-transition>
|
75c32d5f
梁灏
rebuild Tree
|
26
27
28
|
</template>
<script>
import Checkbox from '../checkbox/checkbox.vue';
|
64633e8c
梁灏
fixed #612
|
29
|
import Icon from '../icon/icon.vue';
|
eae3e936
Aresn
Tree support tran...
|
30
|
import CollapseTransition from '../base/collapse-transition';
|
75c32d5f
梁灏
rebuild Tree
|
31
32
33
34
35
36
37
38
|
import Emitter from '../../mixins/emitter';
import { findComponentsDownward } from '../../utils/assist';
const prefixCls = 'ivu-tree';
export default {
name: 'TreeNode',
mixins: [ Emitter ],
|
eae3e936
Aresn
Tree support tran...
|
39
|
components: { Checkbox, Icon, CollapseTransition },
|
75c32d5f
梁灏
rebuild Tree
|
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
props: {
data: {
type: Object,
default () {
return {};
}
},
multiple: {
type: Boolean,
default: false
},
showCheckbox: {
type: Boolean,
default: false
},
visible: {
type: Boolean,
default: false
}
},
data () {
return {
prefixCls: prefixCls,
|
53754a31
梁灏
fixed #468
|
63
|
indeterminate: false
|
75c32d5f
梁灏
rebuild Tree
|
64
65
66
67
68
69
|
};
},
computed: {
classes () {
return [
`${prefixCls}-children`
|
3c145e6f
梁灏
update Tree
|
70
|
];
|
75c32d5f
梁灏
rebuild Tree
|
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
},
selectedCls () {
return [
{
[`${prefixCls}-node-selected`]: this.data.selected
}
];
},
arrowClasses () {
return [
`${prefixCls}-arrow`,
{
[`${prefixCls}-arrow-disabled`]: this.data.disabled,
[`${prefixCls}-arrow-open`]: this.data.expand,
[`${prefixCls}-arrow-hidden`]: !(this.data.children && this.data.children.length)
}
];
},
titleClasses () {
return [
`${prefixCls}-title`,
{
[`${prefixCls}-title-selected`]: this.data.selected
}
];
}
},
methods: {
handleExpand () {
if (this.data.disabled) return;
this.$set(this.data, 'expand', !this.data.expand);
|
75dad873
Lawrence Lee
add listener on T...
|
102
|
this.dispatch('Tree', 'toggle-expand', this.data);
|
75c32d5f
梁灏
rebuild Tree
|
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
},
handleSelect () {
if (this.data.disabled) return;
if (this.data.selected) {
this.data.selected = false;
} else if (this.multiple) {
this.$set(this.data, 'selected', !this.data.selected);
} else {
this.dispatch('Tree', 'selected', this.data);
}
this.dispatch('Tree', 'on-selected');
},
handleCheck () {
if (this.disabled) return;
|
3c145e6f
梁灏
update Tree
|
117
118
119
120
121
122
123
|
const checked = !this.data.checked;
if (!checked || this.indeterminate) {
findComponentsDownward(this, 'TreeNode').forEach(node => node.data.checked = false);
} else {
findComponentsDownward(this, 'TreeNode').forEach(node => node.data.checked = true);
}
this.data.checked = checked;
|
75c32d5f
梁灏
rebuild Tree
|
124
|
this.dispatch('Tree', 'checked');
|
53754a31
梁灏
fixed #468
|
125
|
this.dispatch('Tree', 'on-checked');
|
75c32d5f
梁灏
rebuild Tree
|
126
127
128
129
130
131
132
133
134
135
136
|
},
setIndeterminate () {
this.indeterminate = this.data.checked ? false : findComponentsDownward(this, 'TreeNode').some(node => node.data.checked);
}
},
created () {
// created node.vue first, mounted tree.vue second
if (!this.data.checked) this.$set(this.data, 'checked', false);
},
mounted () {
this.$on('indeterminate', () => {
|
53754a31
梁灏
fixed #468
|
137
|
this.broadcast('TreeNode', 'indeterminate');
|
75c32d5f
梁灏
rebuild Tree
|
138
|
this.setIndeterminate();
|
3c145e6f
梁灏
update Tree
|
139
|
});
|
75c32d5f
梁灏
rebuild Tree
|
140
141
142
|
}
};
</script>
|