1.2.0 • Published 4 years ago
cra-template-hubert v1.2.0
Create your own Create React App Template
Create React App is a convienient way to start building a new single-page application in React. Your app only needs one build dependency react-scripts. Under the hood it uses webpack, Babel, ESLint, and other amazing projects to power your app.
Make it your own
If you don't like the default scaffold of create react app it really easy to adjust.
- Start by creating a folder called - cra-template.
- Cd into the folder and run - yarn init -yor- npm init -yif your prefer npm. This will generate a basic- package.jsonfile for you.
- Create a - template.jsonwith your specific template settings. Any dependencies you add here will be added to the final dependency list.
{
	"package": {
		"dependencies": {
			"@testing-library/jest-dom": "^5.16.2",
			"@testing-library/react": "^12.1.4",
			"@testing-library/user-event": "^13.5.0",
			"sass": "^1.49.9",
			"react-icons": "^4.3.1",
			"react-router-dom": "^6.2.2",
			"web-vitals": "^2.1.4"
		},
		"eslintConfig": {
			"extends": ["react-app", "react-app/jest"]
		}
	}
}- Create a - templatefolder.
- Create a - gitignorefile with the content below. Make sure to omit the dot.
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
# dependencies
/node_modules
/.pnp
.pnp.js
# testing
/coverage
# production
/build
# misc
.DS_Store
.env.local
.env.development.local
.env.test.local
.env.production.local
npm-debug.log*
yarn-debug.log*
yarn-error.log*- Inside the templatefolder create apublicfolder with the followingindex.html.
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="utf-8" />
		<link rel="icon" href="%PUBLIC_URL%/favicon.ico" />
		<meta name="viewport" content="width=device-width, initial-scale=1" />
		<meta name="theme-color" content="#000000" />
		<meta name="description" content="Web site created using create-react-app" />
		<link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
		<link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
		<title>Starter template</title>
	</head>
	<body>
		<noscript>You need to enable JavaScript to run this app.</noscript>
		<div id="root"></div>
	</body>
</html>- Inside the templatefolder create asrcfolder and anindex.jsin it.
import React from 'react';
import { createRoot } from 'react-dom/client';
import App from './App';
import './index.scss';
const container = document.getElementById('root');
const root = createRoot(container)
root.render(
	<React.StrictMode>
		<App />
	</React.StrictMode>
);- Inside the template/srcfolder create aApp.jsfile.
import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';
import { Home, NotFound } from './pages';
const App = () => {
	return (
		<Router>
			<Routes>
				<Route path="/" element={<Home />} />
				<Route path="*" element={<NotFound />} />
			</Routes>
		</Router>
	);
};
export default App;- Test that your scaffold is working locally by running
npx create-react-app my-app --template file:.Publish to npm
npm publishUse your published template in a project
npx create-react-app my-app --template cra-template-namenpx create-react-app my-app --template barebones