Skip to content

Commit

Permalink
Refactor #5130
Browse files Browse the repository at this point in the history
  • Loading branch information
tugcekucukoglu committed Jan 24, 2024
1 parent 88bb7e6 commit c138ef5
Show file tree
Hide file tree
Showing 8 changed files with 40 additions and 24 deletions.
6 changes: 5 additions & 1 deletion components/lib/orderlist/BaseOrderList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,11 @@ export default {
},
autoOptionFocus: {
type: Boolean,
default: false
default: true
},
focusOnHover: {
type: Boolean,
default: true
},
responsive: {
type: Boolean,
Expand Down
7 changes: 6 additions & 1 deletion components/lib/orderlist/OrderList.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -227,9 +227,14 @@ export interface OrderListProps {
metaKeySelection?: boolean | undefined;
/**
* Whether to focus on the first visible or selected element.
* @defaultValue false
* @defaultValue true
*/
autoOptionFocus?: boolean | undefined;
/**
* When enabled, the focus is placed on the hovered option.
* @defaultValue true
*/
focusOnHover?: boolean | undefined;
/**
* Inline style of the the list element.
*/
Expand Down
8 changes: 7 additions & 1 deletion components/lib/orderlist/OrderList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,9 @@
:class="cx('item', { item, id: `${id}_${i}` })"
@click="onItemClick($event, item, i)"
@touchend="onItemTouchEnd"
:aria-selected="isSelected(item)"
@mousedown="onOptionMouseDown(i)"
@mousemove="onOptionMouseMove(i)"
:aria-selected="isSelected(item)"
v-bind="getPTOptions(item, 'item', i)"
:data-p-highlight="isSelected(item)"
:data-p-focused="`${id}_${i}` === focusedOptionId"
Expand Down Expand Up @@ -191,6 +192,11 @@ export default {
this.focused = true;
this.focusedOptionIndex = index;
},
onOptionMouseMove(index) {
if (this.focusOnHover && this.focused) {
this.changeFocusedOptionIndex(index);
}
},
onArrowDownKey(event) {
const optionIndex = this.focusedOptionIndex !== -1 ? this.findNextOptionIndex() : this.findFirstSelectedOptionIndex();
Expand Down
7 changes: 1 addition & 6 deletions components/lib/orderlist/style/OrderListStyle.js
Original file line number Diff line number Diff line change
Expand Up @@ -50,12 +50,7 @@ const classes = {
}
],
controls: 'p-orderlist-controls',
container: ({ instance }) => [
'p-orderlist-list-container',
{
'p-focus': instance.focused
}
],
container: 'p-orderlist-list-container',
header: 'p-orderlist-header',
list: 'p-orderlist-list',
item: ({ instance, item, id }) => [
Expand Down
6 changes: 5 additions & 1 deletion components/lib/picklist/BasePickList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,11 @@ export default {
},
autoOptionFocus: {
type: Boolean,
default: false
default: true
},
focusOnHover: {
type: Boolean,
default: true
},
responsive: {
type: Boolean,
Expand Down
7 changes: 6 additions & 1 deletion components/lib/picklist/PickList.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -337,9 +337,14 @@ export interface PickListProps {
metaKeySelection?: boolean | undefined;
/**
* Whether to focus on the first visible or selected element.
* @defaultValue false
* @defaultValue true
*/
autoOptionFocus?: boolean | undefined;
/**
* When enabled, the focus is placed on the hovered option.
* @defaultValue true
*/
focusOnHover?: boolean | undefined;
/**
* Inline style of the the list element.
*/
Expand Down
9 changes: 8 additions & 1 deletion components/lib/picklist/PickList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@
@dblclick="onItemDblClick($event, item, 0)"
@touchend="onItemTouchEnd"
@mousedown="onOptionMouseDown(i, 'sourceList')"
@mousemove="onOptionMouseMove(i, 'sourceList')"
role="option"
:aria-selected="isSelected(item, 0)"
v-bind="getPTOptions(item, 'item', `${idSource}_${i}`, 0)"
Expand Down Expand Up @@ -162,6 +163,7 @@
@dblclick="onItemDblClick($event, item, 1)"
@keydown="onItemKeyDown($event, 'targetList')"
@mousedown="onOptionMouseDown(i, 'targetList')"
@mousemove="onOptionMouseMove(i, 'targetList')"
@touchend="onItemTouchEnd"
role="option"
:aria-selected="isSelected(item, 1)"
Expand Down Expand Up @@ -313,6 +315,11 @@ export default {
this.focused[listType] = true;
this.focusedOptionIndex = index;
},
onOptionMouseMove(index, listType) {
if (this.focusOnHover && this.focused[listType]) {
this.changeFocusedOptionIndex(index, listType);
}
},
moveUp(event, listIndex) {
if (this.d_selection && this.d_selection[listIndex]) {
let valueList = [...this.modelValue[listIndex]];
Expand Down Expand Up @@ -902,7 +909,7 @@ export default {
return ObjectUtils.isEmpty(this[list]);
},
hasSelectedOption(listType) {
return listType === 'sourceList' ? ObjectUtils.isNotEmpty(this.d_selection[0]) : ObjectUtils.isNotEmpty(this.d_selection[0]);
return listType === 'sourceList' ? ObjectUtils.isNotEmpty(this.d_selection[0]) : ObjectUtils.isNotEmpty(this.d_selection[1]);
}
},
computed: {
Expand Down
14 changes: 2 additions & 12 deletions components/lib/picklist/style/PickListStyle.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,21 +46,11 @@ const classes = {
}
],
sourceControls: 'p-picklist-buttons p-picklist-source-controls',
sourceWrapper: ({ instance }) => [
'p-picklist-list-wrapper p-picklist-source-wrapper',
{
'p-focus': instance.focused.sourceList
}
],
sourceWrapper: 'p-picklist-list-wrapper p-picklist-source-wrapper',
sourceHeader: 'p-picklist-header',
sourceList: 'p-picklist-list p-picklist-source-list',
buttons: 'p-picklist-buttons p-picklist-transfer-buttons',
targetWrapper: ({ instance }) => [
'p-picklist-list-wrapper p-picklist-target-wrapper',
{
'p-focus': instance.focused.targetList
}
],
targetWrapper: 'p-picklist-list-wrapper p-picklist-target-wrapper',
targetHeader: 'p-picklist-header',
targetList: 'p-picklist-list p-picklist-target',
item: ({ instance, item, id, listIndex }) => [
Expand Down

0 comments on commit c138ef5

Please sign in to comment.