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 🙏

© 2024 – Pkg Stats / Ryan Hefner

@no-gravity-elements/react-adapter

v3.0.0

Published

No Gravity Elements adapter for React

Downloads

18

Readme

@no-gravity-elements/react-adapter

This package declares all No Gravity Elements web components as JSX intrinsic elements so that they can be consumed in React and provides typings and intellisense.

Setting up React adapter

Install in your React project.

npm i @no-gravity-elements/react-adapter

Import in your app entry point

import '@no-gravity-elements/react-adapter';

Now you can consume no-gravity-elements in your React project.

Consuming no-gravity-elements

We provide a hook for handling custom events easily. Each component exposes a type with its events.

import '@no-gravity-elements/select';
import { SelectTypes } from '@no-gravity-elements/types';
import { SelectEvents } from '@no-gravity-elements/select';
import { useNgeEvents } from '@no-gravity-elements/react-adapter';

const App = () => {
  const [selected, setSelected] = useState<SelectOption>(SELECT_OPTIONS[0]);

  const handleSelectChange = (newSelected: SelectOption) => {
    setSelected(newSelected);
  };

  const { ref } = useNgeEvents<SelectEvents>({
    onChange: handleSelectChange,
  });

  return (
    <nge-select ref={ref} options={SELECT_OPTIONS} selected={selected} />
  );
};

Development

Generating React adapter

The React Adapter is automatically generated based on the existing components in the repository. The generate-adapter.js script will search for all components and generate a typescript declaration that adds them to JSX.

To generate the adapter, run yarn build-react-adapter from the monorepo root folder or yarn build from this package directory.

CICD

Publish job is set up to generate new version of adapter and commit it upon merging to main.