- The customer is central in every product or service that is offered, hence obtaining customer feedback is essential to the success of any business small or large.
- This feedback often comes in the form of unstructured data, such as text. In fact, open ended questions are one of the best ways to obtain feedback. In addition, this feedback can come from many sources, such as surveys, client interviews and social media.
- Gathering this data from multiple sources and attempting to extract key information is both time consuming and tiring thus it is an expense to the business.
- There are already existing platforms that provide businesses with a unified source to gather this data, as well as mine information from it. One example is Microsoft Dynamics 365 that has this capability, however it costs $1,500 per user to obtain and understand this feedback - making it an infeasible expense for small businesses, startups and content creators.
- Our platform would provide this audience with a tool that acts as a unified source to obtain this information and make sense of it.
-
Front End
- React + Typescript
- HTML/CSS
-
Back End
- Node.js + TypeScript
- Express.js
- PostgreSQL
Using github desktop:
- Click on the repository name on the top left
- Click add
- Click clone
- Click URL
- Clone
https://github.com/UTSCCSCC01/finalprojects22-byte-peeps
Using CLI:
git checkout https://github.com/UTSCCSCC01/finalprojects22-byte-peeps -b <NEW-BRANCH-NAME>
Instructions are available here
- If you were on MacOS, you need to download Pgadmin here
- Open Pgadmin
- Click on Local server
- If you do not see this option on the dashboard, click 'Add New Server'.
- Under the
Connection
tab fill in 'localhost' for the host name field - Ensure port 5432 is the selected port
- Input your postgres password. If you get a password authentication error and cannot remember your password then reset it
- Right click databases
- Click create -> database
- name it
c01
- Connecting to Production DB:
- Right click on servers
- Click create...
- New server
- Enter a name
- Go to connection tab
- Enter credentials given from one of our fellow developers.
- Updating of Local DB with Production DB data:
- Right click on the
c01
DB on the production server - Click back up and save it
- Right click on the development DB
- Click restore
- Select the backup you made
- Click restore
Before completing your backend set up, you require a DatumBox API key. To obtain the key, you require to go register on the DatumBox website: click register, then go back to this page, scroll down to How to use the API?
on the bottom right and click the text hyperlink API Key
.
Now you can complete the backend set up.
- cd into the backend folder then app folder and run the command:
npm i --include=dev
- Create a
.env
file in thebackend/app
directory. Paste the following content
BACKEND_PORT=3000
FRONTEND_PORT=3001
DB_HOST=localhost
POSTGRES_PORT=5432
POSTGRES_DB=c01
POSTGRES_USER=postgres
POSTGRES_PASSWORD=<YOUR-POSTGRES-PASSWORD>
DATUMBOX_API_KEY=<YOUR-DATUMBOX-API-KEY>
# Facebook API
FACEBOOK_APP_ID=724313855458609
FACEBOOK_APP_SECRET=<FACEBOOK-APP-SECRET>
# Twitter API
TWITTER_APP_BEARER_TOKEN=<TWITTER-BEARER-TOKEN>
# YouTube API
YOUTUBE_API_KEY=<YOUTUBE-API-KEY>
# Yelp API
YELP_API_KEY=<YELP-API-KEY>
- To run the dev server:
npm run dev
- cd into the frontend folder then the app folder in the frontend and run the command:
npm i --include=dev
- Create a
.env
file in thefrontend/app
directory. Paste the following content
REACT_APP_BACKEND_ENDPOINT=http://localhost:3000/
PORT=3001
# Facebook API
REACT_APP_FACEBOOK_APP_ID=724313855458609
- To start the server:
npm run start
-
Do you use Git Flow?
- Yes, we use a main branch, a development branch and many feature branches.
-
What do you name your branches?
- main:
main
branch that is deployed - develop:
develop
latest development branch - hotfix:
hot-fix-<issue-name>
- feature:
feature-<feature-name>
- bug (that is not a hot fix):
bug-<bug-info>
- main:
-
Do you use github issues or another ticketing website?
- We will be using
Jira
as a ticketing platform.
- We will be using
-
Creating frontend components:
- Use the template complement folder under the components directory
-
Creating backend files:
- There must be a new file under each of the controllers, models and routes folder following the same structure as the template file
-
Do you use pull requests?
- Yes each feature, bug and hot fix should have an independent pull request.
-
Process:
- Clone this repository and create a new branch off the dev branch with the appropriate name.
- Implement the feature.
- Test your feature and ensure it does not break any existing functionality.
- Create and submit a pull request with a detailed description to be reviewed by at least two other contributors.
Due to github actions being displayed, we will be running the github actions locally using act to deploy.
Currently, the website is deployed at: https://www.datalytic.ml/
-
Installation:
-
Files:
-
The following files are needed and should be placed at the root directy of the code:
ssh-key.txt
my.secrets
-
-
Run the following commands at the root directory:
- Backend Deployment:
act -s KEY="$(< ssh-key.txt)" --secret-file my.secrets -W .github/workflows/local-build-backend.yml
- Frontend Deployment:
act -s KEY="$(< ssh-key.txt)" --secret-file my.secrets -W .github/workflows/local-build-frontend.yml