Fixed #6533 - CascadeSelect: move move/enter behavior changes
parent
31aff977d3
commit
d09d992e71
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue