npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

react-atomic-comp

v0.5.6

Published

React atomic components for ready to use in your projects

Downloads

37

Readme

React Atomic Components

This project was bootstrapped with Create React App.

Available Scripts

In the project directory, you can run:

npm run start

npm start is a shortcut for npm run start. npm run is used to run scripts that you define in the scripts object of your package.json, if there is no start key in the scripts object, it will default to node server.js. npm start is the command used to run the project

npm run storybook

Runs the storybook in the development mode. Open http://localhost:9002/ to view it in the browser.

The page will reload if you make edits. You will also see any lint errors in the console.44

npm test

Launches the test runner in the interactive watch mode. See the section about running tests for more information.

npm run build

Builds the app for production to the build folder. It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes. Your app is ready to be deployed!

Available Themes

Default Theme

Default theme defines different theme palette as:primary,secondary,danger,alert,success, white. It has various grayscales defined and fonts available as:

  • primary: Helvetica Neue, Helvetica,Roboto,sans-serif;
  • pre: Consolas, Liberation Mono, Menlo, Courier,monospace;
  • quote: Georgia, serif .

Generic Theme

Generic theme defined same as default one, the only difference relies in their theme sizes which can be adjusted accordingly to the user requirement.

Overview of the components:

Component

Atoms

Block

Block is useful as it provide the block to add on the simple text.It further contain types as:default,reverse,palette,palette reverse,palette opaque and palette opaque reverse where palette has propstypes as string and reverse and opaque as bool .

Button

Button: A component that is necessary for fulfilment of different purposes as default, reverse,disabled or a link button.The following paramters are used while making the button:

const { to, href } = props;
if (to) {
  return <StyledLink {...props} />;
}
if (href) {
  return <Anchor {...props} />;
}

return <StyledButton {...props} type={type} />;
};

Button.propTypes = {
disabled: PropTypes.bool,
palette: PropTypes.string,
transparent: PropTypes.bool,
reverse: PropTypes.bool,
height: PropTypes.number,
type: PropTypes.string,
to: PropTypes.string,
href: PropTypes.string
};

Button.defaultProps = {
palette: "primary",
type: "button",
height: 40
}; 

Above code is having a parameter named as StyledLink which is explained as below :

const StyledLink = styled(
({ disabled, transparent, reverse, palette, height, theme, ...props }) => (
  <Link {...props} />
)
)`
${styles}
`;

Also, StyledButton is having the ${styles} included in it.

Label

The label defines a label for a <button>, <input>, <meter>, <output>, <progress>, <select>, or <textarea> etc. The label does not render as anything special for the user. However, it provides a usability improvement for mouse users, because if the user clicks on the text within the label element, it toggles the control.Here, Label uses propTypes as boolean value.

Label.propTypes = {
reverse: PropTypes.bool
};

List

There are two types of List:

1.Unordered

The list items will be marked with bullets (small black circles) by default. The style of the list item marker: 1.disc Sets the list item marker to a bullet (default) 2.circle Sets the list item marker to a circle 3.square Sets the list item marker to a square 4.none The list items will not be marked

2.Ordered

The list items will be marked with numbers by default. The type of the list item marker: 1.type="1" The list items will be numbered with numbers (default) 2.type="A" The list items will be numbered with uppercase letters 3.type="a" The list items will be numbered with lowercase letters 4.type="I" The list items will be numbered with uppercase roman numbers 5.type="i" The list items will be numbered with lowercase roman numbers

Here, List Uses :

  return React.createElement(ordered ? Ol : Ul, props, children);
  };

Here, Ol and Ul are const using the {styles} And props and children are properties.

PreformattedText

In PreformattedText, text is displayed in a fixed-width font (usually Courier), and it preserves both spaces and line breaks.

Spinner

Indicates the loading state of a component or page. Spinners can be used to show the loading state in your projects.Their appearance, alignment, and sizing can be easily customized with our amazing utility classes.

Tooltip

A tooltip is often used to specify extra information about something when the user moves the mouse pointer over an element. To create a tooltip, add the data-toggle="tooltip" attribute to an element.Use the title attribute to specify the text that should be displayed inside the tooltip.

Positioning Tooltips

By default, the tooltip will appear on top of the element.Use the data-placement attribute to set the position of the tooltip on top, bottom, left or the right side of the element.

const Tooltip = styled(
  ({ position, align, reverse, children, theme, ...props }) =>
    React.cloneElement(children, props)
)`
  ${styles}
`;

Tooltip.propTypes = {
  position: PropTypes.oneOf(["top", "right", "bottom", "left"]),
  align: PropTypes.oneOf(["start", "center", "end"]),
  reverse: PropTypes.bool,
  "data-title": PropTypes.string.isRequired,
  children: PropTypes.element.isRequired
};
Tooltip.defaultProps = {
  position: "top",
  align: "center",
  tabIndex: 0
};

Tooltip sets position as top and alignment as center bydefault.

Molecules

CardBox

A card is a bordered box with some padding around its content. It includes options for headers, footers, content, colors, etc. The user can add the header and footer to the respective card if needed by using .card-header class and the .card-footer class. You can also add on a background color to the card, use contextual classes like, (.bg-primary, .bg-success, .bg-info, .bg-warning, .bg-danger, .bg-secondary, bg-dark and .bg-light).

In index.stories.js file we will add the addWithJSX function for displaying the code relevant to component on the jsx screen for that respective component.

storiesOf("CardBox", module)**.addWithJSX**("default", () => <CardBox>Hello Dev</CardBox>);

Also, in the index.js file:

const CardBox = ({ children, ...props }) => (
<CardWapper {...props}>
  <Card {...props}>{children}</Card>
</CardWapper> 
);

CardWapper used as contant having various CSS properties like background-color, width, padding etc for the CardBox as :

  const CardWapper = styled(Card)`
  .card {
    background-color: ${bgColor};
    font-family: ${font("quote")};
    width: ${cardWidth};
    min-height: ${cardMinHeight};
    padding: 25px; 
    margin: auto;
    ${ifProp(
  "responsive",
  css`
        @media screen and (max-width: ${prop("breakpoint")}px) {
          width: 100%;
        }
      `
)}
  }
`;

GridListToggle

Grid / List toggle is a simple plugin which adds a Grid / List toggle button to your product archives allowing users to, toggle between grid / list views of your product.The list view arranges products in a vertical list and pulls in the excerpt to give a more detailed overview.

   <ButtonGroup
        style={this.props.style}
        aria-label={this.props.ariaLabel}
        className={this.props.className}
      >
        <Button
          title="Grid View"
          variant={this.props.variant}
          onClick={() => {
            this.onToggle("grid");
          }}
          active={this.state.selectOption === "grid"}
        >
          <i className="fa fa-th" />
        </Button>
        <Button
          title="List View"
          variant={this.props.variant}
          onClick={() => {
            this.onToggle("list");
          }}
          active={this.state.selectOption === "list"}
        >
          <i className="fa fa-list" />
        </Button>
      </ButtonGroup>

Here, we are using two button one for The Grid view and another one is for TheList view. Whenever the button got active on click, the respective option got selected and displayed. Also, in its index.stories.js file the Alert got displayed on Toggle as shown on below code.

    storiesOf("GridListToggle", module).addWithJSX("default", () => (
    <GridListToggle
      default="list"
      onToggle={data => {
        alert(data);
      }}
    />
  ));

Slider

Slider with custom range is great opportunity and function to use.Create a dynamic range slider to display the current value.Here, we made out default, reverse, disabled, responsive with breakpoints sliders having Square Slider moving. For reference you can follow the below code as well:

     <Wrapper {...props}>
    <Text responsive={responsive} breakpoint={breakpoint}>{min}</Text>
    <Range id={id} min={min} max={max} defaultValue={defaultValue} step={step} {...props} />
    <Text responsive={responsive} breakpoint={breakpoint}>{max}</Text>
  </Wrapper>

StarRating

Rating helps in knowing the feedback from the end user from their experience and thoughts or they are used by reviewers for ranking things.

Table

A Basic Table has only horizontal dividers but here we use the bordered table and also table with heading and footer.We can asily add on the caption to a table. A table simply has a division of rows and columns.

Thumbnail

A thumbnail is a small image that represents a larger image (when clicked on), and is often recognized with a border around it. In the index.js file of the Thumbnail component we use bootstrap class fa fa-expand and set its position as fixed .


  render() {
    return (
      <StyledBlock
        className={this.props.className}
        style={this.props.style}
        {...this.props}
      >
        {this.props.enlarge && (
          <i
            onClick={() => {
              this.props.onEnlarge();
            }}
            className="fa fa-expand"
            aria-hidden="true"
            style={{
              position: "fixed",
              zIndex: "900",
              right: "0",
              cursor: "pointer"
            }}
          />
        )}
        {this.props.children}
      </StyledBlock>
    );
  }

TrayCarouselArrow

The TrayCarousel plugin is a component for cycling through elements and simply behaves like a tray of different images or videos. The feature is quite useful in achieving the beauty of a website. **The Arrow ** here helps ion moving the tray images forward or backward.

TrayCarouselDots

These Dots indicates that on which Tray of Carousel user is currently heading or working.

Organisms

BarChart

The bar chart we are going to create displays a list of rectangles of varying height proportional to the values they represent. The number of bars, their values and labels are all inputs. If the values change the heights will animate from the old to the new value.The chart has many properties that describe how the data is displayed including color, margin and speed like in our snippet code as follows:

  
  componentDidMount() {
    const node = this.node;
    this.myChart = new Chart(node, {
      type: "bar",
      data: this.props.data,
      options: this.props.options
    });
  }
  componentWillUnmount = () => {
    this.myChart = {};
  };

  render() {
    const { ...props } = this.props;
    return (
      <div>
        <canvas style={props.canvasStyle} ref={node => (this.node = node)} />
      </div>
    );
  }

