UNPKG

@e22m4u/js-service

Version:

Реализация принципа инверсии управления для JavaScript

106 lines (94 loc) 2.13 kB
import {Constructor} from './types.js'; import {FindServicePredicate, ServiceContainer} from './service-container.js'; /** * Service class name. */ export const SERVICE_CLASS_NAME: 'Service'; /** * Service. */ export declare class Service { /** * Kind. */ static readonly kinds: string[]; /** * Container. */ container: ServiceContainer; /** * Constructor. * * @param container */ constructor(container?: ServiceContainer); /** * Получить существующий или новый экземпляр. * * @param ctor * @param args */ getService<T extends object>( ctor: Constructor<T>, ...args: any[], ): T; /** * Получить существующий или новый экземпляр, * только если конструктор зарегистрирован. * * @param ctor * @param args */ getRegisteredService<T extends object>( ctor: Constructor<T>, ...args: any[], ): T; /** * Проверка существования конструктора в контейнере. * * @param ctor */ hasService<T extends object>( ctor: Constructor<T>, ): boolean; /** * Добавить конструктор в контейнер. * * @param ctor * @param args */ addService<T extends object>( ctor: Constructor<T>, ...args: any[], ): this; /** * Добавить конструктор и создать экземпляр. * * @param ctor * @param args */ useService<T extends object>( ctor: Constructor<T>, ...args: any[], ): this; /** * Добавить конструктор и связанный экземпляр. * * @param ctor * @param service */ setService<T extends object>( ctor: Constructor<T>, service: T, ): this; /** * Найти сервис удовлетворяющий условию. * * @param predicate * @param noParent */ findService<T extends object>( predicate: FindServicePredicate<T>, noParent?: boolean, ): T | undefined; }