HeartSync is a product of the Hack for Good initiative, inspired by Big at Heart's problem statement. We extend our gratitude to them for their support and contributions.
Offering customizable enrollment forms, streamlined QR attendance tracking, comprehensive reporting and more, HeartSync serves as a comprehensive solution, connecting organizations with eager volunteers and empowering kind-hearted individuals to extend a helping hand effortlessly.
To test out our demo, here are some credentials you can use:
- Volunteer: Username:
lwj@gmail.com
| Password:password
- Admin: Username:
rk@gmail.com
| Password:password
Access our project demo here!
Check out our Devpost and Pitch Deck too!
- HeartSync
This project is currently in development. We have many features in place (see features below for a more in-depth walk through of our product) and to come!
Users can sign up for an account if they are using the page for the first time, or log in with their credentials if they already have an account.
We provide 2 interfaces - one for the volunteer, another for the admin.
- See volunteer features
- See admin features
Volunteers have access to a profile page, dashboard, events, personal activity page, blogs.
This page allows volunteers to manage their personal details by
- updating basic personal information such as age, name, email, gender, date of birth, education level, immigration status, description, salutation, profile image.
- updating skills and interest by choosing from preselected lists
- updating availability such as commitment preference (Adhoc, Weekly, Monthly), vehicle ownage and exact time intervals they are free on throughout the week (split into Morning, Afternoon, Evening time slots) Additionally, attendance for events can be taken by scanning the volunteers individual QR code found within their profile page.
- enabling Two-Factor Authentication to further protect their account. See 2-FA below for more details.
For further security, volunteers can choose to enable 2-FA in their profile page. This will allow them to use Singpass to log in to their accounts.
The dashboard is the page the volunteer is greeted by upon log in/ sign up. It contains a all-in-one view of
- upcoming events the user has signed up for (top left)
- activities (top right)
- blogs (bottom left)
- outstanding feedback reminders (bottom right)
This page allows volunteers
- to browse events
- sign up for events. By clicking on a specific event, the volunteer will be brought to the main page of the activity containing more details on the event such as location, timing, description. From there if they can click on the
Enroll in Event
button to indicate their availability for specific timeslots.
This page allows users to track their events by
- viewing all of their upcoming and past events they have signed up for
Additionally, for events that they have attended, volunteers can
- check if they have received any feedback
- download certificates issued to them by the organisation in charge of the event
This page allows volunteers to reflect and recount on their experience and read about others journey through
- reading blogs they and other volunteers have written
- filtering blogs written by themselves
- creating, editing and deleting their blog entries
Admins have access to the volunteer list, activity list, organisation list, volunteer activity report, volunteer demographic report
Admins are able to manage volunteers on this page by:
- using the search bar on the top left to look for volunteers by their name or emails
- have a full view of all volunteers that have signed up and their emails
- clicking on a specific volunteer to
- view their profile, including events they have signed up for, attendance, skills, interests, availability etc
- provide feedback for a specific event by clicking on the eye icon in the feedback column
Admins are able to manage activities by:
- using the search bar on the top left to look for activities by their name
- have a full view of all activities together with their type (Volunteering, Workshop, Training) and the organisations they fall under
- creating new activities by clicking on the
Create
button on the top right corner. This leads them to fill in details of the activity such as name, location, session timings, description, images, capacity and type - clicking on a specific activity to:
- view details of the activity, including description, sessions
- create and customise enrollment forms by clicking on the
Create Enrollment Form
button. See Create Enrollment Form for more details. - edit activity details
- delete the activity
- manage attendance for a specific session. See Attendance Taking for more details.
This feature falls under the activity section. Upon clicking on an activity in the activity list, the admin can click on Create Enrollment Form
to start customising questions needed for that activity by adding as many questions as they would like by using the Add Input
button. With this, admins can add
- Short Answer Type Questions: volunteers can submit a short piece of text
- Paragraph Type Questions: volunteers can submit a longer piece of text
- Checkbox Type Questions: admins can add a variety of options with
Add Option
where volunteers can select multiple options to submit - Dropdown Type Questions: admins can add a variety of options with
Add Option
for volunteers to choose one to submit
This feature falls under the activity session. After a admin navigates to a specific activity, clicking on a specific session allows them to:
- view details of the session, including date, duration, number of registrations, capacity
- view session feedbacks and reflections
- track enrollment form submissions
- manage registrations and attendance by
- clicking on
Manage Attendance
to mark volunteers as attended or not attended. Clicking onTake Attendance
further brings the admin to a QR code scaner, where they can scan the volunteers QR code with their camera to mark them as attended. Alternatively they can also use manual input to register the volunteers - clicking on
Generate Blank Attendance List
should they need the empty attendance sheet in excel format - clicking on
Export Registration/ Attendance Data
to export the records in excel format
- clicking on
Admins are able to manage organisations by:
- have a full view of all organisations
- creating new organisations by clicking on the
Create Organisation
button on the top right corner. This leads them to fill in details of the organisation such as name, description, images, tags, website url - clicking on a specific organisation to:
- edit existing organisations
- view specific organisations page containing all their details, including activities they offer
This feature allows admins to analyse volunteer activity by
- viewing visual reports generated by volunteer activity by volunteer or hour across a timeline for different interest areas
- exporting these reports as a excel file
- using the search bar to look for volunteers by their name or email
This feature allows admins to analyse volunteer demographic information by
- viewing visual reports generated by grouping volunteers by their age, gender, immigration status, skills, interests
- exporting these reports as a excel file
- using the search bar to look for volunteers by their name or email
- filtering the volunteer list of a specific view by their sub-categories e.g. (selecting Gender as the main view and male as the sub-category)
Contributions are welcome! Please follow these steps:
- Fork the repository
- Create your feature branch (git checkout -b feature-name)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin feature-name)
- Create a new Pull Request
-
Move to a directory you want to store the project:
cd [path to folder you want to store the project]
-
Clone the repository
git clone https://github.com/seelengxd/h4g-2024.git
-
Once the project is done cloning, go to the project-directory
cd [project-directory]
-
Install the dependencies for frontend and backend seperately
-
Navigate to backend and type into your command prompt
cd backend npm install
-
Return to root directory and do the same for frontend
cd frontend npm install
-
-
Setting up your environment
-
Ensure you have Postgresql set up on your computer, running on port
5432
with usernamepostgres
and passwordpostgres
. -
Please copy this into into
backend/.env
FRONTEND_URL="http://localhost:3000" DATABASE_URL="postgresql://postgres:postgres@localhost:5432/h4g?schema=public" SECRET="some_h4gsecret" PORT=3001 GMAIL_USER=<PLACEHOLDER> GMAIL_PASSWORD=<PLACEHOLDER> TEMPORARY_TOKEN_SECRET="some_secret" BACKEND_URL="http://localhost:3001" SGID_CLIENT_ID=<PLACEHOLDER> SGID_CLIENT_SECRET=<PLACEHOLDER> SGID_PRIVATE_KEY=<PLACEHOLDER>
-
Please copy this into
frontend/.env
REACT_APP_BACKEND_URL="http://localhost:3001/api"
-
For the redacted environment variables, please set up your own via:
-
-
Running the project
- Open 2 command prompts
- Navigate to backend and run
npm run dev
- In another command prompt, navigate to frontend and run
npm start
We built this project with:
- Design:
Figma
- Frontend:
React
,Redux
,Formik
,TailwindCSS
,CanvasJS
,XLSX-renderer
- Backend:
Express
,Prisma
,PDFLib
- Deployment:
Nginx
,DigitalOcean
List of Contributors: