Remix is a powerful web framework for building modern JavaScript applications. One of its key features is its flexible stack-based architecture, which provides a unified API for client-side and server-side rendering. In this post, we'll explore Remix Stacks, which are pre-configured stacks of middleware and components that can be used to quickly build and customize different types of web applications.
Remix Stacks are essentially pre-configured sets of middleware and UI components that provide specific functionality for building different types of web applications. They are designed to make it easy to build scalable and maintainable web applications, without having to spend a lot of time configuring each individual component.
There are currently three main types of Remix Stacks: Blues, Indie, and Grunge. Each stack is designed for different use cases and provides a different set of features and technologies.
The Blues Stack is designed for building traditional server-rendered web applications.
It uses technologies like Node.js, Express, and Handlebars to provide a powerful and flexible server-side rendering engine. The Blues Stack also includes support for client-side rendering using React, and it includes pre-configured middleware for handling things like user authentication, caching, and API requests.
Some good applications of the Blues stack would be: a blogging platform, an e-commerce website, or a news website. This is because the Blues Stack provides a powerful server-side rendering engine, which allows for fast initial load times and better search engine optimization (SEO).
Why you should not use other stacks on Blues Stack: Using other stacks on Blues Stack would be unnecessary as the Blues Stack is specifically designed for server-side rendering. For instance, using the Indie Stack on a traditional server-rendered web application would be overkill, as it would add unnecessary complexity to the project and potentially slow down the initial load time of the website.
Here's an example of a real-life code application that would be most suitable for the Blues Stack:
bluesStack.js
1const express = require('express');2const handlebars = require('handlebars');34const app = express();56app.engine('handlebars', handlebars());7app.set('view engine', 'handlebars');89app.get('/', (req, res) => {10res.render('home', { title: 'Welcome to my website!' });11});1213app.listen(3000, () => {14console.log('Server is running on port 3000');15});16
In this example, we're using the Express framework to create a web server that renders Handlebars templates. We've set the view engine to Handlebars, and we're rendering a home template with a dynamic title value. This code application is well-suited for the Blues Stack because it requires server-side rendering and uses Handlebars as its templating engine.
You should not use the Indie or Grunge Stacks on this code application because they are designed for different use cases. The Indie Stack is designed for building progressive web applications and single-page applications, while the Grunge Stack is designed for building complex web applications with advanced features.
The Indie Stack is designed for building progressive web applications (PWAs) and single-page applications (SPAs). It uses technologies like React, Next.js, and Emotion to provide a powerful and flexible client-side rendering engine. The Indie Stack also includes pre-configured middleware for handling things like routing, caching, and API requests.
Some good applications of the Indie stack would be: a social media platform, a project management tool, or a messaging app. This is because the Indie Stack provides a powerful client-side rendering engine, which allows for faster page transitions and a more interactive user experience.
Why you should not use other stacks on Indie Stack: Using other stacks on the Indie Stack would be unnecessary as the Indie Stack is specifically designed for client-side rendering. For example, using the Blues Stack on a progressive web application would be overkill, as it would add unnecessary complexity to the project and potentially slow down the page transition speed of the application.
Here's an example of a real-life code application that would be most suitable for the Indie Stack:
indieStack.js
1import React from 'react';2import ReactDOM from 'react-dom';3import { BrowserRouter, Route, Switch } from 'react-router-dom';4import { Global, css } from '@emotion/core';56import Home from './pages/Home';7import About from './pages/About';8import NotFound from './pages/NotFound';910const globalStyles = css`11body {12margin: 0;13padding: 0;14font-family: sans-serif;15}16`;1718ReactDOM.render(19<BrowserRouter>20<Global styles={globalStyles} />21<Switch>22<Route exact path="/" component={Home} />23<Route path="/about" component={About} />24<Route component={NotFound} />25</Switch>26</BrowserRouter>,27document.getElementById('root')28);29
In this example, we're using React and React Router to create a client-side rendered application. We've set up routes for the Home, About, and NotFound pages, and we're using Emotion to apply global styles to the application. This code application is well-suited for the Indie Stack because it requires client-side rendering and uses React as its primary framework.
You should not use the Blues or Grunge Stacks on this code application because they are designed for different use cases. The Blues Stack is designed for building traditional server-rendered web applications, while the Grunge Stack is designed for building complex web applications with advanced features.
The Grunge Stack is designed for building complex web applications that require advanced features like real-time collaboration and serverless functions. It uses technologies like React, Next.js, and AWS Amplify to provide a powerful and flexible architecture for building these types of applications. The Grunge Stack also includes pre-configured middleware for handling things like data synchronization, authentication, and real-time messaging.
Some good applications of the Indie stack would be: a real-time document collaboration tool, a video conferencing platform, or an online game. This is because the Grunge Stack provides a powerful and flexible architecture for building these types of applications. It uses technologies like React, Next.js, and AWS Amplify to provide advanced features like real-time data synchronization, serverless functions, and real-time messaging.
Why you should not use other stacks on Grunge Stack: Using other stacks on the Grunge Stack would be unnecessary as the Grunge Stack is specifically designed for building complex web applications with advanced features. For example, using the Blues Stack on a real-time document collaboration tool would not provide the necessary real-time data synchronization and serverless functions needed for this type of application. Similarly, using the Indie Stack on an online game would not provide the necessary real-time messaging and data synchronization features required for a seamless multiplayer gaming experience.
Here's an example of a real-life code application that would be most suitable for the Grunge Stack:
grungeStack.js
1import React, { useState, useEffect } from 'react';2import { API } from 'aws-amplify';3import { withAuthenticator } from '@aws-amplify/ui-react';4import { v4 as uuid } from 'uuid';56import TodoList from './components/TodoList';7import TodoForm from './components/TodoForm';89function App() {10const [todos, setTodos] = useState([]);1112useEffect(() => {13fetchTodos();14}, []);1516async function fetchTodos() {17const apiData = await API.get('todos', '/todos');18setTodos(apiData.data);19}2021async function addTodo(text) {22const newTodo = { id: uuid(), text };23const apiData = await API.post('todos', '/todos', {24body: newTodo,25});26setTodos([...todos, apiData.data]);27}2829async function deleteTodo(id) {30await API.del('todos', `/todos/${id}`);31setTodos(todos.filter(todo => todo.id !== id));32}3334return (35<div>36<h1>My Todo List</h1>37<TodoForm addTodo={addTodo} />38<TodoList todos={todos} deleteTodo={deleteTodo} />39</div>40);41}4243export default withAuthenticator(App);44
In this example, we're using React, AWS Amplify, and the Amplify UI library to build a real-time todo list application. We've set up API endpoints for getting, creating, and deleting todos, and we're using the Amplify API
object to make requests to these endpoints. This code application is well-suited for the Grunge Stack because it requires advanced features like real-time collaboration and serverless functions.
You should not use the Blues or Indie Stacks on this code application because they are designed for different use cases. The Blues Stack is designed for building traditional server-rendered web applications, while the Indie Stack is designed for building progressive web applications and single-page applications.
Each stack has its own set of strengths and weaknesses, and the best one to use depends on the specific needs of your project. For example, if you're building a traditional server-rendered web application, the Blues Stack is a great choice. If you're building a progressive web application or single-page application, the Indie Stack is a good choice. And if you're building a complex web application with advanced features, the Grunge Stack is a good choice.
In conclusion, Remix Stacks are a powerful feature of the Remix web framework that make it easy to build scalable and maintainable web applications. By providing pre-configured sets of middleware and UI components for different use cases, Remix Stacks make it easy to get started with building web applications quickly and efficiently. Whether you're building a traditional server-rendered web application, a progressive web application, or a complex web application with advanced features, there's a Remix Stack that can help you get the job done.
Written by Alissa Nguyen
FollowAlissa Nguyen is a software engineer with main focus is on building better software with latest technologies and frameworks such as Remix, React, and TailwindCSS. She is currently working on some side projects, exploring her hobbies, and living with her two kitties.
Learn more about me
If you found this article helpful.
You will love these ones as well.
Built and designed by Alissa Nguyen a.k.a Tam Nguyen.
Copyright © 2025 All Rights Reserved.