Skip to content

Build server-rendered and single-page React applications with no configuration

License

Notifications You must be signed in to change notification settings

cereallarceny/carioca

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

79 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Carioca

Carioca

Tests Coverage License Version

Sit back, drink a caipirinha, vai ficar tudo bem!

A starter project that gives you everything you need to start building great looking websites and web applications.

  • πŸ™Œ Zero-config development for React web applications
  • πŸš€ Full support for SPA (single-page applications) or SSR (server-side rendered) applications
  • πŸ’ Support for both Typescript and Javascript
  • πŸ™ˆ Built-in ESLint and Prettier for code formatting suggestions
  • πŸ”₯ Full hot-module replacement with error overlays in development
  • πŸ‘ Never worry about configuring Webpack for local development, builds, or deployments
  • πŸ’ͺ Write in the latest Javascript (we support up to ES2020)
  • TODO: Write better features section

Skip to installation instructions

Why do I need this?

There's no shortage of generator projects out there! Two of the most popular are Create React App for single-page applications and Razzle for server-rendered applications, but of course, there are many others. Carioca isn't special, but it is simple. Here's a few things that make this project a little different:

  • Carioca supports both single-page applications (SPA's) and server-side rendering (SSR). Create React App has made it very clear that they never have any intention of supporting SSR and directly tell you to use Razzle or Next.js to solve this purpose. Razzle also supports for SPA's and SSR.
  • Carioca is actively maintained. Razzle is not - at least the original author has loosely handed over development to a few other contributors. No shame there, that's the way open-source development goes. However, I'm paid to do only open-source development and I use Carioca in all of my projects (most notably OpenMined uses Carioca for all of its web applications). I'm going to be maintaining this for a while.
  • Carioca doesn't tie your builds to specific development environments. Razzle does. When you build, you're building for production. You can't build for development, which I find somewhat annoying when I find descreapancies between my development build using HMR and the final compiled build. It sucks to have to do that testing against production data - not cool!
  • Carioca is opinionated, but for good reason. I think you'll like Carioca's opinions. There are a few, but not too many to be obnoxious. A lot of projects aim to support every possible configuration of a React application, but this often results in a confusing, sloppy, and difficult-to-maintain codebase. I'm always open to PR's for new functionality, but the list of features isn't expected to increase unless there's a good reason.
  • Carioca is well documented. The entire codebase should read like a book and virtually every line in the project is well-explained so that you have context to follow along.
  • Carioca supports service workers and PWA's. Let us handle all that Webpack and Workbox nonsense for you - ain't no thang.
  • Carioca supports custom templates. What do you do every time you run npx create-react-app? You delete all the crap you don't need, remove all the styles, and spinning logos. Nonsense! With Carioca, we support your own custom templates so that whenever you start a new project it follows your project structure - not what I think is best for you.
  • Carioca supports smart SEO defaults. One of the opinions we've determined for you is how to handle SEO <meta> tags. Let's be honest, you don't like doing this anyhow. SEO is notoriously hard to implement on the server-side, but our reusable <Page> component make this stupid simple. If you really want to extend it to support your own tags, go for it!
  • Carioca supports internationalization by default. One of the last opinions we have is that websites should be built for the entire world to use. While it's not a requirement for your website to support more than one language, we've create some smart internationalization defaults so that its one less thing you need to think about. Considering internationalization is one of the hardest things I've come across in writing websites. Next.js is notorious for having internalization hiccups like adding the locale to the main <html> tag of the page... silliness.
  • Carioca supports multiple domain deployment by default. Speaking of internationalization, are you deploying multiple versions to multiple domains? I've been there, super tough. Carioca has support for multi-domain deployment combined with internationalization.

Opinions

Here's a relatively exhaustive list of opinions that carioca has about your build process:

  • You must use React and React Router, although technically it's fine if you only have a single route and don't use any React Router code yourself.
  • You must use Jest for testing, we also provide react-test-renderer behind the scenes. We also support overriding the default Jest configuration.
  • You must use Prettier for style enforcement and ESLint for enforcement of best-practices, although you may override the configuration of both.
  • You may use either Javascript or Typescript, and you may provide your own custom Typescript configuration.
  • We suggest you use Express for your server, although it's not strictly required.

Installation

Creating a new project

npx @carioca/generator

... and run through the prompt that follows!

Once you've finished, you can run:

  • yarn dev (or npm run dev) to start the development server (docs)
  • yarn build (or npm run build) to build your application (docs)
  • yarn test (or npm run test) to test your application (docs)
  • yarn start (or npm run start) to start your application (must run the build command first) (docs)

See the CLI documentation for more command options

Adding to an existing project

Using Yarn:

yarn add @carioca/scripts

Using NPM:

npm install @carioca/scripts

From there, you can run any of the following commands:

carioca dev - Runs a live-reload server for local development (docs) carioca build - Builds your application (docs) carioca test - Runs the Jest test suite (docs) carioca start - Starts your build application (docs)

See the CLI documentation for more command options

CLI

dev

Start the application in development mode

Options

  • -m, --mode: The mode you want to build as (ssr or spa) (default ssr)
  • -p, --port: The port where you want your application to run (default 3000)

Examples

  • carioca dev --mode spa
  • carioca dev --port 8000

build

Build the application

Options

  • -e, --env: The environment you want to build (production or development) (default production)
  • -m, --mode: The mode you want to build as (ssr or spa) (default ssr)
  • -p, --port: The port where you want your application to run (default 3000)

Examples

  • carioca build --env development
  • carioca build --mode spa
  • carioca build --port 8000

test

Runs the test suite

Options

[Supports all Jest CLI flags

Examples

  • carioca test --watch
  • carioca test --coverage
  • carioca test --passWithNoTests --verbose

start

'Run the built application - make sure to build first!

Options

None

Examples

  • carioca start

API

Switching modes (SSR or SPA)

TODO: Documentation coming soon

Custom server for SSR

TODO: Documentation coming soon

Service Workers and PWA's

TODO: Documentation coming soon

Environment variables

TODO: Documentation coming soon

Adding custom templates

TODO: Documentation coming soon

SEO and the <Page> component

TODO: Documentation coming soon

Internationalization

TODO: Documentation coming soon

Custom configuration files

TODO: Documentation coming soon tsconfig.json, .eslintrc, .prettierrc, and jest.config.js

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change. Please make sure to update tests and documentation as appropriate. PR's without proper tests and documentation will not be accepted - period.

Folder structure

Inside of the packages folder sit all of the various projects in the carioca ecosystem. Here's a description of what each project does:

generator - A CLI to generate a full app when the user is starting from scratch (think of this as the equivalent to npx create-react-app my-app). This is deployed to NPM as @carioca/generator. scripts - A CLI to run the various build, dev, test, and start functions that all implementers will need to call. If you're familiar with react-scripts, this is carica's equivalent project. This is deployed to NPM as @carioca/scripts. server - A sample server and some helper functions to make building the server portion of SSR a little easier. This is deployed to NPM as @carioca/server. utils - A project to help organize all shared code between the other modules. This is not deployed to NPM.

Setting up the development environment

To get started, simply run yarn bootstrap. This will use Lerna to install all the appropriate dependencies and get your project set up.

If you need to reset this environment to test additional functionality you've created, run yarn reset, which will clean up all the dependencies, remove all the node_modules folders, and then run yarn bootstrap itself.

Local development workflow

If you make a change to the generators, scripts, server, or utils packages, then your workflow will look something like this:

  1. Run the initial yarn bootstrap command
  2. Make a change in some file - do your work here!
  3. From the root of the project, run yarn reset
  4. **From the sample-app folder, run the command that will trigger your change (yarn dev, yarn build, yarn test, yarn start, etc.)
  5. If you need to fix something, go back to step 2

Testing

You can run the test suite across all our projects by running yarn test from the root of the project.

Acknowledgements

No doubt, this project shares about 80% of its logical inspiration from Razzle. However, this library has become quite bloated in my opinion, and is no longer maintained actively by Jared Palmer. I wanted a simpler, more opinionated library for abstracting away build concerns for building SSR and SPA-based web applications. If there's any message you should get from reading this paragraph, it's that I love Razzle with all my heart, but I grew frustrated when trying to work with the codebase and bend it to my will.

License

Apache License 2.0