Instagram clone redesign, Webpack 5, Tailwind 2, HMR, using babel, sass, with a hot dev server and an optimized production build
as close to this shot on Dribble as I could.
- added SVGR as a webpack loader to import your SVG directly as a React Component.
- added build-staging script. same as build but using .env.staging
- added dotenv-webpack to handle process.env.VARS
- added Prettier
- added react-refresh-webpack-plugin for HMR
git clone https://github.com/artmxra7/instagram-redesign.git
cd instagram-redesign
yarn / npm i
yarn start / npm startYou can view the development server at localhost:3000.
(change port in ./config/webpack.dev.js)
yarn build / npm run buildwebpack- Module and asset bundler.webpack-cli- Command line interface for webpackwebpack-dev-server- Development server for webpackwebpack-merge- Simplify development/production configuration
@babel/core- Transpile ES6+ to backwards compatible JavaScript@babel/plugin-proposal-class-properties- Use properties directly on a class (an example Babel config)@babel/preset-env- Smart defaults for Babel
babel-loader- Transpile files with Babel and webpacksass-loader- Load SCSS and compile to CSSnode-sass- Node Sasscss-loader- Resolve CSS importspostcss-loader- Loader to process CSS with PostCSSstyle-loader- Inject CSS into the DOM
eslint-config-prettier- Turns off all rules that are unnecessary or might conflict with Prettier.eslint-import-resolver-alias- a simple Node behavior import resolution plugin for eslint-plugin-import, supporting module alias.eslint-plugin-babel- an eslint rule plugin companion to babel-eslint.eslint-plugin-import- This plugin intends to support linting of ES2015+ (ES6+) import/export syntax, and prevent issues with misspelling of file paths and import names.eslint-plugin-prettier- Runs prettier as an eslint rule.eslint-plugin-react- React specific linting rules for ESLint.eslint-plugin-react-hooks- Enforces the Rules of React Hooks.
clean-webpack-plugin- Remove/clean build folderscopy-webpack-plugin- Copy files to build directoryhtml-webpack-plugin- Generate HTML files from templatemini-css-extract-plugin- Extract CSS into separate filesoptimize-css-assets-webpack-plugin- Optimize and minimize CSS assetsterser-webpack-plugin- Optimize and minimize JavaScriptreact-refresh-webpack-plugin- HMR using React Fast Refreshdotenv-webpack- Supports dotenv and other environment variables@svgr/webpack- SVGR can be used as a webpack loader, this way you can import your SVG directly as a React Component.
Pull requests are welcome!