In componentDidMount method, create a new object for chart class whose displaying and execution type will be bar and also we are refering to the current node.

Footer

A footer element typically contains:

  • Authorship information
  • Copyright information
  • Contact information
  • Sitemap
  • Back to top links
  • Related documents like we used footer for the Copyright information as follows:
  const Footer = () => {
    return (
      <NavBarWrapper bg="dark" variant="dark" expand="lg">
        <SubContainer>Copy Rights</SubContainer>
      </NavBarWrapper>
    );
  };

Header

A header element typically contains:

  • One or more heading elements

  • Logo or icon

  • Authorship information

ItemBox

The ItemBox displays the box having item listed in it with serial number and the order number.

    const ItemBox = ({
    palette,
    rating,
    reverse,
    transparent,
    addToCartClick,
    ...props
  }) => {
    return (
      <ItemWrapper onClick={props.itemClick}>
        <ImageWrapper
          {...props}
          style={{ backgroundPosition: "center center" }}
        />

        <TitleWrapper>{props.details.name}</TitleWrapper>
        <CodeWrapper>
          <span
            style={{
              display: "flex",
              flexDirection: "column",
              justifyContent: "center"
            }}
          >
            Serial No. - {props.details.serialNo}
          </span>
          <span
            style={{
              display: "flex",
              flexDirection: "column",
              justifyContent: "center"
            }}
          >
            |
          </span>
          <span
            style={{
              display: "flex",
              flexDirection: "column",
              justifyContent: "center"
            }}
          >
            Order No. - {props.details.orderNo}
          </span>
        </CodeWrapper>
        {rating && (
          <RatingWrapper>
            <StarRating
              editing={false}
              name={rating.name}
              value={rating.value}
              emptyStarColor={rating.emptyStarColor}
              starColor={rating.starColor}
              starCount={rating.starCount}
            />
          </RatingWrapper>
        )}
      </ItemWrapper>
    );
  };
  ItemBox.propTypes = {
    reverse: PropTypes.bool,
    details: PropTypes.object,
    transparent: PropTypes.bool,
    rating: PropTypes.shape({
      value: PropTypes.number.isRequired,
      emptyStarColor: PropTypes.string.isRequired,
      starColor: PropTypes.string.isRequired,
      starCount: PropTypes.number.isRequired,
      name: PropTypes.string.isRequired
    }),
    itemClick: PropTypes.func,
    addToCartClick: PropTypes.func
  };

Here, RatingWrapper is used for the StarRating, and CodeWrapper is helpful is displaying the serialno and orderno.

ItemList

The ItemList is list of the ItemBox having multiple serial number and the order number respective of the ItemBox.

Login

The login page should be the first page that users see in the modified application. It should provide two text fields - one for entering a login name i.e. USERNAME and one for entering a password i.e. PASSWORD. In addition it should have a command button that initiates the password checking action. If either of the text fields is left blank it is an error that must be reported to the user. If both fields are filled in but there is no record of the user name or the password is incorrect that must also be reported to the user.

Users that have not yet registered cannot log in. They must first register by clicking on the register button. They should be able to do this without getting an error for an empty name or password field.

The validation process for username and password can be done as:

    validateForm = e => {
    e.preventDefault();
    this.setState({ submitted: true });
    const username = findDOMNode(this.refs.username);
    const password = findDOMNode(this.refs.password);
    if (username.value && password.value) {
      this.setState({ username: username.value, password: password.value });
      this.props.handleLogin(
        username.value,
        password.value,
        this.loginCallback
      );
    }
  };

And

   loginCallback = response => {
    if (response) {
      if (response.message) {
        this.setState({ responseMessage: response.message });
      }
      if (response.redirectUrl) {
        this.setState({ redirectUrl: response.redirectUrl });
      }
    }
  };

ModalPopup

The Modal plugin is a dialog box/popup window that is displayed on top of the current page.Tooltips and popovers can be placed within modals as needed. When modals are closed, any tooltips and popovers within are also automatically dismissed.You can better understand the popup scenario as follows:

 
    return (
      <Modal
        id={this.props.idName}
        size={this.props.size}
        show={this.props.show}
        onHide={() => this.props.onHide(false)}
        aria-labelledby={this.props.ariaLabelledby}
      >
        {this.props.headerTitle && (
          <Modal.Header closeButton>
            <Modal.Title id={`${this.props.idName}-title`}>
              {this.props.headerTitle}
            </Modal.Title>
          </Modal.Header>
        )}
        <Modal.Body>{this.props.children}</Modal.Body>
      </Modal>
    );
 

TrayCarousel

The TrayCarousel plugin is a component for cycling through elements and simply behaves like a tray of different images or videos. The feature is quite useful in beautifying a website.

TreeView

In this, there is a full fledge tree view of all the items. The important parameters used in this component are: displayNameKey for name, onExpandedNode for expanding the node, onSelectedNode indicates tree data last node, rootNameKey, treeData for further classification of the children of respective root node. In the Index.stories.js of TreeView component, file is containg the json format file in it.