@ -0,0 +1,46 @@ |
|||
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg |
|||
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html |
|||
:alt: License: AGPL-3 |
|||
|
|||
Education ERP Dashboard |
|||
======================= |
|||
A visually informative interface of education ERP system provides an at-a-glance overview of essential data. |
|||
|
|||
Configuration |
|||
============= |
|||
- No additional configuration required |
|||
|
|||
Company |
|||
------- |
|||
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__ |
|||
|
|||
Credits |
|||
------- |
|||
Developer: (V15) Sruthi Renjith, Contact: odoo@cybrosys.com |
|||
|
|||
Contacts |
|||
-------- |
|||
* Mail Contact : odoo@cybrosys.com |
|||
* Website : https://cybrosys.com |
|||
|
|||
License |
|||
------- |
|||
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3 (AGPLv3) |
|||
(https://www.gnu.org/licenses/agpl-3.0-standalone.html) |
|||
|
|||
Bug Tracker |
|||
----------- |
|||
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. |
|||
|
|||
Maintainer |
|||
========== |
|||
.. image:: https://cybrosys.com/images/logo.png |
|||
:target: https://cybrosys.com |
|||
|
|||
This module is maintained by Cybrosys Technologies. |
|||
|
|||
For support and more information, please visit `Our Website <https://cybrosys.com/>`__ |
|||
|
|||
Further information |
|||
=================== |
|||
HTML Description: `<static/description/index.html>`__ |
@ -0,0 +1,22 @@ |
|||
# -*- coding: utf-8 -*- |
|||
################################################################################ |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). |
|||
# Author: Sruthi Renjith (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from . import models |
@ -0,0 +1,55 @@ |
|||
# -*- coding: utf-8 -*- |
|||
################################################################################ |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). |
|||
# Author: Sruthi Renjith (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
{ |
|||
'name': 'Education ERP Dashboard', |
|||
'version': '15.0.1.0.0', |
|||
'category': 'Industries, Productivity', |
|||
'summary': 'An integrated view of the education ERP system', |
|||
'description': """A comprehensive module designed to provide educational |
|||
institutions to manage and monitor various operations""", |
|||
'author': "Cybrosys Techno Solutions", |
|||
'company': 'Cybrosys Techno Solutions', |
|||
'maintainer': 'Cybrosys Techno Solutions', |
|||
'website': "https://www.cybrosys.com", |
|||
'depends': ['base', 'education_attendances', 'education_promotion', |
|||
'education_time_table'], |
|||
'data': [ |
|||
'security/ir.model.access.csv', |
|||
'views/dashboard_tag_views.xml', |
|||
'views/erp_dashboard_menu.xml'], |
|||
'assets': { |
|||
'web.assets_backend': [ |
|||
'education_erp_dashboard/static/src/js/dashboard.js', |
|||
'education_erp_dashboard/static/src/css/dashboard.css', |
|||
'https://cdn.jsdelivr.net/npm/chart.js' |
|||
], |
|||
'web.assets_qweb': [ |
|||
'education_erp_dashboard/static/src/xml/dashboard_templates.xml', |
|||
'education_erp_dashboard/static/src/xml/dashboard_content_templates.xml' |
|||
], |
|||
}, |
|||
'images': ['static/description/banner.jpg'], |
|||
'license': 'AGPL-3', |
|||
'installable': True, |
|||
'auto_install': False, |
|||
'application': True, |
|||
} |
@ -0,0 +1,6 @@ |
|||
## Module <education_erp_dashboard> |
|||
|
|||
#### 22.09.2023 |
|||
#### Version 15.0.1.0.0 |
|||
#### ADD |
|||
- Initial commit for Education ERP Dashboard |
@ -0,0 +1,22 @@ |
|||
# -*- coding: utf-8 -*- |
|||
################################################################################ |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). |
|||
# Author: Sruthi Renjith (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from . import erp_dashboard |
@ -0,0 +1,166 @@ |
|||
# -*- coding: utf-8 -*- |
|||
################################################################################ |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). |
|||
# Author: Sruthi Renjith (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class ERPDashboard(models.Model): |
|||
""" Class to get all the required data for the dashboard """ |
|||
_name = "erp.dashboard" |
|||
_description = "Education ERP Dashboard" |
|||
|
|||
@api.model |
|||
def erp_data(self): |
|||
""" Function to get the datas like number of application, number of |
|||
students, number of faculties, number of amenities and number of |
|||
exams """ |
|||
return { |
|||
'applications': self.env['education.application'].search_count([]), |
|||
'students': self.env['education.student'].search_count([]), |
|||
'faculties': self.env['education.faculty'].search_count([]), |
|||
'amenities': self.env['education.amenities'].search_count([]), |
|||
'exams': self.env['education.exam'].search_count([]), |
|||
} |
|||
|
|||
@api.model |
|||
def get_all_applications(self): |
|||
""" Function to get count of applications in each academic year """ |
|||
years = self.env['education.application'].search([]).mapped( |
|||
'academic_year_id') |
|||
application_count_dict = { |
|||
year.name: self.env['education.application'].search_count( |
|||
[('academic_year_id', '=', year.name)]) for year in years} |
|||
return application_count_dict |
|||
|
|||
@api.model |
|||
def get_rejected_accepted_applications(self): |
|||
""" Function to get count of all accepted and rejected applications """ |
|||
application_dict = {} |
|||
academic_year_date = 0 |
|||
academic_year_year = '' |
|||
academic_year = self.env['education.academic.year'].search([]) |
|||
for years in academic_year: |
|||
academic_year_date = years.ay_end_date |
|||
academic_year_year = years.name |
|||
for year in academic_year: |
|||
if academic_year_date < year.ay_end_date: |
|||
academic_year_date = year.ay_end_date |
|||
academic_year_year = year.name |
|||
rejected_applications = self.env['education.application'].search_count( |
|||
[('state', '=', 'reject'), |
|||
('academic_year_id', '=', academic_year_year)]) |
|||
accepted_applications = self.env['education.application'].search_count( |
|||
[('state', '=', 'done'), |
|||
('academic_year_id', '=', academic_year_year)]) |
|||
application_dict.update( |
|||
{'Done': accepted_applications, 'Reject': rejected_applications}) |
|||
return application_dict |
|||
|
|||
@api.model |
|||
def get_exam_result(self): |
|||
""" Function to get total exam result """ |
|||
exam_result_dict = {} |
|||
pass_count = self.env['results.subject.line'].search_count( |
|||
[('pass_or_fail', '=', True)]) |
|||
fail_count = self.env['results.subject.line'].search_count( |
|||
[('pass_or_fail', '=', False)]) |
|||
exam_result_dict.update({'Pass': pass_count, 'Fail': fail_count}) |
|||
return exam_result_dict |
|||
|
|||
@api.model |
|||
def get_attendance(self): |
|||
""" Function to get total attendance """ |
|||
attendance_dict = {} |
|||
absents = self.env['education.attendance.line'].search_count( |
|||
[('date', '=', fields.Date.today()), ('full_day_absent', '=', 1)]) |
|||
total = self.env['education.student'].search_count([]) |
|||
presents = total - absents |
|||
attendance_dict.update({'Presents': presents, 'Absents': absents}) |
|||
return attendance_dict |
|||
|
|||
@api.model |
|||
def get_student_strength(self): |
|||
""" Function to get class wise student strength """ |
|||
classes = self.env['education.class.division'].search([]) |
|||
class_wise_dict = { |
|||
clas.name: self.env['education.student'].search_count( |
|||
[('class_id', '=', clas.id)]) for clas in classes} |
|||
return class_wise_dict |
|||
|
|||
@api.model |
|||
def get_average_marks(self): |
|||
""" Function to get class wise average marks """ |
|||
class_average_mark_dict = {} |
|||
classes = self.env['education.class.division'].search([]) |
|||
for clas in classes: |
|||
all_students = self.env['education.student'].search( |
|||
[('class_id', '=', clas.id)]) |
|||
if all_students: |
|||
class_mark_list = [sum( |
|||
self.env['education.exam.results'].search( |
|||
[('student_id', '=', student.id)]).mapped( |
|||
'total_mark_scored')) for student in all_students] |
|||
count = len(class_mark_list) |
|||
total_marks = sum(class_mark_list) |
|||
average_mark = total_marks / count |
|||
class_average_mark_dict.update({clas.name: average_mark}) |
|||
return class_average_mark_dict |
|||
|
|||
@api.model |
|||
def get_academic_year(self): |
|||
""" Function to get the academic year """ |
|||
academic_dict = {year.id: year.name for year in |
|||
self.env['education.academic.year'].search([])} |
|||
return academic_dict |
|||
|
|||
@api.model |
|||
def get_academic_year_exam_result(self, *args): |
|||
""" Function to get exam results in each academic year """ |
|||
academic_exam_result_dict = {} |
|||
academic_pass_count = self.env['results.subject.line'].search_count( |
|||
[('academic_year.id', '=', *args), ('pass_or_fail', '=', True)]) |
|||
academic_fail_count = self.env['results.subject.line'].search_count( |
|||
[('academic_year.id', '=', *args), ('pass_or_fail', '=', False)]) |
|||
academic_exam_result_dict.update( |
|||
{'Pass': academic_pass_count, 'Fail': academic_fail_count}) |
|||
return academic_exam_result_dict |
|||
|
|||
@api.model |
|||
def get_classes(self): |
|||
""" Function to get the classes """ |
|||
class_dict = {clas.id: clas.name for clas in |
|||
self.env['education.class.division'].search([])} |
|||
return class_dict |
|||
|
|||
@api.model |
|||
def get_class_attendance_today(self, *args): |
|||
""" Function to get class wise attendance """ |
|||
class_attendance_dict = {} |
|||
class_absents = self.env['education.attendance.line'].search_count( |
|||
[('division_id.id', '=', *args), |
|||
('date', '=', fields.Date.today()), |
|||
('full_day_absent', '=', 1)]) |
|||
class_total = self.env['education.student'].search_count( |
|||
[('class_id.id', '=', *args)]) |
|||
class_presents = class_total - class_absents |
|||
class_attendance_dict.update( |
|||
{'Presents': class_presents, 'Absents': class_absents}) |
|||
return class_attendance_dict |
|
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 576 B |
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 911 B |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 673 B |
After Width: | Height: | Size: 878 B |
After Width: | Height: | Size: 653 B |
After Width: | Height: | Size: 905 B |
After Width: | Height: | Size: 839 B |
After Width: | Height: | Size: 427 B |
After Width: | Height: | Size: 627 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 988 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.9 KiB |
After Width: | Height: | Size: 2.2 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 2.1 KiB |
After Width: | Height: | Size: 13 KiB |
After Width: | Height: | Size: 589 B |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 967 B |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 3.8 KiB |
After Width: | Height: | Size: 5.0 KiB |
After Width: | Height: | Size: 103 KiB |
After Width: | Height: | Size: 124 KiB |
After Width: | Height: | Size: 90 KiB |
After Width: | Height: | Size: 136 KiB |
After Width: | Height: | Size: 71 KiB |
After Width: | Height: | Size: 68 KiB |
After Width: | Height: | Size: 13 KiB |
After Width: | Height: | Size: 23 KiB |
After Width: | Height: | Size: 12 KiB |
After Width: | Height: | Size: 71 KiB |
After Width: | Height: | Size: 18 KiB |
After Width: | Height: | Size: 97 KiB |
After Width: | Height: | Size: 15 KiB |
After Width: | Height: | Size: 17 KiB |
After Width: | Height: | Size: 42 KiB |
After Width: | Height: | Size: 142 KiB |
After Width: | Height: | Size: 9.4 KiB |
@ -0,0 +1,735 @@ |
|||
<div style="background-color: #714B67; min-height: 600px; width: 100%; padding: 15px; position: relative;"> |
|||
<!-- TITLE BAR --> |
|||
<div class="d-flex align-items-center justify-content-between" |
|||
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;"> |
|||
<img src="assets/misc/e_logo.png" width="162" height="60" |
|||
style="width:auto !important; height:60px !important"/> |
|||
<div> |
|||
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" |
|||
class="mr-2"> |
|||
<i class="fa fa-check mr-1"></i>Community |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF TITLE BAR --> |
|||
|
|||
<div class="container"> |
|||
<div class="row"> |
|||
<div class="col-sm-12 col-md-12 col-lg-12"> |
|||
<!-- APP HERO --> |
|||
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;"> |
|||
Education ERP Dashboard</h1> |
|||
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;"> |
|||
Insight to Educational ERP</p> |
|||
<!-- END OF APP HERO --> |
|||
<img src="assets/screenshots/hero.gif" |
|||
style="width: 75%; height: auto; position: absolute; margin-left: auto; margin-right: auto; top: 45%; left: 12%; right: auto;"/> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<!-- NAVIGATION SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/compass.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Explore This |
|||
Module</h2> |
|||
</div> |
|||
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;"> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#overview"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn |
|||
more about this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#config"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Configuration</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View |
|||
configuration of this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#features"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View |
|||
features of this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#screenshots"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View |
|||
screenshots for this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<!-- END OF NAVIGATION SECTION --> |
|||
|
|||
<!-- OVERVIEW SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" |
|||
id="overview"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/pie-chart.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Overview |
|||
</h2> |
|||
</div> |
|||
<div class="row" |
|||
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> |
|||
<div class="col-sm-12 py-4"> |
|||
Education ERP Dashboard give an insight to Education ERP Core. |
|||
This dashboard allows a quick analysis of the details related to |
|||
students, faculties, exams and all. |
|||
</div> |
|||
</div> |
|||
<!-- END OF OVERVIEW SECTION --> |
|||
|
|||
<!-- CONFIGURATION SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="config"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/config.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Configuration |
|||
</h2> |
|||
</div> |
|||
<div class="row" |
|||
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> |
|||
<div class="col-sm-12 py-4"> |
|||
No additional configuration is required. |
|||
</div> |
|||
</div> |
|||
<!-- END OF CONFIGURATION SECTION --> |
|||
|
|||
<!-- FEATURES SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" |
|||
id="features"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/features.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Features |
|||
</h2> |
|||
</div> |
|||
<div class="row" |
|||
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> |
|||
<div class="col-sm-12 col-md-6"> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 40px; margin-bottom: 40px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Clickable dashboard cards.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">A quick analysis of the counts.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Insight of upcoming and recent activities.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Academic wise exam results.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 40px; margin-bottom: 40px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Attendance details as doughnut chart.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Exam result in pie chart.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Class wise student strength.</span> |
|||
</div> |
|||
</div> |
|||
<div class="d-flex align-items-start" |
|||
style="margin-top: 30px; margin-bottom: 30px"> |
|||
<img src="assets/misc/check-box.png" class="mr-2"/> |
|||
<div> |
|||
<span |
|||
style="display: block; font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Student application details.</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF FEATURES SECTION --> |
|||
|
|||
<!-- SCREENSHOTS SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" |
|||
id="screenshots"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/pictures.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Screenshots |
|||
</h2> |
|||
</div> |
|||
<div class="row"> |
|||
<div class="col-sm-12"> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Dashboard view</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
This is the overall view of the dashboard.</p> |
|||
<img src="assets/screenshots/dashboard.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Clickable tiles</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
This gives all the details in one click.</p> |
|||
<img src="assets/screenshots/tiles.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Application Bar Chart</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
This gives the count of applications in each academic year.</p> |
|||
<img src="assets/screenshots/application.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Student Attendance</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
A doughnut chart that gives the total and class wise attendance |
|||
details.</p> |
|||
<img src="assets/screenshots/attendance.png" class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Exam Result</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
A pie chart the gives the academic wise and total exam |
|||
results.</p> |
|||
<img src="assets/screenshots/exam_result.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Student Strength</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
A line chart that gives the details related to the class |
|||
strength.</p> |
|||
<img src="assets/screenshots/student_strength.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Average Marks</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
A bar chart that gives the details of average marks in |
|||
each class.</p> |
|||
<img src="assets/screenshots/average_marks.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Rejected Applications</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
A bar chart that shows the count of accepted and rejected |
|||
applications.</p> |
|||
<img src="assets/screenshots/rejected_applications.png" |
|||
class="img-thumbnail"> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF SCREENSHOTS SECTION --> |
|||
|
|||
<!-- SUGGESTED PRODUCTS --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/categories.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Suggested |
|||
Products |
|||
</h2> |
|||
</div> |
|||
<div class="row"> |
|||
<div class="col-sm-12"> |
|||
<div id="demo1" class="row carousel slide" data-ride="carousel"> |
|||
<!-- The slideshow --> |
|||
<div class="carousel-inner" style="padding: 30px;"> |
|||
<div class="carousel-item" style="min-height: 198.656px;"> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_core/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/1.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_promotion/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/2.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_time_table/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/3.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="carousel-item active" |
|||
style="min-height: 198.656px;"> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_exam/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/4.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_attendances/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/5.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/15.0/education_hostel/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-radius: 0px;" |
|||
src="./assets/modules/6.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Left and right controls --> |
|||
<a class="carousel-control-prev" href="#demo1" data-slide="prev" |
|||
style="width:35px; color:#000"> <span |
|||
class="carousel-control-prev-icon"><i |
|||
class="fa fa-chevron-left" |
|||
style="font-size:24px"></i></span> |
|||
</a> <a class="carousel-control-next" href="#demo1" |
|||
data-slide="next" style="width:35px; color:#000"> |
|||
<span class="carousel-control-next-icon"><i |
|||
class="fa fa-chevron-right" |
|||
style="font-size:24px"></i></span> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF SUGGESTED PRODUCTS --> |
|||
|
|||
<!-- OUR SERVICES --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/star.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Our Services |
|||
</h2> |
|||
</div> |
|||
<div class="container my-5"> |
|||
<div class="row"> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/cogs.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Customization</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/wrench.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Implementation</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/lifebuoy.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Support</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/user.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Hire |
|||
Odoo |
|||
Developer</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/puzzle.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Integration</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/update.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Migration</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/consultation.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Consultancy</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/training.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Implementation</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/license.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Licensing Consultancy</h6> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF OUR SERVICES --> |
|||
|
|||
<!-- OUR INDUSTRIES --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/corporate.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Our |
|||
Industries |
|||
</h2> |
|||
</div> |
|||
|
|||
<div class="container my-5"> |
|||
<div class="row"> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/trading-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Trading |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Easily procure |
|||
and |
|||
sell your products</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/pos-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
POS |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Easy |
|||
configuration |
|||
and convivial experience</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/education-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Education |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
A platform for |
|||
educational management</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/manufacturing-black.png" |
|||
class="img-responsive mb-3" height="48px" |
|||
width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Manufacturing |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Plan, track and |
|||
schedule your operations</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="./assets/icons/ecom-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
E-commerce & Website |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Mobile |
|||
friendly, |
|||
awe-inspiring product pages</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="./assets/icons/service-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Service Management |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Keep track of |
|||
services and invoice</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="./assets/icons/restaurant-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Restaurant |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Run your bar or |
|||
restaurant methodically</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="./assets/icons/hotel-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Hotel Management |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
An |
|||
all-inclusive |
|||
hotel management application</p> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF OUR INDUSTRIES --> |
|||
|
|||
<!-- SUPPORT --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/customer-support.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Support |
|||
</h2> |
|||
</div> |
|||
<div class="container mt-5"> |
|||
<div class="row"> |
|||
<div class="col-sm-12 col-md-6"> |
|||
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;"> |
|||
<div class="mr-4" |
|||
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;"> |
|||
<img src="assets/misc/support.png" height="48" width="48" |
|||
style="width: 42px; height: 42px;"/> |
|||
</div> |
|||
<div> |
|||
<h4>Need Help?</h4> |
|||
<p style="line-height: 100%;">Got questions or need help? |
|||
Get in touch.</p> |
|||
<a href="mailto:odoo@cybrosys.com"> |
|||
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;"> |
|||
odoo@cybrosys.com</p> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6"> |
|||
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;"> |
|||
<div class="mr-4" |
|||
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;"> |
|||
<img src="assets/misc/whatsapp.png" height="52" width="52" |
|||
style="width: 52px; height: 52px;"/> |
|||
</div> |
|||
<div> |
|||
<h4>WhatsApp</h4> |
|||
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p> |
|||
<a href="https://api.whatsapp.com/send?phone=918606827707"> |
|||
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;"> |
|||
+91 86068 |
|||
27707</p> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="row"> |
|||
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center"> |
|||
<img src="assets/misc/logo.png" width="144" height="31" |
|||
style="width:144px; height: 31px; margin-top: 40px;"/> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF SUPPORT --> |
@ -0,0 +1,176 @@ |
|||
.stat-icon { |
|||
width: 30%; |
|||
height: 65px; |
|||
text-align: center; |
|||
background: #ffa07a; |
|||
color: #fff; |
|||
padding-top: 2%; |
|||
font-size: xx-large; |
|||
display: inline-block; |
|||
border-radius: 10px; |
|||
} |
|||
.stat-content { |
|||
text-align: center; |
|||
color: black !important; |
|||
display: inline-block; |
|||
width: 50%; |
|||
} |
|||
.stat-count{ |
|||
text-align: center; |
|||
width: 50%; |
|||
} |
|||
.stat-head { |
|||
text-align: left !important; |
|||
font-weight: 300; |
|||
font-size: 18px; |
|||
margin-left: 10px; |
|||
width: 100%; |
|||
} |
|||
.stat-widget-one .stat-icon { |
|||
vertical-align: top; |
|||
margin: auto; |
|||
font-weight: 900; |
|||
display: inline-block; |
|||
} |
|||
.stat-widget-one{ |
|||
font-weight: bold; |
|||
} |
|||
.content-card-body { |
|||
display: flex; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
} |
|||
.stat-widget-one { |
|||
margin-top: 2.3rem; |
|||
margin-left: 1rem; |
|||
} |
|||
.stat-widget-one{ |
|||
margin-left: 1rem; |
|||
margin-top: -1px; |
|||
font-family: initial |
|||
} |
|||
.stat-widget-one .stat-icon{ |
|||
font-weight: 900; |
|||
display: inline-block; |
|||
color: #fff; |
|||
} |
|||
.stat-widget-one { |
|||
background-color: white; |
|||
text-align: left; |
|||
} |
|||
.stat-widget-one { |
|||
background: none; |
|||
} |
|||
.stat-widget-one .stat-icon { |
|||
text-align: center; |
|||
padding-top: 9px; |
|||
} |
|||
.stat-widget-one{ |
|||
margin: 0; |
|||
text-align: center; |
|||
width: 100% !important; |
|||
padding: 0; |
|||
color: #fff; |
|||
} |
|||
.stat-widget-one .stat-icon .fa { |
|||
font-size: 30px; |
|||
margin: 0px; |
|||
box-shadow: none; |
|||
} |
|||
.content-card { |
|||
font-size: 1rem; |
|||
} |
|||
.content-card:hover { |
|||
transform:none !important; |
|||
box-shadow: none !important; |
|||
} |
|||
.content-card { |
|||
padding-top: 0px; |
|||
padding: 0px; |
|||
margin-bottom: 1.5rem; |
|||
border-radius: 10px; |
|||
box-shadow: none; |
|||
background: none; |
|||
transition: transform 0.2s ease, box-shadow 0.2s ease; |
|||
will-change: transform, box-shadow; |
|||
} |
|||
.content-card:hover { |
|||
transform: translateY(-2px) translateZ(0) !important; |
|||
box-shadow: 0 10px 10px 0 rgba(62, 57, 107, 0.12), 0 0 0 transparent !important; |
|||
} |
|||
.content-card { |
|||
transition: transform 0.2s ease, box-shadow 0.2s ease; |
|||
will-change: transform, box-shadow; |
|||
box-shadow: 0 10px 40px 0 rgba(62,57,107,0.07), 0 2px 9px 0 rgba(62,57,107,0.06); |
|||
} |
|||
.content-card { |
|||
margin: 0; |
|||
margin-bottom: 0px; |
|||
margin-bottom: 0px; |
|||
padding-bottom: 7px; |
|||
transition: transform 0.2s ease, box-shadow 0.2s ease; |
|||
will-change: transform, box-shadow; |
|||
box-shadow: 0 10px 40px 0 rgba(62,57,107,0.07), 0 2px 9px 0 rgba(62,57,107,0.06); |
|||
} |
|||
.content-card { |
|||
background: #fafad2; |
|||
transition: transform 0.2s ease, box-shadow 0.2s ease; |
|||
will-change: transform, box-shadow; |
|||
box-shadow: 0 10px 40px 0 rgba(62,57,107,0.07), 0 2px 9px 0 rgba(62,57,107,0.06); |
|||
padding: 15px; |
|||
} |
|||
.content-card{ |
|||
transition: none !important; |
|||
will-change: none !important; |
|||
box-shadow: none !important; |
|||
margin-bottom: 5px; |
|||
} |
|||
.content-card:hover{ |
|||
transform: translateY(-2px) translateZ(0) !important; |
|||
box-shadow: 0 10px 10px 0 rgba(62, 57, 107, 0.12), 0 0 0 transparent !important; |
|||
} |
|||
.row{ |
|||
margin-right: 0px; !important; |
|||
padding:30px; |
|||
} |
|||
.stat-count { |
|||
font-size: 20px; |
|||
text-align: center; |
|||
color: #000 !important; |
|||
width: 100%; |
|||
float: left; |
|||
} |
|||
.render_graph_div { |
|||
text-align: center; |
|||
width: 100%; |
|||
} |
|||
.inline { |
|||
display: inline-block; |
|||
width: 50%; |
|||
float: left; |
|||
padding: 80px; |
|||
} |
|||
.pie_canvas{ |
|||
margin-left: 50px; |
|||
height: 400px; |
|||
width: 100%; |
|||
text-align: center; |
|||
} |
|||
.graph_canvas{ |
|||
margin-top: 30px; |
|||
} |
|||
.doughnut_canvas{ |
|||
margin-left: 50px; |
|||
height: 380px; |
|||
width: 100%; |
|||
text-align: center; |
|||
display: flex; |
|||
} |
|||
.pie-chart-filter{ |
|||
width: 50%; |
|||
margin-left:60px; |
|||
} |
|||
.doughnut-chart-filter{ |
|||
width: 50%; |
|||
margin-left:60px; |
|||
} |
@ -0,0 +1,742 @@ |
|||
odoo.define("education_erp_dashboard.EducationalDashboard", function (require) { |
|||
"use strict"; |
|||
var AbstractAction = require('web.AbstractAction'); |
|||
var core = require('web.core'); |
|||
var QWeb = core.qweb; |
|||
var rpc = require('web.rpc'); |
|||
var DashBoard = AbstractAction.extend({ |
|||
contentTemplate: 'EducationalDashboard', |
|||
/* Loading the dashboard template */ |
|||
init: function(parent, context) { |
|||
this._super(parent, context); |
|||
this.dashboard_templates = ['MainSection']; |
|||
}, |
|||
/* Showing the total exam result and total attendance and hiding |
|||
the academic wise exam result and class wise attendance |
|||
when loading */ |
|||
start: function() { |
|||
var self = this; |
|||
self.set("title", 'Dashboard'); |
|||
return self._super().then(function() { |
|||
self.$('.academic_exam_result').hide(); |
|||
self.$('.exam_result').show(); |
|||
self.$('.class_attendance_today').hide(); |
|||
self.$('.total_attendance_today').show(); |
|||
/* Rendering the dashboard, graphs and filters */ |
|||
self.render_dashboards(); |
|||
self.render_graphs(); |
|||
self.render_filters(); |
|||
}); |
|||
}, |
|||
/* This function is called before the actual start */ |
|||
willStart: function(){ |
|||
var self = this; |
|||
return self._super() |
|||
}, |
|||
/* Function to render dashboard */ |
|||
render_dashboards: function() { |
|||
var self = this; |
|||
self.fetch_data() |
|||
var templates = [] |
|||
var templates = ['MainSection']; |
|||
_.each(templates, function(template) { |
|||
self.$('.o_hr_dashboard').append(QWeb.render(template, {widget: self})) |
|||
}); |
|||
}, |
|||
/* RPC call to fetch the count of applications, students, faculties, |
|||
amenities and total exams */ |
|||
fetch_data: function() { |
|||
var self = this; |
|||
rpc.query({ |
|||
model: 'erp.dashboard', |
|||
method: "erp_data", |
|||
}).then(function (result) { |
|||
self.$('#all_applications').append('<span>' + result.applications + '</span>'); |
|||
self.$('#all_students').append('<span>' + result.students + '</span>'); |
|||
self.$('#all_faculties').append('<span>' + result.faculties + '</span>'); |
|||
self.$('#all_amenities').append('<span>' + result.amenities + '</span>'); |
|||
self.$('#all_exams').append('<span>' + result.exams + '</span>'); |
|||
}); |
|||
}, |
|||
/* Click events for the tiles and change event for the filters */ |
|||
events:{ |
|||
'click #all_applications':'application_list', |
|||
'click #all_students':'student_list', |
|||
'click #all_faculties':'faculty_list', |
|||
'click #all_amenities':'amenity_list', |
|||
'click #all_attendance':'attendance_list', |
|||
'click #exams':'exam_result', |
|||
'click #timetable':'timetable', |
|||
'click #promotion':'promotions', |
|||
'change #select_period': function(e){ |
|||
e.preventDefault(); |
|||
if(e.target.value == 'select'){ |
|||
this.$('.academic_exam_result').hide(); |
|||
this.$('.exam_result').show(); |
|||
this.render_exam_result_pie(); |
|||
} |
|||
else{ |
|||
this.$('.exam_result').hide(); |
|||
this.$('.academic_exam_result').show(); |
|||
this.get_academic_exam_result(e.target.value); |
|||
} |
|||
}, |
|||
'change #select_class': function(e){ |
|||
e.preventDefault(); |
|||
if(e.target.value == 'select'){ |
|||
this.$('.class_attendance_today').hide(); |
|||
this.$('.total_attendance_today').show(); |
|||
this.render_attendance_doughnut(); |
|||
} |
|||
else{ |
|||
this.$('.total_attendance_today').hide(); |
|||
this.$('.class_attendance_today').show(); |
|||
this.get_class_attendance(e.target.value); |
|||
} |
|||
} |
|||
}, |
|||
/* Functions that to show the details on click event */ |
|||
/* Click event function to show the applications */ |
|||
application_list:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Applications", |
|||
res_model: "education.application", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the students */ |
|||
student_list:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Students", |
|||
res_model: "education.student", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the faculties */ |
|||
faculty_list:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Faculties", |
|||
res_model: "education.faculty", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the amenities */ |
|||
amenity_list:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Amenities", |
|||
res_model: "education.amenities", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the attendance list */ |
|||
attendance_list:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Attendance", |
|||
res_model: "education.attendance", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the exam results */ |
|||
exam_result:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Exam Result", |
|||
res_model: "education.exam", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the time table */ |
|||
timetable:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Timetable", |
|||
res_model: "education.timetable", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Click event function to show the promotions */ |
|||
promotions:function(e){ |
|||
e.preventDefault(); |
|||
this.do_action({ |
|||
type: "ir.actions.act_window", |
|||
name: "Student Promotions", |
|||
res_model: "education.student.final.result", |
|||
views: [[false,'list'],[false,'form']], |
|||
target: 'current', |
|||
view_type : 'list', |
|||
view_mode : 'list', |
|||
}); |
|||
}, |
|||
/* Calling the functions to creates charts */ |
|||
render_graphs:function(){ |
|||
var self = this; |
|||
self.render_total_application_graph(); |
|||
self.render_exam_result_pie(); |
|||
self.render_attendance_doughnut(); |
|||
self.render_rejected_accepted_applications(); |
|||
self.render_student_strength(); |
|||
self.render_class_wise_average_marks(); |
|||
}, |
|||
/* Calling the filter functions */ |
|||
render_filters:function(){ |
|||
var self = this; |
|||
self.render_pie_chart_filter(); |
|||
self.render_doughnut_chart_filter(); |
|||
}, |
|||
/* Function to create a bar chart to show application counts in each |
|||
academic year */ |
|||
render_total_application_graph:function(){ |
|||
var self = this |
|||
var ctx = self.$(".application_count"); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_all_applications", |
|||
}).then(function (result) { |
|||
var data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: 'Application', |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#87cefa", |
|||
"#b0c4de", |
|||
"#20b2aa", |
|||
], |
|||
borderColor: [ |
|||
"#87cefa", |
|||
"#b0c4de", |
|||
"#20b2aa", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0 |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
//Create Chart class object
|
|||
new Chart(ctx, { |
|||
type: "bar", |
|||
data: data, |
|||
options: { |
|||
responsive:true, |
|||
maintainAspectRatio: false, |
|||
legend: { |
|||
display: false |
|||
}, |
|||
} |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to create a bar chart that shows the count of accepted and |
|||
rejected applications */ |
|||
render_rejected_accepted_applications:function(){ |
|||
var self = this |
|||
var ctx = self.$(".rejected_accepted_count"); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_rejected_accepted_applications", |
|||
}).then(function (result) { |
|||
var data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: 'Application', |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#778899", |
|||
"#f08080", |
|||
], |
|||
borderColor: [ |
|||
"#778899", |
|||
"#f08080", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0 |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
//Create Chart class object
|
|||
new Chart(ctx, { |
|||
type: "bar", |
|||
data: data, |
|||
options: { |
|||
scales : { |
|||
y : { |
|||
beginAtZero: true, |
|||
suggestedMin: 0, |
|||
} |
|||
}, |
|||
responsive:true, |
|||
maintainAspectRatio: false, |
|||
legend: { |
|||
display: false |
|||
}, |
|||
} |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to create a pie chart that shows the exam results */ |
|||
chart_total_result : false, |
|||
render_exam_result_pie:function(){ |
|||
var self = this; |
|||
if (this.chart_total_result){ |
|||
this.chart_total_result.destroy() |
|||
} |
|||
var ctx = self.$(".exam_result")[0].getContext('2d'); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_exam_result" |
|||
}).then(function (result) { |
|||
var data; |
|||
if (! result.Fail && ! result.Pass){ |
|||
data = { |
|||
labels : ['No data'], |
|||
datasets: [{ |
|||
label: "No Result", |
|||
data: [1], |
|||
backgroundColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
else{ |
|||
data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: "Exam Result", |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#003f5c", |
|||
"#dc143c" |
|||
], |
|||
borderColor: [ |
|||
"#003f5c", |
|||
"#dc143c", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
legend: { |
|||
display: true, |
|||
position: "bottom", |
|||
labels: { |
|||
fontColor: "#333", |
|||
fontSize: 16 |
|||
} |
|||
}, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
/* Create Chart class object */ |
|||
self.chart_total_result = new Chart(ctx, { |
|||
type: "pie", |
|||
data: data, |
|||
options: options |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to create a doughnut chart that shows attendance details */ |
|||
chart_total_attendance : false, |
|||
render_attendance_doughnut:function(){ |
|||
var self = this; |
|||
if(this.chart_total_attendance){ |
|||
this.chart_total_attendance.destroy() |
|||
} |
|||
var ctx = self.$(".total_attendance_today")[0].getContext('2d'); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_attendance" |
|||
}).then(function (result) { |
|||
var data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: "Attendance", |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#006400", |
|||
"#e9967a" |
|||
], |
|||
borderColor: [ |
|||
"#006400", |
|||
"#e9967a", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
legend: { |
|||
display: true, |
|||
position: "bottom", |
|||
labels: { |
|||
fontColor: "#333", |
|||
fontSize: 16 |
|||
} |
|||
}, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
/* Create Chart class object */ |
|||
self.chart_total_attendance = new Chart(ctx, { |
|||
type: "doughnut", |
|||
data: data, |
|||
options: options |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to create a line chart that shows the class wise student strength */ |
|||
render_student_strength:function(){ |
|||
var self = this |
|||
var ctx = self.$(".student_strength"); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_student_strength", |
|||
}).then(function (result) { |
|||
var data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: 'Student Strength', |
|||
data: Object.values(result), |
|||
Color: [ |
|||
"#8b0000", |
|||
], |
|||
borderColor: [ |
|||
"#8b0000", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
//Create Chart class object
|
|||
new Chart(ctx, { |
|||
type: "line", |
|||
data: data, |
|||
options: { |
|||
responsive:true, |
|||
maintainAspectRatio: false, |
|||
legend: { |
|||
display: false |
|||
}, |
|||
} |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to create a bar chart that shows the average marks in each class */ |
|||
render_class_wise_average_marks:function(){ |
|||
var self = this |
|||
var ctx = self.$(".average_marks"); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_average_marks", |
|||
}).then(function (result) { |
|||
var data |
|||
if (Object.values(result) == 0){ |
|||
data = { |
|||
labels : ['No data'], |
|||
datasets: [{ |
|||
label: "No Marks", |
|||
data: [1], |
|||
backgroundColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
else{ |
|||
data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: 'Average Marks', |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#cd5c5c", |
|||
], |
|||
borderColor: [ |
|||
"#cd5c5c", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
/* Create Chart class object */ |
|||
new Chart(ctx, { |
|||
type: "bar", |
|||
data: data, |
|||
options: { |
|||
scales : { |
|||
y : { |
|||
beginAtZero: true, |
|||
suggestedMin: 0, |
|||
} |
|||
}, |
|||
|
|||
responsive:true, |
|||
maintainAspectRatio: false, |
|||
legend: { |
|||
display: false |
|||
} |
|||
} |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to add the filter option */ |
|||
render_pie_chart_filter:function(){ |
|||
var self = this |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_academic_year", |
|||
}).then(function (result) { |
|||
self.$('#select_period').append('<option value=' + 'select' + '>' + 'Total Result' + '</option>') |
|||
for (let key in result){ |
|||
self.$('#select_period').append('<option value=' + key + '>' + result[key] + '</option>') |
|||
} |
|||
}) |
|||
}, |
|||
/* Function to get academic wise exam result and to create chart accordingly */ |
|||
chart_academy_result : false, |
|||
get_academic_exam_result:function(academic_year){ |
|||
var self = this; |
|||
if (this.chart_academy_result){ |
|||
this.chart_academy_result.destroy() |
|||
} |
|||
var ctx = self.$(".academic_exam_result")[0].getContext('2d'); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_academic_year_exam_result", |
|||
args: [academic_year] |
|||
}).then(function (result) { |
|||
var data |
|||
if (! result.Fail && ! result.Pass){ |
|||
data = { |
|||
labels : ['No data'], |
|||
datasets: [{ |
|||
label: "No Result", |
|||
data: [1], |
|||
backgroundColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderColor: [ |
|||
"#f6f7f9" |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
else{ |
|||
data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: "Exam Result", |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#003f5c", |
|||
"#dc143c" |
|||
], |
|||
borderColor: [ |
|||
"#003f5c", |
|||
"#dc143c", |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
} |
|||
//Options to add appearance for the graph
|
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
legend: { |
|||
display: true, |
|||
position: "bottom", |
|||
labels: { |
|||
fontColor: "#333", |
|||
fontSize: 16 |
|||
} |
|||
}, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
self.chart_academy_result = new Chart(ctx, { |
|||
type: "pie", |
|||
data: data, |
|||
options: options |
|||
}); |
|||
}); |
|||
}, |
|||
/* Function to add filter option for doughnut chart */ |
|||
render_doughnut_chart_filter:function(){ |
|||
var self = this |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_classes", |
|||
}).then(function (result) { |
|||
self.$('#select_class').append('<option value=' + 'select' + '>' + 'Total Attendance' + '</option>') |
|||
for (let key in result){ |
|||
self.$('#select_class').append('<option value=' + key + '>' + result[key] + '</option>') |
|||
} |
|||
}) |
|||
}, |
|||
/* Function to get class wise attendance and to create chart accordingly */ |
|||
chart_class_attendance : false, |
|||
get_class_attendance:function(clas){ |
|||
var self = this; |
|||
if(this.chart_class_attendance){ |
|||
this.chart_class_attendance.destroy() |
|||
} |
|||
var ctx = self.$(".class_attendance_today")[0].getContext('2d'); |
|||
rpc.query({ |
|||
model: "erp.dashboard", |
|||
method: "get_class_attendance_today", |
|||
args: [clas] |
|||
}).then(function (result) { |
|||
var data = { |
|||
labels : Object.keys(result), |
|||
datasets: [{ |
|||
label: "Attendance", |
|||
data: Object.values(result), |
|||
backgroundColor: [ |
|||
"#006400", |
|||
"#e9967a" |
|||
], |
|||
borderColor: [ |
|||
"#006400", |
|||
"#e9967a" |
|||
], |
|||
borderWidth: 1 |
|||
},] |
|||
}; |
|||
var options = { |
|||
responsive: true, |
|||
title: false, |
|||
legend: { |
|||
display: true, |
|||
position: "bottom", |
|||
labels: { |
|||
fontColor: "#333", |
|||
fontSize: 16 |
|||
} |
|||
}, |
|||
scales: { |
|||
yAxes: [{ |
|||
ticks: { |
|||
min: 0, |
|||
} |
|||
}] |
|||
} |
|||
}; |
|||
/* Create Chart class object */ |
|||
self.chart_class_attendance = new Chart(ctx, { |
|||
type: "doughnut", |
|||
data: data, |
|||
options: options |
|||
}); |
|||
}); |
|||
}, |
|||
}) |
|||
core.action_registry.add('erp_dashboard_tag', DashBoard); |
|||
return DashBoard; |
|||
}); |
@ -0,0 +1,228 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<template> |
|||
<!-- Template represents the main section of the dashboard --> |
|||
<t t-name="MainSection"> |
|||
<!-- Tiles --> |
|||
<div class="row main-section"> |
|||
<!-- Tile that shows the number of applications --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-wpforms"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Applications</div> |
|||
<div class="stat-count"> |
|||
<span id="templates"> |
|||
<div id="all_applications"/> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the number of students --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-user"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Students</div> |
|||
<div class="stat-count"> |
|||
<span id="templates"> |
|||
<div id="all_students"/> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the number of faculties --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-male"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Faculties</div> |
|||
<div class="stat-count"> |
|||
<span id="templates"> |
|||
<div id="all_faculties"/> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the number of amenities --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-list"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Amenities</div> |
|||
<div class="stat-count"> |
|||
<span id="templates"> |
|||
<div id="all_amenities"/> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the attendance table --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" id="all_attendance" |
|||
style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-check-square-o"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Attendance Table</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the exam results --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" id="exams" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-line-chart"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Exam Result</div> |
|||
<div class="stat-count"> |
|||
<span id="templates"> |
|||
<div id="all_exams"/> |
|||
</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the timetable --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" id="timetable" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-calendar"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Time Table</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Tile that shows the student promotions --> |
|||
<div class="col-md-3 col-sm-3"> |
|||
<div class="content-card" id="promotion" style="width: 288px;"> |
|||
<div class="content-card-body"> |
|||
<div class="stat-widget-one"> |
|||
<div class="stat-icon"> |
|||
<i class="fa fa-graduation-cap"/> |
|||
</div> |
|||
<div class="stat-content"> |
|||
<div class="stat-head">Student Promotions</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<div class="render_graph_div col-lg-12 col-md-2"> |
|||
<!-- Division to show the bar chart for applications --> |
|||
<div class="chart-container inline"> |
|||
<h2>Applications</h2> |
|||
<hr/> |
|||
<div class="graph_canvas"> |
|||
<canvas class="application_count" width="340px" |
|||
height="400px"/> |
|||
</div> |
|||
</div> |
|||
<!-- Division to show the pie chart for exam results --> |
|||
<div class="pie-container inline"> |
|||
<h2>Exam Result</h2> |
|||
<hr/> |
|||
<!-- Division for chart filter --> |
|||
<div class="pie-chart-filter" style="margin-left:180px;"> |
|||
<select class="academic_year_filter" id="select_period" |
|||
required="true"> |
|||
</select> |
|||
</div> |
|||
<!-- Division to show the chart --> |
|||
<div class="pie_canvas" style="margin-left:180px;"> |
|||
<canvas class="exam_result" width="100%"/> |
|||
<canvas id="academic_exam_result" |
|||
class="academic_exam_result" width="100%"/> |
|||
<canvas class="no_data_exam_result" width="100%"/> |
|||
</div> |
|||
</div> |
|||
<!-- Division to show the line chart for student strength --> |
|||
<div class="student-strength-container inline"> |
|||
<h2>Student Strength</h2> |
|||
<hr/> |
|||
<div class="student_strength_canvas"> |
|||
<canvas class="student_strength" width="340px" |
|||
height="400px"/> |
|||
</div> |
|||
</div> |
|||
<!-- Division to show the bar chart for rejected and accepted |
|||
applications --> |
|||
<div class="rejected-application-container inline"> |
|||
<h2>Rejected Applications</h2> |
|||
<hr/> |
|||
<div class="rejected_canvas"> |
|||
<canvas class="rejected_accepted_count" width="340px" |
|||
height="400px"/> |
|||
</div> |
|||
</div> |
|||
<!-- Division to show the bar chart for average marks --> |
|||
<div class="class-average-marks-container inline"> |
|||
<h2>Average Marks</h2> |
|||
<hr/> |
|||
<div class="average_mark_canvas"> |
|||
<canvas class="average_marks" width="340px" |
|||
height="400px"/> |
|||
</div> |
|||
</div> |
|||
<!-- Division to show the doughnut chart for attendance --> |
|||
<div class="doughnut-container inline"> |
|||
<h2>Attendance</h2> |
|||
<hr/> |
|||
<!-- Division for attendance filter --> |
|||
<div class="doughnut-chart-filter" style="margin-left:180px;"> |
|||
<select class="class_attendance_filter" id="select_class" |
|||
required="true"> |
|||
</select> |
|||
</div> |
|||
<!-- Division to show the chart --> |
|||
<div class="doughnut_canvas" style="margin-left:180px;"> |
|||
<canvas class="total_attendance_today" width="100%"/> |
|||
<canvas class="class_attendance_today" width="100%"/> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</t> |
|||
</template> |
@ -0,0 +1,9 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<!-- Main template for the dashboard --> |
|||
<template> |
|||
<t t-name="EducationalDashboard"> |
|||
<div class="oh_dashboards"> |
|||
<div class="container-fluid my-5 o_hr_dashboard"/> |
|||
</div> |
|||
</t> |
|||
</template> |
@ -0,0 +1,9 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- Record to create a tag for Educational Dashboard --> |
|||
<record id="education_erp_dashboard_action" model="ir.actions.client"> |
|||
<field name="name">Educational Dashboard</field> |
|||
<field name="tag">erp_dashboard_tag</field> |
|||
<field name="target">current</field> |
|||
</record> |
|||
</odoo> |
@ -0,0 +1,11 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- Root menu item representing the Educational Dashboard --> |
|||
<menuitem id="education_erp_dashboard_menu_root" |
|||
name="Educational Dashboard" |
|||
web_icon="education_erp_dashboard,static/description/icon.png"/> |
|||
<!-- Submenu of Educational Dashboard which linked to an action --> |
|||
<menuitem id="education_erp_dashboard_menu" name="Dashboard" |
|||
action="education_erp_dashboard_action" |
|||
parent="education_erp_dashboard_menu_root"/> |
|||
</odoo> |