| import { PageContainer } from '@ant-design/pro-components'; |
| import { useModel } from '@umijs/max'; |
| import { Card, theme } from 'antd'; |
| import React from 'react'; |
| |
| /** |
| * 每个单独的卡片,为了复用样式抽成了组件 |
| * @param param0 |
| * @returns |
| */ |
| const InfoCard: React.FC<{ |
| title: string; |
| index: number; |
| desc: string; |
| href: string; |
| }> = ({ title, href, index, desc }) => { |
| const { useToken } = theme; |
| |
| const { token } = useToken(); |
| |
| return ( |
| <div |
| style={{ |
| backgroundColor: token.colorBgContainer, |
| boxShadow: token.boxShadow, |
| borderRadius: '8px', |
| fontSize: '14px', |
| color: token.colorTextSecondary, |
| lineHeight: '22px', |
| padding: '16px 19px', |
| minWidth: '220px', |
| flex: 1, |
| }} |
| > |
| <div |
| style={{ |
| display: 'flex', |
| gap: '4px', |
| alignItems: 'center', |
| }} |
| > |
| <div |
| style={{ |
| width: 48, |
| height: 48, |
| lineHeight: '22px', |
| backgroundSize: '100%', |
| textAlign: 'center', |
| padding: '8px 16px 16px 12px', |
| color: '#FFF', |
| fontWeight: 'bold', |
| backgroundImage: |
| "url('https://gw.alipayobjects.com/zos/bmw-prod/daaf8d50-8e6d-4251-905d-676a24ddfa12.svg')", |
| }} |
| > |
| {index} |
| </div> |
| <div |
| style={{ |
| fontSize: '16px', |
| color: token.colorText, |
| paddingBottom: 8, |
| }} |
| > |
| {title} |
| </div> |
| </div> |
| <div |
| style={{ |
| fontSize: '14px', |
| color: token.colorTextSecondary, |
| textAlign: 'justify', |
| lineHeight: '22px', |
| marginBottom: 8, |
| }} |
| > |
| {desc} |
| </div> |
| <a href={href} target="_blank" rel="noreferrer"> |
| 了解更多 {'>'} |
| </a> |
| </div> |
| ); |
| }; |
| |
| const Welcome: React.FC = () => { |
| const { token } = theme.useToken(); |
| const { initialState } = useModel('@@initialState'); |
| return ( |
| <PageContainer> |
| <Card |
| style={{ |
| borderRadius: 8, |
| }} |
| bodyStyle={{ |
| backgroundImage: |
| initialState?.settings?.navTheme === 'realDark' |
| ? 'background-image: linear-gradient(75deg, #1A1B1F 0%, #191C1F 100%)' |
| : 'background-image: linear-gradient(75deg, #FBFDFF 0%, #F5F7FF 100%)', |
| }} |
| > |
| <div |
| style={{ |
| backgroundPosition: '100% -30%', |
| backgroundRepeat: 'no-repeat', |
| backgroundSize: '274px auto', |
| backgroundImage: |
| "url('https://gw.alipayobjects.com/mdn/rms_a9745b/afts/img/A*BuFmQqsB2iAAAAAAAAAAAAAAARQnAQ')", |
| }} |
| > |
| <div |
| style={{ |
| fontSize: '20px', |
| color: token.colorTextHeading, |
| }} |
| > |
| 欢迎使用 Ant Design Pro |
| </div> |
| <p |
| style={{ |
| fontSize: '14px', |
| color: token.colorTextSecondary, |
| lineHeight: '22px', |
| marginTop: 16, |
| marginBottom: 32, |
| width: '65%', |
| }} |
| > |
| Ant Design Pro 是一个整合了 umi,Ant Design 和 ProComponents |
| 的脚手架方案。致力于在设计规范和基础组件的基础上,继续向上构建,提炼出典型模板/业务组件/配套设计资源,进一步提升企业级中后台产品设计研发过程中的『用户』和『设计者』的体验。 |
| </p> |
| <div |
| style={{ |
| display: 'flex', |
| flexWrap: 'wrap', |
| gap: 16, |
| }} |
| > |
| <InfoCard |
| index={1} |
| href="https://umijs.org/docs/introduce/introduce" |
| title="了解 umi" |
| desc="umi 是一个可扩展的企业级前端应用框架,umi 以路由为基础的,同时支持配置式路由和约定式路由,保证路由的功能完备,并以此进行功能扩展。" |
| /> |
| <InfoCard |
| index={2} |
| title="了解 ant design" |
| href="https://ant.design" |
| desc="antd 是基于 Ant Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。" |
| /> |
| <InfoCard |
| index={3} |
| title="了解 Pro Components" |
| href="https://procomponents.ant.design" |
| desc="ProComponents 是一个基于 Ant Design 做了更高抽象的模板组件,以 一个组件就是一个页面为开发理念,为中后台开发带来更好的体验。" |
| /> |
| </div> |
| </div> |
| </Card> |
| </PageContainer> |
| ); |
| }; |
| |
| export default Welcome; |