@migration-planner-ui/ioc 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,7 @@
1
+ /** A naive, singleton-scoped dependency injection container */
2
+ export declare class Container {
3
+ #private;
4
+ constructor();
5
+ get<T>(registeredInterfaceSymbol: symbol): T;
6
+ register<T = unknown>(registeredInterfaceSymbol: symbol, value: T): Container;
7
+ }
@@ -0,0 +1,28 @@
1
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
+ if (kind === "m") throw new TypeError("Private method is not writable");
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
+ };
7
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
+ };
12
+ var _Container_registry;
13
+ /** A naive, singleton-scoped dependency injection container */
14
+ export class Container {
15
+ constructor() {
16
+ _Container_registry.set(this, void 0);
17
+ __classPrivateFieldSet(this, _Container_registry, {}, "f");
18
+ }
19
+ get(registeredInterfaceSymbol) {
20
+ const value = __classPrivateFieldGet(this, _Container_registry, "f")[registeredInterfaceSymbol];
21
+ return value;
22
+ }
23
+ register(registeredInterfaceSymbol, value) {
24
+ __classPrivateFieldGet(this, _Container_registry, "f")[registeredInterfaceSymbol] = value;
25
+ return this;
26
+ }
27
+ }
28
+ _Container_registry = new WeakMap();
@@ -0,0 +1,2 @@
1
+ import { Container } from "./Container";
2
+ export declare const Context: import("react").Context<Container>;
@@ -0,0 +1,2 @@
1
+ import { createContext } from "react";
2
+ export const Context = createContext(null);
@@ -0,0 +1,5 @@
1
+ import { type FC, type PropsWithChildren } from "react";
2
+ import { Container } from "./Container";
3
+ export declare const Provider: FC<PropsWithChildren<{
4
+ container: Container;
5
+ }>>;
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Context } from "./Context";
3
+ export const Provider = (props) => {
4
+ const { container, children } = props;
5
+ return _jsx(Context.Provider, { value: container, children: children });
6
+ };
@@ -0,0 +1 @@
1
+ export declare function useInjection<T>(registeredInterfaceSymbol: symbol): T;
@@ -0,0 +1,9 @@
1
+ import { useContext } from "react";
2
+ import { Context } from "../Context";
3
+ export function useInjection(registeredInterfaceSymbol) {
4
+ const container = useContext(Context);
5
+ if (!container) {
6
+ throw new ReferenceError("useInjection must be used inside its Provider");
7
+ }
8
+ return container.get(registeredInterfaceSymbol);
9
+ }
@@ -0,0 +1,4 @@
1
+ export * from "./Container";
2
+ export * from "./Provider";
3
+ export * from "./hooks/UseInjection";
4
+ export * from './Context';
package/dist/index.js ADDED
@@ -0,0 +1,4 @@
1
+ export * from "./Container";
2
+ export * from "./Provider";
3
+ export * from "./hooks/UseInjection";
4
+ export * from './Context';
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@migration-planner-ui/ioc",
3
+ "version": "0.0.2",
4
+ "description": "A basic IoC solution for React apps (inspired by InversifyJs)",
5
+ "author": "Jonathan Kilzi <jkilzi@redhat.com>",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "https://github.com/kubev2v/migration-planner-ui.git",
9
+ "directory": "packages/ioc"
10
+ },
11
+ "exports": {
12
+ ".": {
13
+ "import": "./dist/index.js",
14
+ "require": "./dist/index.cjs",
15
+ "types": "./dist/index.d.ts"
16
+ }
17
+ },
18
+ "typesVersions": {
19
+ "*": {
20
+ ".": [
21
+ "./src/index.ts",
22
+ "./dist/index.d.ts"
23
+ ]
24
+ }
25
+ },
26
+ "sideEffects": false,
27
+ "publishConfig": {
28
+ "access": "public"
29
+ },
30
+ "scripts": {
31
+ "build": "yarn run -T tsc -b",
32
+ "bundle": "yarn build && yarn pack --out dist/%s-%v.tgz",
33
+ "clean": "rm -rf node_modules dist",
34
+ "lint": "yarn run -T eslint . --report-unused-disable-directives --max-warnings 0"
35
+ },
36
+ "devDependencies": {
37
+ "@patternfly/react-core": "*",
38
+ "@patternfly/react-icons": "*",
39
+ "@patternfly/react-tokens": "*",
40
+ "react": "*",
41
+ "react-dom": "*",
42
+ "react-router-dom": "*"
43
+ },
44
+ "peerDependencies": {
45
+ "@patternfly/react-core": "^5.4.0",
46
+ "@patternfly/react-icons": "^5.4.0",
47
+ "@patternfly/react-tokens": "^5.4.0",
48
+ "react": "^18.3.1",
49
+ "react-dom": "^18.3.1",
50
+ "react-router-dom": "^6.26.0"
51
+ },
52
+ "stableVersion": "1.1.1"
53
+ }
@@ -0,0 +1,22 @@
1
+ /** A naive, singleton-scoped dependency injection container */
2
+ export class Container {
3
+ readonly #registry: Record<symbol, unknown>;
4
+
5
+ constructor() {
6
+ this.#registry = {};
7
+ }
8
+
9
+ get<T>(registeredInterfaceSymbol: symbol): T {
10
+ const value = this.#registry[registeredInterfaceSymbol] as T;
11
+ return value;
12
+ }
13
+
14
+ register<T = unknown>(
15
+ registeredInterfaceSymbol: symbol,
16
+ value: T
17
+ ): Container {
18
+ this.#registry[registeredInterfaceSymbol] = value;
19
+
20
+ return this;
21
+ }
22
+ }
package/src/Context.ts ADDED
@@ -0,0 +1,4 @@
1
+ import { createContext } from "react";
2
+ import { Container } from "./Container";
3
+
4
+ export const Context = createContext<Container | null>(null);
@@ -0,0 +1,10 @@
1
+ import { type FC, type PropsWithChildren } from "react";
2
+ import { Context } from "./Context";
3
+ import { Container } from "./Container";
4
+
5
+ export const Provider: FC<
6
+ PropsWithChildren<{ container: Container }>
7
+ > = (props) => {
8
+ const { container, children } = props;
9
+ return <Context.Provider value={container}>{children}</Context.Provider>;
10
+ };
@@ -0,0 +1,11 @@
1
+ import { useContext } from "react";
2
+ import { Context } from "../Context";
3
+
4
+ export function useInjection<T>(registeredInterfaceSymbol: symbol): T {
5
+ const container = useContext(Context);
6
+ if (!container) {
7
+ throw new ReferenceError("useInjection must be used inside its Provider");
8
+ }
9
+
10
+ return container.get<T>(registeredInterfaceSymbol);
11
+ }
package/src/index.ts ADDED
@@ -0,0 +1,4 @@
1
+ export * from "./Container";
2
+ export * from "./Provider";
3
+ export * from "./hooks/UseInjection";
4
+ export * from './Context';
package/tsconfig.json ADDED
@@ -0,0 +1,17 @@
1
+ {
2
+ "compilerOptions": {
3
+ "tsBuildInfoFile": "../../node_modules/.tmp/ioc/tsconfig.tsbuildinfo",
4
+ "composite": true,
5
+ "declaration": true,
6
+ "useDefineForClassFields": true,
7
+ "jsx": "react-jsx",
8
+ "target": "es6",
9
+ "module": "ESNext",
10
+ "moduleResolution": "bundler",
11
+ "rootDir": "src",
12
+ "outDir": "dist",
13
+ "paths": {
14
+ "#/*": ["./src/*"]
15
+ }
16
+ },
17
+ }