New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

iflex-create-library

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

iflex-create-library - npm Package Compare versions

Comparing version 10.0.26 to 10.0.27

2

package.json
{
"name": "iflex-create-library",
"version": "10.0.26",
"version": "10.0.27",
"main": "build/main.js",

@@ -5,0 +5,0 @@ "files": [

# React Component Library
[![Build status](https://badge.buildkite.com/90ff98db996bb137c5be1bdce666c4b1ce68a25b17af0a6a04.svg?branch=master)](https://buildkite.com/harvey/react-component-library)
[![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://opensource.org/licenses/MIT)
This project skeleton was created to help people get started with creating their own React component library using:
- [Rollup](https://github.com/rollup/rollup)
- [Sass](https://sass-lang.com/)
- [TypeScript](https://www.typescriptlang.org/)
It also features:
- [Storybook](https://storybook.js.org/) to help you create and show off your components
- [Jest](https://jestjs.io/) and [React Testing Library](https://github.com/testing-library/react-testing-library) enabling testing of the components
[**Read my blog post about why and how I created this project skeleton ▸**](https://blog.harveydelaney.com/creating-your-own-react-component-library/)
## Development
### Testing
```
npm run test
```
### Building
```
npm run build
```
### Storybook
To run a live-reload Storybook server on your local machine:
```
npm run storybook
```
To export your Storybook as static files:
```
npm run storybook:export
```
You can then serve the files under `storybook-static` using S3, GitHub pages, Express etc. I've hosted this library at: https://www.harveydelaney.com/react-component-library
### Generating New Components
I've included a handy NodeJS util file under `util` called `create-component.js`. Instead of copy pasting components to create a new component, you can instead run this command to generate all the files you need to start building out a new component. To use it:
```
npm run generate YourComponentName
```
This will generate:
```
/src
/YourComponentName
YourComponentName.tsx
YourComponentName.stories.tsx
YourComponentName.test.tsx
YourComponentName.types.ts
YourComponentName.scss
```
The default templates for each file can be modified under `util/templates`.
Don't forget to add the component to your `index.ts` exports if you want the library to export the component!
### Installing Component Library Locally
Let's say you have another project (`test-app`) on your machine that you want to try installing the component library into without having to first publish the component library. In the `test-app` directory, you can run:
```
npm i --save ../react-component-library
```
which will install the local component library as a dependency in `test-app`. It'll then appear as a dependency in `package.json` like:
```JSON
...
"dependencies": {
...
"react-component-library": "file:../react-component-library",
...
},
...
```
Your components can then be imported and used in that project.
## Publishing
### Hosting via NPM
First, make sure you have an NPM account and are [logged into NPM using the `npm login` command.](https://docs.npmjs.com/creating-a-new-npm-user-account)
Then update the `name` field in `package.json` to reflect your NPM package name in your private or public NPM registry. Then run:
```
npm publish
```
The `"prepublishOnly": "npm run build"` script in `package.json` will execute before publish occurs, ensuring the `build/` directory and the compiled component library exist.
### Hosting via GitHub
I recommend you host the component library using NPM. However, if you don't want to use NPM, you can use GitHub to host it instead.
You'll need to remove `build/` from `.gitignore`, build the component library (`npm run build`), add, commit and push the contents of `build`. [See this branch for an example.](https://github.com/HarveyD/react-component-library/tree/host-via-github)
You can then install your library into other projects by running:
```
npm i --save git+https://github.com/HarveyD/react-component-library.git#branch-name
```
OR
```
npm i --save github:harveyd/react-component-library#branch-name
```
## Usage
Let's say you created a public NPM package called `harvey-component-library` with the `TestComponent` component created in this repository.
Usage of the component (after the library installed as a dependency into another project) will be:
```TSX
import React from "react";
import { TestComponent } from "harvey-component-library";
const App = () => (
<div className="app-container">
<h1>Hello I'm consuming the component library</h1>
<TestComponent theme="primary" />
</div>
);
export default App;
```
[Check out this Code Sandbox for a live example.](https://codesandbox.io/s/harvey-component-library-example-y2b60?file=/src/App.js)
### Using Component Library SASS Variables
I've found that it's helpful to export SASS variables to projects consuming the library. As such, I've added the `rollup-plugin-copy` NPM package and used it to copy the `typography.scss` and `variables.scss` into the `build` directory as part of the Rollup bundle process. This allows you to use these variables in your projects consuming the component library.
For example, let's say you installed `harvey-component-library` into your project. To use the exported variables/mixins, in a SASS file you would do the following:
```Sass
@import '~harvey-component-library/build/typography';
.example-container {
@include heading;
color: $harvey-white;
}
```
## Additional Help
### Using Alternatives to Sass
#### Less or Stylus
The Rollup plugin `rollup-plugin-postcss` supports Sass, Less and Stylus:
- For Stylus, install stylus: `yarn add stylus --dev`
- For Less, install less: `yarn add less --dev`
You can then remove `node-sass` from your dependencies.
#### CSS Modules
If you want to use CSS Modules, update `postcss` in `rollup-config.js` to:
```
postcss({
modules: true
})
```
#### Styled Components
If you want to use [`styled-components`](https://styled-components.com/), the changes required are a bit more involved. As such, I've created a branch where I've got `styled-components` working in this component library, [check it out here](https://github.com/HarveyD/react-component-library/tree/styled-components).
### Component Code Splitting
Code splitting of your components is not supported by default.
[Read this section of my blog post](https://blog.harveydelaney.com/creating-your-own-react-component-library/#introducing-code-splitting-optional-) to find out how and why you would enable code splitting of your components. In summary, code splitting enables users to import components in isolation like:
```
import TestComponent from 'harvey-component-library/build/TestComponent';
```
This can reduce the bundle size for projects using older (CJS) module formats.
You can check out [this branch](https://github.com/HarveyD/react-component-library/tree/code-splitting) or [this commit](https://github.com/HarveyD/react-component-library/commit/94631be5a871f3b39dbc3e9bd3e75a8ae5b3b759) to see what changes are neccesary to implement it.
Please note, there's an issue with code splitting and using `rollup-plugin-postcss`. I recommend using `rollup-plugin-sass` instead alongside code splitting.
### Supporting Image Imports
Add the following library to your component library [@rollup/plugin-image](https://github.com/rollup/plugins/tree/master/packages/image):
```
npm i -D @rollup/plugin-image
```
Then add it to `rollup-config.js`:
```
...
plugins:[
...,
image(),
...
]
...
```
You can then import and render images in your components like:
```tsx
import logo from "./rollup.png";
export const ImageComponent = () => (
<div>
<img src={logo} />
</div>
);
```
### Supporting JSON Imports
Add the following library to your component library [@rollup/plugin-json](https://github.com/rollup/plugins/tree/master/packages/json):
```
npm i -D @rollup/plugin-json
```
Then add it to `rollup-config.js`:
```
...
plugins:[
...,
json(),
...
]
...
```
You can then import and use JSON as ES6 Modules:
```tsx
import data from "./some-data.json";
export const JsonDataComponent = () => <div>{data.description}</div>;
```
Checkout the [official Rollup plugin list](https://github.com/rollup/plugins) for additional helpful plugins.
This package is a webpack based library template tool for creating React Libraries. For an improved exeperience using Rollup, please move to iflex-react-library
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc