Skip to content

Commit

Permalink
DataViews: Fix focus loss when removing all filters or resetting
Browse files Browse the repository at this point in the history
  • Loading branch information
ntsekouras committed Nov 14, 2024
1 parent 46ab740 commit 0e41d32
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 28 deletions.
81 changes: 55 additions & 26 deletions packages/dataviews/src/components/dataviews-filters/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
useRef,
useMemo,
useCallback,
useEffect,
} from '@wordpress/element';
import { __experimentalHStack as HStack, Button } from '@wordpress/components';
import { funnel } from '@wordpress/icons';
Expand Down Expand Up @@ -70,7 +71,7 @@ export function useFilters( fields: NormalizedField< any >[], view: View ) {
}, [ fields, view ] );
}

export function FilterVisibilityToggle( {
export function FiltersToggle( {
filters,
view,
onChangeView,
Expand All @@ -85,6 +86,7 @@ export function FilterVisibilityToggle( {
isShowingFilter: boolean;
setIsShowingFilter: React.Dispatch< React.SetStateAction< boolean > >;
} ) {
const buttonRef = useRef< HTMLButtonElement >( null );
const onChangeViewWithFilterVisibility = useCallback(
( _view: View ) => {
onChangeView( _view );
Expand All @@ -98,47 +100,74 @@ export function FilterVisibilityToggle( {
if ( filters.length === 0 ) {
return null;
}

const addFilterButtonProps = {
label: __( 'Add filter' ),
'aria-expanded': false,
isPressed: false,
};
const toggleFiltersButtonProps = {
label: _x( 'Filter', 'verb' ),
'aria-expanded': isShowingFilter,
isPressed: isShowingFilter,
onClick: () => {
if ( ! isShowingFilter ) {
setOpenedFilter( null );
}
setIsShowingFilter( ! isShowingFilter );
},
};
const buttonComponent = (
<Button
ref={ buttonRef }
className="dataviews-filters__visibility-toggle"
size="compact"
icon={ funnel }
{ ...( hasVisibleFilters
? toggleFiltersButtonProps
: addFilterButtonProps ) }
/>
);
if ( ! hasVisibleFilters ) {
return (
<AddFilterMenu
filters={ filters }
view={ view }
onChangeView={ onChangeViewWithFilterVisibility }
setOpenedFilter={ setOpenedFilter }
trigger={
<Button
className="dataviews-filters__visibility-toggle"
size="compact"
icon={ funnel }
label={ __( 'Add filter' ) }
isPressed={ false }
aria-expanded={ false }
/>
}
trigger={ buttonComponent }
/>
);
}
return (
<div className="dataviews-filters__container-visibility-toggle">
<Button
className="dataviews-filters__visibility-toggle"
size="compact"
icon={ funnel }
label={ _x( 'Filter', 'verb' ) }
onClick={ () => {
if ( ! isShowingFilter ) {
setOpenedFilter( null );
}
setIsShowingFilter( ! isShowingFilter );
} }
isPressed={ isShowingFilter }
aria-expanded={ isShowingFilter }
/>
<FilterVisibilityToggle buttonRef={ buttonRef }>
{ buttonComponent }
{ hasVisibleFilters && !! view.filters?.length && (
<span className="dataviews-filters-toggle__count">
{ view.filters?.length }
</span>
) }
</FilterVisibilityToggle>
);
}

function FilterVisibilityToggle( {
buttonRef,
children,
}: {
buttonRef: React.RefObject< HTMLButtonElement >;
children: React.ReactNode;
} ) {
// Focus the `add filter` button when unmounts.
useEffect(
() => () => {
buttonRef.current?.focus();
},
[ buttonRef ]
);
return (
<div className="dataviews-filters__container-visibility-toggle">
{ children }
</div>
);
}
Expand Down
4 changes: 2 additions & 2 deletions packages/dataviews/src/components/dataviews/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ import DataViewsContext from '../dataviews-context';
import {
default as DataViewsFilters,
useFilters,
FilterVisibilityToggle,
FiltersToggle,
} from '../dataviews-filters';
import DataViewsLayout from '../dataviews-layout';
import DataViewsFooter from '../dataviews-footer';
Expand Down Expand Up @@ -135,7 +135,7 @@ export default function DataViews< Item >( {
className="dataviews__search"
>
{ search && <DataViewsSearch label={ searchLabel } /> }
<FilterVisibilityToggle
<FiltersToggle
filters={ filters }
view={ view }
onChangeView={ onChangeView }
Expand Down

0 comments on commit 0e41d32

Please sign in to comment.