Check it out at https://coachboard.ca/.
This django-based webapp helps sports clubs manage their staff and reduce communications.
In a typical sports club, there are coaches, atheletes, and managing staff. Managing the day to day operations of the club poses a challenge.
This app offers a centralized location for coaches and administrative staff to manage coaching schedules. The app also allows managing staff to keep track of employee hours and calculate their pay over specific time period.
In the app, coaches and managing staff create an account they use to identify themselves as either a coach or managing staff member.
A typical use case for a coach would be to log in and view their shifts, preview the upcoming work schedule, and respond to any other coaches that need a substitute.
A managing staff member can view the shifts of all coaches and calculate employees' hours for payroll.
Prerequisites:
- Python3 with pip
- Local Postgresql installation or another backend
Clone repository:
git clone https://github.com/alexander-yf-yu/coachboard.git
If you want to use a virtualenv, create one now. Here is a link to the python virtual environments documentation.
Install python package requirements using pip:
pip install -r path/to/requirements.txt
This section assumes the use of postgresql, for more information on using other databases, checkout the django docs.
Create a new database and database-user in postgresql. You can do this through the psql CLI. Check out the psql docs for more info. This video is a good resource for a beginner to postgresql and for troubleshooting issues.
In the settings.py file at path/to/coachboard/mysite/mysite/settings.py, edit the file to connect django to the database installation. Fill in the 'DATABASES' dictionary with your database name and user credentials. Change the port number if you're not using the default 5432.
# settings.py
...
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'DATABASE_NAME',
'USER': 'DATABASE_USER_USERNAME',
'PASSWORD': 'DATABASE_USER_PASSWORD',
'HOST': 'localhost',
'PORT': '5432',
}
}
...
The password reset and create subrequest emailing functionalities also require the email settings to be defined in settings.py at the very bottom of the file.
Navigate to the directory containing manage.py:
cd coachboard/mysite/
Migrate the django default models and our custom models into the database.
python3 manage.py migrate
Now start the server with:
python3 manage.py runserver
The server should be running on http://127.0.0.1:8000/, and visiting that url in a browser should display the site.