Open vdegenne opened 11 months ago
Start a new pull request in StackBlitz Codeflow.
This is breaking rollup-plugin-import-css-classes when running on Vite.
I created a package which currently supports only webpack but I would love to add support for Vite too.
Unfortunately I get The "code" property of ModuleInfo is not supported.
during vite dev:
The information I need is available but only behind a private api (this._container.moduleGraph.idToModuleMap.get(id).transformResult.code
)
With Webpack it is possible during dev and build https://webpack.js.org/api/loaders/#thisloadmodule to access the code
and attributes
of other modules
Is there anything I can do to support adding this feature?
It appears that the return value of this.load
differs between serve and build modes.
In serve mode, the moduleInfo
object only contains the id and meta properties, as seen in these lines:
While we can manually obtain a ModuleNode
object using this._container.moduleGraph.getModuleById(id)
, the transformResult
remains null. This suggests that the module might not have been loaded or transformed at all.
In build mode, everything just works as expected.
Describe the bug
When using
this.getModuleInfo(id).attributes
in a plugin (for instance intransform
hook) the following error occurs :But the same code works in native Rollup plugins.
related issue: Support for moduleInfo.meta in resolveId hook still not equivalent in vite dev and vite build
Reproduction
https://stackblitz.com/edit/vitejs-vite-5et2xu?file=vite.config.js&terminal=dev
System Info
Used Package Manager
npm
Logs
Click to expand!
```shell 10:46:44 PM [vite] Internal server error: [vite] The "attributes" property of ModuleInfo is not supported. ```Validations