frontend
frontend copied to clipboard
Add a "Prettify" button to the in-app GraphQL Console
Does what is says on the Tin!
data:image/s3,"s3://crabby-images/afef2/afef2eb17c058e2189491de019bdd89c24f470d5" alt="image"
GraphiQL (the editor that this is loosely based on) uses a pretty basic way of doing "prettification"
print(parse(query))
Essentially it parses the query into an AST, and re-prints the AST with some standard formatting rules. The biggest drawback with this approach is that comments aren't part of the AST, so they're dropped on the floor after hitting the "pretty" button - which is kinda shitty.
I've opted for pulling in the "prettier" package instead and which does do the right thing with comments. I'm doing a magical Webpack import thing since it's only used in this one place and there's no need to import for everything and bloat the main packages - hopefully I did it right!
Wow, I was going to ask “how big is Prettier?” and yikes!
data:image/s3,"s3://crabby-images/4b5bc/4b5bc6c19311823f58b324e5e7a7b61eaf7fc219" alt="image"
Good call lazy-loading.
brb implementing prettier in dev... 😉😜
@keithpitt are you still planning to land this?