refactor: tree

pull/4577/head
tangjinzhou 2021-08-17 22:52:28 +08:00
parent 448788eaa5
commit 8c5a23f377
5 changed files with 26 additions and 8 deletions

View File

@ -1,4 +1,4 @@
import type { VNode, PropType, DefineComponent, ExtractPropTypes } from 'vue';
import type { VNode, PropType, DefineComponent, ExtractPropTypes, CSSProperties } from 'vue';
import { ref } from 'vue';
import { defineComponent } from 'vue';
import classNames from '../_util/classNames';
@ -16,7 +16,7 @@ import dropIndicatorRender from './utils/dropIndicator';
export interface AntdTreeNodeAttribute {
eventKey: string;
prefixCls: string;
className: string;
class: string;
expanded: boolean;
selected: boolean;
checked: boolean;
@ -239,6 +239,7 @@ export default defineComponent({
onExpand={handleExpand}
onSelect={handleSelect}
v-slots={{
...slots,
checkable: () => <span class={`${prefixCls.value}-checkbox-inner`} />,
}}
children={filterEmpty(slots.default?.())}

View File

@ -1046,13 +1046,14 @@ export default defineComponent({
onNodeDragLeave,
onNodeDragEnd,
onNodeDrop,
slots: slots,
}}
>
<div
role="tree"
class={classNames(prefixCls, className, {
[`${prefixCls}-show-line`]: showLine,
[`${prefixCls}-focused`]: focused,
[`${prefixCls}-focused`]: focused.value,
[`${prefixCls}-active-focused`]: activeKey.value !== null,
})}
>

View File

@ -5,6 +5,7 @@ import { convertNodePropsToEventData } from './utils/treeUtil';
import { computed, defineComponent, getCurrentInstance, onMounted, onUpdated, ref } from 'vue';
import { treeNodeProps } from './props';
import classNames from '../_util/classNames';
import { warning } from '../vc-util/warning';
const ICON_OPEN = 'open';
const ICON_CLOSE = 'close';
@ -17,7 +18,11 @@ export default defineComponent({
props: treeNodeProps,
isTreeNode: 1,
slots: ['title', 'icon', 'switcherIcon', 'checkable'],
setup(props, { attrs, expose, slots }) {
setup(props, { attrs, slots }) {
warning(
!('slots' in props.data),
'treeData slots is deprecated, please use `v-slot:icon` or `v-slot:title`, `v-slot:switcherIcon` instead',
);
const dragNodeHighlight = ref(false);
const context = useInjectTreeContext();
const instance = getCurrentInstance();
@ -198,7 +203,10 @@ export default defineComponent({
};
const renderSwitcherIconDom = (isLeaf: boolean) => {
const { switcherIcon: switcherIconFromProps = slots.switcherIcon } = props;
const {
switcherIcon: switcherIconFromProps = slots.switcherIcon ||
context.value.slots?.[props.data?.slots?.switcherIcon],
} = props;
const { switcherIcon: switcherIconFromCtx } = context.value;
const switcherIcon = switcherIconFromProps || switcherIconFromCtx;
@ -327,7 +335,13 @@ export default defineComponent({
// Icon + Title
const renderSelector = () => {
const { title = slots.title, selected, icon = slots.icon, loading, data } = props;
const {
title = slots.title || context.value.slots?.[props.data?.slots?.title],
selected,
icon = slots.icon,
loading,
data,
} = props;
const {
prefixCls,
showIcon,
@ -345,7 +359,7 @@ export default defineComponent({
let $icon;
if (showIcon) {
const currentIcon = icon || treeIcon;
const currentIcon = icon || context.value.slots?.[data?.slots?.icon] || treeIcon;
$icon = currentIcon ? (
<span class={classNames(`${prefixCls}-iconEle`, `${prefixCls}-icon__customize`)}>
@ -377,7 +391,7 @@ export default defineComponent({
class={classNames(
`${wrapClass}`,
`${wrapClass}-${nodeState.value || 'normal'}`,
!disabled && (selected || dragNodeHighlight) && `${prefixCls}-node-selected`,
!disabled && (selected || dragNodeHighlight.value) && `${prefixCls}-node-selected`,
!disabled && mergedDraggable && 'draggable',
)}
draggable={(!disabled && mergedDraggable) || undefined}

View File

@ -80,6 +80,7 @@ export interface TreeContextProps {
onNodeDragLeave: NodeDragEventHandler;
onNodeDragEnd: NodeDragEventHandler;
onNodeDrop: NodeDragEventHandler;
slots: Record<string, any>;
}
const TreeContextKey: InjectionKey<ComputedRef<TreeContextProps>> = Symbol('TreeContextKey');

View File

@ -16,6 +16,7 @@ export interface DataNode {
/** Set style of TreeNode. This is not recommend if you don't have any force requirement */
class?: string;
style?: CSSProperties;
slots?: Record<string, string>;
}
export interface EventDataNode extends DataNode {