This is my U03 assignment for the backend course at Chas Academy. Ordna is a task management app designed to help you track and organize your tasks efficiently. There are both custom and smart lists to categorize your tasks. Each task includes detailed information such as a deadline, a scheduled date, and notes. The app also supports user authentication with a username and password to keep your data secure.
First, build and run the docker container:
docker compose up
This will start three services:
- The PHP server, available at http://localhost/
- The MariaDB database
- Adminer, available at http://localhost:8080/
- Credentials for logging in can be found in docker-compose.yml
The first time you build the container the database structure will be set up according to seed.sql.
Once the docker container is up and running you can run PHP_CodeSniffer to check the code against the PSR-12 standard with:
docker compose exec php phpcs --extensions=php /var/www/html/
The project is organized into the following directories:
All routes, like index.php
and today.php
are kept at the root of the /src
directory. Here you can also find the Database
class used to get the singleton instance of the connection connecting the project to the MariaDB database. There is also a file called layout.php
that is responsible for providing a base template to all routes.
Handles mutations like creating and managing tasks and lists. Each file represents a resource that decides what type of CRUD action is to be used.
Contains reusable templates and class components for modularity and reusability. Most components consist of a component.php
and a component.template.php
. The first file is responsible for handling props and data, while the template is responsible for handling markup. All components have a render
function that is used any time you want to display the component.
Component::render($props);
Contains controllers essential for the core functionality of the app. These files include reusable code, such as authentication logic and crud functions for tasks and lists, that can be used across different parts of the application.
This project is mostly built with PHP but there are some small user experience parts that are built with JavaScript. This directory includes logic for opening and closing modals, input field previews and more...
The project is styled with SCSS to create reusable and well structured styling. This directory consists of partial SCSS files that are being pulled in to style.scss and compiled to CSS.
Includes helper functions for things such as date formatting, input validating and navigation, to simplify the main application logic.