Browse Source

Apr 17: [ADD] Initial Commit 'advanced_project_management_system'

pull/313/head
RisvanaCybro 1 year ago
parent
commit
05293288e0
  1. 49
      advanced_project_management_system/README.rst
  2. 24
      advanced_project_management_system/__init__.py
  3. 85
      advanced_project_management_system/__manifest__.py
  4. 25
      advanced_project_management_system/data/ir_actions_server_data.xml
  5. 25
      advanced_project_management_system/data/ir_cron_data.xml
  6. 12
      advanced_project_management_system/data/ir_sequence_data.xml
  7. 116
      advanced_project_management_system/data/mail_template_data.xml
  8. 6
      advanced_project_management_system/doc/RELEASE_NOTES.md
  9. 34
      advanced_project_management_system/models/__init__.py
  10. 71
      advanced_project_management_system/models/ir_attachment.py
  11. 33
      advanced_project_management_system/models/project_category.py
  12. 36
      advanced_project_management_system/models/project_checklist.py
  13. 55
      advanced_project_management_system/models/project_checklist_info.py
  14. 33
      advanced_project_management_system/models/project_checklist_template.py
  15. 67
      advanced_project_management_system/models/project_issue.py
  16. 219
      advanced_project_management_system/models/project_project.py
  17. 126
      advanced_project_management_system/models/project_task.py
  18. 37
      advanced_project_management_system/models/project_task_checklist.py
  19. 63
      advanced_project_management_system/models/project_task_checklist_info.py
  20. 33
      advanced_project_management_system/models/project_task_checklist_template.py
  21. 30
      advanced_project_management_system/models/project_task_type.py
  22. 69
      advanced_project_management_system/models/res_config_settings.py
  23. 23
      advanced_project_management_system/report/__init__.py
  24. 25
      advanced_project_management_system/report/ir_action_report.xml
  25. 102
      advanced_project_management_system/report/project_project_template.xml
  26. 72
      advanced_project_management_system/report/project_task_burnup_chart_report.py
  27. 39
      advanced_project_management_system/report/project_task_burnup_chart_report_views.xml
  28. 112
      advanced_project_management_system/report/project_task_template.xml
  29. 72
      advanced_project_management_system/report/project_task_velocity_chart_report.py
  30. 50
      advanced_project_management_system/report/project_task_velocity_chart_report_views.xml
  31. 12
      advanced_project_management_system/security/advanced_project_management_system_security.xml
  32. 15
      advanced_project_management_system/security/ir.model.access.csv
  33. 5
      advanced_project_management_system/static/csv/task_checklist.csv
  34. BIN
      advanced_project_management_system/static/description/assets/icons/capture (1).png
  35. BIN
      advanced_project_management_system/static/description/assets/icons/check.png
  36. BIN
      advanced_project_management_system/static/description/assets/icons/chevron.png
  37. BIN
      advanced_project_management_system/static/description/assets/icons/cogs.png
  38. BIN
      advanced_project_management_system/static/description/assets/icons/consultation.png
  39. BIN
      advanced_project_management_system/static/description/assets/icons/ecom-black.png
  40. BIN
      advanced_project_management_system/static/description/assets/icons/education-black.png
  41. BIN
      advanced_project_management_system/static/description/assets/icons/hotel-black.png
  42. BIN
      advanced_project_management_system/static/description/assets/icons/img.png
  43. BIN
      advanced_project_management_system/static/description/assets/icons/license.png
  44. BIN
      advanced_project_management_system/static/description/assets/icons/lifebuoy.png
  45. BIN
      advanced_project_management_system/static/description/assets/icons/manufacturing-black.png
  46. BIN
      advanced_project_management_system/static/description/assets/icons/photo-capture.png
  47. BIN
      advanced_project_management_system/static/description/assets/icons/pos-black.png
  48. BIN
      advanced_project_management_system/static/description/assets/icons/puzzle.png
  49. BIN
      advanced_project_management_system/static/description/assets/icons/restaurant-black.png
  50. BIN
      advanced_project_management_system/static/description/assets/icons/service-black.png
  51. BIN
      advanced_project_management_system/static/description/assets/icons/trading-black.png
  52. BIN
      advanced_project_management_system/static/description/assets/icons/training.png
  53. BIN
      advanced_project_management_system/static/description/assets/icons/update.png
  54. BIN
      advanced_project_management_system/static/description/assets/icons/user.png
  55. BIN
      advanced_project_management_system/static/description/assets/icons/wrench.png
  56. BIN
      advanced_project_management_system/static/description/assets/misc/Cybrosys R.png
  57. 33
      advanced_project_management_system/static/description/assets/misc/email.svg
  58. 3
      advanced_project_management_system/static/description/assets/misc/phone.svg
  59. 9
      advanced_project_management_system/static/description/assets/misc/star (1) 2.svg
  60. 9
      advanced_project_management_system/static/description/assets/misc/support (1) 1.svg
  61. 6
      advanced_project_management_system/static/description/assets/misc/support-email.svg
  62. 17
      advanced_project_management_system/static/description/assets/misc/tick-mark.svg
  63. 9
      advanced_project_management_system/static/description/assets/misc/whatsapp 1.svg
  64. 33
      advanced_project_management_system/static/description/assets/misc/whatsapp.svg
  65. BIN
      advanced_project_management_system/static/description/assets/modules/1.png
  66. BIN
      advanced_project_management_system/static/description/assets/modules/2.jpg
  67. BIN
      advanced_project_management_system/static/description/assets/modules/3.png
  68. BIN
      advanced_project_management_system/static/description/assets/modules/4.jpg
  69. BIN
      advanced_project_management_system/static/description/assets/modules/5.png
  70. BIN
      advanced_project_management_system/static/description/assets/modules/6.jpg
  71. BIN
      advanced_project_management_system/static/description/assets/screenshots/1.png
  72. BIN
      advanced_project_management_system/static/description/assets/screenshots/10.png
  73. BIN
      advanced_project_management_system/static/description/assets/screenshots/11.png
  74. BIN
      advanced_project_management_system/static/description/assets/screenshots/12.png
  75. BIN
      advanced_project_management_system/static/description/assets/screenshots/13.png
  76. BIN
      advanced_project_management_system/static/description/assets/screenshots/14.png
  77. BIN
      advanced_project_management_system/static/description/assets/screenshots/15.png
  78. BIN
      advanced_project_management_system/static/description/assets/screenshots/16.png
  79. BIN
      advanced_project_management_system/static/description/assets/screenshots/17.png
  80. BIN
      advanced_project_management_system/static/description/assets/screenshots/18.png
  81. BIN
      advanced_project_management_system/static/description/assets/screenshots/19.png
  82. BIN
      advanced_project_management_system/static/description/assets/screenshots/2.png
  83. BIN
      advanced_project_management_system/static/description/assets/screenshots/20.png
  84. BIN
      advanced_project_management_system/static/description/assets/screenshots/21.png
  85. BIN
      advanced_project_management_system/static/description/assets/screenshots/22.png
  86. BIN
      advanced_project_management_system/static/description/assets/screenshots/23.png
  87. BIN
      advanced_project_management_system/static/description/assets/screenshots/24.png
  88. BIN
      advanced_project_management_system/static/description/assets/screenshots/25.png
  89. BIN
      advanced_project_management_system/static/description/assets/screenshots/26.png
  90. BIN
      advanced_project_management_system/static/description/assets/screenshots/27.png
  91. BIN
      advanced_project_management_system/static/description/assets/screenshots/28.png
  92. BIN
      advanced_project_management_system/static/description/assets/screenshots/29.png
  93. BIN
      advanced_project_management_system/static/description/assets/screenshots/3.png
  94. BIN
      advanced_project_management_system/static/description/assets/screenshots/30.png
  95. BIN
      advanced_project_management_system/static/description/assets/screenshots/31.png
  96. BIN
      advanced_project_management_system/static/description/assets/screenshots/32.png
  97. BIN
      advanced_project_management_system/static/description/assets/screenshots/33.png
  98. BIN
      advanced_project_management_system/static/description/assets/screenshots/4.png
  99. BIN
      advanced_project_management_system/static/description/assets/screenshots/5.png
  100. BIN
      advanced_project_management_system/static/description/assets/screenshots/6.png

49
advanced_project_management_system/README.rst

