Skip to content

Latest commit

 

History

History
77 lines (54 loc) · 1.51 KB

README.md

File metadata and controls

77 lines (54 loc) · 1.51 KB

@injets/functional

A lightweight dependency injection library for JavaScript and TypeScript with functional programming.

Installation

npm install @injets/core @injets/functional

Usage

import {
  createResolver,
  Token,
  depends,
  transient,
  constant,
  singleton,
  inject
} from '../src';

class MyService {
  constructor(private readonly hostname: string) {}

  send() {
    console.log('MyService send', this.hostname);
  }
}

const RANDOM: Token<number> = 'random';
const CONFIG_HOSTNAME: Token<string> = 'hostname';
const CONFIG_PORT: Token<number> = 'port';

const useConfig = createResolver('Config', () => {
  constant(CONFIG_HOSTNAME, 'localhost');
  constant(CONFIG_PORT, 3000);
});


const useApp = createResolver('App', () => {
  depends(useConfig);

  transient(RANDOM, () => Math.random());

  singleton(MyService, () => new MyService(inject(CONFIG_HOSTNAME)));
});

// Resolve token
const val = useApp(RANDOM);

// Resolve multiple tokens
const [
  service,
  randomValue,
] = useApp([
  MyService,
  RANDOM,
]);

console.log(service, randomValue, val);

API

Decorators

createResolver(name: string, factory: ResolverFactory): Resolver

Creates a resolver function for all providers defined in the factory.

Other packages