mirror of
https://gitee.com/baidu/amis.git
synced 2024-11-30 02:58:05 +08:00
636 lines
16 KiB
TypeScript
636 lines
16 KiB
TypeScript
import React from 'react';
|
|
import {Switch} from 'react-router-dom';
|
|
import {navigations2route} from './App';
|
|
import makeMarkdownRenderer from './MdRenderer';
|
|
function wrapDoc(doc: any) {
|
|
return {
|
|
default: makeMarkdownRenderer(doc)
|
|
};
|
|
}
|
|
|
|
export const cssDocs = [
|
|
{
|
|
label: '开始',
|
|
children: [
|
|
{
|
|
label: '快速开始',
|
|
path: '/zh-CN/style/index',
|
|
component: React.lazy(() =>
|
|
import('../../docs/zh-CN/style/index.md').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'CSS 变量',
|
|
path: '/zh-CN/style/css-vars',
|
|
component: React.lazy(() =>
|
|
import('../../docs/zh-CN/style/css-vars.md').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: '辅助类 - 响应式设计',
|
|
path: '/zh-CN/style/responsive-design',
|
|
component: React.lazy(() =>
|
|
import('../../docs/zh-CN/style/responsive-design.md').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: '辅助类 - 状态样式',
|
|
path: '/zh-CN/style/state',
|
|
component: React.lazy(() =>
|
|
import('../../docs/zh-CN/style/state.md').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
// prefix: ({classnames: cx}) => <li className={cx('AsideNav-divider')} />,
|
|
label: 'Layout',
|
|
children: [
|
|
{
|
|
label: 'Box Sizing',
|
|
path: '/zh-CN/style/layout/box-sizing',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_box-sizing.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Display',
|
|
path: '/zh-CN/style/layout/display',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_display.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Floats',
|
|
path: '/zh-CN/style/layout/floats',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_float.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Clear',
|
|
path: '/zh-CN/style/layout/clear',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_clear.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Overflow',
|
|
path: '/zh-CN/style/layout/overflow',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_overflow.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Position',
|
|
path: '/zh-CN/style/layout/position',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_position.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Top / Right / Bottom / Left',
|
|
path: '/zh-CN/style/layout/top-right-bottom-left',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_top-right-bottom-left.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Visibility',
|
|
path: '/zh-CN/style/layout/visibility',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_visibility.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Z-Index',
|
|
path: '/zh-CN/style/layout/z-index',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/layout/_z-index.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Flexbox',
|
|
children: [
|
|
{
|
|
label: 'Flex Direction',
|
|
path: '/zh-CN/style/flex/direction',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_direction.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Flex Wrap',
|
|
path: '/zh-CN/style/flex/wrap',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_wrap.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Flex',
|
|
path: '/zh-CN/style/flex/flex',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_flex.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Flex Grow',
|
|
path: '/zh-CN/style/flex/grow',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_grow.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Flex Shrink',
|
|
path: '/zh-CN/style/flex/shrink',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_shrink.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Flex Order',
|
|
path: '/zh-CN/style/flex/order',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/flex/_order.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Grid',
|
|
children: [
|
|
{
|
|
label: 'Grid Template Columns',
|
|
path: '/zh-CN/style/grid/columns',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_columns.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Column Start / End',
|
|
path: '/zh-CN/style/grid/column-start-end',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_column-start-end.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Template Rows',
|
|
path: '/zh-CN/style/grid/rows',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_rows.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Row Start / End',
|
|
path: '/zh-CN/style/grid/row-start-end',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_row-start-end.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Auto Flow',
|
|
path: '/zh-CN/style/grid/auto-flow',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_auto-flow.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Auto Columns',
|
|
path: '/zh-CN/style/grid/auto-columns',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_auto-columns.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Grid Auto Rows',
|
|
path: '/zh-CN/style/grid/auto-rows',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_auto-rows.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Gap',
|
|
path: '/zh-CN/style/grid/gap',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/grid/_gap.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
{
|
|
label: 'Box Alignment',
|
|
children: [
|
|
{
|
|
label: 'Justify Content',
|
|
path: '/zh-CN/style/box-alignment/justify-content',
|
|
component: React.lazy(() =>
|
|
import(
|
|
'amis-ui/scss/helper/box-alignment/_justify-content.scss'
|
|
).then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Justify Items',
|
|
path: '/zh-CN/style/box-alignment/justify-items',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_justify-items.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Justify Self',
|
|
path: '/zh-CN/style/box-alignment/justify-self',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_justify-self.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Align Content',
|
|
path: '/zh-CN/style/box-alignment/align-content',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_align-content.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Align Items',
|
|
path: '/zh-CN/style/box-alignment/align-items',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_align-items.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Align Self',
|
|
path: '/zh-CN/style/box-alignment/align-self',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_align-self.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Place Content',
|
|
path: '/zh-CN/style/box-alignment/place-content',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_place-content.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Place Items',
|
|
path: '/zh-CN/style/box-alignment/place-items',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_place-items.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Place Self',
|
|
path: '/zh-CN/style/box-alignment/place-self',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/box-alignment/_place-self.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Spacing',
|
|
children: [
|
|
{
|
|
label: 'Padding',
|
|
path: '/zh-CN/style/spacing/padding',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/spacing/_padding.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Margin',
|
|
path: '/zh-CN/style/spacing/margin',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/spacing/_margin.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Space Between',
|
|
path: '/zh-CN/style/spacing/space-between',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/spacing/_space-between.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Sizing',
|
|
children: [
|
|
{
|
|
label: 'Width',
|
|
path: '/zh-CN/style/sizing/width',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/sizing/_width.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
{
|
|
label: 'Height',
|
|
path: '/zh-CN/style/sizing/height',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/sizing/_height.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Typography',
|
|
children: [
|
|
{
|
|
label: 'Font Family',
|
|
path: '/zh-CN/style/typography/font-family',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_font-family.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Font Size',
|
|
path: '/zh-CN/style/typography/font-size',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_font-size.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Font style',
|
|
path: '/zh-CN/style/typography/font-style',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_font-style.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Font Weight',
|
|
path: '/zh-CN/style/typography/font-weight',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_font-weight.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Letter Spacing',
|
|
path: '/zh-CN/style/typography/letter-spacing',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_letter-spacing.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Line Height',
|
|
path: '/zh-CN/style/typography/line-height',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_line-height.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'List Style Type',
|
|
path: '/zh-CN/style/typography/list-style-type',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_list-style-type.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Text Alignment',
|
|
path: '/zh-CN/style/typography/text-align',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_text-align.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Text Color',
|
|
path: '/zh-CN/style/typography/text-color',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_text-color.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Text Decoration',
|
|
path: '/zh-CN/style/typography/text-decoration',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_text-decoration.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Text Transform',
|
|
path: '/zh-CN/style/typography/text-transform',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_text-transform.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Vertical Alignment',
|
|
path: '/zh-CN/style/typography/vertical-align',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_vertical-align.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Whitespace',
|
|
path: '/zh-CN/style/typography/whitespace',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_whitespace.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Word Break',
|
|
path: '/zh-CN/style/typography/word-break',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/typography/_word-break.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Backgrounds',
|
|
children: [
|
|
{
|
|
label: 'Background Color',
|
|
path: '/zh-CN/style/background/background-color',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/background/_background-color.scss').then(
|
|
wrapDoc
|
|
)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'BORDERS',
|
|
children: [
|
|
{
|
|
label: 'Border Radius',
|
|
path: '/zh-CN/style/border/border-radius',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/border/_border-radius.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Border Width',
|
|
path: '/zh-CN/style/border/border-width',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/border/_border-width.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Border Color',
|
|
path: '/zh-CN/style/border/border-color',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/border/_border-color.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Border Style',
|
|
path: '/zh-CN/style/border/border-style',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/border/_border-style.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
},
|
|
|
|
{
|
|
label: 'Effect',
|
|
children: [
|
|
{
|
|
label: 'Box Shadow',
|
|
path: '/zh-CN/style/effect/box-shadow',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/effect/_box-shadow.scss').then(wrapDoc)
|
|
)
|
|
},
|
|
|
|
{
|
|
label: 'Opacity',
|
|
path: '/zh-CN/style/effect/opacity',
|
|
component: React.lazy(() =>
|
|
import('amis-ui/scss/helper/effect/_opacity.scss').then(wrapDoc)
|
|
)
|
|
}
|
|
]
|
|
}
|
|
];
|
|
|
|
export default class CSSDocs extends React.PureComponent<any> {
|
|
componentDidMount() {
|
|
this.props.setNavigations(cssDocs);
|
|
}
|
|
|
|
componentDidUpdate() {
|
|
this.props.setNavigations(cssDocs, false);
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<Switch>
|
|
{navigations2route(cssDocs, {
|
|
theme: this.props.theme,
|
|
classPrefix: this.props.classPrefix,
|
|
locale: this.props.locale,
|
|
viewMode: this.props.viewMode,
|
|
offScreen: this.props.offScreen
|
|
})}
|
|
{/* {React.cloneElement(this.props.children as any, {
|
|
...(this.props.children as any).props,
|
|
theme: this.props.theme,
|
|
classPrefix: this.props.classPrefix,
|
|
locale: this.props.locale,
|
|
viewMode: this.props.viewMode,
|
|
offScreen: this.props.offScreen
|
|
})} */}
|
|
</Switch>
|
|
);
|
|
}
|
|
}
|