@ -0,0 +1,49 @@
.. image:: https://img.shields.io/badge/license-LGPL--3-green.svg
:target: https://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
Advanced project management system
==================================
All additional features of project module are in single module
Configuration
=============
- No additional configuration required
License
-------
General Public License, Version 3 (LGPL v3).
(https://www.gnu.org/licenses/lgpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer: (V16) Sreeshanth V S, Jumana Jabin MP,
(V17) Kailas Krishna
Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
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>`__

24
advanced_project_management_system/__init__.py

@ -0,0 +1,24 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import models
from . import report
from . import wizard

85
advanced_project_management_system/__manifest__.py

@ -0,0 +1,85 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': "Advanced Project Management System",
"version": "17.0.1.0.0",
"category": "Project",
"summary": "Advanced Project Management System can handle projects,"
"tasks, due dates, checklists",
"description": """Advanced Project Management System designed to streamline
every aspect of your projects. From handling projects and tasks to managing
due dates and checklists, this all-in-one solution simplifies project and
task management for you.""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['project', 'hr_timesheet'],
'data': [
'security/advanced_project_management_system_security.xml',
'security/ir.model.access.csv',
'data/ir_cron_data.xml',
'data/mail_template_data.xml',
'data/ir_actions_server_data.xml',
'data/ir_sequence_data.xml',
'views/project_milestone_views.xml',
'views/res_config_settings_views.xml',
'views/project_checklist_views.xml',
'views/project_task_checklist_views.xml',
'views/project_task_views.xml',
'views/project_task_checklist_template_views.xml',
'views/project_checklist_template_views.xml',
'views/project_category_views.xml',
'views/project_project_views.xml',
'views/ir_attachment_views.xml',
'views/project_issue_views.xml',
'report/project_project_template.xml',
'report/project_task_template.xml',
'report/ir_action_report.xml',
'report/project_task_burnup_chart_report_views.xml',
'report/project_task_velocity_chart_report_views.xml',
'wizard/project_task_checklist_import_views.xml',
'wizard/project_stage_update_views.xml',
'wizard/project_task_mass_update_views.xml',
'wizard/project_shortcut_views.xml'
],
'assets': {
'web.assets_backend': {
'advanced_project_management_system/static/src/scss/style.scss',
'advanced_project_management_system/static/src/js/burnup_chart_search_model.js',
'advanced_project_management_system/static/src/js/burnup_chart_model.js',
'advanced_project_management_system/static/src/js/burnup_chart_view.js',
'advanced_project_management_system/static/src/xml/burnup_chart_view.xml',
'advanced_project_management_system/static/src/xml/chatter_templates.xml',
'advanced_project_management_system/static/src/js/composer_patch.js',
'advanced_project_management_system/static/src/js/velocity_chart_model.js',
'advanced_project_management_system/static/src/js/velocity_chart_search_model.js',
'advanced_project_management_system/static/src/js/velocity_chart_view.js',
'advanced_project_management_system/static/src/xml/velocity_chart_view.xml',
},
},
'images': ['static/description/banner.jpg'],
'license': 'LGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

25
advanced_project_management_system/data/ir_actions_server_data.xml

@ -0,0 +1,25 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data noupdate="1">
<!-- server action for updating project stage -->
<record id="project_stage_multi_update" model="ir.actions.server">
<field name="name">Mass Stage Update</field>
<field name="model_id" ref="model_project_project"/>
<field name="binding_model_id" ref="model_project_project"/>
<field name="state">code</field>
<field name="code">
action = record.project_multi_stage_update()
</field>
</record>
<!-- server action for mass task details update -->
<record id="task_mass_update" model="ir.actions.server">
<field name="name">Mass Update</field>
<field name="model_id" ref="model_project_task"/>
<field name="binding_model_id" ref="model_project_task"/>
<field name="state">code</field>
<field name="code">
action = record.task_mass_update()
</field>
</record>
</data>
</odoo>

25
advanced_project_management_system/data/ir_cron_data.xml

@ -0,0 +1,25 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data noupdate="1">
<!-- schedule action for document expiry notification -->
<record id="document_expire_schedule_action" model="ir.cron">
<field name="name">Document Expire</field>
<field name="model_id" ref="model_ir_attachment"/>
<field name="state">code</field>
<field name="code">model.document_expire_notification()</field>
<field name="interval_number">1</field>
<field name="interval_type">days</field>
<field name="numbercall">-1</field>
</record>
<!-- schedule action for task overdue notification -->
<record id="task_overdue_notification_schedule_action" model="ir.cron">
<field name="name">Task overdue notification</field>
<field name="model_id" ref="model_project_task"/>
<field name="state">code</field>
<field name="code">model.task_overdue_notification()</field>
<field name="interval_number">1</field>
<field name="interval_type">days</field>
<field name="numbercall">-1</field>
</record>
</data>
</odoo>

12
advanced_project_management_system/data/ir_sequence_data.xml

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data noupdate="1">
<!-- Generate sequence for the project issue -->
<record id="seq_project_issue" model="ir.sequence">
<field name="name">Sequence</field>
<field name="code">project.issue</field>
<field name="prefix">PI</field>
<field name="padding">3</field>
</record>
</data>
</odoo>

116
advanced_project_management_system/data/mail_template_data.xml

@ -0,0 +1,116 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data noupdate="1">
<!-- document expiry notification template for customers -->
<record id="document_expire_notification_to_customer"
model="mail.template">
<field name="name">Document Expire Notification</field>
<field name="model_id"
ref="advanced_project_management_system.model_ir_attachment"/>
<field name="auto_delete" eval="True"/>
<field name="email_from">{{object.company_id.email}}</field>
<field name="email_to">{{object.partner_id.email}}</field>
<field name="subject">Document Expiry Notification for
{{object.name}}
</field>
<field name="body_html" type="html">
<p>
Dear Mr/Ms<t t-out="object.partner_id.name"/>,
<br/>
Your document
<strong>
<t t-out="object.name"/>
</strong>
is expiring on
<strong>
<t t-out="object.expiry_date"/>
</strong>
<div style="margin: 16px 0px 16px 0px;">
<a t-attf-href="{{ object.get_base_url() }}/web#id={{object.id}}&amp;cids=1&amp;model=ir.attachment&amp;view_type=form"
style="background-color: #875A7B; padding: 8px 16px 8px 16px; text-decoration: none; color: #fff; border-radius: 5px; font-size:13px;">
View Document
</a>
</div>
Thank you
</p>
</field>
</record>
<!-- document expiry notification email template to team-->
<record id="document_expire_notification_mail_template"
model="mail.template">
<field name="name">Document Expire Notification</field>
<field name="model_id"
ref="advanced_project_management_system.model_ir_attachment"/>
<field name="auto_delete" eval="True"/>
<field name="email_from">{{object.company_id.email}}</field>
<field name="email_to">{{object.document_email_to}}</field>
<field name="subject">Document Expiry Notification for
{{object.name}}
</field>
<field name="body_html" type="html">
<p>
Hi Team,
<br/>
The document
<strong>
<t t-out="object.name"/>
</strong>
is expiring on
<strong>
<t t-out="object.expiry_date"/>
</strong>
<div style="margin: 16px 0px 16px 0px;">
<a t-attf-href="{{ object.get_base_url() }}/web#id={{object.id}}&amp;cids=1&amp;model=ir.attachment&amp;view_type=form"
style="background-color: #875A7B; padding: 8px 16px 8px 16px; text-decoration: none; color: #fff; border-radius: 5px; font-size:13px;">
View Document
</a>
</div>
Thank you
</p>
</field>
</record>
<!-- Task due email notification template -->
<record id="task_due_email_notification"
model="mail.template">
<field name="name">Task due Notification</field>
<field name="model_id"
ref="advanced_project_management_system.model_project_task"/>
<field name="auto_delete" eval="True"/>
<field name="email_from">{{object.company_id.email}}</field>
<field name="email_to">{{object._get_user_emails()}}</field>
<field name="subject">Task Overdue notification
</field>
<field name="body_html" type="html">
<p>
Dear Employee
<br/>
Your overdue tasklist are
<table class="table">
<thead>
<tr>
<th>Project</th>
<th>Task</th>
<th>Deadline Date</th>
</tr>
</thead>
<tbody>
<tr>
<td>
<t t-out="object.project_id.name"/>
</td>
<td>
<t t-out="object.name"/>
</td>
<td>
<t t-out="object.date_deadline"/>
</td>
</tr>
</tbody>
</table>
Thank you
</p>
</field>
</record>
</data>
</odoo>

6
advanced_project_management_system/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <advanced_project_management_system>
#### 30.03.2024
#### Version 17.0.1.0.0
#### ADD
- Initial commit for Advanced project management system

34
advanced_project_management_system/models/__init__.py

@ -0,0 +1,34 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import ir_attachment
from . import project_project
from . import project_category
from . import project_checklist
from . import project_checklist_info
from . import project_checklist_template
from . import project_issue
from . import project_task
from . import project_task_checklist
from . import project_task_checklist_info
from . import project_task_checklist_template
from . import project_task_type
from . import res_config_settings

71
advanced_project_management_system/models/ir_attachment.py

@ -0,0 +1,71 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models
class IrAttachment(models.Model):
""" Added document expiry information"""
_inherit = 'ir.attachment'
expiry_date = fields.Date(string='Expiry Date',
help="for setting expiry date for the document")
expiry_notification = fields.Boolean(string='Expiry Date Notification',
help="For sending expiry notification")
partner_id = fields.Many2one('res.partner', string="partner",
help="For adding the partner ")
document_email_to = fields.Char(
default=lambda self: self.env['ir.config_parameter'].sudo().get_param(
'res.config.settings.email'), string="Email to",
help="For getting owner email")
document_mai_customer = fields.Boolean(
default=lambda self: self.env['ir.config_parameter'].sudo().get_param(
'res.config.settings.notify_customer'), string="Email to customer",
help="Notify email to customer ")
def document_expire_notification(self):
""" Automatically sent email when the
document expiration date is over"""
if self.env['ir.config_parameter'].sudo().get_param(
'res.config.settings.notify_customer'):
attachments = self.search([('expiry_date', '!=', None)])
for attachment in attachments:
if attachment.expiry_date < fields.Date.today():
mail_template = attachment.env.ref(
'advanced_project_management_system.document_expire_notification_to_customer')
mail_template.send_mail(attachment.id, force_send=True)
attachments = self.search([('expiry_date', '!=', None)])
for attachment in attachments:
if attachment.expiry_notification:
if attachment.expiry_date < fields.Date.today():
mail_template = attachment.env.ref(
'advanced_project_management_system.document_expire_notification_mail_template')
mail_template.send_mail(attachment.id, force_send=True)
@api.onchange('res_id')
def _onchange_res_id(self):
""" Compute customer name and add to attachment from projects"""
attachments = self.search([('res_model', '=', 'project.project')])
for attachment in attachments:
projects = self.env['project.project'].search(
[('id', '=', attachment.res_id)])
if projects.partner_id:
attachment.partner_id = projects.partner_id.id

33
advanced_project_management_system/models/project_category.py

@ -0,0 +1,33 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectCategory(models.Model):
""" Setting up the project category"""
_name = "project.category"
_description = "Project categories"
name = fields.Char(string='Project Category', tracking=True,
help="Name of the category")
is_active = fields.Boolean(string='Active',
help="Check is it active or not ")

36
advanced_project_management_system/models/project_checklist.py

@ -0,0 +1,36 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectChecklist(models.Model):
""" Project checklist information"""
_name = "project.checklist"
_description = "Project checklist"
name = fields.Char(string='Name', required=True,
name="name of the checklist")
description = fields.Char(string='Description', required=True,
help="Description about the checklist ")
company_id = fields.Many2one('res.company', string='Company',
required=True, help="Company information",
default=lambda self: self.env.company.id)

55
advanced_project_management_system/models/project_checklist_info.py

@ -0,0 +1,55 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectChecklistInfo(models.Model):
""" Project checklist details"""
_name = "project.checklist.info"
_description = "Project checklist information"
checklist_id = fields.Many2one('project.checklist',
string='Name',
help="Project checklist details")
description = fields.Char(string='Description',
related='checklist_id.description',
help="description about the checklist")
project_id = fields.Many2one('project.project', string="Project",
help="details of the project")
date = fields.Date(string='Date', default=fields.Date.today(),
help="get the date ")
state = fields.Selection(
selection=[('new', 'New'), ('progres', 'In Progress'),
('done', 'Done'), ('cancel', 'Cancel')], default='new',
readonly=False, string="Status",
help="Get information about the state")
def action_set_checklist_complete(self):
""" Mark the checklist progress and completion"""
if self.state in ['new', 'progres']:
self.state = 'done'
self.project_id.checklist_progress += 100 / float(
len(self.search([('project_id', '=', self.project_id.id)])))
def action_set_checklist_close(self):
""" Checklist cancel details"""
self.state = 'cancel'

33
advanced_project_management_system/models/project_checklist_template.py

@ -0,0 +1,33 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectChecklistTemplate(models.Model):
""" Project checklist template"""
_name = "project.checklist.template"
_description = "Project checklist template"
name = fields.Char(string='Name', help="name of the template")
checklist_ids = fields.Many2many('project.checklist',
string='Checklist',
help="checklist information")

67
advanced_project_management_system/models/project_issue.py

@ -0,0 +1,67 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models
class ProjectIssue(models.Model):
""" For managing project issues"""
_name = "project.issue"
_description = 'Project and task issue'
user_id = fields.Many2one("res.users", string="Assigned to",
help="The person who is responsible to solve "
"the issue")
summary = fields.Text(string='Issue summary', help="Adding project issue")
email = fields.Char(string="Email", help="Email address")
project_id = fields.Many2one('project.project', string="project",
help="To know issue noticed in which project")
task_id = fields.Many2one('project.task', string="Task",
help="To know issue noticed in which task",
domain=[('project_id', '=', project_id)])
priority = fields.Selection([('0', 'Low'), ('1', 'High')], default='0',
string="Priority")
tag_ids = fields.Many2many('project.tags', string='Tags',
help='Set the tags')
partner_id = fields.Many2one('res.partner', string="Contact",
help="Know about the contact details")
name = fields.Char(string='Number', default='new',
help='To track the issue reference')
description = fields.Text(string='Description',
help="To add the issue in detail")
extra_info = fields.Text(string="Extra Info",
help="To add some extra information")
state = fields.Selection([('new', 'New'), ('progress', 'In Progress'),
('done', 'Done'), ('cancel', 'Cancel')],
default='new', string='State',
help='Project issue pipeline stages')
create_date = fields.Datetime(string="Create Date",
help='For tracking the record creation date',
default=fields.Datetime.now())
@api.model
def create(self, vals):
""" Added reference number"""
if vals.get('name', 'New'):
vals['name'] = self.env['ir.sequence'].next_by_code(
'project.issue')
res = super(ProjectIssue, self).create(vals)
return res

219
advanced_project_management_system/models/project_project.py

@ -0,0 +1,219 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
import json
from odoo import api, fields, models, _
class ProjectProject(models.Model):
""" Added project documents,checklist,stage updates"""
_inherit = 'project.project'
project_category_id = fields.Many2one('project.category',
string='Project Category',
help="For adding project category ")
document_count = fields.Integer(string='Documents',
compute='_compute_document_count',
help="For getting the document count")
project_stage_id = fields.Many2one('project.project.stage',
tracking=True, string='Stage',
help="Project stages")
project_checklist_info_ids = fields.One2many('project.checklist.info',
'project_id',
help="Project checklist details",
string='Checklist')
checklist_progress = fields.Float(string="Progress",
help="For checklist progress bar ")
checklist_template_ids = fields.Many2many('project.checklist.template',
string='checklist template',
help="For getting checklist "
"template")
issue_count = fields.Integer(string="Project issue",
help="For getting project issue ",
compute="_compute_issue_count")
shortcut_ids = fields.One2many('project.shortcut', 'project_id',
string='Shortcuts')
url_shortcut = fields.Char(string="URL Shortcut",
compute="_compute_url_shortcut",
help="Enter the URL shortcut.")
is_active = fields.Boolean(string="Is Active", store=True,
help="Check this box if the URL is active.")
url_link = fields.Char(string="URL Link", help="Enter the URL link.")
url_name = fields.Char(string="URL Name",
help="Enter the name associated with the URL.")
def open_project_creation_wizard(self):
""" Open the project creation wizard """
return {
'type': 'ir.actions.act_window',
'res_model': 'project.project',
'view_mode': 'form',
'view_id': self.env.ref(
'advanced_project_management_system.project.project.view.form.'
'simplified').id,
'target': 'current',
}
@api.depends('url_link', 'url_name')
def _compute_url_shortcut(self):
""" Compute the URL shortcut and its activation status """
for project in self:
if project.url_link:
project.is_active = True
project.url_shortcut = project.url_link
else:
project.url_shortcut = "Add Link"
project.is_active = False
def open_url_shortcut(self):
""" Open the URL shortcut """
for project in self:
if project.url_shortcut:
return {
'name': self.url_name,
'type': 'ir.actions.act_url',
'url': project.url_shortcut,
'target': 'self',
}
def button_document(self):
""" Return document kanban for the project"""
return {
'name': 'Documents',
'type': 'ir.actions.act_window',
'res_model': 'ir.attachment',
'view_mode': 'kanban,form',
'res_id': self._origin.id,
'domain': [
('res_id', '=', self._origin.id),
('res_model', '=', 'project.project')
],
}
def _compute_document_count(self):
""" Compute document count and return """
for rec in self:
attachment_ids = self.env['ir.attachment'].search(
[('res_model', '=', 'project.project'),
('res_id', '=', rec.id)])
rec.document_count = len(attachment_ids)
def project_multi_stage_update(self):
""" Return wizard to update the project stage"""
return {
'type': 'ir.actions.act_window',
'name': 'Mass Update',
'view_mode': 'form',
'target': 'new',
'res_model': 'project.stage.update',
}
@api.onchange('checklist_template_ids')
def _onchange_checklist_template_ids(self):
""" Updating checklist"""
check_list_id = self.env['project.checklist.template'].browse(
self.checklist_template_ids.ids)
if check_list_id:
for checklist_id in check_list_id.checklist_ids.ids:
self.update({
'project_checklist_info_ids':
[(0, 0, {
'checklist_id': checklist_id
})]
})
def _compute_issue_count(self):
""" For getting project issue count"""
for rec in self:
issue_id = self.env['project.issue'].search(
[('project_id', '=', rec.id)])
rec.issue_count = len(issue_id)
def button_issue(self):
"""Return project issues"""
return {
'type': 'ir.actions.act_window',
'name': 'Project Issues',
'view_mode': 'tree,form',
'res_model': 'project.issue',
'domain': [('project_id', '=', self.id)]
}
def _get_stat_buttons(self):
""" Get statistical buttons for the project """
self.ensure_one()
buttons = super(ProjectProject, self)._get_stat_buttons()
if self.user_has_groups('project.group_project_user'):
buttons.append({
'icon': 'area-chart',
'text': _('Burnup Chart'),
'action_type': 'action',
'action': 'advanced_project_management_system.action_project_task_burnup_chart_report',
'additional_context': json.dumps({
'active_id': self.id,
}),
'show': True,
'sequence': 60,
})
if self.user_has_groups('project.group_project_user'):
buttons.append({
'icon': 'line-chart',
'text': _('Velocity Chart'),
'action_type': 'action',
'action': 'advanced_project_management_system.action_project_velocity_chart_report',
'additional_context': json.dumps({
'active_id': self.id,
}),
'show': True,
'sequence': 60,
})
return buttons
def action_project_task_burnup_chart_report(self):
""" Open the Burnup Chart report for the project """
action = self.env['ir.actions.act_window']._for_xml_id(
'advanced_project_management_system'
'.action_project_task_burnup_chart_report')
action['display_name'] = _("%(name)s's Burnup Chart", name=self.name)
return action
def action_project_velocity_chart_report(self):
""" Open the Velocity Chart report for the project """
action = self.env['ir.actions.act_window']._for_xml_id(
'advanced_project_management_system'
'.action_project_velocity_chart_report')
action['display_name'] = _("%(name)s's Velocity Chart",
name=self.name)
return action
def action_open_shortcut(self):
""" Open the shortcut creation form """
view_id = self.env.ref(
'advanced_project_management_system.project_shortcut_view_form').id
return {
'name': 'Add Custom Project Shortcut',
'view_type': 'form',
'view_mode': 'form',
'res_model': 'project.shortcut',
'views': [(view_id, 'form')],
'type': 'ir.actions.act_window',
'target': 'new',
}

126
advanced_project_management_system/models/project_task.py

@ -0,0 +1,126 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models
class ProjectTask(models.Model):
""" Added checklist and document details"""
_inherit = 'project.task'
document_count = fields.Integer(string='Documents',
compute='_compute_document_count',
help="For getting document count")
checklist_template_ids = fields.Many2many(
'project.task.checklist.template',
string='Checklist', help="For adding project checklist template")
checklist_info_ids = fields.One2many('project.task.checklist.info',
'task_id', string="checklist info",
help="for getting project checklist "
"details")
checklist_progress = fields.Float(string='Checklist Completed',
colors="red,orange,yellow,green",
help="For tracking checklist progress",
max_value=1, min_value=0)
task_type = fields.Selection([
('task', 'Task'),
('subtask', 'Subtask'),
('bug', 'Bug'),
], string='Task Type', default="task")
def task_overdue_notification(self):
""" Scheduled action for email notification to
employee about task due """
if self.env['ir.config_parameter'].sudo().get_param(
'res.config.settings.is_overdue_notification'):
task_ids = self.search([])
for task in task_ids:
if task.stage_id.name not in (
'Done',
'Canceled') and task.date_deadline and task.date_deadline < fields.Date.today():
mail_template = task.env.ref(
'advanced_project_management_system.task_due_email_notification')
mail_template.send_mail(task.id, force_send=True)
def _get_user_emails(self):
""" Return email ids of the employee"""
emails = []
task_ids = self.search([('date_deadline', '<', fields.Date.today())])
for task in task_ids:
if task.stage_id.name not in ('Done', 'Canceled'):
for user in task.user_ids:
emails.append(user.login)
return emails
def _compute_document_count(self):
""" Compute document count and return """
for rec in self:
attachment_ids = self.env['ir.attachment'].search(
[('res_model', '=', 'project.task'), ('res_id', '=', rec.id)])
rec.document_count = len(attachment_ids)
def button_task_document(self):
""" Return document kanban for the task"""
return {
'name': 'Documents',
'type': 'ir.actions.act_window',
'res_model': 'ir.attachment',
'view_mode': 'kanban,form',
'res_id': self._origin.id,
'domain': [
('res_id', '=', self._origin.id),
('res_model', '=', 'project.task')],
}
def task_mass_update(self):
""" Return wizard for updating task details"""
return {
'name': 'Documents',
'type': 'ir.actions.act_window',
'res_model': 'project.task.mass.update',
'target': 'new',
'view_mode': 'form',
}
@api.onchange('stage_id')
def _onchange_stage_id(self):
""" While changing task stage task will automatically assign to
users from task stage"""
if self.stage_id.user_ids:
self.user_ids = self.stage_id.user_ids
@api.onchange('checklist_template_ids')
def _onchange_checklist_template_ids(self):
"""When the `checklist_template_ids` field is modified, this method is
triggered to update the `checklist_info_ids` field.
It browses the selected checklist templates and for each checklist item in these templates,
it creates a new checklist info record linked to the current task.
"""
check_list_id = self.env['project.task.checklist.template'].browse(
self.checklist_template_ids.ids)
if check_list_id:
for checklist_id in check_list_id.checklist_ids.ids:
self.update({
'checklist_info_ids':
[(0, 0, {
'checklist_id': checklist_id
})]
})

37
advanced_project_management_system/models/project_task_checklist.py

@ -0,0 +1,37 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectChecklist(models.Model):
"""Task checklist details"""
_name = "project.task.checklist"
_description = "Task Custom Checklist"
name = fields.Char(string='Name', required=True,
help="name of the checklist")
description = fields.Char(string='Description', required=True,
help="Description of the checklist")
company_id = fields.Many2one('res.company', string='Company',
required=True,
default=lambda self: self.env.company.id,
help="For getting company details")

63
advanced_project_management_system/models/project_task_checklist_info.py

@ -0,0 +1,63 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models, _
from odoo.exceptions import ValidationError
class ProjectTaskChecklistInfo(models.Model):
""" Task checklist details"""
_name = "project.task.checklist.info"
_description = "Task checklist information"
checklist_id = fields.Many2one('project.task.checklist',
string='Name', help="checklist")
description = fields.Char(string='Description',
related='checklist_id.description',
help="Description of the checklist info ")
task_id = fields.Many2one('project.task', string="Task",
help="Task details")
checklist_progress = fields.Integer(string="progress",
help="For tracking the checklist "
"progress and completion")
date = fields.Date(string='Date', default=fields.Date.today(),
help="Get the date information")
state = fields.Selection(
selection=[('new', 'New'), ('progres', 'In Progress'),
('done', 'Done'), ('cancel', 'Cancel')], default='new',
string="Status", help="get the status of the checklist ")
def action_set_checklist_complete(self):
""" Managing the checklist progress and completion"""
if self.state in ['new', 'progres']:
checklist_template_id = self.env[
'project.task.checklist.template'].search(
[('id', 'in', self.task_id.checklist_template_ids.ids)])
if len(checklist_template_id.checklist_ids.ids) > 0:
self.task_id.checklist_progress += 100 / float(
len(checklist_template_id.checklist_ids.ids))
self.state = 'done'
else:
raise ValidationError(_("Please add checklist"))
def action_set_checklist_close(self):
""" Checklist cancel info """
self.state = 'cancel'

33
advanced_project_management_system/models/project_task_checklist_template.py

@ -0,0 +1,33 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectTaskChecklistTemplate(models.Model):
"""Task checklist template"""
_name = "project.task.checklist.template"
_description = "Task checklist template"
name = fields.Char(string='Name', help="name of the template")
checklist_ids = fields.Many2many('project.task.checklist',
string='Checklist',
help="To get the checklist details")

30
advanced_project_management_system/models/project_task_type.py

@ -0,0 +1,30 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ProjectTaskType(models.Model):
""" Added user information"""
_inherit = 'project.task.type'
user_ids = fields.Many2many('res.users', string='Assign Multiple Users',
help="We can assign multiple users ")

69
advanced_project_management_system/models/res_config_settings.py

@ -0,0 +1,69 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models
class ResConfigSettings(models.TransientModel):
""" Added document expiry notification expiry mail details """
_inherit = "res.config.settings"
is_project_category = fields.Boolean(
string='Enable Project Category',
help="Enabling project category",
config_parameter='advanced_project_management_system.is_project_category')
document_expiry_notification = fields.Boolean(
string='Document Expiry Notification',
help="For sending document expiry notification",
config_parameter='advanced_project_management_system.document_expiry_notification')
notify_customer = fields.Boolean(
string='Notify Customer',
help="For notifying the customer",
config_parameter='advanced_project_management_system.notify_customer')
on_expiry_notification = fields.Boolean(
string='On Expiry Date Notification', help="Sent expiry notification",
config_parameter='advanced_project_management_system.on_expiry_notification')
email = fields.Char(
string='Notify Email to', help="Get email id",
config_parameter='advanced_project_management_system.email')
notify_days = fields.Integer(
string='Notify After Expiry Date',
help="Notification sent before these days",
config_parameter='advanced_project_management_system.notify_days')
is_overdue_notification = fields.Boolean(
string='Overdue Notification?',
help="For sending overdue notification",
config_parameter='advanced_project_management_system.is_overdue_notification')
notification_before = fields.Integer(
string='Notification Days',
help="Sent notification before these days",
config_parameter='advanced_project_management_system.notification_before')
@api.onchange('is_project_category')
def _onchange_is_project_category(self):
"""Handles the addition or removal of the current user from the
`group_project_category` based on the state of `is_project_category`."""
groups = self.env.ref(
'advanced_project_management_system.group_project_category')
if self.is_project_category:
groups.write({'users': [(4, self.env.user.id)]})
else:
groups.write({'users': [(3, self.env.user.id)]})

23
advanced_project_management_system/report/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import project_task_burnup_chart_report
from . import project_task_velocity_chart_report

25
advanced_project_management_system/report/ir_action_report.xml

@ -0,0 +1,25 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- project report action -->
<record id="action_print_project_details" model="ir.actions.report">
<field name="name">Print Project</field>
<field name="model">project.project</field>
<field name="report_type">qweb-pdf</field>
<field name="report_name">advanced_project_management_system.project_details_report</field>
<field name="report_file">project_report</field>
<field name="print_report_name">'Project Details'</field>
<field name="binding_model_id" ref="model_project_project"/>
<field name="binding_type">report</field>
</record>
<!-- task report action-->
<record id="action_print_project_task_details" model="ir.actions.report">
<field name="name">Print Task</field>
<field name="model">project.task</field>
<field name="report_type">qweb-pdf</field>
<field name="report_name">advanced_project_management_system.task_details_report</field>
<field name="report_file">task_report</field>
<field name="print_report_name">'Task Details'</field>
<field name="binding_model_id" ref="model_project_task"/>
<field name="binding_type">report</field>
</record>
</odoo>

102
advanced_project_management_system/report/project_project_template.xml

@ -0,0 +1,102 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- PDF report template for project -->
<template id="project_details_report">
<t t-call="web.html_container">
<div class="article">
<div class="header">
<div class="row text-left"
style="border-top: 1px solid black;">
<div class="col-xs-3 col-xs-offset-9 text-right">
<ul class="list-inline"
style="margin-top:10px;">
<li>
<span class="page"/>
/
<span class="topage"/>
</li>
</ul>
</div>
</div>
</div>
<h3>
<strong>
<center>
<t t-set="docs" t-value="docs"/>
<span class="text-left" style="color:black;"
t-esc="docs.name"/>
</center>
</strong>
</h3>
<strong style="font-size:21px;">Project Manager: </strong>
<span class="text-left" style="color:black;font-size:19px;"
t-esc="docs.user_id.name"/>
<br/>
<strong style="font-size:21px;">Customer: </strong>
<span class="text-left" style="color:black;font-size:19px;"
t-esc="docs.partner_id.name"/>
<br/><br/>
<table class="table">
<thead>
<tr>
<th>Task Name</th>
<th>Allocated Hours</th>
<th>Spend Hours</th>
<th>Remaining Hours</th>
<th>Assigned To</th>
<th>Assign Date</th>
<th>Deadline</th>
<th>Stage</th>
</tr>
</thead>
<tbody>
<t t-foreach="docs.task_ids" t-as="task">
<tr>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.name"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.allocated_hours"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.effective_hours"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.remaining_hours"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.user_ids.name"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.date_assign"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.date_deadline"/>
</td>
<td>
<span class="text-left"
style="color:black;"
t-esc="task.stage_id.name"/>
</td>
</tr>
</t>
</tbody>
</table>
</div>
</t>
</template>
</odoo>

72
advanced_project_management_system/report/project_task_burnup_chart_report.py

@ -0,0 +1,72 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from collections import defaultdict
from odoo import fields, models, _
class ProjectTaskBurnupChartReport(models.AbstractModel):
"""This model defines the Burnup Chart report for project tasks. """
_name = 'project.task.burnup.chart.report'
_description = 'Burnup Chart'
_auto = True
project_id = fields.Many2one('project.project', readonly=True)
date = fields.Datetime(string='Date', readonly=True,
help='The date of data entry')
completed_count = fields.Integer(string='Completed Tasks', readonly=True,
help='The number of completed tasks')
total_count = fields.Integer(string='Total Tasks', readonly=True,
help='The total number of tasks')
def _read_group(self, domain, groupby=(), aggregates=(), having=(),
offset=0, limit=None, order=None):
data = []
project_id = self._context.get('active_id')
if groupby:
tasks = self.env['project.task'].search([
('project_id', '=', project_id),
('stage_id.name', '=', 'Done')
])
task_counts = defaultdict(lambda: defaultdict(int))
task_names = defaultdict(list)
for task in tasks:
completion_date = task.date_deadline or task.create_date.date()
if isinstance(completion_date, fields.date):
completion_date = fields.datetime.combine(completion_date,
fields.datetime.min.time())
start_date = task.create_date.date()
if task.stage_id.name == 'Done':
month_year = completion_date
task_counts[month_year]['Total'] += 1
if start_date != completion_date:
task_counts[month_year]['Start'] += 1
task_names[month_year].append(task.name)
for month_year, counts in task_counts.items():
data.append((month_year, task_names[month_year], counts['Total']))
return data

39
advanced_project_management_system/report/project_task_burnup_chart_report_views.xml

@ -0,0 +1,39 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- BurnUp chart -->
<record id="project_task_burnup_chart_report_view_search" model="ir.ui.view">
<field name="name">project.task.burnup.chart.report.view.search</field>
<field name="model">project.task.burnup.chart.report</field>
<field name="arch" type="xml">
<search string="burnup Chart">
<separator/>
</search>
</field>
</record>
<!-- BurnUp chart view -->
<record id="project_task_burnup_chart_report_view_graph" model="ir.ui.view">
<field name="name">project.task.burnup.chart.report.view.graph</field>
<field name="model">project.task.burnup.chart.report</field>
<field name="arch" type="xml">
<graph string="burnup Chart" type="line" sample="1" disable_linking="1" js_class="burnup_chart">
<field name="date" string="Date" interval="month"/>
<field name="completed_count" string="Completed Tasks"/>
</graph>
</field>
</record>
<!-- Define an action for opening the BurnUp Chart -->
<record id="action_project_task_burnup_chart_report" model="ir.actions.act_window">
<field name="name">burnup Chart</field>
<field name="res_model">project.task.burnup.chart.report</field>
<field name="view_mode">graph</field>
<field name="search_view_id" ref="project_task_burnup_chart_report_view_search"/>
<field name="context">{'search_default_project_id': active_id, 'search_default_date': 1, 'search_default_stage': 1, 'search_default_filter_date': 1}</field>
<field name="domain">[('project_id', '!=', False)]</field>
<field name="help" type="html">
<p class="o_view_nocontent_empty_folder">
No data yet!
</p>
<p>Analyze how quickly your team is completing your project's tasks and check if everything is progressing according to plan.</p>
</field>
</record>
</odoo>

112
advanced_project_management_system/report/project_task_template.xml

@ -0,0 +1,112 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- PDF report template for task details -->
<template id="task_details_report">
<t t-call="web.html_container">
<div class="article">
<div class="header">
<div class="row text-left"
style="border-top: 1px solid black;">
<div class="col-xs-3 col-xs-offset-9 text-right">
<ul class="list-inline"
style="margin-top:10px;">
<li>
<span class="page"/>
/
<span class="topage"/>
</li>
</ul>
<br/>
<div>
<t t-set="docs" t-value="docs"/>
<span class="text-left"
style="color:black;"
t-esc="docs.company_id.name"/>
<br/>
<span class="text-left"
style="color:black;"
t-esc="docs.company_id.street"/>
<br/>
<span class="text-left"
style="color:black;"
t-esc="docs.company_id.state_id.name"/>
<span class="text-left"
style="color:black;"
t-esc="docs.company_id.country_id.name"/>
<br/>
<span class="text-left"
style="color:black;"
t-esc="docs.company_id.email"/>
<br/>
</div>
</div>
</div>
</div>
<div style="border:1px solid black;">
<h3>
<strong>
<center>
<t t-set="docs" t-value="docs"/>
<span class="text-left"
style="color:black;"
t-esc="docs.name"/>
</center>
</strong>
</h3>
</div>
<div style="border:1px solid black;">
<strong>Project Name:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.project_id.name"/>
<br/>
<br/>
<strong>Customer Name:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.partner_id.name"/>
<br/>
<br/>
<strong>Customer Email:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.partner_id.email"/>
<br/>
<br/>
<strong>Responsible User:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.user_ids.name"/>
<br/>
<br/>
<strong>Assign To:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.user_ids.name"/>
<br/>
<br/>
<strong>Assign Date:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.date_assign"/>
<br/>
<br/>
<strong>Deadline Date:</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.date_deadline"/>
<br/>
<br/>
<div align="center">
<strong>Description</strong>
<span class="text-left"
style="color:black;"
t-esc="docs.description"/>
</div>
<br/>
<br/>
</div>
</div>
</t>
</template>
</odoo>

72
advanced_project_management_system/report/project_task_velocity_chart_report.py

@ -0,0 +1,72 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from collections import defaultdict
from odoo import api, fields, models, _
class ProjectVelocityChartReport(models.AbstractModel):
"""
Abstract model for the Velocity Chart report.
This model is used to calculate and display the Velocity Chart report
for a specific project and task.
"""
_name = 'project.velocity.chart.report'
_description = 'Velocity Chart'
date = fields.Date(string='Sprint Start Date', readonly=True,
help="The start date of the sprint.")
completed_story_points = fields.Float(string='Completed Story Points',
readonly=True,
help="The total story points"
" completed in the sprint.")
@api.model
def _read_group(self, domain, groupby=(), aggregates=(), having=(),
offset=0, limit=None, order=None):
"""Compute grouped data for the Velocity Chart report."""
data = []
project_id = self._context.get('active_id')
if groupby:
tasks = self.env['project.task'].search([
('project_id', '=', project_id),
('stage_id.name', '=', 'Done')
])
completed_within_deadline_count = defaultdict(
lambda: defaultdict(int))
completed_names = defaultdict(list)
for task in tasks:
sprint_start_date = task.create_date.date()
completion_date = task.date_deadline or task.create_date.date()
if isinstance(completion_date, fields.date):
completion_date = fields.datetime.combine(completion_date,
fields.datetime.min.time())
if task.stage_id.name == 'Done':
month_year = completion_date
completed_within_deadline_count[month_year]['Total'] += 1
if sprint_start_date != completion_date:
completed_within_deadline_count[month_year][
'Start'] += 1
completed_names[month_year].append(task.name)
for month_year, counts in completed_within_deadline_count.items():
data.append((month_year, completed_names[month_year], counts['Total']))
return data

50
advanced_project_management_system/report/project_task_velocity_chart_report_views.xml

@ -0,0 +1,50 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- Define a view for searching Velocity Chart records -->
<record id="project_velocity_chart_report_view_search"
model="ir.ui.view">
<field name="name">project.velocity.chart.report.view.search</field>
<field name="model">project.velocity.chart.report</field>
<field name="arch" type="xml">
<search string="Velocity Chart">
<separator/>
</search>
</field>
</record>
<!-- Define a view for displaying the Velocity Chart as a graph -->
<record id="project_velocity_chart_report_view_graph"
model="ir.ui.view">
<field name="name">project.velocity.chart.report.view.graph</field>
<field name="model">project.velocity.chart.report</field>
<field name="arch" type="xml">
<graph string="Velocity Chart" type="line" sample="1"
disable_linking="1" js_class="velocity_chart">
<field name="date" string="Sprint Start Date"
interval="month"/>
<field name="completed_story_points"
string="Completed Story Points"/>
</graph>
</field>
</record>
<!-- Define an action for opening the Velocity Chart -->
<record id="action_project_velocity_chart_report"
model="ir.actions.act_window">
<field name="name">Velocity Chart</field>
<field name="res_model">project.velocity.chart.report</field>
<field name="view_mode">graph</field>
<field name="search_view_id"
ref="project_velocity_chart_report_view_search"/>
<field name="context">{'search_default_project_id': active_id,
'search_default_date': 1}
</field>
<field name="domain">[('project_id', '!=', False)]</field>
<field name="help" type="html">
<p class="o_view_nocontent_empty_folder">
No data yet!
</p>
<p>Analyze your project's velocity over time with the Velocity
Chart.
</p>
</field>
</record>
</odoo>

12
advanced_project_management_system/security/advanced_project_management_system_security.xml

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- security groups -->
<record id="ir_attachment_group_user" model="res.groups">
<field name="name">Access Project Document</field>
<field name="category_id" ref="base.module_category_usability"/>
</record>
<record id="group_project_category" model="res.groups">
<field name="name">Access Project Category Menu</field>
<field name="category_id" ref="base.module_category_usability"/>
</record>
</odoo>

15
advanced_project_management_system/security/ir.model.access.csv

@ -0,0 +1,15 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_project_task_checklist,access.project.task.checklist,model_project_task_checklist,base.group_user,1,1,1,1
access_project_task_checklist_import,access.project.task.checklist.import,model_project_task_checklist_import,base.group_user,1,1,1,1
access_project_task_checklist_info,access.project.task.checklist.info,model_project_task_checklist_info,base.group_user,1,1,1,1
access_project_category,access.project.category,model_project_category,base.group_user,1,1,1,1
access_project_stage_update,access.project.stage.update,model_project_stage_update,base.group_user,1,1,1,1
access_project_task_mass_update,access.project.task.mass.update,model_project_task_mass_update,base.group_user,1,1,1,1
access_project_task_checklist_template,access.project.task.checklist.template,model_project_task_checklist_template,base.group_user,1,1,1,1
access_project_checklist,access.project.checklist,model_project_checklist,base.group_user,1,1,1,1
access_project_checklist_template,access.project.checklist.template,model_project_checklist_template,base.group_user,1,1,1,1
access_project_checklist_info,access.project.checklist.info,model_project_checklist_info,base.group_user,1,1,1,1
access_project_issue,access.project.issue,model_project_issue,base.group_user,1,1,1,1
access_project_task_burnup_chart_report,access.burnup.chart.report,model_project_task_burnup_chart_report,base.group_user,1,1,1,1
advanced_project_management_system.access_project_shortcut,access.project.shortcut,advanced_project_management_system.model_project_shortcut,base.group_user,1,1,1,1
access_project_velocity_chart_report,access.velocity.chart.report,model_project_velocity_chart_report,base.group_user,1,1,1,1
1 id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
2 access_project_task_checklist access.project.task.checklist model_project_task_checklist base.group_user 1 1 1 1
3 access_project_task_checklist_import access.project.task.checklist.import model_project_task_checklist_import base.group_user 1 1 1 1
4 access_project_task_checklist_info access.project.task.checklist.info model_project_task_checklist_info base.group_user 1 1 1 1
5 access_project_category access.project.category model_project_category base.group_user 1 1 1 1
6 access_project_stage_update access.project.stage.update model_project_stage_update base.group_user 1 1 1 1
7 access_project_task_mass_update access.project.task.mass.update model_project_task_mass_update base.group_user 1 1 1 1
8 access_project_task_checklist_template access.project.task.checklist.template model_project_task_checklist_template base.group_user 1 1 1 1
9 access_project_checklist access.project.checklist model_project_checklist base.group_user 1 1 1 1
10 access_project_checklist_template access.project.checklist.template model_project_checklist_template base.group_user 1 1 1 1
11 access_project_checklist_info access.project.checklist.info model_project_checklist_info base.group_user 1 1 1 1
12 access_project_issue access.project.issue model_project_issue base.group_user 1 1 1 1
13 access_project_task_burnup_chart_report access.burnup.chart.report model_project_task_burnup_chart_report base.group_user 1 1 1 1
14 advanced_project_management_system.access_project_shortcut access.project.shortcut advanced_project_management_system.model_project_shortcut base.group_user 1 1 1 1
15 access_project_velocity_chart_report access.velocity.chart.report model_project_velocity_chart_report base.group_user 1 1 1 1

5
advanced_project_management_system/static/csv/task_checklist.csv

@ -0,0 +1,5 @@
Name,Description
checklist A,checklist A
checklist B,checklist B
checklist C,checklist C
checklist D,checklist D
1 Name Description
2 checklist A checklist A
3 checklist B checklist B
4 checklist C checklist C
5 checklist D checklist D

BIN
advanced_project_management_system/static/description/assets/icons/capture (1).png

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

BIN
advanced_project_management_system/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

BIN
advanced_project_management_system/static/description/assets/icons/chevron.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

BIN
advanced_project_management_system/static/description/assets/icons/cogs.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
advanced_project_management_system/static/description/assets/icons/consultation.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
advanced_project_management_system/static/description/assets/icons/ecom-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

BIN
advanced_project_management_system/static/description/assets/icons/education-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

BIN
advanced_project_management_system/static/description/assets/icons/hotel-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
advanced_project_management_system/static/description/assets/icons/img.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
advanced_project_management_system/static/description/assets/icons/license.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
advanced_project_management_system/static/description/assets/icons/lifebuoy.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
advanced_project_management_system/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
advanced_project_management_system/static/description/assets/icons/photo-capture.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

BIN
advanced_project_management_system/static/description/assets/icons/pos-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

BIN
advanced_project_management_system/static/description/assets/icons/puzzle.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

BIN
advanced_project_management_system/static/description/assets/icons/restaurant-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

BIN
advanced_project_management_system/static/description/assets/icons/service-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

BIN
advanced_project_management_system/static/description/assets/icons/trading-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

BIN
advanced_project_management_system/static/description/assets/icons/training.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

BIN
advanced_project_management_system/static/description/assets/icons/update.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
advanced_project_management_system/static/description/assets/icons/user.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

BIN
advanced_project_management_system/static/description/assets/icons/wrench.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
advanced_project_management_system/static/description/assets/misc/Cybrosys R.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

33
advanced_project_management_system/static/description/assets/misc/email.svg

@ -0,0 +1,33 @@
<svg width="80" height="81" viewBox="0 0 80 81" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="3116889_design_email_material_communication_mail_icon 1" clip-path="url(#clip0_81_366)">
<g id="layer1">
<path id="rect3851" d="M74.6067 0.730957H5.5424C2.75742 0.730957 0.499756 3.01685 0.499756 5.83664V75.7642C0.499756 78.584 2.75742 80.8699 5.5424 80.8699H74.6067C77.3916 80.8699 79.6493 78.584 79.6493 75.7642V5.83664C79.6493 3.01685 77.3916 0.730957 74.6067 0.730957Z" fill="#DB534B"/>
<g id="Clip path group">
<mask id="mask0_81_366" style="mask-type:luminance" maskUnits="userSpaceOnUse" x="1" y="5" width="78" height="76">
<g id="clipPath4206">
<path id="rect4208" d="M73.6244 5.2915H6.62595C3.92428 5.2915 1.73413 7.4473 1.73413 10.1066V76.0546C1.73413 78.7139 3.92428 80.8697 6.62595 80.8697H73.6244C76.3261 80.8697 78.5162 78.7139 78.5162 76.0546V10.1066C78.5162 7.4473 76.3261 5.2915 73.6244 5.2915Z" fill="white"/>
</g>
</mask>
<g mask="url(#mask0_81_366)">
<g id="g4145" opacity="0.489612">
<g id="g4147">
<path id="path4149" d="M65.8115 41.5171C65.8115 54.9863 54.4292 65.9053 40.3884 65.9053L198.828 221.861C212.869 221.861 224.251 210.942 224.251 197.472L65.8115 41.5171Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4151" d="M40.3884 65.9051C33.2495 65.9051 26.7979 63.0825 22.1802 58.5371L180.62 214.492C185.237 219.038 191.689 221.86 198.828 221.86L40.3884 65.9051Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4153" d="M22.1802 58.5373C17.7157 54.1428 14.9653 48.1381 14.9653 41.5171L173.405 197.472C173.405 204.093 176.155 210.098 180.62 214.493L22.1802 58.5373Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4155" d="M14.9653 41.5171C14.9653 28.0479 26.3476 17.1289 40.3884 17.1289L198.828 173.084C184.787 173.084 173.405 184.003 173.405 197.472L14.9653 41.5171Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4157" d="M40.3884 17.1289C47.5273 17.1289 53.9789 19.9516 58.5966 24.4969L217.036 180.452C212.418 175.907 205.967 173.084 198.828 173.084L40.3884 17.1289Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4159" d="M58.5964 24.4971C63.0609 28.8916 65.8113 34.8963 65.8113 41.5173L224.251 197.473C224.251 190.852 221.5 184.847 217.036 180.452L58.5964 24.4971Z" fill="black" fill-opacity="0.0588235"/>
</g>
<path id="path4111" d="M65.8114 41.5171C65.8114 54.9863 54.4291 65.9053 40.3884 65.9053C26.3476 65.9053 14.9653 54.9863 14.9653 41.5171C14.9653 28.0479 26.3476 17.1289 40.3884 17.1289C54.4291 17.1289 65.8114 28.0479 65.8114 41.5171Z" fill="black" fill-opacity="0.0588235"/>
</g>
</g>
</g>
<path id="path3864" d="M17.506 17.5386H62.9018C64.4068 17.5386 65.8501 18.1439 66.9143 19.2214C67.9784 20.2988 68.5763 21.7602 68.5763 23.284V57.7564C68.5763 58.5109 68.4295 59.258 68.1443 59.9551C67.8592 60.6521 67.4412 61.2855 66.9143 61.819C66.3873 62.3525 65.7618 62.7757 65.0733 63.0645C64.3849 63.3532 63.647 63.5018 62.9018 63.5018H17.506C14.3567 63.5018 11.8315 60.9164 11.8315 57.7564V23.284C11.8315 20.0953 14.3567 17.5386 17.506 17.5386ZM40.2039 37.6475L62.9018 23.284H17.506L40.2039 37.6475ZM17.506 57.7564H62.9018V30.0923L40.2039 44.4271L17.506 30.0923V57.7564Z" fill="white"/>
</g>
</g>
<defs>
<clipPath id="clip0_81_366">
<rect width="80" height="81" fill="white"/>
</clipPath>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 3.2 KiB

3
advanced_project_management_system/static/description/assets/misc/phone.svg

@ -0,0 +1,3 @@
<svg width="36" height="44" viewBox="0 0 36 44" fill="none" xmlns="http://www.w3.org/2000/svg">
<path id="Vector" d="M7.25 19.3903C10.13 26.0689 14.76 31.5322 20.43 34.9305L24.83 29.7268C25.38 29.0778 26.17 28.889 26.86 29.1486C29.1 30.0218 31.51 30.4938 34 30.4938C35.11 30.4938 36 31.544 36 32.8537V41.1135C36 42.4233 35.11 43.4734 34 43.4734C15.22 43.4734 0 25.5143 0 3.35456C0 2.0448 0.9 0.994629 2 0.994629H9C10.11 0.994629 11 2.0448 11 3.35456C11 6.29268 11.4 9.1364 12.14 11.7795C12.36 12.5937 12.2 13.5259 11.65 14.1749L7.25 19.3903Z" fill="white"/>
</svg>

After

Width:  |  Height:  |  Size: 565 B

9
advanced_project_management_system/static/description/assets/misc/star (1) 2.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 26 KiB

9
advanced_project_management_system/static/description/assets/misc/support (1) 1.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 43 KiB

6
advanced_project_management_system/static/description/assets/misc/support-email.svg

@ -0,0 +1,6 @@
<svg width="49" height="37" viewBox="0 0 49 37" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="Group">
<path id="Vector" d="M2.23798 3.59132C3.53363 4.39742 21.5313 15.9748 22.2027 16.3917C22.8741 16.8087 23.5573 17.0032 24.6173 17.0032C25.6774 17.0032 26.3606 16.8087 27.0319 16.3917C27.7033 15.9748 45.701 4.39742 46.9967 3.59132C47.4796 3.29945 48.2923 2.77131 48.469 2.17368C48.7753 1.11741 48.4455 0.714355 47.138 0.714355H24.6173H2.09664C0.789214 0.714355 0.459412 1.13131 0.765656 2.17368C0.942335 2.78521 1.75506 3.29945 2.23798 3.59132Z" fill="white"/>
<path id="Vector_2" d="M48.0214 4.21664C47.0555 4.80037 38.3865 12.0831 32.6503 16.4611L42.3323 29.3171C42.5679 29.5951 42.6739 29.9286 42.5443 30.0954C42.403 30.2483 42.0967 30.1649 41.8494 29.9008L30.2357 18.3374C28.4807 19.6716 27.2439 20.5889 27.0319 20.7279C26.1249 21.2699 25.4889 21.3394 24.6173 21.3394C23.7457 21.3394 23.1096 21.2699 22.2027 20.7279C21.9789 20.5889 20.7539 19.6716 18.9989 18.3374L7.38519 29.9008C7.14961 30.1788 6.83159 30.2622 6.69025 30.0954C6.54891 29.9425 6.65491 29.5951 6.89048 29.3171L16.5607 16.4611C10.8245 12.0831 2.06126 4.80037 1.09541 4.21664C0.0588929 3.59121 0 4.32783 0 4.89766C0 5.46749 0 33.3893 0 33.3893C0 34.6819 1.61367 36.2941 2.76797 36.2941H24.6173H46.4666C47.6209 36.2941 48.999 34.668 48.999 33.3893C48.999 33.3893 48.999 5.4536 48.999 4.89766C48.999 4.31393 49.0697 3.59121 48.0214 4.21664Z" fill="white"/>
</g>
</svg>

After

Width:  |  Height:  |  Size: 1.4 KiB

17
advanced_project_management_system/static/description/assets/misc/tick-mark.svg

@ -0,0 +1,17 @@
<svg width="52" height="52" viewBox="0 0 52 52" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="52" height="52" fill="#F5F5F5"/>
<g clip-path="url(#clip0_0_1)">
<rect width="1440" height="7504" transform="translate(-107 -1660)" fill="white"/>
<rect x="-45" y="-203" width="1305" height="937" rx="19" fill="#FFF5FC"/>
<rect width="52" height="52" fill="url(#pattern0)"/>
</g>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_0_1" transform="scale(0.00387597)"/>
</pattern>
<clipPath id="clip0_0_1">
<rect width="1440" height="7504" fill="white" transform="translate(-107 -1660)"/>
</clipPath>
<image id="image0_0_1" width="258" height="258" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQIAAAECCAYAAAAVT9lQAAAACXBIWXMAAAsTAAALEwEAmpwYAAAJJ0lEQVR4nO3dYZXjNhQGUDEohEAohEAohEAYCIawEAxhIQRCIQTCQmhX202bTWcmcWzpSda953y/J9JYL5EsyykBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD1/f49f37PXwXztVprgMXeUtkCkDNXaw2wyOF7zql8EXir1SBgmTw4v6XyReBUq0HA835L/8zVSxeAXGSOldoELPBHqvMrIP+N3yu1CXhS/hXwJZUvAIoANKrGbcFr8t/5rU6zgGfVWhBUBKBBtRYEFQFoVJ4KXJIiAMOqsUNQEYBG1Z4K/PXz7ykC0IjaU4GcuUrLgKecUt0CoAhAQ/JP8jwgFQEY1CHV2yCkCECDaj0rcJ8/azQOeGxK9QvAtQi4OwDBIm4NKgLQkJoPDCkC0KCo9QBFABpRe6uwIgANidofcM23pAhAqDwAo9YDrkXAyUIQKA/AqPUARQAacEqxRSBHEYBAkYuC15yKtxL40JwUARhWXhQ8p/gi4DVkEOSQYu8MXDOXbijwvug7A4oABIvcLnwbuwYhyCnFFwBFAALVet/go+RfI4fCbQXekefi0QXgWgRsGILKWrk9eM0fZZsL3It+cOg+p7LNBe5Fnib0XuayzQXutbJHQBGAIK0VAbcJobI8B2+pCDhhCCrLRSB64N8XAbcJoaLWikCO24RQ0ZTiB/19PFIMFc0pftDfZy7aYuAXLRYBLyeFilosApfkDgFU02IRcIcAKmnt4aHbuEMAFbT28NBtpoLtBn5quQh8Ldhu4KeWi4BnCKCClouAo8aggpaLQM6xXNOBrPUiYPswFNZ6EZjLNR3IWi8CFgehsNaLgMVBKKz1IpBj5yAU1EMRmIq1HuiiCNg5CAX1UAQuyeIgFNNDEfBYMRTUQxHIOZXqAKDd8wRuMxdrPdDkyUL3ceYgFNRDEbBpCArqoQjk2DQEhfRSBKZSHQCj+5LiB/gzOZfqABjdKcUP8GfibcVQSC9FIOdYqA9gaD0VgalQH8DQ8rdr9OB+NudCfQBDy/vy83w7eoA/E+sCUEBPRSDnWKYbYFz5m7WnIjCV6QYYVy9PEl5zLtMNMK7eioB1ASggf7tGD+4lOZbpBhjXnOIH9pJ8KdMNMK5enh+4xvkCsLFTih/YS+J8AdhYb0Ugx/kCsKG8YSh6UC/NXKQnaFb+h+d5oJ+AZfS2azDHy0oHk4vA9Z+fL9ZT7MfZnTyYLil+YC+N9xEM5LYI3Ca/osq3wXq9bRi65q1EZ9Cmj4rANflb7Bj26fYhF9ToQb003lM4kEdF4DZT0Gfs3ZI+biW2EA/klQvUQuIy+ad19KB+JccSnUF71nxLWUh8Tu6j6AH9SmwhHsSaInAbC4kf6/E2YY4txIPYqghcc0l+Rt47pD6LgFeXD2LrInCbqWI7WtbrbcIctwoHULIIXGMhsb9zBa5xq3AANYrANSMvJNbs563/Z9Z6di7q4hxtITEXv+gB/Wo8Vbhz0d9QlzTGQmJuY/RgfjVuFe5cdBG4zVS4rZF6vU2Yc0lj/WobTktF4Jo9LiT2fIcgx63CnWv14tzbQuI5xffpq5kK9AeNaf3n6h4WEucU34+vxu7BgZxS/AX3WS6p34XE1vv2sziAdEA9PAM/FWt9Gbl4RffZmtg9OKBejsbqZSExf8aWp1yPct6+S+hFLyfmtr6Q2PsdArsH6epwjFYXEucU3zdrYvcgP/SwXnDNJbW1kNhTIX0vHijiX72sF9xmKtITy+SCFN0Pa2JKwP/0eFFHLiTmv9vz4mDOcfNeYRemFH9xLk3EQmLvi4M5HijiU+cUf5G+kpoLiXOlNpXKJZkS8EC+QHr9yZsv8OP2XfKL3hcHc0r3ETuRL5Toi3VNpu275Ife+yXHlIBF8gUTfdGuydYLiT3/UrrtE1MCFut9QWzLhcTe+yLHGQO85JD6/xbMWbuQ2Puvo5xpRfvhx/bT6It4i1zSa4tke2i/MwbYxJziL+atMi1o9yHt4xeRKQGb2MMGmts8s5C4lzZPD9oJi/TyyPKzebSQODfwGdfGlIAi9rCZ5j7vLSTuYV0gx5SAYnp6ZPnZXNJ/C4mHtI91gend/x5sZA8baz4bPHtYFzAloIpjir/Y5eOYElDNlOIvePl/ps/+aVDCHn5G7ymmBIQ4pP2uF/QYUwLCnFL8ABBTAhowp/iBMHIuyePFNKDHU5D3lOPjfxHUsbctyL3EiUM0Z0rxA2OkXJIpAY06p/gBMkqOT/5PoLpDckuxRkwJaN5ent5rNV5VRjf2cM5fq/H2YrqxlxN+Wou3F9MdtxS3jSkB3drjqUZROS3se2jKOcUPot5zXtzr0JhDcktxTb6lbV/fBmHcUnw90wv9Dc2aU/yg6i0OG2F3PKW4PA4bYZfcUnw+04t9DF3IF3j0IGs9l2TPAAOw6/DzHF/vWujHIbml+FHmFf0K3Tml+EHXWmwjZkh7fJfimpzWdSf0ac/vUlya88q+hK4dU/wgjI5txJAcZDKt70Lo38gHmdhGDDdG3XV43KLzYE/yT+TogVkzTiOGD5xT/ACtEXsG4BOHNMYtRacRwwN7P+vwvF1Xwb7tedfhYcN+gl3b667DactOghHs7azDy7bdA+OYU/wA3irHjfsGhrGXsw7nrTsGRpO/SaMH8prYMwAb6fnBpLcC/QFD6nWK4KEi2FiPDyZ5NwEUMKX4wf1sPFQEBfVwdoEFQiishynCqVjrgX+1PEU4F2w3cKfVKcKhZKOBX7U4RZiKthh4V0tThEuyQAhhWpkiOHUIArUwRTgXbyXwUPQU4VC+icAzoqYIU43GAc+JmCJckgVCaE7tKYIFQmhUrSnCuVaDgOVqTREOtRoEvKb0FGGq1xRgjVJTBAuE0JFSU4RTzUYA6209RbBACB3a+tBTZxBCp45pmyLgDELo3Nr3IjiDEHZg7RTBAiHsxKtvV/aSEtiZr2l5ITiGfFKgmDxFyPP9Z4vAHPMxgdLyS0mfXSA8BH1GoIK8MehRIZjCPh1QxaPtx5e4jwbUlL/xPyoEDhyBQXy0t+Ac+aGA+t7bW+B5AhjQ7d4CzxPAoPItwm/J8wQwvLxw+Bb9IQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4DV/A/Mf3+pWEmbtAAAAAElFTkSuQmCC"/>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.0 KiB

9
advanced_project_management_system/static/description/assets/misc/whatsapp 1.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 38 KiB

33
advanced_project_management_system/static/description/assets/misc/whatsapp.svg

@ -0,0 +1,33 @@
<svg width="80" height="80" viewBox="0 0 80 80" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="3116884_whatsapp_square_chat_design_message_icon 1" clip-path="url(#clip0_81_382)">
<g id="layer1">
<path id="rect3851" d="M74.6066 0.72168H5.5424C2.75742 0.72168 0.499756 2.97935 0.499756 5.76433V74.8286C0.499756 77.6135 2.75742 79.8712 5.5424 79.8712H74.6066C77.3916 79.8712 79.6492 77.6135 79.6492 74.8286V5.76433C79.6492 2.97935 77.3916 0.72168 74.6066 0.72168Z" fill="#39BB59"/>
<g id="Clip path group">
<mask id="mask0_81_382" style="mask-type:luminance" maskUnits="userSpaceOnUse" x="6" y="9" width="75" height="72">
<g id="clipPath4206">
<path id="rect4208" d="M75.7716 9.01709H11.1629C8.55758 9.01709 6.44556 11.0471 6.44556 13.5512V75.6502C6.44556 78.1543 8.55758 80.1843 11.1629 80.1843H75.7716C78.3769 80.1843 80.4889 78.1543 80.4889 75.6502V13.5512C80.4889 11.0471 78.3769 9.01709 75.7716 9.01709Z" fill="white"/>
</g>
</mask>
<g mask="url(#mask0_81_382)">
<g id="g4145" opacity="0.489612">
<g id="g4147">
<path id="path4149" d="M68.2374 43.1284C68.2374 55.8115 57.2611 66.0932 43.7212 66.0932L196.51 212.946C210.049 212.946 221.026 202.665 221.026 189.982L68.2374 43.1284Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4151" d="M43.7211 66.0932C36.8369 66.0932 30.6154 63.4353 26.1624 59.1553L178.951 206.008C183.404 210.289 189.625 212.946 196.51 212.946L43.7211 66.0932Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4153" d="M26.1623 59.1553C21.8571 55.0173 19.2048 49.363 19.2048 43.1284L171.993 189.982C171.993 196.216 174.645 201.87 178.951 206.008L26.1623 59.1553Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4155" d="M19.2048 43.1284C19.2048 30.4453 30.1811 20.1636 43.7211 20.1636L196.509 167.017C182.969 167.017 171.993 177.299 171.993 189.982L19.2048 43.1284Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4157" d="M43.7212 20.1636C50.6054 20.1636 56.8269 22.8215 61.2799 27.1015L214.068 173.955C209.615 169.675 203.394 167.017 196.51 167.017L43.7212 20.1636Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4159" d="M61.2798 27.1016C65.585 31.2396 68.2373 36.8939 68.2373 43.1284L221.026 189.982C221.026 183.747 218.373 178.093 214.068 173.955L61.2798 27.1016Z" fill="black" fill-opacity="0.0588235"/>
</g>
<path id="path4111" d="M68.2373 43.1284C68.2373 55.8115 57.261 66.0932 43.7211 66.0932C30.1811 66.0932 19.2048 55.8115 19.2048 43.1284C19.2048 30.4453 30.1811 20.1636 43.7211 20.1636C57.261 20.1636 68.2373 30.4453 68.2373 43.1284Z" fill="black" fill-opacity="0.0588235"/>
</g>
</g>
</g>
<path id="path4074" d="M51.3896 43.6875C51.9673 43.9879 52.337 44.1497 52.4526 44.3808C52.5912 44.635 52.545 45.7904 51.9673 47.1076C51.5051 48.4017 49.1018 49.6496 48.0388 49.6958C46.9758 49.7421 46.9527 50.5277 41.1985 48.0089C35.4444 45.49 31.9781 39.3431 31.7008 38.9502C31.4235 38.5574 29.4823 35.7612 29.5748 32.9188C29.6903 30.0995 31.1693 28.7592 31.7701 28.2046C32.3247 27.6037 32.9487 27.5344 33.3415 27.6037H34.4276C34.7743 27.6037 35.2596 27.4651 35.6986 28.6437L37.2931 32.965C37.4318 33.2654 37.5242 33.6121 37.3163 33.9818L36.6923 34.9293L35.7911 35.8998C35.5138 36.1771 35.1902 36.4776 35.5138 37.0553C35.7911 37.6561 36.9465 39.5741 38.5641 41.1687C40.667 43.2022 42.5158 43.8724 43.0704 44.1728C43.625 44.4963 43.9716 44.4501 44.3182 44.0804L46.1901 41.9081C46.6291 41.3304 46.9989 41.4691 47.5304 41.6539L51.3896 43.6875ZM40.4128 16.0493C46.5417 16.0493 52.4195 18.484 56.7533 22.8178C61.0871 27.1515 63.5217 33.0293 63.5217 39.1582C63.5217 45.287 61.0871 51.1649 56.7533 55.4986C52.4195 59.8324 46.5417 62.2671 40.4128 62.2671C35.8604 62.2671 31.6315 60.9498 28.0496 58.6852L17.304 62.2671L20.8858 51.5214C18.6212 47.9396 17.304 43.7106 17.304 39.1582C17.304 33.0293 19.7386 27.1515 24.0724 22.8178C28.4061 18.484 34.284 16.0493 40.4128 16.0493ZM40.4128 20.6711C35.5098 20.6711 30.8075 22.6188 27.3405 26.0858C23.8735 29.5528 21.9257 34.2551 21.9257 39.1582C21.9257 43.1329 23.1736 46.8072 25.2996 49.8114L23.0812 56.4898L29.7596 54.2714C32.7638 56.3974 36.4381 57.6453 40.4128 57.6453C45.3159 57.6453 50.0182 55.6975 53.4852 52.2305C56.9522 48.7635 58.9 44.0613 58.9 39.1582C58.9 34.2551 56.9522 29.5528 53.4852 26.0858C50.0182 22.6188 45.3159 20.6711 40.4128 20.6711Z" fill="white"/>
</g>
</g>
<defs>
<clipPath id="clip0_81_382">
<rect width="80" height="80" fill="white"/>
</clipPath>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.3 KiB

BIN
advanced_project_management_system/static/description/assets/modules/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 47 KiB

BIN
advanced_project_management_system/static/description/assets/modules/2.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 KiB

BIN
advanced_project_management_system/static/description/assets/modules/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
advanced_project_management_system/static/description/assets/modules/4.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

BIN
advanced_project_management_system/static/description/assets/modules/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 KiB

BIN
advanced_project_management_system/static/description/assets/modules/6.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/10.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 182 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/11.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 158 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/12.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/13.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/14.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 144 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/15.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/16.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 39 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/17.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 79 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/18.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/19.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 105 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/20.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 89 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/21.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 35 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/22.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/23.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/24.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 83 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/25.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/26.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 87 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/27.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/28.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/29.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 65 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 33 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/30.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/31.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/32.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 123 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/33.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 130 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 33 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
advanced_project_management_system/static/description/assets/screenshots/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

Some files were not shown because too many files changed in this diff

Loading…
Cancel
Save