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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@spirex/di-react

v1.1.0

Published

Type-safe React integration for SpireX/DI. Provides a fully typed and declarative dependency injection system.

Readme

NPM Type Definitions NPM Version Codecov GitHub License

SpireX/DI integration for React

@spirex/di-react

Type-safe React integration for SpireX/DI — a lightweight dependency injection library for JavaScript and TypeScript applications.

@spirex/di-react provides React developers with a fully typed, declarative, and scoped DI system built on top of the React Context API and hooks. It brings the full power of SpireX/DI to React applications while keeping components decoupled, testable, and maintainable.

With a tiny footprint and support for modern React, this package ensures predictable dependency injection, strong TypeScript guarantees, and clean component architecture.

Features

  • Type-safe DI: Full TypeScript support, with IDE autocompletion
  • Root & child DI scopes: Control lifetime and visibility of dependencies
  • Declarative injection: useInject hook for functional components, withInject HOC for props-based injection
  • Automatic scope disposal: Child scopes unmount cleanly with React components
  • Lightweight: Only 0.78kb (0.46kb gzipped)

Installation

Install both the core DI container and React integration:

# NPM
npm install @spirex/di @spirex/di-react

# Yarn
yarn add @spirex/di @spirex/di-react

# PNPM
pnpm add @spirex/di @spirex/di-react

Quickstart

import React from "react";
import { diBuilder, factoryOf, TypeMapOf } from "@spirex/di";
import { createDIContext } from "@spirex/di-react";


// Build the core container
const buildContainer = () => diBuilder<{
    auth: AuthService;
    viewModel: SampleViewModel;
}>()
    .bindFactory('authService', factoryOf(AuthService)
    .bindFactory('viewModel', factoryOf(SampleViewModel))
    .build();

// Extract TypeMap
export type TypeMap = TypeMapOf<ReturnType<typeof buildContainer>>;

// Create typed React DI context
export const { DIRootScope, useInject } = createDIContext<TypeMap>();

// Component using hook-based injection
const MyComponent: React.VFC = () => {
    const authService = useInject('authService')
    const viewModel = useInject('viewModel')

    return (
        <div>
            <h1>{viewModel.title}</h1>
            <button onClick={() => authService.login()}>
                {authService.isAuthorized ? 'Logout' : 'Login'}
            </button>
        </div>
    );
};

// Application root with DI scope
export const App: React.VFC = () => {
    const container = React.useState(buildContainer)[0];
    return (
        <DIRootScope root={container}>
            <MyComponent />
        </DIRootScope>
    );
};

This small example shows:

  • Creating typed DI context for React;
  • Root DI scope (DIRootScope) attached to the React tree;
  • Hook-based dependency injection (useInject) in a functional component

DIRootScope connects the container to React’s component tree. All components inside the root scope can access injected dependencies.

Documentation

License

@spirex/di-react is released under the MIT License.

You are free to use, modify, and distribute the library in both personal and commercial projects.