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

@hln/design-system

v0.7.9

Published

React based design system for HLN's current and future projects.

Downloads

81

Readme

HLN Design System npm

React based design system, with the goal of modernizing and streamlining the development of public health web applications by HLN Consulting, LLC and it's contractors.

Installation

Please note, that this package is actively under development, and is not intended to be used in production environments at this time.

To begin using the HLN Design System, we first need to install a few dependencies.

We recommend using the Yarn package manager for installing from NPM, managing dependency workspaces, and running package scripts.

yarn add @hln/design-system styled-components

Alternatively, you may use NPM 5+ to install the design system package:

npm i @hln/design-system styled-components

Exploring the Design System

  • Components contains off-the-shelf React components, ready for use in your application
  • Elements houses lower-level items that make up components, as well as commonplace UI elements such as Buttons, Icons, etc.
  • Theme is where you can find the included color palette for the active theme,

Compatibility

| @hln/design-system | React | React Native | Styled Components | | -------------------- | ------- | ------------ | ----------------- | | <1.0 Unreleased | ~16.9 | ~0.61 | ~5.0 |

Using Design System Components

As with most modern Javascript packages, we expose multiple entrypoints to import various classifications of components for use in your projects.

The categorization follows a very similar model to that of our Storybook, where we divide available imports into the three top level classifications outlined above as "Exploring the Design System."

A quick note on styling and styled-components

Due to issues from differences in versions used, the HLN Design System does not ship with a bundled version of styled components, a wonderful library that allows us to use traditional CSS syntax, and mix it with JSX/ES6 to deliver highly modularized and build-optimized styling to applications. Please ensure you also install styled-components per the guidance above.

Importing and using a component or element

Suppose you wish to use <FeedbackCard /> in a component. First, we'd need to import our respective components and elements:

import React from 'react';
+ import { FeedbackCard } from '@hln/design-system/components';

Now, further down in your actual component render:

// ...

render = () => (
    <SomeStyledContainerComponent>
+        <FeedbackCard
+            feedback={{
+                heading: `Success!`,
+                message: `The operation was successful.`
+            }}
+        />
    </SomeStyledContainerComponent>
);

// ...

And like that, you've added a component from the HLN Design System into your application!

Advanced use case

Imagine we need our theme context to get the brand colors to style an external library's component, to be rendered inside of a dialog with a few action buttons.

Our imports will become a bit more complicated:

import React, { useContext } from 'react';
+ import { Dialog } from '@hln/design-system/components';
+ import { Button, DialogHeader, DialogFooter } from '@hln/design-system/elements';
+ import { ThemeContext } from 'styled-components';
// ...
+ import SomeExternalComponent from 'external-library';

...as will our render:

// ...

render = () => {
    const theme = useContext(ThemeContext);

    return (
        <Dialog close={() => null} size="md" visible>
            <DialogHeader close={() => null}>Hello there.</DialogHeader>
            <DialogBody>
                <SomeExternalComponent color={theme.colors.brand.primary} />
                <p style={{ margin: `1.33rem 0 0 0` }}>
                    {`I'm a dialog. You can put whatever kind of content you'd like into me.`}
                </p>
            </DialogBody>
            <DialogFooter>
                <Button appearance="secondary" text>
                    Cancel
                </Button>
                <Button appearance="primary" text>
                    Continue
                </Button>
            </DialogFooter>
        </Dialog>
    );
};

// ...

By following these patterns, we hope that you can find using the HLN Design System straightforward and without too many roadblocks to achieving success.

Implementing the provided theme

Components not looking the same as they do here on Storybook? Without providing the default theme to the bundled components and elements, you will notice that styling is quite broken.

Following the guidance of styled components' Theming documentation, we recommend two of the possible ways to pass in a theme bundled with the HLN Design System: through a <ThemeProvider /> that wraps your primary React component, or via the useContext React hook.

<ThemeProvider />

Suppose your application has a single entry point, such as this simplified example:

const App = () => (
    <MyAppContainer>
        <AppRouterOrNavigation />
    </MyAppContainer>
);

To have the theme in all child styled component instances, you would first import the styled component <ThemeProvider /> and the desired theme(s) as follows:

import { defaultTheme } from '@hln/design-system/themes';
import { ThemeProvider } from 'styled-components';

...and then add the <ThemeProvider /> wrapper:

const App = () => (
+   <ThemeProvider theme={defaultTheme}>
        <MyAppContainer>
            <AppRouterOrNavigation />
        </MyAppContainer>
+   </ThemeProvider>
);

Now, when extending or using styled components in your application, you will have access to the theme prop, for example:

const SomeStyledTextComponent = styled(({ ...rest }) => <span {...rest} />)`
    color: ${(prop) => prop.theme.colors.brand};
    font-size: 1.1rem;
    font-weight: 400;
`;

useContext React hook

Sometimes, you may want to use a value from the currently applied theme in your functional component, without needing this value for providing a styled attribute to itself. As the styled component library added support for React Hooks in v4, this is very easy to implement.

import { useContext } from 'react';
import { ThemeContext } from 'styled-components';

const BasicComponent = () => {
    const theme = useContext(ThemeContext);

    console.log(`Active theme object: `, theme);
    // ...
};

Contributing

As this package is actively under development, we are not actively seeking external contributors at this time.

Additional Information

Storybook

We utilize Storybook to develop, audit, and document the various elements, components, and theming options that the HLN Design System affords developers.

To initialize your own Storybook environment, simply pull or fork the repository, install dependencies, and run:

yarn storybook

Versioning

We use SemVer for versioning. For the versions available, see the releases on this repository.

License

This package is licensed under the MIT License. For more information, refer to LICENSE in the official repository.