Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/changeweb/Unifiedtransform
A school management Software
https://github.com/changeweb/Unifiedtransform
attendance-system bootstrap laravel oop php7 school-grading-system school-management school-management-software teacher-student
Last synced: 2 months ago
JSON representation
A school management Software
- Host: GitHub
- URL: https://github.com/changeweb/Unifiedtransform
- Owner: changeweb
- License: gpl-3.0
- Created: 2019-03-12T08:34:52.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-01-29T05:44:11.000Z (12 months ago)
- Last Synced: 2024-02-15T02:32:22.304Z (11 months ago)
- Topics: attendance-system, bootstrap, laravel, oop, php7, school-grading-system, school-management, school-management-software, teacher-student
- Language: PHP
- Homepage: https://changeweb.github.io/Unifiedtransform/
- Size: 11.3 MB
- Stars: 2,723
- Watchers: 179
- Forks: 1,199
- Open Issues: 117
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-opensource-apps - Unifiedtransform
README
## Version 2.X is here!!
For Version 1.X, view [releases](https://github.com/changeweb/Unifiedtransform/releases). Continuation of Version 1.X support in **[v1-x-branch](https://github.com/changeweb/Unifiedtransform/tree/v1-x-branch)** branch.
School Management and Accounting Software[![Build Status](https://travis-ci.org/changeweb/Unifiedtransform.svg?branch=master)](https://travis-ci.org/changeweb/Unifiedtransform)
![Pricing](https://img.shields.io/badge/Pricing-Free-brightgreen)
[![Linux](https://img.shields.io/travis/changeweb/Unifiedtransform/master.svg?label=linux)](https://travis-ci.org/changeweb/Unifiedtransform)
[![Code Climate](https://codeclimate.com/github/changeweb/Unifiedtransform/badges/gpa.svg)](https://codeclimate.com/github/changeweb/Unifiedtransform)
[![Latest release](https://img.shields.io/github/release/changeweb/Unifiedtransform/all.svg)](https://github.com/changeweb/Unifiedtransform/releases)
[![MadeWithLaravel.com shield](https://madewithlaravel.com/storage/repo-shields/1362-shield.svg)](https://madewithlaravel.com/p/unifiedtransform/shield-link)
[![Discord](https://img.shields.io/discord/917848091107946556)](https://discord.gg/8sz6kpup99)
[![Contribute](https://img.shields.io/badge/Help%20Wanted-Contribute-blue)](https://github.com/changeweb/Unifiedtransform/issues?q=is%3Aissue+is%3Aopen+)We like to challenge the quality of what we build to make it better. To do so, we try to make the product intuitive, beautiful, and user friendly. Innovation and hard work help to fulfill these requirements. I believe in order to innovate we need to think differently. A few months ago I discovered there was no open source free school management software that met my quality standards. I happen to know a bit of programming so I decided to make one. I also believe that working with more people can push the standard higher than working alone. So I decided to make it open source and free.
## Featured on Laravel News !!
![Screenshot_2019-04-07 Laravel News](https://user-images.githubusercontent.com/9896315/55683832-1b3c8c80-5966-11e9-8dfb-ab30a79a98ed.png)
See the news [here](https://laravel-news.com/unified-transform-open-source-school-management-platform)## Framework used
- [Laravel 8.X](https://laravel.com/docs/8.x)
- [Bootstrap 5.X](https://getbootstrap.com/docs/5.0/getting-started/introduction/)## Server Requirements
- PHP >= 7.4
- OpenSSL PHP Extension
- PDO PHP Extension
- Mbstring PHP Extension
- Tokenizer PHP Extension
- XML PHP Extension## Testing
- We want testable softwares. Most parts of the software in the previous version 1.x were covered by tests. Lets cover version 2.x as well. You also can contribute by writing test case!
- To run Feature and Unit Tests run following commands:```sh
$ docker exec -it app sh
// Inside container shell
:/# php artisan test
```## License
GNU General Public License v3.0
## Contribute
Unifiedtransform is 100% open source and free forever!!
Community contribution can make this product better!!
When you contribute to a Github project you agree with this terms of [Github Terms of Service(Contributions Under Repository License)](https://help.github.com/en/articles/github-terms-of-service#6-contributions-under-repository-license).
Since this project is under **GNU General Public License v3.0**, according to Github's Terms of Service all your contributions are also under the same license terms.
Thus you permit the user of this software to use your contribution under the terms of **GNU General Public License v3.0**.## Whats New
v2.X is built from scratch. Both UI and internal workflow of the application are changed to a better design.## Features yet to be migrated from v1.X to v2.X
Following features that exist in v1.X will be added in v2.X as well in future.- Stripe payment
- Messaging
- Managing library
- Managing Income and Expenses
- Mass student and teachers export and import.
- Printing reports
- Managing certificates.
- Supported other languages (Spanish, ...).## How to Start
### Using Docker Container:#### Video instruction
https://user-images.githubusercontent.com/9896315/231230479-bb497be3-024c-4568-b3ea-2b0e8f3501aa.mp4
#### Document instruction
**[Docker](https://www.docker.com/)** is now supported and improved.
[How To Set Up Laravel, Nginx, and MySQL With Docker Compose on Ubuntu 20.04](https://www.digitalocean.com/community/tutorials/how-to-set-up-laravel-nginx-and-mysql-with-docker-compose-on-ubuntu-20-04)
With the improved Docker setup, you will get:
- Nginx
- PHP 7.4
- MySQL 5.7### Steps to install:
1. Clone or download the repository.
2. Create **purify** folder in `storage/app/` directory.
3. Run `cp .env.example .env`.
4. Run `docker-compose up -d`.
5. Run `docker exec -it db sh`. Inside the shell, run:```sh
:/# mysql -u root -p
```Mysql **Root password**: `your_mysql_root_password` in the `docker-compose.yml` file. Then run following commands:
```sql
mysql> SHOW DATABASES;
mysql> GRANT ALL ON unifiedtransform.* TO 'unifiedtransform'@'%' IDENTIFIED BY 'secret';
mysql> FLUSH PRIVILEGES;
mysql> EXIT;
```
6. Finally, exit the container by running `exit` in the container shell.
7. Run `docker exec -it app sh`. Inside the shell, run following commands:```sh
:/# composer install
:/# php artisan key:generate
:/# php artisan config:cache
:/# php artisan migrate:fresh --seed
```Then exit from the container.
8. Visit **http://localhost:8080**. Admin login credentials:- Email: [email protected]
- Password: password## Steps to follow:
Please carefully follow the steps to setup the school.**Role: Admin**
**School Dashboard**
### 1. Create a School Session:
After logging in for the first time, you will see following message at the top nav bar.To create a new session, go to **Academic Settings** page.
#### Academic Settings page:
Successful creation of session using following form will display success message:
### 2. Create a Semester
Now create a semester. A semester duration usually is 3 - 6 months.### 3. Create classes
Now create classes. Give common names such as: **Class 1** or **Class 11 (Science)**.### 4. Create sections
Now create sections for each classes. Give section's name (e.g.: Section A, Section B), room number and assign them to respective class.### 5. Create Courses
Now create courses and assign them to respective semester and class.### 6. Set attendance type
Attendance can be maintained in two ways: 1. By section, 2. By course. Stick to one type for a semester. Default: **By section**.### 7. Add teachers
Now add teachers.### 8. Assign teacher
Now assign teachers to semester, class, section, and course.### 9. Add students
Now add students and assign them to class, and section.### 10. View added teachers and students
Now browse to **View Teachers** and **View Students** pages.### 11. View student and teacher profile
Now browse to **Profile** from student and teacher list.### 12. View and Edit Classes and Sections
Now go to **Classes**. Here you can view all classes and their respective sections, syllabi, and courses. Classes, sections, and courses can be edited from here.### 13. Create Grading Systems
Now create grading system for each class and a semester.### 14. View Grading Systems
Now browse to created Grading Systems.### 15. Add and view Grading System Rules
Now add rules to the grading system and browse them.### 16. Add Notices
Admin can add notice. Right now, notices can be written using a rich text editor.### 17. Create Events
Events can be created inside a calendar. Click and drag on a date or time period to prompt the input box. An already created event can be **deleted** by clicking on the event.### 18. Create and view Routines
Routines can be created for each class and section.### 19. Add Syllabi
Syllabus for each class and course can be added. Admin can view them from **Classes** page. Syllabus can be downloaded.### 20. Browse by Sessions
You can browse previous sessions like a snapshot. This mode is **Read only**. Nobody should be able to change the previous sessions' data.### 21. Allow Teachers to submit Final Marks
Submitting final marks of a semester should be controlled. By enabling this feature, it is possible to open a Mark Submission Window for a short time period. **Default: Disallowed**.### 22. Promote students
Students can only be promoted to a new class and section when a new Session along with its classes and sections are created.
**Role: Teacher**
**Teacher's dashboard**
### 1. View assigned courses
Teachers can manage their assigned courses from this page. From this page, teacher can do following:- Take and view attendance
- View Syllabus
- Create and view Assignment
- Give Marks
- Message Students (Available in v1.X. Will be added in v2.X as well).### 2. Take attendance
Teacher can take attendance for a section or a course (attendance type set by Admin).### 3. View attendance
Teacher can view attendance.### 4. View syllabus
Teacher can view and download syllabus.### 5. Create assignment
Teacher can create assignment for an assigned course by uploading files.### 6. View assignments
Teacher can view and download created assignments.### 7. Create Exams
Before giving marks, teacher needs to create exams and set their rules. Don't have to create all the exams at a time. (Admin can also create exams on behalf of teachers).### 8. View created exams
Teacher can view their created exams.### 9. Add, edit and view exam rules
Teacher can add, edit, and view exam rules.### 10. Give marks
Teacher can give marks after creating exams. Clicking on the exam names will lead to associated exam rules.### 11. Submit Final Marks
When the Grade submission window is open, teacher can submit final marks. Calculated marks will be generated based on all exams' marks. Final marks should be in **between** the marks set in the grade rules.If final marks is submitted, a message will be shown in place of submit button in **Give Marks** page.
### 12. View Final Results
Teachers can view final results and calculated grades for a semester, class, section, and course based on their created grade rules.**Role: Student**
**Student dashboard**
### 1. View attendance
A student can view his/her attendance.### 2. View courses
A student can view his/her courses that are assigned in his/her class. From here, a student can do following:- View Marks
- View Syllabus
- View Assignments### 3. View Marks
A student can view marks, final results and grade for a course.### 4. View and download Syllabus
Students can view and download syllabi of their courses just like their teachers.### 5. View and download assignments
Students can view and download assignments of their courses just like their teachers.### 6. View routine
Students can view their class and section routine just like their admin/teachers.