data:image/s3,"s3://crabby-images/c5096/c5096d0976b814f9c3c12229d0cd3738e8766418" alt="Cover Image for Effortlessly Navigate TypeScript Code in VSCode with This Handy Tip"
Effortlessly Navigate TypeScript Code in VSCode with This Handy Tip
data:image/s3,"s3://crabby-images/e7247/e7247844be5125d0864308b5836a8e206c322494" alt="Bartek Witczak"
data:image/s3,"s3://crabby-images/e7247/e7247844be5125d0864308b5836a8e206c322494" alt="Bartek Witczak"
How often do you use Go to Definition in VSCode? I use it quite often, especially when working with new libraries. When working with TypeScript, you've probably noticed that Go to Definition goes to the TypeScript declaration file, usually index.d.ts
. It's great. Most of the time, I want to check the type definition:
- Drill into possible params
- Check if generics are supported
- Debug why I'm getting compiler errors
Still, once in a while, I want to dive into the code. Usually, I didn't even bother to check VSCode options. I simply dive into the GitHub repo. But it's slow. 🐢 Navigating between files is cumbersome. I cannot use my VIM super powers. Ehhhhh.
Last time I was digging into GraphQL pagination. We're using Apollo with relayStylePagination. Muscle memory took me to the file declaration. But the pure type definition was not helping:
export declare function relayStylePagination<TNode extends Reference = Reference>(keyArgs?: KeyArgs): RelayFieldPolicy<TNode>;
I had to dig into the source code. I didn't want to play with GitHub. Luckily, there's an option: TypeScript: Go to Source Definition. 🥳
data:image/s3,"s3://crabby-images/9605d/9605df4724921d9761648d59852975082e5e4554" alt="Go to Source Definition"
You don't know what you don't know.
Why didn't I check that years ago? I don't know. Until the need was big enough, I didn't even bother to check for options. I also didn't find anyone writing / talking about that, so I didn't discover this by accident. 😜
Now you know. I hope you find that useful. 💪