Progress.js 4.24 KB
import React, { Component } from 'react';
import { Row, Col, Breadcrumb, BreadcrumbItem, Progress, TabContent, TabPane, Nav, NavItem, NavLink } from 'reactstrap';
import SyntaxHighlighter from 'react-syntax-highlighter/dist/prism';
import classnames from 'classnames';
import { tomorrow } from 'react-syntax-highlighter/dist/styles/prism';

class Buttons extends Component {
  state = {
    defaultProgressTabId: '1',
  };

  changeTab(field, id) {
    this.setState({
      [field]: id,
    })
  }

  render() {
    return (
      <Row>
        <Col md={10}>
          <Breadcrumb>
            <BreadcrumbItem>YOU ARE HERE</BreadcrumbItem>
            <BreadcrumbItem>Documentation</BreadcrumbItem>
            <BreadcrumbItem>Components</BreadcrumbItem>
            <BreadcrumbItem active>Progress</BreadcrumbItem>
          </Breadcrumb>
        </Col>

        <Col lg={9}>
          <h2>Progress</h2>
          <p className="mb-lg">Cards support a wide variety of content, including images, text, list groups, links, and more. Below are examples of whats supported.</p>
          <SyntaxHighlighter language='javascript' style={tomorrow}>
            {"import { Progress } from 'reactstrap';"}
          </SyntaxHighlighter>
          <Nav tabs className="bg-transparent mt">
            <NavItem>
              <NavLink
                className={classnames({ active: this.state.defaultProgressTabId === '1' })}
                onClick={() => {
                  this.changeTab('defaultProgressTabId', '1');
                }}
              >
                Example
              </NavLink>
            </NavItem>
            <NavItem>
              <NavLink
                className={classnames({ active: this.state.defaultProgressTabId === '2' })}
                onClick={() => {
                  this.changeTab('defaultProgressTabId', '2');
                }}
              >
                Code
              </NavLink>
            </NavItem>
          </Nav>
          <TabContent className="mb-xlg" activeTab={this.state.defaultProgressTabId}>
            <TabPane tabId="1">
              <div className="text-center">0%</div>
              <Progress />
              <div className="text-center">25%</div>
              <Progress value="25" />
              <div className="text-center">50%</div>
              <Progress value={50} />
              <div className="text-center">75%</div>
              <Progress striped value={75} />
              <div className="text-center">100%</div>
              <Progress animated value="100" />
              <div className="text-center">Multiple bars</div>
              <Progress multi>
                <Progress bar value="15" />
                <Progress bar color="success" value="30" />
                <Progress bar color="info" value="25" />
                <Progress bar color="warning" value="20" />
                <Progress bar color="danger" value="5" />
              </Progress>
            </TabPane>
            <TabPane tabId="2">
              <SyntaxHighlighter language='javascript' style={tomorrow}>{'<div className="text-center">0%</div>\n' +
              '<Progress />\n' +
              '<div className="text-center">25%</div>\n' +
              '<Progress value="25" />\n' +
              '<div className="text-center">50%</div>\n' +
              '<Progress value={50} />\n' +
              '<div className="text-center">75%</div>\n' +
              '<Progress striped value={75} />\n' +
              '<div className="text-center">100%</div>\n' +
              '<Progress animated value="100" />\n' +
              '<div className="text-center">Multiple bars</div>\n' +
              '<Progress multi>\n' +
              '  <Progress bar value="15" />\n' +
              '  <Progress bar color="success" value="30" />\n' +
              '  <Progress bar color="info" value="25" />\n' +
              '  <Progress bar color="warning" value="20" />\n' +
              '  <Progress bar color="danger" value="5" />\n' +
              '</Progress>'}</SyntaxHighlighter>
            </TabPane>
          </TabContent>
          For more examples please refer to <a href="https://reactstrap.github.io/components/progress/" target="_blank" rel="noopener noreferrer">Reactstrap Progress</a>
        </Col>
      </Row>
    );
  }
}

export default Buttons;