Skip to content

Latest commit

 

History

History
158 lines (150 loc) · 5.72 KB

File metadata and controls

158 lines (150 loc) · 5.72 KB
id Banner
section components

import { Fragment } from 'react'; import { css } from '@patternfly/react-styles'; import display from '@patternfly/react-styles/css/utilities/Display/display'; import { DashboardWrapper } from '@patternfly/react-core/dist/js/demos/DashboardWrapper';

Demos

Basic sticky banner

import { Fragment } from 'react';
import { Banner, Card, CardBody, Flex, Gallery, GalleryItem, PageSection, Content } from '@patternfly/react-core';

import { DashboardWrapper } from '@patternfly/react-core/dist/js/demos/DashboardWrapper';
import { css } from '@patternfly/react-styles';
import display from '@patternfly/react-styles/css/utilities/Display/display';

class BannerDemo extends React.Component {
  render() {
    const banner = (
      <Banner isSticky>
        <Flex
          justifyContent={{ default: 'justifyContentCenter', lg: 'justifyContentSpaceBetween' }}
          flexWrap={{ default: 'nowrap' }}
        >
          <div className={css(display.displayNone, display.displayBlockOnLg)}>Localhost</div>
          <div className={css(display.displayNone, display.displayBlockOnLg)}>
            This message is sticky to the top of the page.
          </div>
          <div className={css(display.displayNoneOnLg)}>Drop some text on mobile, truncate if needed.</div>
          <div className={css(display.displayNone, display.displayBlockOnLg)}>Ned Username</div>
        </Flex>
      </Banner>
    );
    return (
      <Fragment>
        <DashboardWrapper banner={banner} breadcrumb={null}>
          <PageSection aria-labelledby="main-title">
            <Content>
              <h1 id="main-title">Main title</h1>
              <p>
                Body text should be Red Hat Text at 1rem(16px). It should have leading of 1.5rem(24px) because <br />
                of it’s relative line height of 1.5.
              </p>
            </Content>
          </PageSection>
          <PageSection aria-label='Cards gallery'>
            <Gallery hasGutter>
              {Array.from({ length: 30 }).map((_value, index) => (
                <GalleryItem key={index}>
                  <Card key={index}>
                    <CardBody>This is a card</CardBody>
                  </Card>
                </GalleryItem>
              ))}
            </Gallery>
          </PageSection>
        </DashboardWrapper>
      </Fragment>
    );
  }
}

Top and bottom banner

import { Fragment } from 'react';
import {
  Banner,
  Card,
  CardBody,
  Flex,
  FlexItem,
  Gallery,
  GalleryItem,
  PageSection,
  Content
} from '@patternfly/react-core';
import { DashboardWrapper } from '@patternfly/react-core/dist/js/demos/DashboardWrapper';
import { css } from '@patternfly/react-styles';
import display from '@patternfly/react-styles/css/utilities/Display/display';

class BannerDemo extends React.Component {
  render() {
    return (
      <Fragment>
        <Flex
          direction={{ default: 'column' }}
          flexWrap={{ default: 'nowrap' }}
          spaceItems={{ default: 'spaceItemsNone' }}
          style={{ height: '100%' }}
        >
          <FlexItem>
            <Banner isSticky>
              <Flex
                justifyContent={{ default: 'justifyContentCenter', lg: 'justifyContentSpaceBetween' }}
                flexWrap={{ default: 'nowrap' }}
              >
                <div className={css(display.displayNone, display.displayBlockOnLg)}>Localhost</div>
                <div className={css(display.displayNone, display.displayBlockOnLg)}>
                  This message is sticky to the top of the page.
                </div>
                <div className={css(display.displayNoneOnLg)}>Drop some text on mobile, truncate if needed.</div>
                <div className={css(display.displayNone, display.displayBlockOnLg)}>Ned Username</div>
              </Flex>
            </Banner>
          </FlexItem>
          <FlexItem grow={{ default: 'grow' }} style={{ minHeight: 0 }}>
            <DashboardWrapper breadcrumb={null}>
              <PageSection aria-labelledby="main-title">
                <Content>
                  <h1 id='main-title'>Main title</h1>
                  <p>
                    Body text should be Red Hat Text at 1rem(16px). It should have leading of 1.5rem(24px) because{' '}
                    <br />
                    of it’s relative line height of 1.5.
                  </p>
                </Content>
              </PageSection>
              <PageSection aria-label='Cards gallery'>
                <Gallery hasGutter>
                  {Array.from({ length: 30 }).map((_value, index) => (
                    <GalleryItem key={index}>
                      <Card key={index}>
                        <CardBody>This is a card</CardBody>
                      </Card>
                    </GalleryItem>
                  ))}
                </Gallery>
              </PageSection>
            </DashboardWrapper>
          </FlexItem>
          <FlexItem>
            <Banner isSticky>
              <Flex
                justifyContent={{ default: 'justifyContentCenter', lg: 'justifyContentSpaceBetween' }}
                flexWrap={{ default: 'nowrap' }}
              >
                <div className={css(display.displayNone, display.displayBlockOnLg)}>Localhost</div>
                <div className={css(display.displayNone, display.displayBlockOnLg)}>
                  This message is sticky to the bottom of the page.
                </div>
                <div className={css(display.displayNoneOnLg)}>Drop some text on mobile, truncate if needed.</div>
                <div className={css(display.displayNone, display.displayBlockOnLg)}>Ned Username</div>
              </Flex>
            </Banner>
          </FlexItem>
        </Flex>
      </Fragment>
    );
  }
}