-
-
Notifications
You must be signed in to change notification settings - Fork 32.4k
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
Typescript Types in beta 6 #7853
Comments
@stevegeek is it only the |
@sebald All typings it seems |
I could reproduce your issue with a clean setup. Sorry for any inconvenience 😞 So far, the only thing I can tell you is that moving the exact same file to |
@sebald I was getting some acceptable from the package. for example.
This will have error lines under There seems to be an extreme amount of inconsistencies with the types. To get the minimal typings from the package I have
added to my |
@marcusjwhelan until this is fixed you can just copy the typings file into your local types directory and everything should work just fine |
@stevegeek I guess I don't have a local types directory. My project is 100% Typescript, so my typings files are generated from my code. I have a couple of open source Typescript projects that I wrote and but I don't have experience with writing a typings file for a JS project. @sebald I also tried moving the typings file into the @types folder in my node modules however I come up with the same result as before. Was there a major change in the structure of the project since |
@marcusjwhelan have a look at https://stackoverflow.com/a/39827904/268602 it might help you set it up |
@stevegeek like I said I have experience with Typescript and know how to set up my project. What I am saying is that the typings form @types is very different from the Types that are shipped with this package. Either some parts like colors are missing or not typed the same way. There would have to be a large amount of missing types. The @types is almost 10k lines while the types shipped with material-ui is only 2.2k |
@marcusjwhelan Right, the types in DT are for 0.18.x , v1 is completely different , you will need to port your project to the new MUI version |
Ah, glad I'm not the only one having typing issues. I'm using tsx and VSCode and can't get it to pull the types from the material-ui package. Even moving them to my local code doesn't seem to be picked up anymore like the last version did. I wonder if it's because of the tests that were recently added. It may be bombing on the 'enzyme' reference and imports. Should that kind of stuff be in the released index.d.ts file? Would it be possible to release these typings as a matching beta version of |
I guess there are no types for material-ui-icons |
@marcusjwhelan They are generated automatically by a script, you will find them in the Though this issue probably also affects those typings , hence why they are not working from the npm installed package |
@stevegeek So I need to git clone beta.5 and run this script to get the typings for it? If it is supposed to automatically run then I don't see the output or am I receiving types for it. I am working to fallow the example given on the AppBar example on the .io website. I see now that the typings are there but very different and able to get the types just fine using the tsconfig which is fine. I did not know there was such a large difference being made. |
If you install the latest version of |
I tried a lot of things, but it seems there is no way to let TS use the I posted a question to SO. Maybe someone else can help If nothing comes from SO, there are basically two options I see: (1) generate files that augment I would prefer (2), because most of the work is already done. Although I am not sure how one imports/installs different versions of libraries with the |
I would also definitely prefer having it go through @types / DefinitelyTyped. I've always just imported them through package.json. I'd expect to import it like this Thanks for looking into all this! |
@sebald I saw that mhegazy was asking for a contained repro of the issues we're having here microsoft/TypeScript#17945 (comment). I quickly put this simple react tsx example together and stumbled onto an interesting situation and wanted to have you take a look. If you feel this represents the problem then feel free to link it to him. https://github.com/vyrotek/material-ui-tsx I tried adding a button to this component:
|
@vyrotek hey, thank you so much! 🙂 I'll still set my own, (a) because I already had that to trying to resolve the issue, (b) I can make changes to my own repo if the TS team requests any. The typings require you to have Even though I prefer (2), I makes my belly aches publishing these typings via |
@vyrotek @sebald Also MS themselves recommend bundling for reasons you stated above and versioning etc - https://www.typescriptlang.org/docs/handbook/declaration-files/publishing.html states z |
Oh, didn't know that 👍 MS! |
Hmm, that's a first for me. This seems a little unusual. Mostly because people won't know to do this until they try once and get the error. Is there no way to have this dependency automatically bundled? |
@sebald @vyrotek @stevegeek I have been using the typings just fine. Many projects are build this way. I just simply added I am not 100% sure I need the @oliviertassinari I am quiet annoyed by the move to |
|
As already pointed out, to make the typings work add the following to your {
"compilerOptions": {
+ "types": ["material-ui"]
}
} @oliviertassinari So, after talking to the TS team, the above is their recommended solution, if we leave the typings like that. An even better solution would by to create (what they call) modules. This basically means, like with flow, for every source file, there should be a Refactoring the typings like this isn't that much of work. If you think that it's annoying to have these typing files inside What do you think? (should I open a seperate issue to discuss this?) |
@sebald I don't have any objection to this change. As far as I recall, we went with the single file to ship the typing sooner. If you think that we should break this file into modules, great 👍 . I see two possible paths going forward. Either we document the compiler options or we create these modules. |
@oliviertassinari I think most people will run into issues, because it's not that common to have to set this compiler option. I never had to this in past project and actually thought that if I start to explicitly load types there that I have to do this for every new lib ... 😨 From an end-uster perspective, we should do the refactoring. Hopefully contributor will also see these typings and update them when they make changes :) Who knows!? I'll make some room tomorrow to apply the changes. Sorry again everyone reading here. Hope you didn't have too much trouble with the messed up typings :-x |
When using withStyles as decorator having this error |
@sebald No prob, the typings are amazing otherwise :)! |
@54vanya please open an issue with a full report. This is not enough information to reproduce your issue. |
if adding types to the compiler-options is not possible, it also works with a triple-slash directive:
at the beginning of any file. |
Problem description
@sebald In beta.6 the typescript types exist for material-ui (I see the .d.ts file in the installed package directory) however I keep getting definition errors when doing imports with
import Paper from 'material-ui/Paper';
error TS7016: Could not find a declaration file for module 'material-ui/Paper'. '...' implicitly has an 'any' type. Try 'npm install @types/material-ui/Paper' if it exists or add a new declaration (.d.ts) file containing 'declare module 'material-ui/Paper';'
Im not sure why, I dont think there is anything strange with my
tsconfig
Steps to reproduce
I installed beta.6 and removed my local copies of the material-ui typings (up to now Ive been keeping the typings locally)
Versions
The text was updated successfully, but these errors were encountered: