Skip to content
This repository has been archived by the owner on Sep 9, 2024. It is now read-only.

Commit

Permalink
fix: properly handle default group and filter
Browse files Browse the repository at this point in the history
  • Loading branch information
KaneFreeman committed Feb 8, 2024
1 parent ccd242c commit 4357297
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 26 deletions.
2 changes: 2 additions & 0 deletions packages/core/dev-test/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ collections:
field: title
create: true
view_filters:
default: posts-with-index
filters:
- name: posts-with-index
label: Posts With Index
Expand All @@ -53,6 +54,7 @@ collections:
field: draft
pattern: true
view_groups:
default: by-year
groups:
- name: by-year
label: Year
Expand Down
4 changes: 4 additions & 0 deletions packages/core/dev-test/data.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 2 additions & 7 deletions packages/core/src/actions/entries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -338,13 +338,8 @@ export function groupByField(collection: CollectionWithDefaults, group: ViewGrou
return async (dispatch: ThunkDispatch<RootState, {}, AnyAction>, getState: () => RootState) => {
const state = getState();
const isFetching = selectIsFetching(state, collection.name);
dispatch({
type: GROUP_ENTRIES_REQUEST,
payload: {
collection: collection.name,
group,
},
});
dispatch(groupEntriesRequest(collection, group));

Check warning on line 341 in packages/core/src/actions/entries.ts

View check run for this annotation

Codecov / codecov/patch

packages/core/src/actions/entries.ts#L341

Added line #L341 was not covered by tests

if (isFetching) {
return;
}
Expand Down
44 changes: 25 additions & 19 deletions packages/core/src/components/collections/CollectionView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -189,22 +189,37 @@ const CollectionView: FC<CollectionViewProps> = ({
const sortGroupFilterEntries = () => {
setTimeout(async () => {
if (defaultSort && defaultSort.field) {
await onSortClick(defaultSort.field, defaultSort.direction ?? SORT_DIRECTION_ASCENDING);
const isDefaultSortActive = Boolean(
Object.values(sort).find(s => s.key === defaultSort.field),
);
if (!isDefaultSortActive) {
await onSortClick(defaultSort.field, defaultSort.direction ?? SORT_DIRECTION_ASCENDING);
}
}

if (defaultViewGroupName) {
const defaultViewGroup = viewGroups?.groups.find(g => g.name === defaultViewGroupName);
if (defaultViewGroup) {
await onGroupClick(defaultViewGroup);
const isDefaultGroupActive = Boolean(
Object.values(group).find(g => g.name === defaultViewGroupName && g.active),
);
if (!isDefaultGroupActive) {
const defaultViewGroup = viewGroups?.groups.find(g => g.name === defaultViewGroupName);
if (defaultViewGroup) {
await onGroupClick(defaultViewGroup);
}
}
}

if (defaultViewFilterName) {
const defaultViewFilter = viewFilters?.filters.find(
f => f.name === defaultViewFilterName,
const isDefaultFilterActive = Boolean(
Object.values(filter).find(f => f.name === defaultViewFilterName && f.active),
);
if (defaultViewFilter) {
await onFilterClick(defaultViewFilter);
if (!isDefaultFilterActive) {
const defaultViewFilter = viewFilters?.filters.find(
f => f.name === defaultViewFilterName,
);
if (defaultViewFilter) {
await onFilterClick(defaultViewFilter);
}
}
}

Expand All @@ -219,17 +234,8 @@ const CollectionView: FC<CollectionViewProps> = ({
return () => {
alive = false;
};
}, [
collection,
onFilterClick,
onGroupClick,
onSortClick,
prevCollection,
readyToLoad,
sort,
viewFilters?.filters,
viewGroups?.groups,
]);
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [collection, onFilterClick, onGroupClick, onSortClick, prevCollection, readyToLoad]);

const collectionDescription = collection?.description;

Expand Down

0 comments on commit 4357297

Please sign in to comment.