@spirex/di-react
v1.2.0
Published
Type-safe React integration for SpireX/DI. Provides a fully typed and declarative dependency injection system.
Maintainers
Readme
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:
useInjecthook for functional components,withInjectHOC 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-reactQuickstart
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
- Dependency Injection in React Applications
- React Integration Package Installation
- Dependency Injection Context for React
- Root DI Scope for React
- Dependency Injection via Component Props
- Dependency Injection via React Hook
- Nested DI Scopes
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.
