Fixed #6533 - CascadeSelect: move move/enter behavior changes

pull/6537/head
tugcekucukoglu 2024-10-07 11:59:27 +03:00
parent 31aff977d3
commit d09d992e71
2 changed files with 35 additions and 13 deletions

View File

@ -72,7 +72,8 @@
:optionGroupLabel="optionGroupLabel" :optionGroupLabel="optionGroupLabel"
:optionGroupChildren="optionGroupChildren" :optionGroupChildren="optionGroupChildren"
@option-change="onOptionChange" @option-change="onOptionChange"
@option-focus-change="onOptionFocusChange" @option-focus-move-change="onOptionFocusMoveChange"
@option-focus-enter-change="onOptionFocusChangeEnter"
:pt="pt" :pt="pt"
:unstyled="unstyled" :unstyled="unstyled"
/> />
@ -303,25 +304,23 @@ export default {
this.clicked = false; this.clicked = false;
}, },
onOptionChange(event) { onOptionChange(event, isSelectable = true) {
const { originalEvent, processedOption, isFocus, isHide } = event; const { originalEvent, processedOption, isFocus, isHide } = event;
if (isEmpty(processedOption)) return; if (isEmpty(processedOption)) return;
const { index, level, parentKey, children } = processedOption; const { index, key, level, parentKey, children } = processedOption;
const grouped = isNotEmpty(children); const grouped = isNotEmpty(children);
const root = isEmpty(processedOption.parent); const root = isEmpty(processedOption.parent);
const selected = this.isSelected(processedOption); const selected = this.isSelected(processedOption);
if (selected) { if (selected) {
const { index, key, level, parentKey } = processedOption;
this.focusedOptionInfo = { index, level, parentKey }; this.focusedOptionInfo = { index, level, parentKey };
this.activeOptionPath = this.activeOptionPath.filter((p) => key !== p.key && key.startsWith(p.key)); this.activeOptionPath = this.activeOptionPath.filter((p) => key !== p.key && key.startsWith(p.key));
this.dirty = !root; this.dirty = !root;
} else { } else {
const activeOptionPath = this.activeOptionPath.filter((p) => p.parentKey !== parentKey); const activeOptionPath = this.activeOptionPath.filter((p) => p.parentKey !== parentKey && p.parentKey !== key);
activeOptionPath.push(processedOption); activeOptionPath.push(processedOption);
@ -329,10 +328,16 @@ export default {
this.activeOptionPath = activeOptionPath; this.activeOptionPath = activeOptionPath;
} }
grouped ? this.onOptionGroupSelect(originalEvent, processedOption) : this.onOptionSelect(originalEvent, processedOption, isHide); if (grouped) {
this.dirty = true;
this.onOptionGroupSelect(originalEvent, processedOption);
} else {
isSelectable && this.onOptionSelect(originalEvent, processedOption, isHide);
}
isFocus && focus(this.$refs.focusInput); isFocus && focus(this.$refs.focusInput);
}, },
onOptionFocusChange(event) { onOptionFocusMoveChange(event) {
if (this.focusOnHover) { if (this.focusOnHover) {
const { originalEvent, processedOption } = event; const { originalEvent, processedOption } = event;
const { index, level, parentKey } = processedOption; const { index, level, parentKey } = processedOption;
@ -341,6 +346,11 @@ export default {
this.changeFocusedOptionIndex(originalEvent, index); this.changeFocusedOptionIndex(originalEvent, index);
} }
}, },
onOptionFocusChangeEnter(event) {
if (this.dirty) {
this.onOptionChange(event, false);
}
},
onOptionSelect(event, processedOption, isHide = true) { onOptionSelect(event, processedOption, isHide = true) {
const value = this.getOptionValue(processedOption?.option); const value = this.getOptionValue(processedOption?.option);

View File

@ -17,7 +17,14 @@
:data-p-focus="isOptionFocused(processedOption)" :data-p-focus="isOptionFocused(processedOption)"
:data-p-disabled="isOptionDisabled(processedOption)" :data-p-disabled="isOptionDisabled(processedOption)"
> >
<div v-ripple :class="cx('optionContent')" @click="onOptionClick($event, processedOption)" @mousemove="onOptionMouseMove($event, processedOption)" v-bind="getPTOptions(processedOption, index, 'optionContent')"> <div
v-ripple
:class="cx('optionContent')"
@click="onOptionClick($event, processedOption)"
@mouseenter="onOptionMouseEnter($event, processedOption)"
@mousemove="onOptionMouseMove($event, processedOption)"
v-bind="getPTOptions(processedOption, index, 'optionContent')"
>
<component v-if="templates['option']" :is="templates['option']" :option="processedOption.option" :selected="isOptionGroup(processedOption) ? false : isOptionSelected(processedOption)" /> <component v-if="templates['option']" :is="templates['option']" :option="processedOption.option" :selected="isOptionGroup(processedOption) ? false : isOptionSelected(processedOption)" />
<span v-else :class="cx('optionText')" v-bind="getPTOptions(processedOption, index, 'optionText')">{{ getOptionLabelToRender(processedOption) }}</span> <span v-else :class="cx('optionText')" v-bind="getPTOptions(processedOption, index, 'optionText')">{{ getOptionLabelToRender(processedOption) }}</span>
<template v-if="isOptionGroup(processedOption)"> <template v-if="isOptionGroup(processedOption)">
@ -46,6 +53,7 @@
:optionGroupChildren="optionGroupChildren" :optionGroupChildren="optionGroupChildren"
@option-change="onOptionChange" @option-change="onOptionChange"
@option-focus-change="onOptionFocusChange" @option-focus-change="onOptionFocusChange"
@option-focus-enter-change="onOptionFocusEnterChange"
:pt="pt" :pt="pt"
:unstyled="unstyled" :unstyled="unstyled"
/> />
@ -55,7 +63,6 @@
</template> </template>
<script> <script>
import { nestedPosition } from '@primeuix/utils/dom';
import { isNotEmpty, resolveFieldData } from '@primeuix/utils/object'; import { isNotEmpty, resolveFieldData } from '@primeuix/utils/object';
import BaseComponent from '@primevue/core/basecomponent'; import BaseComponent from '@primevue/core/basecomponent';
import AngleRightIcon from '@primevue/icons/angleright'; import AngleRightIcon from '@primevue/icons/angleright';
@ -65,7 +72,7 @@ export default {
name: 'CascadeSelectSub', name: 'CascadeSelectSub',
hostName: 'CascadeSelect', hostName: 'CascadeSelect',
extends: BaseComponent, extends: BaseComponent,
emits: ['option-change', 'option-focus-change'], emits: ['option-change', 'option-focus-change', 'option-focus-enter-change'],
container: null, container: null,
props: { props: {
selectId: String, selectId: String,
@ -82,8 +89,7 @@ export default {
}, },
activeOptionPath: Array, activeOptionPath: Array,
level: Number, level: Number,
templates: null, templates: null
isParentMount: Boolean
}, },
methods: { methods: {
@ -136,6 +142,9 @@ export default {
onOptionClick(event, processedOption) { onOptionClick(event, processedOption) {
this.$emit('option-change', { originalEvent: event, processedOption, isFocus: true }); this.$emit('option-change', { originalEvent: event, processedOption, isFocus: true });
}, },
onOptionMouseEnter(event, processedOption) {
this.$emit('option-focus-enter-change', { originalEvent: event, processedOption });
},
onOptionMouseMove(event, processedOption) { onOptionMouseMove(event, processedOption) {
this.$emit('option-focus-change', { originalEvent: event, processedOption }); this.$emit('option-focus-change', { originalEvent: event, processedOption });
}, },
@ -145,6 +154,9 @@ export default {
onOptionFocusChange(event) { onOptionFocusChange(event) {
this.$emit('option-focus-change', event); this.$emit('option-focus-change', event);
}, },
onOptionFocusEnterChange(event) {
this.$emit('option-focus-enter-change', event);
},
containerRef(el) { containerRef(el) {
this.container = el; this.container = el;
}, },