Content Management System (CMS) for managing content of STEM Diverse TV backend. This repository is for frontend part for STEM Diverse TV backend, so we could manage add/remove and edit content of our platform apps.
At the moment all content is coming from Youtube, however we are planning to extend that with other sources in future.
STEM Diverse TV is a project which gather and provide inspiring, motivating, informative, educational and supportive videos about diversity in STEM. This is the frontend of the project.
- React JS.
To setup the project locally follow the instructions:
Note: This is only needed if you want to contribute to the project.
If you want to contribute to the project you will have to create your own copy of the project on GitHub. You can do this by clicking the Fork button that can be found on the top right corner of the landing page of the repository.
Note: For this you need to install git on your machine. You can download the git tool from here.
-
If you have forked the project, run the following command -
git clone https://github.com/YOUR_GITHUB_USER_NAME/stem-diverse-tv-cms
where
YOUR_GITHUB_USER_NAME
is your GitHub handle. -
If you haven't forked the project, run the following command -
git clone https://github.com/anitab-org/stem-diverse-tv-cms
-
Now after you cloned the repository, get into the stem-diverse-tv-cms directory by -
cd stem-diverse-tv-cms
Note: This is only needed if you want to contribute to the project.
When a repository is cloned, it has a default remote named origin
that points to your fork on GitHub, not the original repository it was forked from. To keep track of the original repository, you should add another remote named upstream. For this project it can be done by running the following command -
git remote add upstream https://github.com/anitab-org/stem-diverse-tv-cms
You can check that the previous command worked by running git remote -v
. You should see the following output:
$ git remote -v
origin https://github.com/YOUR_GITHUB_USER_NAME/stem-diverse-tv-cms (fetch)
origin https://github.com/YOUR_GITHUB_USER_NAME/stem-diverse-tv-cms (push)
upstream https://github.com/anitab-org/stem-diverse-tv-cms (fetch)
upstream https://github.com/anitab-org/stem-diverse-tv-cms (push)
Download the latest stable version of NodeJs here and install it.
Install yarn
. Run node --version
and yarn --version
to verify successful installation.
To get the frontend running locally:
-
Run
yarn
ornpm i
to install all required dependencies -
Setup the env file in the root directory of the project & copy the template from the sample env file
-
If you are running it locally & want your credentials to be stored in your project that you made on firebase you need to set REACT_APP_ENVIRONMENT_CONFIG=local
-
If you are running it & want your credentials to be stored on the hosted version of this project i.e,
https://stem-diverse-tv.herokuapp.com/
,you need to set REACT_APP_ENVIRONMENT_CONFIG=prod
-
-
Run
yarn start
ornpm run start
to start the local server
This repository using Eslint and Prettier for linting code and formatting source code.
You may use npm
or yarn
for this -
npm run lint
: Lint check.
npm run lint:fix
: Lint check and also fixes errors.
npm run format:check
: Check if code already formatted.
npm run format
: Format code.
This project is under active development
Please read our Contributing Guidelines, Code of Conduct and Reporting Guidelines thoroughly.
Thanks goes to these people (emoji key):
Anna Bauza ๐ป ๐ง |
This project follows the all-contributors specification. Contributions of any kind welcome!
- master: This contains the latest code. All the contributing PRs must be sent to this branch.
- production: Merge to master will trigger deployment static github page and publish it on production branch.
If you have any questions or want to discuss something about this repo, feel free to reach out to our team on our Zulip channel #STEM-Diverse-TV. If you are a new contributor, head over to this project's stream on Zulip to see ongoing discussions.
The project is licensed under the GNU General Public License v3.0. Learn more about it in the LICENSE file.