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

@elemental-ui-alpha/box

v0.0.2

Published

The box primitive allows consumers to implement aesthetic changes within the constraints of the theme.

Downloads

12

Readme

Box

import { Box } from '@elemental-ui-alpha/box';

Style Props

Background / Foreground

Target the background color and foreground color:

<Box background="shade" foreground="accent">
  accent
</Box>

Padding

The padding keys allow targeting each side as well as the x-axis and y-axis.

  • padding
  • paddingTop
  • paddingRight
  • paddingBottom
  • paddingLeft
  • paddingX padding-left and padding-right
  • paddingY padding-top and padding-bottom
<Box padding="medium" background="shade">
  padding
</Box>

Margin

The margin keys allow targeting each side as well as the x-axis and y-axis.

  • margin
  • marginTop
  • marginRight
  • marginBottom
  • marginLeft
  • marginX margin-left and margin-right
  • marginY margin-top and margin-bottom
<Box margin="medium" background="shade">
  margin
</Box>

Rounding

The rounding keys allow targeting each box side.

  • rounding border-radius
  • roundingBottom border-bottom-left-radius and border-bottom-right-radius
  • roundingLeft border-bottom-left-radius and border-top-left-radius
  • roundingRight border-bottom-right-radius and border-top-right-radius
  • roundingTop border-bottom-left-radius and border-bottom-right-radius

The rounding values don't follow the traditional t-shirt sizes.

  • none
  • small
  • medium
  • large
<Box rounding="small" background="shade">
  rounding
</Box>

Text Align

Align the text within a box:

  • textAlign text-align CSS property

The available values match the CSS property:

  • left
  • right
  • center
  • justify
  • start
  • end
<Box textAlign="center" padding="small" background="shade">
  centered text
</Box>

Height

Set the height of a box:

  • height height CSS property
<Box height={100} background="shade">
  100px tall
</Box>

Width

Set the width of a box:

  • width width CSS property
<Box width={200} background="shade">
  200px wide
</Box>

Combined

Mix and match style properties to achieve the desired aesthetic.

<Box
  background="shade"
  foreground="action"
  paddingX="large"
  paddingY="medium"
  margin="small"
  rounding="small"
  width={200}
>
  combined
</Box>

Responsive Props

Instead of manually managing media queries and adding nested style objects throughout a code base, we offer a convenient shorthand syntax for adding responsive styles with a mobile-first approach.

Each of the above style props accepts a value or array of values. To skip certain breakpoints, you can pass null to any position in the array to avoid generating unnecessary CSS.

While this approach has been widely adopted with great success, much like any new idea, it can seem odd or off-putting at first. We recommend giving it a chance.

<Box background="shade" padding={['small', null, 'medium', 'none', 'large']}>
  responsive props
</Box>