
Product
Introducing Socket Firewall Enterprise: Flexible, Configurable Protection for Modern Package Ecosystems
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.
es-components
Advanced tools
https://wtw-im.github.io/es-components/
npm install --save es-components
es-components comes optimized for tree shaking. If your build tool does not support tree shaking please direct your imports towards es-components/lib.
You may use either direct file paths or destructure from the index file.
// use this to keep the size of your bundles light
import Component from 'es-components/lib/path/to/component';
// or
import { Component } from 'es-components/lib';
es-components is functional with both styled-components@5 and styled-components@6. However, if you are using typescript, we recommend using styled-components@6 without @types/styled-components. If on styled-components@5 with @types/styled-components, some types within es-components will break.
### Using The UMD Bundle
Because ES Components needs a reference to `document.body` on startup, you must either include the `defer` attribute, or place the `<script>` tag somwhere within the `body` of your html page. Here we're showing it using the `defer` attribute.
```html
<!DOCTYPE html>
<head>
  <meta charset="UTF-8" />
  <title>My ES Components Site</title>
  <!-- These fonts are used by es-components -->
  <link
    rel="stylesheet"
    href="https://app.viabenefits.com/static/cdn/es-assets/icons.css"
  />
  <link
    rel="stylesheet"
    href="https://app.viabenefits.com/static/cdn/es-assets/source-sans-pro.css"
  />
  <!-- You must include React, ReactDOM, PropTypes and Styled Components. ES Components depends on those packages. -->
  <script
    crossorigin
    src="https://app.viabenefits.com/static/third-party/react@16/umd/react.production.min.js"
  ></script>
  <script
    crossorigin
    src="https://app.viabenefits.com/static/third-party/react-dom@16/umd/react-dom.production.min.js"
  ></script>
  <script
    crossorigin
    src="https://app.viabenefits.com/static/third-party/prop-types@15/prop-types.js"
  ></script>
  <script
    crossorigin
    src="https://app.viabenefits.com/static/third-party/styled-components/dist/styled-components.min.js"
  ></script>
  <script
    crossorigin
    defer
    src="https://app.viabenefits.com/static/third-party/es-components/bundle/main.min.js"
  ></script>
</head>
<body>
  <!-- My ES Components Site Body -->
</body>
es-components uses ResizeObserver, but if you're using jsdom, it doesn't come with it. You can set
up jest to work with es-components by using build-utils/jest in your setupFilesAfterEnv
configuration. Eg:
// jest.config.js
module.exports = {
  // other jest config
  setupFilesAfterEnv: [
    'es-components/build-utils/jest'
    // others...
  ]
};
21.15.1 (2025-03-14)
Note: Version bump only for package es-components-monorepo
FAQs
React components built for Exchange Solutions products
We found that es-components demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.

Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.