Open elderapo opened 5 years ago
This issue has been automatically marked as stale because it has not had any recent activity. It will be closed in 5 days if no further activity occurs.
Are there any plans regarding this issue?
I understand that there might not be an easy fix becuase of how babel compiles typescript. However, there are few nice libraries (ex. InversifyJS
) that heavily rely on reflect-metadata
package and the fact that cra-2
is not complatible is really discouraging.
I think this would need to be addressed in Babel. Can you find or create an issue there and link to it here?
@iansu, here you go https://github.com/babel/babel/issues/9681.
Any likelihood of getting babel-plugin-transform-typescript-metadata added? It seems like a sensible default if Typescript is used anywhere, since a lot of libraries use the type metadata.
That might be possible. It depends how mature that plugin is and what kind of impact it has on build performance. cc @ianschmitz @mrmckeb
Can anyone confirm the stability of the metadata proposal? What stage is it in? Last time I checked I seem to remember it not having been proposed yet as they were waiting for decorators to be later stage?
We typically don't support early stage proposals in CRA as they are too volatile. For example the decorators proposal changed drastically during the first couple stages.
@iainbeeston can we config babel and eslint in CRA?In this way, the responsibility for maintaining the plugin of babel can be given to the user.
Is there any workaround for this to get any dependency injection library to run?
Is there any workaround for this to get any dependency injection library to run?
@Obiwarn You can use a package like https://github.com/arackaf/customize-cra, which allows you to load extra babel plugins without ejectting cra. You can then include the babel-plugin-transform-typescript-metadata plugin
@rmoedt I installed both and tried
const { override, addExternalBabelPlugin } = require("customize-cra");
module.exports = override(
addExternalBabelPlugin("babel-plugin-transform-typescript-metadata")
);
But tsyringe still throws Error: TypeInfo not known
@rmoedt I installed both and tried
const { override, addExternalBabelPlugin } = require("customize-cra"); module.exports = override( addExternalBabelPlugin("babel-plugin-transform-typescript-metadata") );
But tsyringe still throws
Error: TypeInfo not known
@Obiwarn I was running into the same issue with CRA x TSyringe. I didn't try customize-cra
but craco
did it for me. See https://github.com/microsoft/tsyringe/issues/29#issuecomment-652596008
// craco.config.js
module.exports = function ({ env: _env }) {
return {
babel: {
plugins: [
"babel-plugin-transform-typescript-metadata"
]
},
};
};
@kmannislands Thank you. I tried it but now, in the classes I use mobx-decorators I get:
TypeError: Reflect.metadata is not a function
@Obiwarn You need to install and import reflect-metadata
package.
@elderapo argh....forgot the import. Thank you!
Now it works!
Now with CRA 4.0 craco breaks, and I don't know if they gonna fix that, after all craco is a big hack, and not a real fix for the main issue that we can't configure babel, or extract metadata, and exporting metadata is a must now days. We have a dependency library that we use in our projects with a useDependency
hook, and we need this feature. We can't upgrade to CRA 4.0 because that breaks craco, but the old CRA is old, and throws random linter errors when working with complex generic cases. Is there any possibility at all to fix this inside CRA without the need of a hack?
I installed craco today and used the configuration from @kmannislands and it worked ❤️
I installed craco today and used the configuration from @kmannislands and it worked heart
It worked but I had to add import 'reflect-metadata'
in the very file where I'm using the @Type
decorator.
Is there anyway to import it just once in intex.tsx
and be done with it?
Does anyone know how to handle the issue with transpilation of es6 syntax with babel? When I try to use tsyringe with craco, I run into the problem when using autoinjection "TypeError: Class constructor x cannot be invoked without 'new'"
Does anyone know how to handle the issue with transpilation of es6 syntax with babel? When I try to use tsyringe with craco, I run into the problem when using autoinjection "TypeError: Class constructor x cannot be invoked without 'new'"
edit tsconfig.json, change "target" value from "es5" to "es6" or more
Is this a bug report?
Yes
Did you try recovering your dependencies?
No
Which terms did you search for in User Guide?
None
Environment
Steps to Reproduce
Just follow the steps from the
Reproducible Demo
part and open console in browser.Expected Behavior
Browsers console should print
someProperty type: Number
.Actual Behavior
It prints
couldn't get the type :(
.Reproducible Demo
The problem
I think the problem is that babel completely strips out TS types before compilation process which makes it impossible for
reflect-metadata
package to do its work.