Stay up to date
Subscribe to the newsletter to stay up to date with articles, courses and much more!
I respect your privacy. Unsubscribe at any time.
Modern web development is fantastic. There are so many great tools available!
Modern web development is exhausting. There are so many great tools available!
Each of these sentiments is true. What’s great is that most of the time, it’s hard to make a choice that is wrong. Seriously. The trade-offs of most of the frameworks and tools you could use to build your application fit within the constraints of the vast majority of apps.
Despite this, engineers consistently struggle with analysis paralysis. Nobody likes the feeling of having to make a decision they’ll have to live with for the foreseeable future and find out it was the wrong one. Like a hungry person getting hungrier looking over menu that’s too long and full of great options, engineers find themselves guessing and second guessing our technology choices.
On top of that, getting team of engineers running the same direction with the chosen technology can be a big challenge. There are numerous considerations, existing skills, training for new skills, the hiring pool, personal preferences and experience, and more.
Oh, and then once you’ve finally selected a web framework, UI library, testing framework, hosting provider, etc. etc. you have to wire everything together before any meaningful work can get done.
And all of this is just a big distraction from what we’re really trying to accomplish here: ship a quality product.
I’ve been developing modern web applications big and small for nearly a decade. In that time, I’ve worked all over the stack. Significant technical decisions I’ve made are still in use at my previous companies (like PayPal). I’ve also made a number of technical decisions that didn’t pan out very well at all and I had to pay the price.
With the help of my team, I’ve shipped web applications to millions of users all over the world as well as smaller internal apps to a handful of stakeholders. I have a solid grip on what it takes to ship excellent user experiences and make choices that keep developer velocity (and morale) high.
That’s why I’ve decided to encode my experience on how to build excellent modern web applications into an opinionated project starter that allows teams to ship their ideas to production faster and on a more stable foundation. And it’s called “The Epic Stack”:
The primary goal of the Epic Stack is to help your team get over analysis paralysis by giving you solid opinions for technologies to use to build your web application. The Epic Stack is really two things:
For those of you starting a new project, you can use the create-remix
CLI custom stacks feature to bootstrap your app with npx create-remix@latest --typescript --install --template epicweb-dev/epic-stack
and you’ll be set.
But most people don't startup their computer every day and start a new project. Most of us work on an existing app. For those folks, the Epic Stack can be a great reference for configuring tools and integrating with solid libraries and services. The Epic Stack decision documents can also serve as a good place to find good arguments for the decisions and trade-offs made.
There’s far too much for us to talk about in a single blog post, so I’ll encourage you to dive into the docs for more and star the repo, but let’s get a high-level view of what you get when you use or follow The Epic Stack.
We’ll start with the guiding principles of the stack:
With that context, here are a few things you get today:
And that’s what we have today, here are some things that will likely find their way into the Epic Stack in the future:
A list of features is fine, but really what you’re getting out of this is a break from analysis paralysis. You get to ship faster on top a solid selection of technologies and tools.
Additionally, my goal is to make the Epic Stack second-to-none with regard to learning resources so your entire team can all get up-to-speed on your stack quickly. And having your entire team on the same page with regard to your stack is invaluable.
And that’s what EpicWeb.dev will be all about: How your team can take the Epic Stack foundation and build a quality application on top of it.
After all the time I’ve spent building web applications and learning from engineers with more experience than myself, I feel extremely confident that the Epic Stack will help tons of engineering teams focus on their core offering, move fast, and build excellent user experiences. I hope you give it a shot. Please join the community by participating in discussions on GitHub and the Epic Stack channels Discord.
See you around the web!
Share this article with your friends
Written by Kent C. Dodds
Kent C. Dodds is a world renowned speaker, teacher, and trainer and he's actively involved in the open source community as a maintainer and contributor of hundreds of popular npm packages. He is the creator of EpicReact.Dev and TestingJavaScript.com. He's an instructor on egghead.io and Frontend Masters. He's also a Google Developer Expert. Kent is happily married and the father of four kids. He likes his family, code, JavaScript, and Remix.
Stay up to date
Subscribe to the newsletter to stay up to date with articles, courses and much more!
I respect your privacy. Unsubscribe at any time.