event-management-frontend/README.md

225 lines
7.1 KiB
Markdown

# Event Management Frontend
The Event Management Frontend is a native Android application developed in
Kotlin. This app provides a comprehensive calendar-based event management
system designed for seamless user interaction.
This project was created as the final assignment for **AP7PD** and **AP7MP** subjects.
It integrates with a custom backend REST API to manage users, events,
attendees, and categories effectively.
## Overview / Key Features
- **Monthly Calendar View**: View events in a grid layout by weeks and days.
- **Daily View**: Easily browse and manage daily events.
- **Event Management**: Create, edit, and delete events with support for categories and attendees.
- **User Authentication**: Register and log in with robust access and refresh
token support, ensuring secure and seamless user sessions.
- **Error Handling**: Gracefully handles API errors, including scenarios where
the backend is unreachable.
## Backend requirements
The application requires a running backend API for full functionality. The
backend is implemented using FastAPI in Python.
You can find the source code and detailed deployment instructions for the
backend API at: [Event Management Backend
Repository](https://git.itsdrike.com/ap7pd/event-management-backend).
> [!TIP]
> The app supports dynamic configuration of the API base URL, allowing you to
> deploy the backend on any server or cloud provider of your choice. If you
> wish to test the app from android studio, you can deploy the backend locally
> (<http://localhost:8000>) and set the base URL to `http://10.0.2.2:8000`.
> This will allow the Android emulator to access the local backend server. Note
> that this is also the default value.
## Showcase
Below is a showcase of key features and screens in the application:
<table style="width: 100%; border-collapse: collapse; text-align: center; margin: auto;">
<tr>
<th>Image</th>
<th>Description</th>
</tr>
<tr>
<td>
<img src="showcase/01_api_unreachable.png" alt="API Unreachable" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Error screen, shown whenever the API becomes unreachable.
</td>
</tr>
<tr>
<td>
<img src="showcase/02_login.png" alt="Login Screen" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Login screen for user authentication.
</td>
</tr>
<tr>
<td>
<img src="showcase/02_login_base_url_change.png" alt="Base URL Change" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Screen to update the API base URL, available from various pages.
</td>
</tr>
<tr>
<td>
<img src="showcase/03_register.png" alt="Register Screen" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
User registration screen.
</td>
</tr>
<tr>
<td>
<img src="showcase/04_month_view.png" alt="Month View" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Monthly calendar view to browse events.
</td>
</tr>
<tr>
<td>
<img src="showcase/05_day_view.png" alt="Day View" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Daily event view with event details for that day.
</td>
</tr>
<tr>
<td>
<img src="showcase/06_duration_event_edit.png" alt="Edit Duration Event" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Edit screen for duration-based events.
</td>
</tr>
<tr>
<td>
<img src="showcase/07_instant_event_edit.png" alt="Edit Instant Event" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Edit screen for instant events.
</td>
</tr>
<tr>
<td>
<img src="showcase/08_invite_user_to_event.png" alt="Invite User to Event" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Interface for inviting users to an event.
</td>
</tr>
<tr>
<td>
<img src="showcase/09_duration_event_details.png" alt="Duration Event Details" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Detailed view of a duration-based event.
</td>
</tr>
<tr>
<td>
<img src="showcase/10_instant_event_details.png" alt="Instant Event Details" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Detailed view of an instant event.
</td>
</tr>
<tr>
<td>
<img src="showcase/11_categories.png" alt="Categories Overview" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
List of event categories of the user.
</td>
</tr>
<tr>
<td>
<img src="showcase/12_new_category.png" alt="Create New Category" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Form to create a new category.
</td>
</tr>
<tr>
<td>
<img src="showcase/13_categories_with_new.png" alt="Updated Categories" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Updated list with a newly added category.
</td>
</tr>
<tr>
<td>
<img src="showcase/14_settings.png" alt="Settings Screen" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Settings menu for app configuration. Only available when logged in.
</td>
</tr>
<tr>
<td>
<img src="showcase/15_notification_invite_bob.png" alt="Notification: Invite" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Notification about an incoming event invite.
</td>
</tr>
<tr>
<td>
<img src="showcase/16_invite_event_details_preview.png" alt="Invite Preview" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Preview of the event from the invite.
</td>
</tr>
<tr>
<td>
<img src="showcase/17_notification_invite_accepted_bob.png" alt="Notification: Invite Accepted" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Notification for the invite after acceptance.
</td>
</tr>
<tr>
<td>
<img src="showcase/18_day_view_invited_event_bob.png" alt="Day View with Invite" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Day view showing the invited event.
</td>
</tr>
<tr>
<td>
<img src="showcase/19_invited_event_details_bob.png" alt="Invited Event Details" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Details of an event the user was invited to.
</td>
</tr>
<tr>
<td>
<img src="showcase/20_notification_invite_accepted_john.png" alt="Notification Accepted John" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Notification about a user accepting an outgoing invite.
</td>
</tr>
<tr>
<td>
<img src="showcase/21_notifications_cleared.png" alt="Notifications Cleared" style="width: 200px; height: 450px; object-fit: contain;" />
</td>
<td>
Screen showing cleared notifications.
</td>
</tr>
</table>