mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-27 20:49:53 +08:00
afedb4127f
* patch route * use data for promise * rename Article file * Article in TS * clean up * use collect * adjust css * card it * listing * res * hiring * add footer * english it * rm others * fix lint * fix navigation * add dropdown button * Header with TS * split input & logo * navigation out * use flex * flex everything * stretch * hide search when narrow * init category * global rules * more cat * pages * level 2 width * level 3 * level 4 * skip before ready * clean up * unqiue shadow variable * update eslintignore * update ignore * fix ssr * fix location param * replace images * shake more * fix top of navigation * remove home * reorder nav & adjust padding style * narrow res style * Update research-form-page.zh-CN.md (#21426) Co-authored-by: Golevka <huangsamfisher@163.com> * rm skip * narrow merge in * reset p style * update svg * fix lint * update ignore * update lint ignore * Update research-result-page.zh-CN.md (#21432) Co-authored-by: mihaideyu <zxy1010414746@163.com> * Update research-result-page.zh-CN.md * Update research-workbench.zh-CN.md (#21438) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-workbench.zh-CN.md * Update research-list-page.zh-CN.md (#21441) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-list-page.zh-CN.md * padding use 40px * add responsive of ref * fix p margin * Update research-workbench.zh-CN.md * Update buttons.md (#21456) Co-authored-by: yingxirz <inseeing@gmail.com> * Update resources.en-US.md (#21457) * Update research-navigation.zh-CN.md (#21453) * Update research-navigation.zh-CN.md * Update research-navigation.zh-CN.md * Update research-navigation.zh-CN.md * Update research-empty.zh-CN.md (#21451) * Update research-empty.zh-CN.md * Update research-empty.zh-CN.md * Update research-empty.zh-CN.md * Update research-empty.zh-CN.md Co-authored-by: 二货机器人 <smith3816@gmail.com> * Update research-exception-page.zh-CN.md (#21452) * Update research-exception-page.zh-CN.md * Update research-exception-page.zh-CN.md * Update research-message-and-feedback.zh-CN.md (#21463) * Update research-message-and-feedback.zh-CN.md (#21467) * Update research-message-and-feedback.zh-CN.md * Update research-message-and-feedback.zh-CN.md * Update research-message-and-feedback.zh-CN.md * Update research-message-and-feedback.zh-CN.md * replace background * fix lines margin * home padding * patch minTilda doc * Update resources.zh-CN.md (#21503) * clean up * Update research-workbench.zh-CN.md (#21512) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-overview.zh-CN.md (#21513) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-result-page.zh-CN.md (#21514) Co-authored-by: mihaideyu <zxy1010414746@163.com> * Update research-list-page.zh-CN.md (#21515) Co-authored-by: yingxirz <inseeing@gmail.com> * fix doc * Update research-message-and-feedback.zh-CN.md (#21516) * adjust home nav width * Update research-message-and-feedback.zh-CN.md (#21535) * Update research-form-page.zh-CN.md (#21554) Co-authored-by: Golevka <huangsamfisher@163.com> * patch file * clean up * update shadow.zh-CN update shadow.zh-CN * add shadow table * Update visual.zh-CN.md (#21577) Co-authored-by: shuwenliu0116 <33922479+shuwenliu0116@users.noreply.github.com> * Update docs/spec/shadow.zh-CN.md Co-Authored-By: 偏右 <afc163@gmail.com> * Update docs/spec/shadow.zh-CN.md Co-Authored-By: 偏右 <afc163@gmail.com> * Update docs/spec/shadow.zh-CN.md Co-Authored-By: 偏右 <afc163@gmail.com> * Update docs/spec/shadow.zh-CN.md Co-Authored-By: 偏右 <afc163@gmail.com> * Update docs/spec/shadow.zh-CN.md Co-Authored-By: 偏右 <afc163@gmail.com> * patch docs * fix doc * rm page suffix * fix style * mobile it * Update resources.en-US.md (#21561) * chart res * add qr code * adjust qr * Update visual.zh-CN.md (#21603) Co-authored-by: shuwenliu0116 <33922479+shuwenliu0116@users.noreply.github.com> * fix site qr * mobile height of it * book update * 3.x site link * isMobile is new cnotext * Update research-form.zh-CN.md (#21604) Co-authored-by: Golevka <huangsamfisher@163.com> * adjust form doc * mobile use link * adjust order * flush * fix ts * Update research-navigation.zh-CN.md (#21606) * Update research-navigation.zh-CN.md (#21609) * rm useless lines * add mobile icon * Update research-exception.zh-CN.md (#21612) * Update research-empty.zh-CN.md (#21610) * Update research-workbench.zh-CN.md * Update visual.zh-CN.md * adjust mobile icon * Update research-message-and-feedback.zh-CN.md (#21613) * Update research-list.zh-CN.md (#21617) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-workbench.zh-CN.md (#21618) Co-authored-by: yingxirz <inseeing@gmail.com> * Update visual.zh-CN.md (#21619) Co-authored-by: shuwenliu0116 <33922479+shuwenliu0116@users.noreply.github.com> * Update research-result.zh-CN.md (#21620) Co-authored-by: mihaideyu <zxy1010414746@163.com> * Update research-form.zh-CN.md (#21615) * Update research-message-and-feedback.zh-CN.md (#21616) * Update research-list.zh-CN.md (#21621) Co-authored-by: yingxirz <inseeing@gmail.com> * Update research-result.zh-CN.md (#21624) Co-authored-by: mihaideyu <zxy1010414746@163.com> * update ref color * update zip file * fix mobile icon * rm skip dark * fix cat * update zip link * update zip link Co-authored-by: Golevka <huangsamfisher@163.com> Co-authored-by: mihaideyu <zxy1010414746@163.com> Co-authored-by: yingxirz <inseeing@gmail.com> Co-authored-by: 偏右 <afc163@gmail.com> Co-authored-by: myeunhyuk <39618466+myeunhyuk@users.noreply.github.com> Co-authored-by: minTilda <31951290+minTilda@users.noreply.github.com> Co-authored-by: ziyuan-174774 <61226089+ziyuan-174774@users.noreply.github.com> Co-authored-by: 竹尔 <54707870+AntDesigners@users.noreply.github.com> Co-authored-by: shuwenliu0116 <33922479+shuwenliu0116@users.noreply.github.com>
153 lines
3.8 KiB
TypeScript
153 lines
3.8 KiB
TypeScript
import * as React from 'react';
|
|
import collect from 'bisheng/collect';
|
|
import { useIntl } from 'react-intl';
|
|
import Article from '../Content/Article';
|
|
import Footer from '../Layout/Footer';
|
|
import * as utils from '../utils';
|
|
import './index.less';
|
|
import AffixTabs from './AffixTabs';
|
|
|
|
interface PageData {
|
|
meta: {
|
|
order?: number;
|
|
title: string;
|
|
filename: string;
|
|
};
|
|
content: ContentUnit[];
|
|
toc: any[];
|
|
}
|
|
|
|
interface PagesData {
|
|
'docs/resources': {
|
|
docs: {
|
|
resources: {
|
|
[locale: string]: () => Promise<PageData>;
|
|
};
|
|
};
|
|
};
|
|
}
|
|
|
|
interface ResourcesProps {
|
|
location: {
|
|
pathname: string;
|
|
};
|
|
data: PagesData;
|
|
localizedPageData: PageData;
|
|
utils: {
|
|
toReactComponent: (content: any[]) => React.ReactElement;
|
|
get: (data: PagesData, path: string[]) => any;
|
|
};
|
|
}
|
|
|
|
type ContentUnit = string | Record<string, any> | ContentUnit[];
|
|
|
|
function getUnitString(unit: ContentUnit[]): string {
|
|
if (!unit) return '';
|
|
|
|
const last = unit[unit.length - 1];
|
|
return Array.isArray(last) ? getUnitString(last) : (last as string);
|
|
}
|
|
|
|
function toList([, ...items]: ContentUnit[]): ContentUnit[] {
|
|
return [
|
|
'div',
|
|
{ className: 'ant-row resource-cards', style: 'margin: -12px -12px 0 -12px' },
|
|
...items.map(([, title, [, image, description, link]]: any) => {
|
|
let titleStr = getUnitString(title);
|
|
const imageStr = getUnitString(image);
|
|
const descStr = getUnitString(description);
|
|
const linkStr = getUnitString(link);
|
|
|
|
let coverColor: string | null = null;
|
|
const titleMatch = titleStr.match(/(.*)(#[\dA-Fa-f]{6})/);
|
|
if (titleMatch) {
|
|
titleStr = titleMatch[1].trim();
|
|
coverColor = titleMatch[2];
|
|
}
|
|
|
|
return [
|
|
'div',
|
|
{
|
|
className: 'ant-col ant-col-xs-24 ant-col-sm-12 ant-col-md-8 ant-col-lg-6 gutter-row',
|
|
style: 'padding: 12px;',
|
|
},
|
|
[
|
|
'a',
|
|
{ className: 'resource-card', target: '_blank', href: linkStr },
|
|
[
|
|
'img',
|
|
{
|
|
className: 'resource-card-image',
|
|
src: imageStr,
|
|
alt: titleStr,
|
|
style: coverColor
|
|
? {
|
|
backgroundColor: coverColor,
|
|
objectFit: 'contain',
|
|
}
|
|
: {},
|
|
},
|
|
],
|
|
['p', { className: 'resource-card-title' }, titleStr],
|
|
['p', { className: 'resource-card-description' }, descStr],
|
|
],
|
|
];
|
|
}),
|
|
];
|
|
}
|
|
|
|
function injectCards(content: ContentUnit[]): ContentUnit[] {
|
|
const newContent: ContentUnit[] = [];
|
|
|
|
for (let i = 0; i < content.length; i += 1) {
|
|
const unit = content[i];
|
|
|
|
if (Array.isArray(unit) && (unit[1] as any).class === 'next-block-use-cards') {
|
|
newContent.push(toList(content[i + 1] as any));
|
|
|
|
i += 1;
|
|
} else {
|
|
newContent.push(unit);
|
|
}
|
|
}
|
|
|
|
return newContent;
|
|
}
|
|
|
|
const Resources = (props: ResourcesProps) => {
|
|
const { localizedPageData } = props;
|
|
const { locale } = useIntl();
|
|
|
|
const content = React.useMemo(() => injectCards(localizedPageData.content), [
|
|
localizedPageData.content,
|
|
]);
|
|
|
|
return (
|
|
<div id="resources-page">
|
|
<AffixTabs />
|
|
|
|
<Article
|
|
{...props}
|
|
content={{
|
|
...localizedPageData,
|
|
content,
|
|
}}
|
|
intl={{ locale }}
|
|
titleRegionClassName="title-region"
|
|
/>
|
|
|
|
<Footer />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default collect(async (nextProps: ResourcesProps) => {
|
|
const { pathname } = nextProps.location;
|
|
const pageDataPath = pathname.replace('-cn', '').split('/');
|
|
const pageData = nextProps.utils.get(nextProps.data, pageDataPath);
|
|
|
|
const locale = utils.isZhCN(pathname) ? 'zh-CN' : 'en-US';
|
|
const pageDataPromise = pageData[locale]();
|
|
return { localizedPageData: await pageDataPromise };
|
|
})(Resources);
|