Skip to content

Commit

Permalink
resolve conflicts
Browse files Browse the repository at this point in the history
  • Loading branch information
ThyeeZz committed Dec 26, 2024
2 parents 482ee6f + 997d559 commit cf3db62
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 26 deletions.
76 changes: 51 additions & 25 deletions src/pages/blog/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@ import Link from 'next/link';
import dayjs from 'dayjs';
import { Trans, useTranslation } from 'react-i18next';
import { InkeepCustomTriggerWrapper } from '@/components/inkeep/inkeepChat';
import { debounce } from '@mui/material';
import ZillizAdv from '@/parts/blogs/zillizAdv';

const PAGE_SIZE = 9;
Expand Down Expand Up @@ -237,7 +236,8 @@ const Blog: React.FC<Props> = props => {
}, [filteredBlogs]);

const generateLinkUrl = (...args: BlogLinkParam[]) => {
const search = new URLSearchParams(router.query as any);
const { [SEARCH_QUERY_KEY]: _, ...queryObject } = filter;
const search = new URLSearchParams(queryObject as any);
args.forEach(({ key, value, shouldRemove }) => {
if (shouldRemove) {
search.delete(key);
Expand All @@ -251,17 +251,43 @@ const Blog: React.FC<Props> = props => {
return `${router.pathname}?${search.toString()}`;
};

const handleSearch = useCallback(
debounce((e: React.FormEvent) => {
const value = (e.target as HTMLInputElement).value.trim();
const url = generateLinkUrl(
{ key: SEARCH_QUERY_KEY, value, shouldRemove: !value },
{ key: PAGINATION_QUERY_KEY, value: 1, shouldRemove: true }
);
router.replace(url, undefined, { scroll: false });
}, 300),
[router]
);
const handleSearch = (e: React.FormEvent) => {
const value = (e.target as HTMLInputElement).value.trim();
const url = generateLinkUrl(
// { key: SEARCH_QUERY_KEY, value, shouldRemove: !value },
{ key: PAGINATION_QUERY_KEY, value: 1, shouldRemove: true }
);
window.history.pushState({}, '', url);
setFilter(f => ({
...f,
[SEARCH_QUERY_KEY]: value,
[PAGINATION_QUERY_KEY]: 1,
}));
};

const handleFilter = (tag: BlogTag | 'all') => (e: React.MouseEvent) => {
// reduce list fetch when router change
e.preventDefault();
const url = generateLinkUrl(
{ key: TAG_QUERY_KEY, value: tag, shouldRemove: tag === DEFAULT_TAG },
{ key: PAGINATION_QUERY_KEY, value: 1, shouldRemove: true }
);
window.history.pushState({}, '', url);
setFilter(f => ({ ...f, [TAG_QUERY_KEY]: tag, [PAGINATION_QUERY_KEY]: 1 }));
};

const handlePaging = (page: number) => (e: React.MouseEvent) => {
// reduce list fetch when router change
e.preventDefault();
const url = generateLinkUrl({
key: PAGINATION_QUERY_KEY,
value: page,
shouldRemove: page === 1,
});
window.history.pushState({}, '', url);
setFilter(f => ({ ...f, [PAGINATION_QUERY_KEY]: page }));
scrollToListNav();
};

const renderRecommend = () => {
const { recommend } = blogs;
Expand Down Expand Up @@ -347,16 +373,16 @@ const Blog: React.FC<Props> = props => {

const renderFilterTagItem = (tag: BlogTag | typeof DEFAULT_TAG) => {
const isActive = tag === (filter[TAG_QUERY_KEY] || DEFAULT_TAG);
const url = generateLinkUrl(
{
key: TAG_QUERY_KEY,
value: tag,
shouldRemove: tag === DEFAULT_TAG,
},
{ key: PAGINATION_QUERY_KEY, value: 1, shouldRemove: true }
);
return (
<Link
key={tag}
href={generateLinkUrl({
key: TAG_QUERY_KEY,
value: tag,
shouldRemove: tag === DEFAULT_TAG,
})}
scroll={false}
>
<Link key={tag} href={url} onClick={handleFilter(tag)} scroll={false}>
<div
className={clsx(styles['filter-tag'], isActive && styles['active'])}
key={tag}
Expand Down Expand Up @@ -420,7 +446,7 @@ const Blog: React.FC<Props> = props => {
<PaginationItem>
<PaginationPrevious
scroll={false}
onClick={scrollToListNav}
onClick={handlePaging(currentPage - 1)}
href={generateLinkUrl({
key: PAGINATION_QUERY_KEY,
value: currentPage - 1,
Expand All @@ -440,7 +466,7 @@ const Blog: React.FC<Props> = props => {
) : (
<PaginationLink
scroll={false}
onClick={scrollToListNav}
onClick={handlePaging(v as number)}
href={generateLinkUrl({
key: PAGINATION_QUERY_KEY,
value: v,
Expand All @@ -460,7 +486,7 @@ const Blog: React.FC<Props> = props => {
<PaginationItem>
<PaginationNext
scroll={false}
onClick={scrollToListNav}
onClick={handlePaging(currentPage + 1)}
href={generateLinkUrl({
key: PAGINATION_QUERY_KEY,
value: currentPage + 1,
Expand Down
2 changes: 1 addition & 1 deletion src/utils/apiReference.ts
Original file line number Diff line number Diff line change
Expand Up @@ -188,7 +188,7 @@ const API_REFERENCE_CONFIG = {
},
[ApiReferenceLanguageEnum.Restful]: {
name: ApiReferenceLabelEnum.Restful,
path: `${BASE_DOC_DIR}/API_Reference/${ApiReferenceLanguageEnum.Restful}`,
path: `${BASE_DOC_DIR}/API_Reference_MDX/${ApiReferenceLanguageEnum.Restful}`,
minVersion: DOCS_MINIMUM_VERSION,
category: ApiReferenceRouteEnum.Restful,
},
Expand Down

0 comments on commit cf3db62

Please sign in to comment.