import React from 'react'; import ReactDOM from 'react-dom'; import { Link } from 'react-router'; import classNames from 'classnames'; import antd, { Row, Col, Icon, Affix } from '../../../'; import Demo from '../Demo'; import BrowserDemo from '../BrowserDemo'; import * as utils from '../utils'; import demosList from '../../../_site/data/demos-list'; // Extract preview as a component Object.keys(demosList).map((key) => demosList[key]) .forEach((demos) => { demos.forEach((demo) => { demo.preview = demo.preview(React, ReactDOM, antd, BrowserDemo); }); }); export default class ComponentDoc extends React.Component { constructor(props) { super(props); this.state = { expandAll: false, }; } handleExpandToggle() { this.setState({ expandAll: !this.state.expandAll, }); } render() { const { doc, location } = this.props; const { description, meta } = doc; const demos = demosList[meta.fileName] || []; const expand = this.state.expandAll; const isSingleCol = meta.cols === '1'; const leftChildren = []; const rightChildren = []; demos.sort((a, b) => { return parseInt(a.meta.order, 10) - parseInt(b.meta.order, 10); }).forEach((demoData, index) => { if (index % 2 === 0 || isSingleCol) { leftChildren.push( ); } else { rightChildren.push( ); } }); const expandTriggerClass = classNames({ 'code-box-expand-trigger': true, 'code-box-expand-trigger-active': expand, }); const jumper = demos.map((demo) => { return (
  • { demo.meta.chinese || demo.meta.english }
  • ); }); return (
      { jumper }

    {meta.chinese || meta.english}

    { description.map(utils.objectToComponent.bind(null, location.pathname)) }

    代码演示

    { leftChildren } { isSingleCol ? null : { rightChildren } }
    { (doc.api || []).map(utils.objectToComponent.bind(null, location.pathname)) }
    ); } }