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.2.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
  • Strict and dynamic typing: Supports full static typing or direct imports with type casts for multi-package setups
  • 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 (StrictMode-safe)
  • Shared context: Single React context — all packages share the same DI tree
  • Lightweight: Only 1kb (0.58kb 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

Static Typed API

When the full TypeMap is available (single-package applications), use getDIReact<TypeMap>() to get fully typed components and hooks:

import React from "react";
import { diBuilder, factoryOf, TypeMapOf } from "@spirex/di";
import { getDIReact } 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>>;

// Get strictly typed React DI tools
export const { DIRootScope, useInject } = getDIReact<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>
    );
};

Dynamic Typed API

For multi-package applications where the full TypeMap is not available in every package, use direct imports with type casts:

import { useInject, DIRootScope } from "@spirex/di-react";
import type { TUseInject } from "@spirex/di-react";
import type { TypeMapOf } from "@spirex/di";
import type { ModuleA } from "./modules/a";
import type { ModuleB } from "./modules/b";

// Combine known type maps from local modules
type LocalTypeMap = TypeMapOf<typeof ModuleA> & TypeMapOf<typeof ModuleB>;

// Narrow the hook type for the current package
const useTypedInject = useInject as TUseInject<LocalTypeMap>;

const MyComponent: React.VFC = () => {
    const service = useTypedInject('myService'); // fully typed
    // ...
};

All packages share the same underlying React context, so DIRootScope provided at the application root is accessible everywhere.

Migration from createDIContext

createDIContext() is deprecated since v1.2.0. It still works as an alias for getDIReact(), but no longer creates isolated contexts — all calls return the same shared components and hooks.

- import { createDIContext } from "@spirex/di-react";
- const { DIRootScope, useInject } = createDIContext<TypeMap>();
+ import { getDIReact } from "@spirex/di-react";
+ const { DIRootScope, useInject } = getDIReact<TypeMap>();

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.