Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Service Container #10

Merged
merged 226 commits into from
Apr 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
226 commits
Select commit Hold shift + click to select a range
6b06888
Init @aedart/contracts/container submodule
aedart Mar 7, 2024
2cc8659
Init @aedart/support/container submodule
aedart Mar 7, 2024
fa5750e
Init @aedart/container package
aedart Mar 7, 2024
ae2511b
Add path alias to container package source
aedart Mar 7, 2024
3a0f90a
Add container path and reference
aedart Mar 7, 2024
06dc228
Add binding identifier type alias
aedart Mar 8, 2024
330157b
Add DEPENDENCIES symbol
aedart Mar 8, 2024
b5e085f
Add dependencies decorator (incomplete)
aedart Mar 8, 2024
ef5bc25
Export dependencies decorator
aedart Mar 8, 2024
4472c31
Merge branch 'main' into add-service-container
aedart Mar 8, 2024
616100c
Merge branch 'main' into add-service-container
aedart Mar 8, 2024
6fa37f9
Fix JSDoc
aedart Mar 8, 2024
c61d36f
Change Target Meta Repository, add hasAny() method
aedart Mar 8, 2024
4a9bae7
Change release notes
aedart Mar 8, 2024
613bcc0
Add utils for defining class and class method dependencies
aedart Mar 8, 2024
c8cf002
Change release notes
aedart Mar 8, 2024
5579444
Update dependencies
aedart Mar 8, 2024
cd6e40e
Fix typo
aedart Mar 8, 2024
0e86c17
Fix typo
aedart Mar 8, 2024
0c94e59
Add Container Exception and Not Found Exception interfaces
aedart Mar 8, 2024
59167c2
Add notice for Psr / MIT License
aedart Mar 8, 2024
cc3c0c6
Add reference to service container
aedart Mar 8, 2024
e7c1508
Add binding alias
aedart Mar 8, 2024
35d3333
Add FactoryCallback type alias
aedart Mar 8, 2024
b4d4c38
Add Binding Entry interface
aedart Mar 8, 2024
6537cd3
Add Container interface (incomplete)
aedart Mar 8, 2024
d4f700e
Export Binding Entry and Container
aedart Mar 8, 2024
4729310
Improve description of FactoryCallback type alias
aedart Mar 8, 2024
d7a1593
Cleanup
aedart Mar 8, 2024
bb8aea4
Cleanup
aedart Mar 8, 2024
c769df8
Add ClassMethodName and ClassMethodReference type aliases
aedart Mar 11, 2024
c4b6620
Change release notes
aedart Mar 11, 2024
4aa1a39
Add isMethod() util
aedart Mar 11, 2024
f01f52d
Add see also references
aedart Mar 11, 2024
247f660
Add array target case
aedart Mar 11, 2024
b898aea
Change release notes
aedart Mar 11, 2024
94b96ef
Refactor, use isMethod()
aedart Mar 11, 2024
8449693
Add isClassMethodReference() util
aedart Mar 11, 2024
a73d39c
Export isMethod() and isClassMethodReference()
aedart Mar 11, 2024
0fc29aa
Change call()'s method type to ClassMethodReference
aedart Mar 11, 2024
f0d382a
Deprecate ConstructorOrAbstractConstructor type alias
aedart Mar 11, 2024
adcbc02
Replace deprecated ConstructorOrAbstractorConstructor type
aedart Mar 11, 2024
1cc3ae0
Change release notes
aedart Mar 11, 2024
72d2c36
Mark isClassConstructor() as stable
aedart Mar 11, 2024
60a163c
Extract tests into own file for isClassConstructor()
aedart Mar 11, 2024
b425078
Add docs for isClassConstructor
aedart Mar 11, 2024
d519d25
Add see also reference to isClassConstructor()
aedart Mar 11, 2024
0ada395
Mark isCallable() as stable
aedart Mar 11, 2024
c8e840b
Improve desc.
aedart Mar 11, 2024
87a6e6a
Extract isCallable tests into own file
aedart Mar 11, 2024
1d5f28a
Add docs for isCallable
aedart Mar 11, 2024
4eb5749
Add additional cases for built-in classes / objects
aedart Mar 11, 2024
83cb52e
Fix example and improve description of util function
aedart Mar 11, 2024
6c6c712
Improve shown examples
aedart Mar 11, 2024
de56a26
Change release notes
aedart Mar 11, 2024
8f394e5
Add callback type alias
aedart Mar 11, 2024
edde298
Change release notes
aedart Mar 11, 2024
3c2c758
Add support for Callback type in call()
aedart Mar 11, 2024
e0f4abf
Add CallbackWrapper interface
aedart Mar 11, 2024
862b8b1
Change release notes
aedart Mar 11, 2024
30a0962
Export CallbackWrapper interface
aedart Mar 11, 2024
6b77879
Add support for calling a CallbackWrapper instance
aedart Mar 11, 2024
36ef536
Change wrapper, add hasBinding() util method
aedart Mar 12, 2024
1bf0c6a
Add CallbackWrapper (implementation
aedart Mar 12, 2024
47d0603
Change release notes
aedart Mar 12, 2024
1a64695
Shorten error message
aedart Mar 12, 2024
235232b
Add static makeFor() method
aedart Mar 12, 2024
3ef86a3
Add tests for Callback Wrapper
aedart Mar 12, 2024
358e67b
Add isCallbackWrapper() util
aedart Mar 12, 2024
f24e6ac
Change release notes
aedart Mar 12, 2024
eed185a
Add case for calling arrow function with binding
aedart Mar 12, 2024
2476af8
Add docs for callback wrapper
aedart Mar 12, 2024
24830e5
Change default value to undefined for D generic
aedart Mar 12, 2024
0903df9
Change release notes
aedart Mar 12, 2024
e00228b
Add ArbitraryData concern
aedart Mar 12, 2024
fe3cacd
(Re)Fix TS1270 and TS1238 errors
aedart Mar 12, 2024
7085852
Fix missing extends JSDoc
aedart Mar 12, 2024
c846b0a
Cleanup
aedart Mar 12, 2024
19cb91b
Cleanup
aedart Mar 12, 2024
3c73b31
Change CallbackWrapper, use Arbitrary Data concern
aedart Mar 12, 2024
81e5c76
Add test for Arbitrary Data concern usage
aedart Mar 12, 2024
fd87a5c
Fix missing tslib as peer dependency
aedart Mar 12, 2024
1635645
Update dependencies
aedart Mar 12, 2024
d7954f2
Change release notes
aedart Mar 12, 2024
d9940a2
Add JSDoc for call()
aedart Mar 12, 2024
c5db4d3
Add ExtendCallback type alias
aedart Mar 12, 2024
2e3dd0d
Change Container, add extend() method
aedart Mar 12, 2024
f28de53
Add before and after resolving hook callbacks
aedart Mar 12, 2024
40977e8
Fix style
aedart Mar 12, 2024
642e6bd
Deprecate service container symbol
aedart Mar 22, 2024
d2257fe
Fix "not under root dir" TypeScript warning
aedart Mar 22, 2024
a0b7ff2
Fix "not under root dir" TypeScript waning for "support" package
aedart Mar 22, 2024
dbd8445
Add Binding Entry class
aedart Mar 22, 2024
3028410
Export Binding Entry
aedart Mar 22, 2024
19b87cb
Mark support packages as external
aedart Mar 22, 2024
dcea404
Throw TypeError in case of invalid binding value
aedart Mar 22, 2024
4537a68
Expand binding identifier to allow constructors and functions
aedart Mar 22, 2024
d5c7876
Add isBindingIdentifier() util
aedart Mar 22, 2024
93f7326
Change release notes
aedart Mar 22, 2024
7468aca
Change Binding Entry - throw TypeError when identifier is not supported
aedart Mar 22, 2024
c435097
Add tests for binding entry
aedart Mar 22, 2024
adf5784
Add notice about Laravel Service Container
aedart Mar 22, 2024
b7a62a5
Add service container class (incomplete)
aedart Mar 22, 2024
e1da3ea
Export service container
aedart Mar 22, 2024
34c7ac5
Fix isBindingIdentifier() included in export
aedart Mar 22, 2024
fe21d38
Add Container's getInstance() and setInstance() static methods
aedart Mar 22, 2024
9365bbf
Add test for container's singleton instance
aedart Mar 22, 2024
4da5eaf
Change container interface, add isAlias() method
aedart Mar 22, 2024
9629ae3
Add implementation of bind, bindIf, singleton, singletonIf, ... etc
aedart Mar 22, 2024
424eac4
Set public visibility on methods that container interface exposes
aedart Mar 22, 2024
77818f7
Add isShared()
aedart Mar 22, 2024
1b26f80
Add container related errors / exceptions
aedart Mar 22, 2024
7f0fef0
Change build, allow argument overwrites
aedart Mar 22, 2024
9193efc
Add implementation for make() and resolve()
aedart Mar 22, 2024
a442868
Add isBinding() util
aedart Mar 23, 2024
a59a522
Add build() implementation
aedart Mar 23, 2024
f293b71
Add resolve dependencies logic
aedart Mar 24, 2024
b4d6e6b
Reorder internals methods
aedart Mar 24, 2024
b3f18b4
Change args to be optional for call()
aedart Mar 24, 2024
a5bd825
Add call() logic
aedart Mar 24, 2024
0cc1b00
Fix support/misc utils included in dist output
aedart Mar 24, 2024
13b77eb
Fix lint
aedart Mar 24, 2024
d1df977
Fix lint
aedart Mar 24, 2024
584c09a
Fix symbol marked as "type" import
aedart Mar 24, 2024
8c94203
Add "rebound" logic
aedart Mar 25, 2024
29a08f1
Add forgetInstance()
aedart Mar 25, 2024
4344861
Add tests for bind() and singleton() methods
aedart Mar 25, 2024
5c3e58e
Add tests for instance()
aedart Mar 25, 2024
c2e3d8f
Change test, add is "bound" expectation
aedart Mar 25, 2024
7c31cb9
Change tests, add isShared() expectations
aedart Mar 25, 2024
99e0119
Fix semantics
aedart Mar 25, 2024
850cd36
Add tests for alias() and alias related utils
aedart Mar 25, 2024
ebda22e
Add tests for make()
aedart Mar 26, 2024
d782a67
Change order of callback arguments, when callback given as defaultValue
aedart Mar 26, 2024
cdf5822
Add tests for makeOrDefault()
aedart Mar 26, 2024
c573920
Move tests to correct "container" suite
aedart Mar 26, 2024
22e78e2
Improve thrown error when not buildable
aedart Mar 26, 2024
40dfa48
Fix error not configured
aedart Mar 26, 2024
74404ca
Improve circular dependency error handling
aedart Mar 26, 2024
21bba2c
Set target and identifier, when circular dependency error thrown
aedart Mar 26, 2024
56f958d
Add tests for build()
aedart Mar 26, 2024
3576c64
Fix missing JSDoc @type for callback options
aedart Mar 27, 2024
23aff6e
Refactor / Redesign array merge, use a custom "Merger" class
aedart Mar 27, 2024
01cad92
Change release notes
aedart Mar 27, 2024
3dcf9de
Rename to Merger
aedart Mar 27, 2024
9f8e3d9
Add tests for custom merge options and callback
aedart Mar 27, 2024
850bf7b
Add merge options docs, for array merge
aedart Apr 2, 2024
a556cae
Change formatting of arguments
aedart Apr 2, 2024
cb54030
Add array merge options, in object merge
aedart Apr 2, 2024
bf47a89
Change release notes
aedart Apr 2, 2024
90a7f65
Add ref. to array merge options, for object merge
aedart Apr 2, 2024
04bff8c
Fix unable to merge arrays containing functions
aedart Apr 2, 2024
0aff652
Change build test, use classes as dependencies directly
aedart Apr 2, 2024
4432040
Change release notes
aedart Apr 2, 2024
bf01df7
Cleanup
aedart Apr 2, 2024
f8c8ccd
Fix dependencies not resolved for callback-wrapper
aedart Apr 2, 2024
128f0f6
Fix dependencies are not resolved for class method when called
aedart Apr 2, 2024
6216e20
Add tests for call()
aedart Apr 2, 2024
3734629
Add tests for extend()
aedart Apr 2, 2024
a216bce
Change order and semantics of rebound callback arguments
aedart Apr 2, 2024
9c6c376
Add tests for rebinding()
aedart Apr 2, 2024
92de8b0
Refactor forget() to use forgetInstance()
aedart Apr 2, 2024
1cde068
Add tests for forget()
aedart Apr 2, 2024
eaa28a3
Add test for flush()
aedart Apr 2, 2024
dacc5c6
Add test for before() and after()
aedart Apr 2, 2024
6c21cf6
Add Facade abstraction
aedart Apr 3, 2024
ccc68f5
Add service container facade
aedart Apr 3, 2024
c0b1c24
Export facades
aedart Apr 3, 2024
3aaf42b
Add notice for Facade abstraction
aedart Apr 3, 2024
f6922a3
Export facade sub-module
aedart Apr 3, 2024
5e82b15
Mark support/facades as external
aedart Apr 3, 2024
742f939
Fix lint
aedart Apr 3, 2024
2683118
Improve descriptions
aedart Apr 4, 2024
4da4b74
Add resolveIdentifier() method
aedart Apr 4, 2024
0f7cb78
Fix Abstract Class Error argument
aedart Apr 4, 2024
91f582a
Rename destroyFacades() to destroy()
aedart Apr 4, 2024
a562307
Fix private properties are not inherited by child classes
aedart Apr 4, 2024
a9c428e
Init contracts/support/facades submodule
aedart Apr 4, 2024
ec0e814
Add SpyFactoryCallback type alias
aedart Apr 4, 2024
8e3d53d
Export facade related types aliases
aedart Apr 4, 2024
f004bfe
Ignore any type
aedart Apr 4, 2024
2517951
Replace spy callback type with SpyFactoryCallback type alias
aedart Apr 4, 2024
748170b
Improve JSDoc for Container Facade
aedart Apr 4, 2024
6f1d1d7
Add tests for Facade abstraction
aedart Apr 4, 2024
31dd7b8
Change release notes
aedart Apr 4, 2024
3ad91ce
Change from private to protected visibility for class properties
aedart Apr 4, 2024
33ecd57
Change release notes
aedart Apr 4, 2024
54953ec
Change release note
aedart Apr 4, 2024
801d77b
Add Contextual Binding Builder interface
aedart Apr 4, 2024
8ea50a0
Change give(), allow TypeError to be thrown
aedart Apr 4, 2024
af894b7
Add concrete Contextual Binding Builder
aedart Apr 4, 2024
a9a18b3
Mark lodash-es as external dependency
aedart Apr 4, 2024
80fe7d2
Change Container, add support for contextual binding
aedart Apr 4, 2024
87f4ace
Add hasContextualBindings()
aedart Apr 4, 2024
553c9a7
Refactor, use spread arg. for concrete
aedart Apr 4, 2024
2584da6
Add tests for contextual bindings
aedart Apr 4, 2024
63745f3
Clear contextual bindings when flush() is invoked
aedart Apr 5, 2024
e8d368a
Rename _instance to "instance"
aedart Apr 5, 2024
e1e4235
Add description of service container package
aedart Apr 5, 2024
7594ba3
Add Service Container introduction
aedart Apr 5, 2024
9a53949
Add prerequisites for using service container
aedart Apr 5, 2024
463927a
Add how to install guide for service container
aedart Apr 5, 2024
768f2b3
Add guide for how to obtain container instance
aedart Apr 5, 2024
3d2f7ad
Add bindings section (incomplete)
aedart Apr 5, 2024
da04c93
Add how to resolve dependencies guide (incomplete)
aedart Apr 5, 2024
d038486
Add Service Container package docs collection
aedart Apr 5, 2024
0336af9
Add guide on how to define dependencies (incomplete)
aedart Apr 5, 2024
f9b76a1
Add dependencies section
aedart Apr 5, 2024
81f62a5
Add guide for how to define contextual bindings (incomplete)
aedart Apr 5, 2024
acf309c
Add contextual bindings
aedart Apr 5, 2024
5929676
Add make() method section (incomplete)
aedart Apr 5, 2024
9bd052d
Add binding basics, identifiers, concrete types,...etc
aedart Apr 5, 2024
84b11fc
Improve sentence
aedart Apr 8, 2024
ffca9d8
Improve sentence
aedart Apr 8, 2024
5fef3a3
Improve sentences
aedart Apr 8, 2024
eab4403
Improve sentences
aedart Apr 8, 2024
00cabcc
Add guide for defining dependencies on class constructors
aedart Apr 8, 2024
85482ea
Improve sentence
aedart Apr 8, 2024
dc04092
Add guide on how to resolve components and values from container
aedart Apr 8, 2024
6c38127
A guide for contextual bindings
aedart Apr 8, 2024
95becf5
Add Facades doc (incomplete)
aedart Apr 8, 2024
ab22048
Add support/facades collection
aedart Apr 8, 2024
f7f04b0
Refactor Facade, remove the need for resolveIdentifier()
aedart Apr 9, 2024
ed3242a
Fix JSDoc type
aedart Apr 9, 2024
dfafaa5
Refine Facades docs
aedart Apr 9, 2024
b862c57
Highlight Service Container and Facades
aedart Apr 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 32 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,18 +9,48 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Added

* Add upgrade guide from v0.7.x- to v0.10.x.
* Service Container package (`@aedart/container`).
* `Facade` abstraction, in `@aedart/support/facades`.
* `DEPENDENCIES` symbol and `Identifier` type in `@aedart/contracts/container`.
* `dependsOn()`, `dependencies()`, `hasDependencies()`, and `getDependencies()`, in `@aedart/support/container`.
* `isBindingIdentifier`, in `@aedart/support/container`.
* `ClassMethodName` and `ClassMethodReference` type aliases in `@aedart/contracts`.
* `isMethod()` util in `@aedart/support/reflections`.
* `ConstructorLike` and `Callback` type aliases, in `@aedart/constracts`.
* `CallbackWrapper` util class, in `@aedart/support`.
* `isCallbackWrapper` util, in `@aedart/support`.
* `ArbitraryData` concern, in `@aedart/support`.
* `arrayMergeOptions` in object `merge()`.
* Add upgrade guide for "v0.7.x- to v0.10.x".

### Changed

**Breaking**

* Added `hasAny()` method in `TargetRepository` interface, in `@aedart/contracts/meta`.
* Default generic for `defaultValue` changed to `undefined`, for `get()` methods in meta `Repository` and `TargetRepository`.

**Non-breaking Changes**

* Root package Typescript dependency changed to `^5.4.2`.
* `@typescript-eslint/eslint-plugin` upgraded to `^7.1.1`, in root package.
* Decorator return types for `meta()`, `targetMeta()`, and `inheritTargetMeta()` (_continued to cause TS1270 and TS1238 errors_). [#8](https://github.com/aedart/ion/pull/8), [#9](https://github.com/aedart/ion/pull/9).
* Refactored all classes' fields, changed from private to protected visibility (_see [private is not inherited](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Inheritance_and_the_prototype_chain) for details in_).
* Removed decorator return types for `use()`, `meta()`, `targetMeta()`, and `inheritTargetMeta()` (_continued to cause TS1270 and TS1238 errors_). [#8](https://github.com/aedart/ion/pull/8), [#9](https://github.com/aedart/ion/pull/9).
* Refactored `hasAllMethods()` to use new `isMethod()` internally, in `@aedart/support/reflections`.
* Refactored all components that used deprecated `ConstructorOrAbstractConstructor` to use new `ConstructorLike` type alias.
* Marked `isClassConstructor()` and `isCallable()` as stable, in `@aedart/support/reflections`.
* Refactored / redesigned the array `merge()` to use a new `ArrayMerger` component, that allows custom merge callback and options.

### Fixed

* Decorator types aliases (_TS1270 and TS1238 issues when applying the various decorator and decorator result types_). [#8](https://github.com/aedart/ion/pull/8).
* Broken link in docs for `isArrayLike`.
* Missing `tslib` as peer dependency for `@aedart/support` package.
* Unable to merge arrays containing functions, in `MetaRepository`.

### Deprecated

* `ConstructorOrAbstractConstructor` type alias. It has been replaced with the new `ConstructorLike` type., in `@aedart/constracts`.

## [0.10.0] - 2024-03-07

Expand Down
4 changes: 2 additions & 2 deletions NOTICE
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@ NOTICES AND INFORMATION
Please do not translate or Localize.

Parts of the herein provided software are considered an "adaptation", or "derivative work", of 3rd party software.
Below you will find general information about which parts are affected, or where you may find additional information
such, along with original license(s), terms and conditions as provided by the 3rd party software.
Below you will find general information about which parts are affected, or where you may find additional information,
along with original license(s), terms and conditions as provided by the 3rd party software.

3rd party software that are included as dependencies by this software is NOT covered by this NOTICE file, unless
explicitly required by 3rd party software license(s). You can find original license(s), terms and
Expand Down
5 changes: 5 additions & 0 deletions aliases.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,15 @@ module.exports = {
// conditionNames: ['require', 'import'],

alias: {
// container
'@aedart/container': path.resolve(__dirname, './packages/container/src'),

// contracts
'@aedart/contracts/container': path.resolve(__dirname, './packages/contracts/container'),
'@aedart/contracts/support/arrays': path.resolve(__dirname, './packages/contracts/support/arrays'),
'@aedart/contracts/support/concerns': path.resolve(__dirname, './packages/contracts/support/concerns'),
'@aedart/contracts/support/exceptions': path.resolve(__dirname, './packages/contracts/support/exceptions'),
'@aedart/contracts/support/facades': path.resolve(__dirname, './packages/contracts/support/facades'),
'@aedart/contracts/support/meta': path.resolve(__dirname, './packages/contracts/support/meta'),
'@aedart/contracts/support/mixins': path.resolve(__dirname, './packages/contracts/support/mixins'),
'@aedart/contracts/support/objects': path.resolve(__dirname, './packages/contracts/support/objects'),
Expand Down
26 changes: 26 additions & 0 deletions docs/.vuepress/archive/Version0x.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,20 @@ export default PagesCollection.make('v0.x', '/v0x', [
collapsible: true,
children: [
'packages/',
{
text: 'Container',
collapsible: true,
children: [
'packages/container/',
'packages/container/prerequisites',
'packages/container/install',
'packages/container/container-instance',
'packages/container/bindings',
'packages/container/dependencies',
'packages/container/resolving',
'packages/container/contextual-bindings',
]
},
{
text: 'Contracts',
collapsible: true,
Expand Down Expand Up @@ -77,6 +91,13 @@ export default PagesCollection.make('v0.x', '/v0x', [
'packages/support/exceptions/customErrors',
]
},
{
text: 'Facades',
collapsible: true,
children: [
'packages/support/facades/',
]
},
{
text: 'Meta',
collapsible: true,
Expand Down Expand Up @@ -141,9 +162,13 @@ export default PagesCollection.make('v0.x', '/v0x', [
'packages/support/reflections/hasAllMethods',
'packages/support/reflections/hasMethod',
'packages/support/reflections/hasPrototypeProperty',
'packages/support/reflections/isCallable',
'packages/support/reflections/isClassConstructor',
'packages/support/reflections/isClassMethodReference',
'packages/support/reflections/isConstructor',
'packages/support/reflections/isKeySafe',
'packages/support/reflections/isKeyUnsafe',
'packages/support/reflections/isMethod',
'packages/support/reflections/isSubclass',
'packages/support/reflections/isSubclassOrLooksLike',
'packages/support/reflections/isWeakKind',
Expand All @@ -164,6 +189,7 @@ export default PagesCollection.make('v0.x', '/v0x', [
'packages/support/misc/toWeakRef',
]
},
'packages/support/CallbackWrapper',
]
},
{
Expand Down
40 changes: 40 additions & 0 deletions docs/archive/current/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,46 @@ _TBD: "To be decided"._

## `v0.x` Highlights

### Service Container <Badge type="tip" text="Available since v0.11" />

An adaptation of Laravel's Service Container that offers a way to with powerful tool to manage dependencies and perform
dependency injection.

```js
import { Container } from "@aedart/container";

container.bind('storage', () => {
return new CloudService('s3');
});

// Later in your application.
const storage = container.make('storage');
```

For additional examples, see the [Service Container documentation](./packages/container/README.md).

### Facades <Badge type="tip" text="Available since v0.11" />

Adaptation of Laravel's Facade component. It acts as an interface or gateway to an underlying object that is resolved
from the Service Container.

```js
import { Facade } from "@aedart/support/facades";

export default class ApiFacade extends Facade
{
static getIdentifier()
{
return 'api_client';
}
}

// Later in your application
const promise = ApiFacade.obtain().fetch('https://acme.com/api/users');
```

See the [Facades documentation](./packages/support/facades/README.md) for additional details.

### Concerns <Badge type="tip" text="Available since v0.9" />

Intended as an alternative to mixins, the [Concerns](./packages/support/concerns/README.md) submodule offers a different
Expand Down
83 changes: 83 additions & 0 deletions docs/archive/current/packages/container/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
---
title: Introduction
description: Ion Service Container package
sidebarDepth: 0
---

# Introduction <Badge type="tip" text="Available since v0.11" vertical="middle" /><Badge type="success" text="Browser" vertical="middle" />

The `@aedart/container` package offers an adaptation of [Laravel's Service Container](https://laravel.com/docs/11.x/container)
(_originally licensed under [MIT](https://github.com/laravel/framework/blob/11.x/src/Illuminate/Container/LICENSE.md)_).

The tools provided by this package give you a way to:
* Manage class dependencies
* Perform [dependency injection](https://en.wikipedia.org/wiki/Dependency_injection)

## Example

### Bindings

Imagine that you have an Api client (_or any component for that matter_). Whenever it is needed, you want it to be
injected into components that depend on it.

```js
export default class ApiClient
{
// ...implementation not shown...
}
```

To ensure that dependency injection can be performed, you must first bind the component in the service container.
Each binding requires a unique identifier, e.g. a string, symbol, number...etc.

```js
import { Container } from "@aedart/container";
import { ApiClient } from "@acme/api";

const container = Container.getInstance();

// Bind 'my_api_client' to the ApiClient component...
container.bind('my_api_client', ApiClient);
```

### Define Dependencies

To define the dependencies of a component, use the `dependencies()` decorator.
By itself, the decorator does not do anything more than to associate a component with one or more dependencies
(_binding identifiers_). In other words, the decorator _**does not automatically inject**_ anything into your class.
It only registers the dependencies as [metadata](../support/meta) onto a class.

```js
import { dependencies } from "@aedart/support/container";

@dependencies('my_api_client')
export default class BookService
{
apiClient;

constructor(client) {
this.apiClient = client;
}

// ...remaining not shown...
}
```

### Resolve

When you want to resolve a component, with all of its dependencies injected into it, use the service container's `make()`
method.

```js
import { Container } from "@aedart/container";
import { BookService } from "@acme/app/services";

const bookService = Container.getInstance().make(BookService);

console.log(bookService.apiClient); // ApiClient
```

### Onward

The above shown example illustrates the most basic usage of the service container. Throughout the remaining of this
package's documentation, more examples and use-cases are covered.
Loading
Loading