feat: Tree - add slot for nodeIcon

closes #4833
pull/5339/head
Isabelle Glasmacher 2024-02-26 12:52:36 +01:00
parent a31f1a0c8f
commit d6d58557ef
No known key found for this signature in database
GPG Key ID: 61180CFCC0D53838
3 changed files with 43 additions and 1 deletions

View File

@ -352,6 +352,16 @@ export interface TreeSlots {
*/ */
expanded: boolean; expanded: boolean;
}): VNode[]; }): VNode[];
/**
* Custom node icon template.
* @param {Object} scope - togglericon slot's params.
*/
nodeIcon(scope: {
/**
* Tree node instance
*/
node: TreeNode;
}): VNode[];
/** /**
* Custom checkbox icon * Custom checkbox icon
* @param {Object} scope - checkboxicon slot's params. * @param {Object} scope - checkboxicon slot's params.

View File

@ -54,4 +54,31 @@ describe('Tree.vue', () => {
expect(wrapper.emitted('filter')).toBeTruthy(); expect(wrapper.emitted('filter')).toBeTruthy();
}); });
it('should render icon', ({expect})=>{
expect(wrapper.find('span.pi-inbox').exists()).toBeTruthy();
expect(wrapper.find('span.pi-inbox').classes('p-treenode-icon')).toBeTruthy()
})
it('should render icon slot', ({expect})=>{
let wrapper = mount(Tree, {
slots: {
nodeIcon: `<i data-node-icon/>`
},
props: {
value: [
{
key: '0',
label: 'Documents',
data: 'Documents Folder',
children: []
}
]
}
});
const nodeIcon = wrapper.find('i[data-node-icon]');
expect(nodeIcon.exists()).toBeTruthy();
})
}); });

View File

@ -32,7 +32,12 @@
<component v-else :is="checked ? 'CheckIcon' : partialChecked ? 'MinusIcon' : null" :class="slotProps.class" v-bind="getPTOptions('nodeCheckbox.icon')" /> <component v-else :is="checked ? 'CheckIcon' : partialChecked ? 'MinusIcon' : null" :class="slotProps.class" v-bind="getPTOptions('nodeCheckbox.icon')" />
</template> </template>
</Checkbox> </Checkbox>
<span :class="[cx('nodeIcon'), node.icon]" v-bind="getPTOptions('nodeIcon')"></span> <template v-if="templates['nodeIcon']">
<component :is="templates['nodeIcon']" v-bind="getPTOptions('nodeIcon')" :class="cx('nodeIcon')" :node="node"></component>
</template>
<template v-else>
<span :class="[cx('nodeIcon'), node.icon]" v-bind="getPTOptions('nodeIcon')"></span>
</template>
<span :class="cx('label')" v-bind="getPTOptions('label')" @keydown.stop> <span :class="cx('label')" v-bind="getPTOptions('label')" @keydown.stop>
<component v-if="templates[node.type] || templates['default']" :is="templates[node.type] || templates['default']" :node="node" /> <component v-if="templates[node.type] || templates['default']" :is="templates[node.type] || templates['default']" :node="node" />
<template v-else>{{ label(node) }}</template> <template v-else>{{ label(node) }}</template>