👆Click to see all implemented features |
|
Run these commands in the terminal:
-
> git clone [email protected]:TowhidKashem/snapchat-clone.git
> cd snapchat-clone
-
> npm install
-
This will:
- Install the dependencies in package.json
- Checkout jeelizFaceFilter package (used for the filters) and set it to the last version this project was tested and confirmed to work with
-
Run
gulp
to concatenate, minify and transpile the files located inpublic/filters/source/*.js
into a single file calledfilters.min.js
-
This will:
-
This part is optional but strongly recomended, without it you won't be able
to view any of the snap map features:
- Make a Mapbox account and get a free API key
-
Rename the
.env.sample
file at the root of the project to just.env
-
Inside enter your new API key, for example:
-
Before:
REACT_APP_MAP_BOX_API_KEY=<REPLACE_WITH_API_KEY>
- After:
REACT_APP_MAP_BOX_API_KEY=xy.abc123
-
Before:
-
> npm start
-
The app should open automatically in your browser at
https://localhost:3000/
-
In Chrome you will receive a "Your connection is not private" error
-
Click "Advanced" > "Proceed to localhost (unsafe)"
-
You'll get this warning because the app uses a self signed
https
certificate. ThegetUserMedia
API used by the camera requires thehttps
protocol so we run the dev server in https mode.
-
You'll get this warning because the app uses a self signed
-
Click "Advanced" > "Proceed to localhost (unsafe)"
- After this you will be prompted to give access to your webcam, click "Allow"
-
In Chrome you will receive a "Your connection is not private" error
Step 1 Step 2 Step 3 -
The app should open automatically in your browser at
- You're all set! 🎉
Not all the buttons are actionable, many of them are there just for show since this is a minimal demo. This video shows all the things you can currently do. Where it's not obvious which buttons actually work I added a red box-shadow as guide. |
Storybook is used to showcase the app's custom
component library. You can run Storybook using the command
|
Redux Devtools Extension is implemented in the app, it makes things like viewing the state, state flow and debugging much easier, to use it you need to install the browser extension here or here . |
👆Click to see the entire test suite being run |
|
-
In addition to running on the localhost domain the app is also available on
your network at
https://192.168.0.185:3000
(useful for viewing on mobile) -
If you want to make changes to the filter files, run the command
cd filters && gulp watchJS
to watch for changes -
If you want to browse the production build run the commands
npm run build && npm run serve
, then navigate tohttp://localhost:5000
locally orhttp://192.168.0.185:5000
on the network -
Webpack root dir is set to
src
which means we can use clean import paths like theseimport Foo from common/Foo
vs messy relative paths likeimport Foo from ../../common/Foo
-
The project was bootsraped using
Create React App
in case you were wondering where webpack configs and such are. You can alwayseject
if you need access to those things.. -
This is purely a front end demo project, the "api" is nothing but a bunch of
hard coded json files located in
/public/api/*.json
. All data is dummy data!
Please note I will not be accepting PR's on this project since it is part of my personal portfolio. You're more than welcome to fork and maintain your own version if you like!