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

@berbix/react-advanced-sdk

v1.4.1

Published

An SDK to support custom React implementations of the Berbix Verify flow.

Downloads

454

Readme

Berbix React Advanced SDK

This is the documentation for the Berbix React Advanced SDK, which lets you compose a Berbix ID verification flow using your own UI components (as opposed to our React SDK, which is a one-line solution to integrate Berbix ID verification).

Getting started

Your app needs to be wrapped in a CameraProvider to provide the appropriate context to the SDK's other components.

import { CameraProvider } from "@berbix/react-advanced-sdk";

export default function App({ children }) {
  return (
    <html>
      <head>
        <meta />
      </head>
      <body>
        <CameraProvider>{children}</CameraProvider>
      </body>
    </html>
  );
}

Learn more about CameraProvider in its API docs.

Showing the stream from the camera

To render the output from the device's camera, use the CameraStream component. This component is essentially a managed <video> element; it takes care of permissions and selection of device cameras, as well as setting up and running real-time shape detection on the camera stream.

It also provides various callbacks that developers can use to detect or respond to various events. You can learn more about this in the CameraStream API docs.

import { CameraStream } from "@berbix/react-advanced-sdk";

function MyPage() {
  return (
    <div>
      <CameraStream
        fit="cover"
        onStreamStart={() => console.log("Stream started")}
        onStreamEnd={() => console.log("Stream ended")}
      />
    </div>
  );
}

Laying out the camera stream

The pixel dimensions of the rendered <CameraStream> element depend on the resolution of the device's camera. Often, this is much larger than the viewport size, leading to scroll bars on the page if not sized correctly. As such, we recommend developers explicitly set the size of the element:

// Size the element to fully cover its parent container
style = { width: "100%", height: "100%" };

// Size the element to fully cover the viewport
style = { width: "100vw", height: "100vw" };

// Set a fixed size on the element
style = { width: "100px", height: "100px" };

<CameraStream style={style} />;

The CameraStream component uses the object-fit CSS property (aliased in the component as the fit prop) to determine how to crop or scale the video stream to fit the dimensions of the element. By default, fit is set to cover, meaning that the video stream will be cropped to ensure that it fully covers the element. Below is an overview of how each fit value behaves:

| fit value | No cropping | No video bars | Preserve aspect ratio | | ----------- | ----------- | ------------- | --------------------- | | cover | | ✅ | ✅ | | contain | ✅ | | ✅ | | fill | ✅ | ✅ |

The MDN docs on object-fit has demos of these different values. You can read the docs here.

Adding shape detection

The CameraStream component has the built-in ability to do real-time shape detection. You can do this as follows:

<CameraStream
  shapeDetector="barcode"
  shapeDetectorProps={{
    active: true,
    onDetect: () => console.log("Shape detected"),
  }}
/>

You can read more about the various options for the shape detector in the shapeDetectorProps section of the docs.

Controlling the camera output

We provide a useCamera hook that gives you functions to control the CameraStream component. You can read about the hook and its functions here.

Capturing camera frames

There are two ways to capture camera frames: either through the capture() function in the useCamera hook, or using shapeDetectorProps.autoCapture. The former needs to be imperatively called; the latter will automatically trigger a capture if a shape is successfully detected.

In either case, it will fire the onCapture callback in the CameraStream component, passing in a Blob of the captured image from the stream. You can add a handler to handle this:

const [active, setActive] = useState(true);

<CameraStream
  onCapture={(blob, shapes) => {
    setActive(false);

    // Do some handling of the blob, e.g. send it to an API.
  }}
  shapeDetector="barcode"
  shapeDetectorProps={{
    active,
    autoCapture: true,
  }}
/>;

References

External