Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/saasify-sh/saasify-frontend-boilerplate-cra
CRA frontend boilerplate for Saasify products.
https://github.com/saasify-sh/saasify-frontend-boilerplate-cra
creact-react-app react saas saas-boilerplate saasify
Last synced: 2 months ago
JSON representation
CRA frontend boilerplate for Saasify products.
- Host: GitHub
- URL: https://github.com/saasify-sh/saasify-frontend-boilerplate-cra
- Owner: saasify-sh
- Created: 2020-06-09T02:08:17.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-07-13T09:26:28.000Z (over 1 year ago)
- Last Synced: 2024-11-01T20:36:22.464Z (3 months ago)
- Topics: creact-react-app, react, saas, saas-boilerplate, saasify
- Language: JavaScript
- Homepage: https://saasify.sh
- Size: 1.85 MB
- Stars: 14
- Watchers: 4
- Forks: 13
- Open Issues: 5
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
[![Build Status](https://travis-ci.com/saasify-sh/saasify-frontend-boilerplate-cra.svg?branch=master)](https://travis-ci.com/saasify-sh/saasify-frontend-boilerplate-cra) [![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
# Saasify Frontend Boilerplate
> CRA frontend boilerplate for [Saasify](https://saasify.sh) products.
## Overview
If you're just getting started with Saasify, we recommend using the built-in "SaaS-in-a-box" frontend. It's less customizable, but it's also much quicker to get off the ground.
Once you're ready for more customization, this boilerplate gives you have full control over your product's frontend.
Some common use cases include:
- Customizing your product's landing page and marketing.
- Deploying your product's webapp to be hosted on a custom domain.
- Adding custom UX to the webapp once a user is signed up.Note that if you decide to customize your product's frontend using this boilerplate, your product will still be integrated with Saasify in order to handle user accounts, subscription billing, and Saasify's API proxy that sits in front of your product's backend.
## Architecture
This **React** webapp uses a slightly customized version of [create-react-app](https://create-react-app.dev).
The main libraries it uses include:
- [react-saasify](https://github.com/saasify-sh/saasify/tree/master/packages/react-saasify) - Provides reusable SaaS components that are linked to your Saasify project.
- [antd](https://3x.ant.design/docs/react/introduce) - Ant Design v3.
- [react-router](https://reacttraining.com/react-router/web/guides/quick-start) - React Router v5.
- [mobx](https://mobx.js.org) - Simple state management for React.In general, these libraries shouldn't prevent you from using other options. They're just used to construct the "SaaS chrome" for the website. You have full control over the contents of that website and are free to use whatever NPM or React libraries you'd like.
## Getting Started
In order to connect this template to your Saasify project, change `$SAASIFY_DEPLOYMENT_ID` in `package.json` to the ID of your Saasify deployment.
Once you've updated this ID, run `yarn update-deployment` (or `npm run update-deployment`).
This will download the latest version of your Saasify project's config and store it as [src/lib/deployment.json](./src/lib/deployment.json).
Every time you want to update this project with your latest Saasify deployment, just re-run this command to keep them in sync.
We recommend integrating this step into your build process, possibly via a `prebuild` npm script.
## Examples
Let's say that you have a Saasify project called `dev/hello-world` and your want to always use your latest published deployment.
You would update your package.json `scripts` to look like this:
```json
{
"update-deployment": "saasify get dev/hello-world -o src/lib/deployment.json"
}
```This will implicitly use `dev/hello-world@latest` which will always point to your **latest published deployment**.
If your want to instead use your most recent deployment while in development, your can set your deployment ID as follows:
```json
{
"update-deployment": "saasify get dev/hello-world@dev -o src/lib/deployment.json"
}
```Your could also use the `@c83487f1` syntax to specify a particular deployment. For example:
```json
{
"update-deployment": "saasify get dev/hello-world@c83487f1 -o src/lib/deployment.json"
}
```## Hosting
Aside from making sure that your Saasify deployment's config is up-to-date, this project is a pretty standard CRA webapp.
You can build your site statically via `yarn build` and deploy this static bundle (under `build/`) to Vercel, Netlify, GitHub Pages, S3, etc.
## Customizations
You'll likely want to start off by customizing [src/App.js](./src/App.js) which holds the application's root React component.
Some common changes you may want to consider:
- Remove the `Docs` page. This page is useful for API-first SaaS products, but if your product doesn't expose a public API, then we recommend removing it.
- You'll also want to remove the links to `/docs` in the `App.js` config.
- You can also remove these dependencies: `@saasify/redoc` and `swagger-ui-react`.
- Customize your support email via find & replace `[email protected]`.
- Customize the various CTAs from "Get Started" to a CTA more in line with your product's onboarding.
- By default, we include all third-party auth pages for Google, GitHub, Twitter, etc. Feel free to remove all of the auth pages you won't be using.
- It is very common to want to change the logged in user experience.
- We recommend starting from [DashboardPage.js](./src/pages/DashboardPage/DashboardPage.js).
- This is the default page where users are redirected after signup and checkout.
- Add custom `meta` tags and `title` to [index.html](./public/index.html).
- Change the default [favicon](./public).## License
MIT © [Saasify](https://saasify.sh)