-
Notifications
You must be signed in to change notification settings - Fork 64
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #908 from zurichat/dev
Update main branch 13th Nov 21
- Loading branch information
Showing
111 changed files
with
1,268 additions
and
2,197 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,69 +1,77 @@ | ||
# YouTube Music-Video Plugin | ||
|
||
> ## Table of contents | ||
* [Overview](#overview) | ||
* [Project Features](#project-features) | ||
* [Technologies](#technologies) | ||
* [Repo Setup](#repo-setup) | ||
* [Setting up the project](#setting-up-the-project) | ||
* [Frontend](#frontend) | ||
* [Build the client](#build-the-client) | ||
* [Build the single-spa root](#build-the-single-spa-root) | ||
* [Start the client](#start-the-client) | ||
* [Start the single-spa root](#start-the-single-spa-root) | ||
* [Lint the Frontend](#lint-the-frontend) | ||
* [Backend](#backend) | ||
* [Run the Django Server](#run-the-django-server) | ||
* [Pre-commit and lint the Backend](#pre-commit-and-lint-the-backend) | ||
* [Links to the project](#links-to-the-project) | ||
* [Status](#status) | ||
* [Contributing to the project](#contributing-to-the-project) | ||
- [Overview](#overview) | ||
- [Project Features](#project-features) | ||
- [Technologies](#technologies) | ||
- [Repo Setup](#repo-setup) | ||
- [Setting up the project](#setting-up-the-project) | ||
- [Frontend](#frontend) | ||
- [Build the client](#build-the-client) | ||
- [Build the single-spa root](#build-the-single-spa-root) | ||
- [Start the client](#start-the-client) | ||
- [Start the single-spa root](#start-the-single-spa-root) | ||
- [Lint the Frontend](#lint-the-frontend) | ||
- [Backend](#backend) | ||
- [Run the Django Server](#run-the-django-server) | ||
- [Pre-commit and lint the Backend](#pre-commit-and-lint-the-backend) | ||
- [Links to the project](#links-to-the-project) | ||
- [Status](#status) | ||
- [Contributing to the project](#contributing-to-the-project) | ||
|
||
# | ||
>## Overview | ||
|
||
> ## Overview | ||
<p align="justify"> | ||
ZuriChat is an open source slack clone that provides the opportunity for people to network, collaborate, educate and learn remotely. It allows people to take their classroom everywhere, make learning fun, stay engaged and inspired with the virtual lounge and games. | ||
ZuriChat is an open source workspace app that provides the opportunity for people to network, collaborate, educate and learn remotely. It allows people to take their classroom everywhere, make learning fun, stay engaged and inspired with the virtual lounge and games. | ||
|
||
One of its unique features are the variety of plugins designed to add features such as tracking company expenses, sending information fast and smoothly, managing files and integrating tools all with ZuriChat. | ||
One of its unique features are the variety of plugins designed to add functionalities such as tracking company expenses, sending information fast and smoothly, managing files and integrating tools all with ZuriChat. | ||
|
||
This project is focused on the ZuriChat music plugin. | ||
|
||
</p> | ||
|
||
![site image](https://drive.google.com/uc?export=view&id=1OinCY56dOGcG6DvliWAhznSj4d7gA4_H) | ||
|
||
# | ||
|
||
> ## Project Features | ||
> | ||
The YouTube music plugin allows the users in the organization to add and play Youtube links.You can also chat in real time with other members of the organization. | ||
|
||
|
||
- Add and Play Youtube music and videos. | ||
|
||
- Chat in realtime in the music room. | ||
|
||
- Song search and filter options. | ||
|
||
- Like and unlike songs. | ||
|
||
</p> | ||
|
||
# | ||
|
||
> ## Technologies | ||
<p align="justify"> | ||
*Note: This project was setup and developed on a system running Windows 10. The stacks used for the project include: | ||
</p> | ||
|
||
|
||
| <b><u>Stack</u></b> | <b><u>Usage</u></b> | | ||
| :--- | :--- | | ||
| **`Python 3.9`** | Programming language. | | ||
| **`React JS`** | Frontend | | ||
| **`MongoDB`** | External Database | | ||
| **` Django Rest framework`** | APIs. | | ||
| <b><u>Stack</u></b> | <b><u>Usage</u></b> | | ||
| :--------------------------- | :-------------------- | | ||
| **`Python 3.9`** | Programming language. | | ||
| **`React JS`** | Frontend | | ||
| **`MongoDB`** | External Database | | ||
| **` Django Rest framework`** | APIs. | | ||
|
||
# | ||
|
||
> ## Repo Setup | ||
<p align="justify"> | ||
To setup the repo, first fork and clone the Zurichat YouTube Music, then clone the forked repository to create a copy on the local machine. | ||
To setup the repo, first fork the Zurichat YouTube Music, then clone the forked repository to create a copy on the local machine. | ||
</p> | ||
|
||
$ git clone [email protected]:pauline-banye/music_video.git | ||
|
@@ -74,9 +82,10 @@ Change directory to the cloned repo and set the original Zurichat repository as | |
|
||
$ git remote add upstream [email protected]:zurichat/zc_plugin_youtube_music_video.git | ||
|
||
|
||
# | ||
|
||
> ## Setting up the project | ||
<p align="justify"> | ||
The first step requires the download and installation of Python 3.9 and a check to confirm that pip and the necessary dependencies are properly installed. | ||
</p> | ||
|
@@ -85,137 +94,143 @@ The first step requires the download and installation of Python 3.9 and a check | |
After the installation of the Python program, setup the project environment with pip and virtualenv in the command prompt, powershell or gitbash terminal. Virtualenv helps to create an isolated Python environment containing all the packages necessary for the project. | ||
</p> | ||
|
||
*Note: | ||
\*Note: | ||
|
||
* This project was setup using the gitbash terminal. Some of the commands used do not work with command prompt or powershell. | ||
- This project was setup using the gitbash terminal. Some of the commands used do not work with command prompt or powershell. | ||
|
||
- If a "pip command not found error" is encountered, download get-pip.py and run `phython get-pip.py` to install it. | ||
* If a "pip command not found error" is encountered, download get-pip.py and run `phython get-pip.py` to install it. | ||
|
||
### | ||
$ pip install virtualenv | ||
|
||
$ pip install virtualenv | ||
|
||
Navigate to the cloned local project folder. Create a virtual environment folder and activate the environment by running the following commands in the gitbash terminal. | ||
|
||
|
||
### | ||
|
||
$ python -m venv venv | ||
$ source venv/scripts/activate | ||
|
||
|
||
<p align="justify"> | ||
Once the virtual environment is active, the next step is the Django installation. Django is an open source Python web application framework thats helps with the rapid development of secure websites. | ||
</p> | ||
|
||
### | ||
$ (venv) pip install django | ||
|
||
$ (venv) pip install django | ||
|
||
<p align="justify"> | ||
After installing Django, install Django REST framework in the gitbash terminal. The Django REST framework is a flexible toolkit for building Web based APIs. The REST framework was used for the creation of APIs, serialization and the authentication process for this project. | ||
</p> | ||
|
||
### | ||
$ (venv) pip install djangorestframework | ||
|
||
$ (venv) pip install djangorestframework | ||
|
||
Install all the necessary dependencies for the project. A few of them are listed below. | ||
|
||
| <b><u>Modules</u></b> | <b><u>Usage</u></b> | | ||
| :--- | :--- | | ||
| <b><u>Modules</u></b> | <b><u>Usage</u></b> | | ||
| :------------------------ | :---------------------------- | | ||
| **`django-cors-headers`** | Cross Origin Resource Sharing | | ||
| **`gunicorn`** | WSGI HTTP server | | ||
| **`whitenoise`** | Static files | | ||
| **`Markdown`** | Markup language | | ||
| **`django-environ`** | Environment configuration | | ||
|
||
|
||
An exhaustive list can be found in the requirements.txt file included in this project. The modules can be 'batch installed' using the `pip install -r requirements.txt` command. | ||
| **`gunicorn`** | WSGI HTTP server | | ||
| **`whitenoise`** | Static files | | ||
| **`Markdown`** | Markup language | | ||
| **`django-environ`** | Environment configuration | | ||
|
||
An exhaustive list can be found in the requirements.txt file included in this project. The modules can be 'batch installed' using the `pip install -r requirements.txt` command. | ||
|
||
### Frontend | ||
|
||
- #### Build the client | ||
- #### Build the client | ||
|
||
$ cd server/client | ||
$ yarn | ||
$ yarn build | ||
$ cd server/client | ||
$ yarn | ||
$ yarn build | ||
|
||
- #### Build the single-spa root | ||
- #### Build the single-spa root | ||
|
||
$ cd root | ||
$ yarn | ||
$ yarn build | ||
$ cd root | ||
$ yarn | ||
$ yarn build | ||
|
||
- #### Start the client | ||
- #### Start the client | ||
|
||
$ cd server/client | ||
$ yarn | ||
$ yarn start | ||
$ cd server/client | ||
$ yarn | ||
$ yarn start | ||
|
||
- #### Start the single-spa root | ||
- #### Start the single-spa root | ||
|
||
$ cd root | ||
$ yarn | ||
$ yarn start | ||
$ cd root | ||
$ yarn | ||
$ yarn start | ||
|
||
- Frontend devs: You don't need to start django server. Only start the client and single-spa root to view your edits. | ||
- Frontend devs: You don't need to start django server. Only start the client and single-spa root to view your edits. | ||
|
||
- #### Lint the Frontend | ||
- #### Lint the Frontend | ||
|
||
- cd into the frontend folder (server/client) | ||
- cd into the frontend folder (server/client) | ||
|
||
$ yarn lint --fix (or yarn lint --fix . to fix all files) | ||
$ yarn lint --fix (or yarn lint --fix . to fix all files) | ||
|
||
# | ||
|
||
### Backend | ||
- #### Run the Django Server | ||
|
||
$ cd server | ||
- #### Run the Django Server | ||
|
||
$ cd server | ||
|
||
- Create .env file in config and put variables for Secret Key as created in sample.env file | ||
- Create .env file in config and put variables for Secret Key as created in sample.env file | ||
|
||
$ python manage.py runserver | ||
$ python manage.py runserver | ||
|
||
- #### Pre-commit and lint the Backend | ||
- #### Pre-commit and lint the Backend | ||
|
||
$ cd server | ||
$ pre-commit run (or pre-commit run --all-files to check all files) | ||
$ cd server | ||
$ pre-commit run (or pre-commit run --all-files to check all files) | ||
|
||
- Backend devs: You don't need to run yarn start to test your endpoints. | ||
- Backend devs: You don't need to run yarn start to test your endpoints. | ||
|
||
# | ||
|
||
### Note to the DevOps | ||
|
||
- Build first before starting django server | ||
- Build first before starting django server | ||
|
||
# | ||
|
||
> ## Links to the project | ||
Local server: <a href='<http://localhost:22672/music>'>http://localhost:22672/music</a> | ||
> | ||
Local server: <a href='<http://localhost:22672/music>'>http://localhost:22672/music</a> | ||
Live site: <a href='<http://staging.zuri.chat/music>'>http://staging.zuri.chat/music</a> | ||
Zurichat Staging site: <a href='<http://staging.zuri.chat/music>'>http://staging.zuri.chat/music</a> | ||
|
||
API root: <a href='http://localhost:22672/music/api/v1'>http://localhost::22672/music/api/v1</a> | ||
Zurichat main site: <a href='<http://zuri.chat/music>'>http://zuri.chat/music</a> | ||
|
||
Live site: <a href='<http://music.zuri.chat/music>'>http://music.zuri.chat/music</a> | ||
|
||
# | ||
|
||
> ## Status | ||
> | ||
This project is a work in progress and is currently under development. | ||
|
||
|
||
# | ||
|
||
> ## Contributing to the project | ||
If you find something worth contributing, please fork the repo, make a pull request and add valid and well-reasoned explanations about your changes or comments. | ||
|
||
Before adding a pull request, please note: | ||
|
||
- It should be inviting and clear. | ||
- Any additions should be relevant. | ||
- It should be easy to contribute to. | ||
- Urls marked **\*** are temporarily unavailable. Don't delete it without confirming that it has permanently expired. | ||
- It should be inviting and clear. | ||
- Any additions should be relevant. | ||
- It should be easy to contribute to. | ||
- Urls marked **\*** are temporarily unavailable. Don't delete it without confirming that it has permanently expired. | ||
|
||
This repository is not meant to contain everything. Only good quality verified information. | ||
|
||
All **`suggestions`** are welcome! | ||
|
||
> Readme created by Pauline Banye | ||
> ###### Readme created by Pauline Banye |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.