Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion packages/dev/s2-docs/src/ComponentCardView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ export interface ComponentCardItem {
id: string,
name: string,
href: string,
description?: string
description?: string,
date?: string
}

interface ComponentCardGridProps {
Expand Down
38 changes: 35 additions & 3 deletions packages/dev/s2-docs/src/MobileSearchMenu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -305,6 +305,15 @@ function MobileNav({pages, currentPage}: PageProps) {
return matchedPages.sort((a, b) => {
let aNameMatch = title(a).toLowerCase().startsWith(searchLower);
let bNameMatch = title(b).toLowerCase().startsWith(searchLower);
if (a.date && b.date) {
let aDate = new Date(a.date);
let bDate = new Date(b.date);
return bDate.getTime() - aDate.getTime();
} else if (a.date && !b.date) {
return 1;
} else if (!a.date && b.date) {
return -1;
}

if (aNameMatch && !bNameMatch) {
return -1;
Expand All @@ -325,16 +334,29 @@ function MobileNav({pages, currentPage}: PageProps) {
let filteredPages = filterPages(pages, searchValue);

return filteredPages
.sort((a, b) => title(a).localeCompare(title(b)))
.map(page => ({id: page.url.replace(/^\//, ''), name: title(page), href: page.url, description: page.exports?.description}));
.sort((a, b) => {
return title(a).localeCompare(title(b));
})
.map(page => ({id: page.url.replace(/^\//, ''), name: title(page), href: page.url, description: page.exports?.description, date: page.exports?.date}));
};

let getAllContent = (libraryId: string, searchValue: string = ''): ComponentCardItem[] => {
let librarySections = getSectionsForLibrary(libraryId);
let allPages = Array.from(librarySections.values()).flat();
let filteredPages = filterPages(allPages, searchValue);
return filteredPages
.sort((a, b) => title(a).localeCompare(title(b)))
.sort((a, b) => {
if (a.date && b.date) {
let aDate = new Date(a.date);
let bDate = new Date(b.date);
return bDate.getTime() - aDate.getTime();
} else if (a.date && !b.date) {
return 1;
} else if (!a.date && b.date) {
return -1;
}
return title(a).localeCompare(title(b));
})
.map(page => ({id: page.url.replace(/^\//, ''), name: title(page), href: page.url, description: page.exports?.description}));
};

Expand All @@ -355,6 +377,16 @@ function MobileNav({pages, currentPage}: PageProps) {
const aIsIntro = a.name === 'Introduction';
const bIsIntro = b.name === 'Introduction';

if (a.date && b.date) {
let aDate = new Date(a.date);
let bDate = new Date(b.date);
return bDate.getTime() - aDate.getTime();
} else if (a.date && !b.date) {
return 1;
} else if (!a.date && b.date) {
return -1;
}

if (aIsIntro && !bIsIntro) {
return -1;
}
Expand Down