Vite Plugin
@inox-tools/inline-mod/vite
exports the Vite plugin and the module declaration functions associated with the plugin.
To have virtual modules automatically resolved by Vite, just add the plugin to your Vite config like so:
The Vite plugin is exported as @inox-tools/inline-mod/vite
. It has no options. Adding it to your Vite config will automatically make Vite resolve any inline modules you define.
Use in other plugins
You can use this plugin embeded with your own plugin:
API
Along with the plugin, there are different functions to define virtual modules.
inlineModule
Use this function to define a module inline. It receives the definition of a module and returns the name of the defined virtual module.
constExports
option
type: Record<string, unknown>
Define values that should be exported as named constants.
For example:
Will generate a module that can be imported like so:
defaultExport
option
type: unknown
Define a value that should be exported as a default export.
For example:
Will generate a module that can be imported like so:
assignExports
option
Defines values that should be exported by assignment. This is a more advanced pattern to be used when you must export a value with a name that cannot be used as an ECMAScript identifier. This may be needed when your module is generated from external schemas.
In this case, the module can be imported using a wildcard import (import * as name
) but not by name individually.
For example, if a value should have the name function
:
This will generate a module like so:
serializeFn
option
A function to allow excluding values referred in the module from being serialized. A functions excluded from serialization will throw if called at runtime.
defineModule
This function accepts a name of a module and the same definition as inlineModule
. The generated module will be available at the given name instead of generating a new name.
Can be imported as:
factory
Define a factory for a value that should be constructed at runtime. Use this when serializing the entire value is unnecessary since the value re-constructed more easily at runtime or when serializing the constructed value is not possible (if it contain references to native values).
For example, an API client may hold references to open sockets, attempting to serialize such a value will result in an error:
To solve this problem, wrap the construction of the value with a factory like so:
Now, instead of attempting to serialize the client, the factory will be serialized the result of calling it will be exported:
The value constructed by the factory is also available at build time like before, but it is only constructed once you try to use it:
This means that if the value is not used during build it will only be constructed at runtime.
asyncFactory
Similar to factory
, this functions allows declaring how to construct a value at runtime. The key difference is that using asyncFactory
the return value of the given factory function will be awaited.
This is useful when you want to load remote information upon initialization of your module, like loading credentials from a remote secret manager.
Will generate the following module:
Just like factory
, the value can be used at runtime, but you need to pass the unawaited value to the module definition: