Merge pull request #6963 from erwanlfrt/dev/fix-tree-on-filter-value

fix: missing last typed letter on filter tree event
pull/7024/head
Tuğçe Küçükoğlu 2024-12-27 12:59:29 +03:00 committed by GitHub
commit ca31fca45d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 10 additions and 5 deletions

View File

@ -47,12 +47,17 @@ describe('Tree.vue', () => {
filter: true filter: true
} }
}); });
let searchField = wrapper.find('input.p-inputtext');
const key = 't';
searchField.element.value = key;
let searchField = wrapper.find('input.p-inputtext'); await searchField.trigger('keyup', {
key
await searchField.trigger('keydown.space'); });
expect(wrapper.emitted('filter')).toBeTruthy(); expect(wrapper.emitted('filter')).toBeTruthy();
expect(wrapper.emitted('filter')[0][0].value).toEqual(key);
}); });
it('should render icon', ({ expect }) => { it('should render icon', ({ expect }) => {

View File

@ -9,7 +9,7 @@
</div> </div>
</template> </template>
<IconField v-if="filter" :unstyled="unstyled" :pt="{ ...ptm('pcFilter'), ...ptm('pcFilterContainer') }" :class="cx('pcFilterContainer')"> <IconField v-if="filter" :unstyled="unstyled" :pt="{ ...ptm('pcFilter'), ...ptm('pcFilterContainer') }" :class="cx('pcFilterContainer')">
<InputText v-model="filterValue" autocomplete="off" :class="cx('pcFilterInput')" :placeholder="filterPlaceholder" :unstyled="unstyled" @keydown="onFilterKeydown" :pt="ptm('pcFilterInput')" /> <InputText v-model="filterValue" autocomplete="off" :class="cx('pcFilterInput')" :placeholder="filterPlaceholder" :unstyled="unstyled" @keyup="onFilterKeyup" :pt="ptm('pcFilterInput')" />
<InputIcon :unstyled="unstyled" :pt="ptm('pcFilterIconContainer')"> <InputIcon :unstyled="unstyled" :pt="ptm('pcFilterIconContainer')">
<!--TODO: searchicon deprecated since v4.0--> <!--TODO: searchicon deprecated since v4.0-->
<slot :name="$slots.filtericon ? 'filtericon' : 'searchicon'" :class="cx('filterIcon')"> <slot :name="$slots.filtericon ? 'filtericon' : 'searchicon'" :class="cx('filterIcon')">
@ -172,7 +172,7 @@ export default {
isNodeLeaf(node) { isNodeLeaf(node) {
return node.leaf === false ? false : !(node.children && node.children.length); return node.leaf === false ? false : !(node.children && node.children.length);
}, },
onFilterKeydown(event) { onFilterKeyup(event) {
if (event.code === 'Enter' || event.code === 'NumpadEnter') { if (event.code === 'Enter' || event.code === 'NumpadEnter') {
event.preventDefault(); event.preventDefault();
} }