Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kvist-no/awilix-vite
Simplify auto-loading of modules in Awilix for Vite projects.
https://github.com/kvist-no/awilix-vite
awilix ioc ioc-container javascript vite vitejs
Last synced: 2 months ago
JSON representation
Simplify auto-loading of modules in Awilix for Vite projects.
- Host: GitHub
- URL: https://github.com/kvist-no/awilix-vite
- Owner: kvist-no
- License: mit
- Created: 2024-07-08T11:33:04.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-10-08T07:51:01.000Z (4 months ago)
- Last Synced: 2024-11-15T03:13:39.138Z (2 months ago)
- Topics: awilix, ioc, ioc-container, javascript, vite, vitejs
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/awilix-vite
- Size: 34.2 KB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# awilix-vite
The awilix-vite plugin is designed for the [Awilix dependency injection library](https://github.com/jeffijoe/awilix). It provides a loadModules method that allows Vite users to achieve almost the same behavior as the loadModules method in the original Awilix library by using Vite's `import.meta.glob`. The available `loadModules` method will take the result from `import.meta.glob` and load the modules correctly with Awilix.
## Installation
To install the awilix-vite plugin, you need to have Awilix and Vite set up in your project. You can then install the plugin via your desired package manager:```
npm install awilix-vite
```## Usage
The `loadModules` method provided by this plugin allows you to load and register modules into an Awilix container using the result of Vite's `import.meta.glob` function.
### Importing the Plugin
```javascript
import { createContainer } from 'awilix/browser';
import { loadModules } from 'awilix-vite';
```### Setting Up the Container
Create an Awilix container where the modules will be registered.
```javascript
const container = createContainer();
```### Loading Modules
Use the `import.meta.glob` with `eager` set to `true` to dynamically import your modules.
```javascript
const modules = import.meta.glob('./path/to/modules/*.js', { eager: true });loadModules(container, modules, {
resolverOptions: {
// Optional: Awilix resolver options
},
formatName: (name) => name // Optional: Custom function to format module names, defaults to camelCase
});
```#### Why use { eager: true }?
When using `import.meta.glob` Vite will transform the code
```javascript
const modules = import.meta.glob('./dir/*.js')
```into the following output:
```javascript
// code produced by vite
const modules = {
'./dir/foo.js': () => import('./dir/foo.js'),
}
```while using `eager: true` will result in the following output:
```javascript
// code produced by vite:
import { setup as __glob__0_0 } from './dir/foo.js'
import { setup as __glob__0_1 } from './dir/bar.js'
const modules = {
'./dir/foo.js': __glob__0_0,
'./dir/bar.js': __glob__0_1,
}
```When using `loadModules` all the modules are supposed to be loaded immediately, so there is no benefit in importing the the modules lazily. Therefore we recommend setting `eager: true` to increase performance.
### Example
Here's a complete example of how to use the awilix-vite plugin to load and register modules.```javascript
import { createContainer } from 'awilix/browser';
import { loadModules } from 'awilix-vite';const container = createContainer();
const modules = import.meta.glob('./services/*.js', { eager: true });
loadModules(container, modules, {
resolverOptions: {
lifetime: 'SINGLETON' // Example: Set lifetime to SINGLETON
},
formatName: (name) => `myPrefix${name.charAt(0).toUpperCase() + name.slice(1)}` // Example: Prefix and camelCase module names
});
```## API
`loadModules(container, globResult, options)`
Parameters
- container (required): The Awilix container where the modules should be registered.
- globResult (required): The result of either import.meta.glob('/*.js') or import.meta.glob('/*.js', { eager: true }).
- options (optional): An object containing the following properties:
- resolverOptions: Optional Awilix resolver options.
- formatName: Optional function to format module names.## Why do i have to use `import.meta.glob`?
The `import.meta.glob` method will be transformed by Vite from
```javascript
const modules = import.meta.glob('./dir/*.js', { eager: true })
```into
```javascript
// code produced by vite:
import { setup as __glob__0_0 } from './dir/foo.js'
import { setup as __glob__0_1 } from './dir/bar.js'
const modules = {
'./dir/foo.js': __glob__0_0,
'./dir/bar.js': __glob__0_1,
}
```by using static code analysis. Because of this behaviour, it's not possible to create a function like this:
```javascript
function loadModules(glob) {
return import.meta.glob(glob, { eager: true })
}
```Vite will not know what files should be imported since the code is transformed during build. This is why
you have to seperately use the `import.meta.glob` yourself, and use the `loadModules` method from this library to
correctly load the modules automatically with Awilix.