@ -1,48 +0,0 @@ |
|||
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg |
|||
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html |
|||
:alt: License: AGPL-3 |
|||
|
|||
Dental Clinic Management |
|||
======================== |
|||
Dental Clinic Management is to manage the entire Dental Clinic. |
|||
|
|||
Configuration |
|||
============= |
|||
* No additional configuration required |
|||
|
|||
License |
|||
------- |
|||
GNU AFFERO GENERAL PUBLIC LICENSE v3.0 (AGPL-3) |
|||
(https://www.gnu.org/licenses/agpl-3.0-standalone.html) |
|||
|
|||
Company |
|||
------- |
|||
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__ |
|||
|
|||
Credits |
|||
------- |
|||
* Developer: (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>`__ |
@ -1,24 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from . import controllers |
|||
from . import models |
|||
from . import wizard |
@ -1,78 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
{ |
|||
'name': 'Dental Clinic Management', |
|||
'version': '17.0.1.0.0', |
|||
'category': 'Industries', |
|||
'summary': """Dental Clinic Management is to manage the entire dental clinic.""", |
|||
'description': """Dental Clinic Management software, dental clinics can |
|||
enhance efficiency, improve patient care, optimize resource utilization, |
|||
and maintain smooth operations.""", |
|||
'author': 'Cybrosys Techno Solutions', |
|||
'company': 'Cybrosys Techno Solutions', |
|||
'maintainer': 'Cybrosys Techno Solutions', |
|||
'website': "https://www.cybrosys.com", |
|||
'depends': ['hr', 'website', 'mail', 'sale_management', 'purchase','stock'], |
|||
'assets': { |
|||
'web.assets_frontend': [ |
|||
"/dental_clinic_management/static/src/js/dental_clinic.js" |
|||
] |
|||
}, |
|||
'data': [ |
|||
'security/dental_clinic_management_groups.xml', |
|||
'security/dental_clinic_management_security.xml', |
|||
'security/ir.model.access.csv', |
|||
'data/ir_sequence.xml', |
|||
'data/dental_department_data.xml', |
|||
'data/dental_specialist_data.xml', |
|||
'data/treatment_category_data.xml', |
|||
'data/dental_treatment_data.xml', |
|||
'data/insurance_company_data.xml', |
|||
'data/medicine_frequency_data.xml', |
|||
'data/dental_time_shift_data.xml', |
|||
'data/website_menu.xml', |
|||
'views/dental_time_shift_views.xml', |
|||
'views/dental_department_views.xml', |
|||
'views/dental_doctor_views.xml', |
|||
'views/dental_patients_views.xml', |
|||
'views/dental_prescription_views.xml', |
|||
'views/dental_medicine_views.xml', |
|||
'views/dental_specialist_views.xml', |
|||
'views/dental_treatment_views.xml', |
|||
'views/insurance_company_views.xml', |
|||
'views/medicine_frequency_views.xml', |
|||
'views/medical_questions_views.xml', |
|||
'views/treatment_category_views.xml', |
|||
'views/dental_appointment_views.xml', |
|||
'views/patient_portal_template.xml', |
|||
'views/dental_clinic_template.xml', |
|||
'report/dental_prescription_templates.xml', |
|||
'report/dental_prescription_report.xml', |
|||
'wizard/xray_report_views.xml', |
|||
'views/dental_clinic_management_menu.xml', |
|||
], |
|||
'images': ['static/description/banner.jpg'], |
|||
'license': 'AGPL-3', |
|||
'installable': True, |
|||
'auto_install': False, |
|||
'application': True, |
|||
} |
@ -1,23 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from . import dental_clinic |
|||
from . import patient_portal |
@ -1,100 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo.exceptions import UserError |
|||
from odoo import _ |
|||
from odoo.http import Controller, request, route |
|||
|
|||
|
|||
class DentalClinic(Controller): |
|||
"""Controller for a dental clinic website that allows users to view clinic |
|||
details and schedule appointments online.""" |
|||
|
|||
@route('/dental_doctor', auth='public', website=True) |
|||
def dental_clinic(self): |
|||
"""Renders the dental clinic page with patient, specialist, and doctor information. |
|||
This method retrieves the current user's partner ID as the patient ID, |
|||
fetches all records from the `dental.specialist` model, and all records |
|||
from the `hr.employee` model to display on the dental clinic webpage.""" |
|||
patient_id = request.env.user.partner_id |
|||
specialised_id = request.env['dental.specialist'].sudo().search([]) |
|||
doctor_id = request.env['hr.employee'].sudo().search([]) |
|||
return request.render('dental_clinic_management.website_dental_template', |
|||
{'patient_id': patient_id, |
|||
'specialised_id': specialised_id, |
|||
'doctor_id': doctor_id}) |
|||
|
|||
@route('/create/appointment', auth='public', website=True) |
|||
def create_appointment(self, **kw): |
|||
"""To create a new appointment from website""" |
|||
if len(kw.get('time_shift')) == 0: |
|||
raise UserError(_('Doctor Doesnot have the available appointment')) |
|||
else: |
|||
patient_appointment = request.env['dental.appointment'].sudo().create({ |
|||
'patient_id': kw.get('patient'), |
|||
'patient_phone': kw.get('phone'), |
|||
'patient_age': kw.get('age'), |
|||
'specialist_id': kw.get('specialization', False), |
|||
'doctor_id': kw.get('doctor'), |
|||
'shift_id': kw.get('time_shift'), |
|||
'date': kw.get('date'), |
|||
}) |
|||
return request.redirect(f'/success_appointment?token={patient_appointment.token_no}') |
|||
|
|||
@route('/success_appointment', auth='public', website=True) |
|||
def success_appointment(self, **kwargs): |
|||
"""Return when appointment creation is success""" |
|||
return request.render( |
|||
'dental_clinic_management.website_rental_success_template', {'token': kwargs}) |
|||
|
|||
@route('/patient_details', type="json", auth='public', website=True) |
|||
def get_patient_details(self, patient_id): |
|||
"""Retrieve and return details of a specific patient by their ID. |
|||
This method accesses the `res.partner` model, retrieves a patient |
|||
record by the given ID, and returns selected fields of the patient |
|||
such as phone number and age. |
|||
Args: |
|||
patient_id (int): The unique identifier of the patient.""" |
|||
patient = request.env['res.partner'].sudo().browse(int(patient_id)) |
|||
return patient.read(fields=['phone', 'patient_age']) |
|||
|
|||
@route('/specialised_doctors', type="json", auth='public', website=True) |
|||
def get_specialised_doctors(self, specialised_id): |
|||
"""To get the list of doctors based on their specialisation""" |
|||
domain = [] |
|||
if specialised_id: |
|||
domain = [('specialised_in_id', '=', int(specialised_id))] |
|||
doctors = request.env['hr.employee'].sudo().search_read(domain, ["name"]) |
|||
return doctors |
|||
|
|||
@route('/doctors_shifts', type="json", auth='public', website=True) |
|||
def get_doctors_shifts(self, doctor_id): |
|||
"""To get the particular doctor time slots""" |
|||
doctors_shift = request.env['hr.employee'].sudo().browse(int(doctor_id)).time_shift_ids |
|||
time_shifts = [{"id": rec.id, "name": rec.name} for rec in doctors_shift] |
|||
return time_shifts |
|||
|
|||
@route('/all_doctors', auth='public', website=True) |
|||
def get_all_doctors(self): |
|||
"""To list all the doctors""" |
|||
doctor_id = request.env['hr.employee'].sudo().search([]) |
|||
return request.render('dental_clinic_management.website_all_doctors', |
|||
{'doctor_ids': doctor_id}) |
@ -1,65 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import http |
|||
from odoo.http import request |
|||
from odoo.addons.portal.controllers import portal |
|||
|
|||
|
|||
class PatientPortal(portal.CustomerPortal): |
|||
"""Provide portal access for patients to view their treatment |
|||
details, prescriptions, and invoices.""" |
|||
def _prepare_home_portal_values(self, counters): |
|||
"""Extends the base method to include the count of dental prescriptions |
|||
in the returned dictionary if requested. |
|||
Args: |
|||
counters (list): A list of strings indicating which counts to |
|||
include in the response.""" |
|||
values = super()._prepare_home_portal_values(counters) |
|||
if 'prescriptions_count' in counters: |
|||
prescriptions_count = request.env['dental.prescription'].sudo().search_count([]) |
|||
values['prescriptions_count'] = prescriptions_count |
|||
return values |
|||
|
|||
@http.route(['/my/prescriptions'], type='http', auth="user", website=True) |
|||
def portal_my_prescriptions(self, **kwargs): |
|||
"""Renders the prescriptions page for the logged-in user based on their role. |
|||
Managers see all prescriptions, doctors see their own, and patients see |
|||
their own prescriptions.""" |
|||
if request.env.ref('dental_clinic_management.group_dental_manager') in request.env.user.groups_id: |
|||
domain = [] |
|||
elif request.env.ref('dental_clinic_management.group_dental_doctor') in request.env.user.groups_id: |
|||
domain = [('prescribed_doctor_id', '=', request.env.user.partner_id.employee_ids.id)] |
|||
else: |
|||
domain = [('patient_id', '=', request.env.user.partner_id.id)] |
|||
prescriptions = request.env['dental.prescription'].sudo().search(domain) |
|||
return request.render("dental_clinic_management.portal_my_prescriptions", |
|||
{'prescriptions': prescriptions, 'page_name': 'prescriptions'}) |
|||
|
|||
@http.route(['/view/prescriptions/<int:id>'], |
|||
type='http', auth="public", website=True) |
|||
def view_prescriptions(self, id): |
|||
"""View prescriptions based on the provided ID. |
|||
:param id: The ID of the prescription to view. |
|||
:return: Rendered template with prescription details.""" |
|||
prescription = request.env['dental.prescription'].browse(id) |
|||
return request.render('dental_clinic_management.prescription_portal_template', |
|||
{'prescription_details': prescription, 'page_name': 'prescription'}) |
@ -1,15 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Dental department data --> |
|||
<record model="hr.department" id="clinical_department"> |
|||
<field name="name">Clinical Department</field> |
|||
</record> |
|||
<record model="hr.department" id="telehealth_department"> |
|||
<field name="name">Telehealth Department</field> |
|||
</record> |
|||
<record model="hr.department" id="quality_assurance"> |
|||
<field name="name">Quality Assurance</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,18 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Data for dental specialist --> |
|||
<record model="dental.specialist" id="orthodontist_specialist"> |
|||
<field name="name">Orthodontist</field> |
|||
<field name="code">ORTHO</field> |
|||
</record> |
|||
<record model="dental.specialist" id="periodontist_specialist"> |
|||
<field name="name">Periodontist</field> |
|||
<field name="code">PEROD</field> |
|||
</record> |
|||
<record model="dental.specialist" id="endodontist_specialist"> |
|||
<field name="name">Endodontist</field> |
|||
<field name="code">ENDO</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,26 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Data for dental time shift --> |
|||
<record model="dental.time.shift" id="shift_morning"> |
|||
<field name="shift_type">morning</field> |
|||
<field name="start_time">06</field> |
|||
<field name="end_time">09</field> |
|||
</record> |
|||
<record model="dental.time.shift" id="shift_evening"> |
|||
<field name="shift_type">evening</field> |
|||
<field name="start_time">17</field> |
|||
<field name="end_time">20</field> |
|||
</record> |
|||
<record model="dental.time.shift" id="shift_day"> |
|||
<field name="shift_type">day</field> |
|||
<field name="start_time">10</field> |
|||
<field name="end_time">12</field> |
|||
</record> |
|||
<record model="dental.time.shift" id="shift_night"> |
|||
<field name="shift_type">night</field> |
|||
<field name="start_time">20</field> |
|||
<field name="end_time">22</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,26 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Dental treatment data --> |
|||
<record model="dental.treatment" id="treatment_teeth_whitening"> |
|||
<field name="name">Teeth Whitening</field> |
|||
<field name="treatment_categ_id" ref="cosmetic_dentistry"/> |
|||
</record> |
|||
<record model="dental.treatment" id="treatment_gum_contouring"> |
|||
<field name="name">Gum Contouring</field> |
|||
<field name="treatment_categ_id" ref="cosmetic_dentistry"/> |
|||
</record> |
|||
<record model="dental.treatment" id="treatment_dental_fillings"> |
|||
<field name="name">Dental Fillings</field> |
|||
<field name="treatment_categ_id" ref="restorative_dentistry"/> |
|||
</record> |
|||
<record model="dental.treatment" id="treatment_dental_cleanings"> |
|||
<field name="name">Dental Cleanings</field> |
|||
<field name="treatment_categ_id" ref="preventive_dentistry"/> |
|||
</record> |
|||
<record model="dental.treatment" id="treatment_check_ups"> |
|||
<field name="name">Routine Check-ups and Examinations</field> |
|||
<field name="treatment_categ_id" ref="preventive_dentistry"/> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,15 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Insurance company data --> |
|||
<record model="insurance.company" id="insurance_company_star_health"> |
|||
<field name="name">Star Health and Allied Insurance</field> |
|||
</record> |
|||
<record model="insurance.company" id="insurance_company_max_bupa"> |
|||
<field name="name">Max Bupa Health Insurance</field> |
|||
</record> |
|||
<record model="insurance.company" id="insurance_company_unitedhealth"> |
|||
<field name="name">UnitedHealth Group</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,19 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo noupdate="1"> |
|||
<!-- Sequence for Prescription --> |
|||
<record id="seq_dental_prescription" model="ir.sequence"> |
|||
<field name="name">Dental Prescription</field> |
|||
<field name="code">dental.prescriptions</field> |
|||
<field name="prefix">PRN</field> |
|||
<field name="padding">3</field> |
|||
<field name="company_id" eval="False"/> |
|||
</record> |
|||
<!-- Sequence for Appointment --> |
|||
<record id="seq_dental_appointment" model="ir.sequence"> |
|||
<field name="name">Dental Appointment</field> |
|||
<field name="code">dental.appointment</field> |
|||
<field name="prefix">DAP</field> |
|||
<field name="padding">5</field> |
|||
<field name="company_id" eval="False"/> |
|||
</record> |
|||
</odoo> |
@ -1,30 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Medical Frequency data --> |
|||
<record model="medicine.frequency" id="medicine_frequency_bd"> |
|||
<field name="code">BD</field> |
|||
<field name="medicament_frequency">Twice a day</field> |
|||
</record> |
|||
<record model="medicine.frequency" id="medicine_frequency_od"> |
|||
<field name="code">OD</field> |
|||
<field name="medicament_frequency">Once in a day</field> |
|||
</record> |
|||
<record model="medicine.frequency" id="medicine_frequency_tds"> |
|||
<field name="code">TDS</field> |
|||
<field name="medicament_frequency">Three times a day</field> |
|||
</record> |
|||
<record model="medicine.frequency" id="medicine_frequency_qds"> |
|||
<field name="code">QDS</field> |
|||
<field name="medicament_frequency">Four times a day</field> |
|||
</record> |
|||
<record model="medicine.frequency" id="medicine_frequency_hs"> |
|||
<field name="code">HS</field> |
|||
<field name="medicament_frequency">Bed Time</field> |
|||
</record> |
|||
<record model="medicine.frequency" id="medicine_frequency_pc"> |
|||
<field name="code">PC</field> |
|||
<field name="medicament_frequency">Before Meals</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,15 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<data noupdate="1"> |
|||
<!-- Data for treatment category --> |
|||
<record model="treatment.category" id="preventive_dentistry"> |
|||
<field name="name">Preventive Dentistry</field> |
|||
</record> |
|||
<record model="treatment.category" id="restorative_dentistry"> |
|||
<field name="name">Restorative Dentistry</field> |
|||
</record> |
|||
<record model="treatment.category" id="cosmetic_dentistry"> |
|||
<field name="name">Cosmetic Dentistry</field> |
|||
</record> |
|||
</data> |
|||
</odoo> |
@ -1,17 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- Appointment Menu in website --> |
|||
<record id="appointment_menu" model="website.menu"> |
|||
<field name="name">Appointment</field> |
|||
<field name="url">/dental_doctor</field> |
|||
<field name="parent_id" ref="website.main_menu"/> |
|||
<field name="sequence" type="int">11</field> |
|||
</record> |
|||
<!-- Doctors Menu in website --> |
|||
<record id="doctors_menu" model="website.menu"> |
|||
<field name="name">Doctors</field> |
|||
<field name="url">/all_doctors</field> |
|||
<field name="parent_id" ref="website.main_menu"/> |
|||
<field name="sequence" type="int">12</field> |
|||
</record> |
|||
</odoo> |
@ -1,6 +0,0 @@ |
|||
## Module <dental_clinic_management> |
|||
|
|||
#### 21.03.2024 |
|||
#### Version 17.0.1.0.0 |
|||
#### ADD |
|||
Initial commit for Dental Clinic Management |
@ -1,34 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from . import dental_appointment |
|||
from . import dental_doctor |
|||
from . import dental_medicine |
|||
from . import dental_patients |
|||
from . import dental_prescription |
|||
from . import dental_specialist |
|||
from . import dental_time_shift |
|||
from . import dental_treatment |
|||
from . import insurance_company |
|||
from . import medical_questionnaire |
|||
from . import medical_questions |
|||
from . import medicine_frequency |
|||
from . import treatment_category |
@ -1,131 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models, _ |
|||
|
|||
|
|||
class DentalAppointment(models.Model): |
|||
"""Patient dental appointment details""" |
|||
_name = 'dental.appointment' |
|||
_description = "Dental Appointment for patients" |
|||
_inherit = "mail.thread" |
|||
_rec_name = 'sequence_no' |
|||
|
|||
sequence_no = fields.Char(string='Sequence No', readonly=True, |
|||
default=lambda self: _('New'), |
|||
copy=False, |
|||
help="Sequence number of appointment") |
|||
token_no = fields.Integer(string='Token No', copy=False, |
|||
readonly=True, |
|||
help="Token number of the appointments") |
|||
patient_id = fields.Many2one('res.partner', |
|||
string="Patient Name", |
|||
domain="[('is_patient', '=', True)]", |
|||
copy=False, |
|||
required=True, |
|||
help="Add the patient") |
|||
patient_phone = fields.Char(related="patient_id.phone", string="Phone", |
|||
help="Phone number of the patient") |
|||
patient_age = fields.Integer(related="patient_id.patient_age", string="Age", |
|||
help="Age of the patient") |
|||
specialist_id = fields.Many2one('dental.specialist', |
|||
string="Doctors Department", |
|||
help='Choose the doctors department') |
|||
doctor_ids = fields.Many2many('hr.employee', |
|||
compute='_compute_doctor_ids', |
|||
string="Doctors Data", help="Doctors Data") |
|||
doctor_id = fields.Many2one('hr.employee', string="Doctor", |
|||
required=True, |
|||
domain="[('id', 'in', doctor_ids)]", |
|||
help="Name the of the doctor") |
|||
time_shift_ids = fields.Many2many('dental.time.shift', |
|||
string="Time Shift", |
|||
help="Choose the time shift", |
|||
compute='_compute_time_shifts') |
|||
shift_id = fields.Many2one('dental.time.shift', |
|||
string="Booking Time", |
|||
domain="[('id','in',time_shift_ids)]", |
|||
help="Choose the time shift") |
|||
date = fields.Date(string="Date", required=True, |
|||
default=fields.date.today(), |
|||
help="Date when to take appointment for doctor") |
|||
reason = fields.Text(string="Please describe the reason", |
|||
help="Just explain about the reason to take doctor appointment") |
|||
state = fields.Selection([('draft', 'Draft'), |
|||
('new', 'New Appointment'), |
|||
('done', 'Prescribed'), |
|||
('cancel', 'Cancel')], |
|||
default="draft", |
|||
string="State", help="state of the appointment") |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
"""Function declared for creating sequence Number for Appointments""" |
|||
if vals.get('sequence_no', _('New')) == _('New'): |
|||
vals['sequence_no'] = self.env['ir.sequence'].next_by_code( |
|||
'dental.appointment') or _('New') |
|||
last_token = self.search( |
|||
[('doctor_id', '=', int(vals['doctor_id'])), |
|||
('date', '=', vals['date']), |
|||
('shift_id', '=', int(vals['shift_id']))], |
|||
order='id desc', limit=1) |
|||
vals['token_no'] = last_token.token_no + 1 if last_token else 1 |
|||
res = super(DentalAppointment, self).create(vals) |
|||
res.state = 'new' |
|||
return res |
|||
|
|||
def action_create_appointment(self): |
|||
"""Change the state of the appointment while click create button""" |
|||
self.state = 'new' |
|||
|
|||
@api.depends('doctor_id') |
|||
def _compute_time_shifts(self): |
|||
"""To get the doctors time shift""" |
|||
for record in self: |
|||
record.time_shift_ids = self.env['dental.time.shift'].search( |
|||
[('id', 'in', record.doctor_id.time_shift_ids.ids)]).ids |
|||
|
|||
@api.depends('specialist_id') |
|||
def _compute_doctor_ids(self): |
|||
"""Searching for doctors based on there specialization""" |
|||
for record in self: |
|||
if record.specialist_id: |
|||
record.doctor_ids = self.env['hr.employee'].search( |
|||
[('specialised_in_id', '=', record.specialist_id.id)]).ids |
|||
else: |
|||
record.doctor_ids = self.env['hr.employee'].search([]).ids |
|||
|
|||
def action_cancel(self): |
|||
"""Change the state of the appointment while click cancel button""" |
|||
self.state = 'cancel' |
|||
|
|||
def action_prescription(self): |
|||
"""Created the action for view the prescriptions |
|||
of 'done' state appointments""" |
|||
return { |
|||
'type': 'ir.actions.act_window', |
|||
'target': 'inline', |
|||
'name': 'Prescription', |
|||
'view_mode': 'form', |
|||
'res_model': 'dental.prescription', |
|||
'res_id': self.env['dental.prescription'].search([ |
|||
('appointment_id', '=', self.id)], limit=1).id, |
|||
} |
@ -1,65 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class DentalDoctor(models.Model): |
|||
"""To add the doctors of the clinic""" |
|||
_inherit = 'hr.employee' |
|||
|
|||
job_position = fields.Char(string="Designation", |
|||
help="To add the job position of the doctor") |
|||
specialised_in_id = fields.Many2one('dental.specialist', |
|||
string='Specialised In', |
|||
help="Add the doctor specialised") |
|||
dob = fields.Date(string="Date of Birth", |
|||
required=True, |
|||
help="DOB of the patient") |
|||
doctor_age = fields.Integer(compute='_compute_doctor_age', |
|||
store=True, |
|||
string="Age", |
|||
help="Age of the patient") |
|||
sex = fields.Selection([('male', 'Male'), |
|||
('female', 'Female')], |
|||
string="Sex", |
|||
help="Sex of the patient") |
|||
time_shift_ids = fields.Many2many('dental.time.shift', |
|||
string="Time Shift", |
|||
help="Time shift of the doctor") |
|||
|
|||
def unlink(self): |
|||
"""Delete the corresponding user from res.users while |
|||
deleting the doctor""" |
|||
for record in self: |
|||
self.env['res.users'].search([('id', '=', record.user_id.id)]).unlink() |
|||
res = super(DentalDoctor, self).unlink() |
|||
return res |
|||
|
|||
@api.depends('dob') |
|||
def _compute_doctor_age(self): |
|||
"""To calculate the age of the doctor from the DOB""" |
|||
for record in self: |
|||
record.doctor_age = (fields.date.today().year - record.dob.year - |
|||
((fields.date.today().month, |
|||
fields.date.today().day) < |
|||
(record.dob.month, |
|||
record.dob.day))) if record.dob else False |
@ -1,36 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class DentalMedicine(models.Model): |
|||
"""For creating the medicines used in the dental clinic""" |
|||
_inherit = 'product.template' |
|||
|
|||
is_medicine = fields.Boolean('Is Medicine', |
|||
help="If the product is a Medicine") |
|||
generic_name = fields.Char(string="Generic Name", |
|||
required=True, |
|||
help="Generic name of the medicament") |
|||
dosage_strength = fields.Integer(string="Dosage Strength", |
|||
required=True, |
|||
help="Dosage strength of medicament") |
@ -1,121 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models, _ |
|||
from odoo.exceptions import UserError |
|||
from odoo.tools import email_normalize |
|||
|
|||
|
|||
class DentalPatients(models.Model): |
|||
"""To create Patients in the clinic, use res.partner model and customize it""" |
|||
_inherit = 'res.partner' |
|||
|
|||
company_type = fields.Selection(selection_add=[('person', 'Patient'), |
|||
('company', 'Medicine Distibutor')], |
|||
help="Patient type") |
|||
dob = fields.Date(string="Date of Birth", |
|||
help="DOB of the patient") |
|||
patient_age = fields.Integer(compute='_compute_patient_age', |
|||
store=True, |
|||
string="Age", |
|||
help="Age of the patient") |
|||
sex = fields.Selection([('male', 'Male'), ('female', 'Female')], |
|||
string="Sex", |
|||
help="Sex of the patient") |
|||
insurance_company_id = fields.Many2one('insurance.company', |
|||
string="Insurance Company", |
|||
help="Mention the insurance company") |
|||
start_date = fields.Date(string="Member Since", |
|||
help="Patient insurance start date") |
|||
expiration_date = fields.Date(string="Expiration Date", |
|||
help="Patient insurance expiration date") |
|||
insureds_name = fields.Char(string="Insured's Name", |
|||
help="Name of the insured's") |
|||
identification_number = fields.Char(string="Identification Number", |
|||
help="Identification Number of insured's") |
|||
is_patient = fields.Boolean(string="Is Patient", |
|||
help="To set it's a patient") |
|||
medical_questionnaire_ids = fields.One2many('medical.questionnaire', |
|||
'patient_id', |
|||
readonly=False, |
|||
help="connect model medical questionnaire in patients") |
|||
report_ids = fields.One2many('xray.report','patient_id', |
|||
string='X-Ray', |
|||
help="To add the xray reports of the patient") |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
"""Overrides the create method to handle additional logic for DentalPatients. |
|||
When a new DentalPatient is created, It then proceeds to create a portal |
|||
wizard for the patient to grant them access to the portal. |
|||
|
|||
If the `company_type` is not `person`, it assumes the record is for a |
|||
Medicine Distributor or another entity. In this case, it creates a user |
|||
from a template with predefined groups and permissions, and normalizes |
|||
the email address for consistency.""" |
|||
|
|||
if 'company_type' in vals and vals['company_type'] == 'person': |
|||
vals['is_patient'] = True |
|||
res = super(DentalPatients, self).create(vals) |
|||
if 'company_type' in vals and vals['company_type'] == 'person': |
|||
wizard = self.env['portal.wizard'].create({ |
|||
'partner_ids': [fields.Command.link(res.id)] |
|||
}) |
|||
portal_wizard = self.env['portal.wizard.user'].sudo().create({ |
|||
'partner_id': res.id, |
|||
'email': res.email, |
|||
'wizard_id': wizard.id, |
|||
}) |
|||
portal_wizard.action_grant_access() |
|||
else: |
|||
try: |
|||
user = self.env['res.users'].with_context(no_reset_password=True)._create_user_from_template({ |
|||
'email': email_normalize(res.email), |
|||
'login': email_normalize(res.email), |
|||
'partner_id': res.id, |
|||
'groups_id': [ |
|||
self.env.ref("base.group_user").id, |
|||
self.env.ref('dental_clinic_management.group_dental_doctor').id, |
|||
self.env.ref('sales_team.group_sale_salesman').id, |
|||
self.env.ref('hr.group_hr_user').id, |
|||
self.env.ref('account.group_account_invoice').id, |
|||
self.env.ref('stock.group_stock_user').id, |
|||
self.env.ref('purchase.group_purchase_user').id |
|||
], |
|||
'company_id': self.env.company.id, |
|||
'company_ids': [(6, 0, self.env.company.ids)], |
|||
}) |
|||
self.env['hr.employee'].search([('work_email', '=', res.email)]).user_id = user.id |
|||
except: |
|||
raise UserError(_("Email already used for another dentist")) |
|||
return res |
|||
|
|||
@api.depends('dob') |
|||
def _compute_patient_age(self): |
|||
"""Computes the age of the patient based on their date of birth (dob) |
|||
and updates the `patient_age` field. The age is calculated by subtracting |
|||
the year of the patient's dob from the current year. If the current |
|||
date is before the patient's birthday in the current year, one year is |
|||
subtracted from the age.""" |
|||
for record in self: |
|||
record.patient_age = (fields.date.today().year - record.dob.year - |
|||
((fields.date.today().month,fields.date.today().day) < |
|||
(record.dob.month,record.dob.day))) if record.dob else False |
@ -1,221 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models, _ |
|||
|
|||
|
|||
class DentalPrescription(models.Model): |
|||
"""Prescription of patient from the dental clinic""" |
|||
_name = 'dental.prescription' |
|||
_description = "Dental Prescription" |
|||
_inherit = ['mail.thread'] |
|||
_rec_name = "sequence_no" |
|||
|
|||
sequence_no = fields.Char(string='Sequence No', required=True, |
|||
readonly=True, default=lambda self: _('New'), |
|||
help="Sequence number of the dental prescription") |
|||
appointment_ids = fields.Many2many('dental.appointment', |
|||
string="Appointment", |
|||
compute="_compute_appointment_ids", |
|||
help="All appointments created") |
|||
appointment_id = fields.Many2one('dental.appointment', |
|||
string="Appointment", |
|||
domain="[('id','in',appointment_ids)]", |
|||
required=True, |
|||
help="All appointments created") |
|||
patient_id = fields.Many2one(related="appointment_id.patient_id", |
|||
string="Patient", |
|||
required=True, |
|||
help="name of the patient") |
|||
token_no = fields.Integer(related="appointment_id.token_no", |
|||
string="Token Number", |
|||
help="Token number of the patient") |
|||
treatment_id = fields.Many2one('dental.treatment', |
|||
string="Treatment", |
|||
help="Name of the treatment done for patient") |
|||
cost = fields.Float(related="treatment_id.cost", |
|||
string="Treatment Cost", |
|||
help="Cost of treatment") |
|||
currency_id = fields.Many2one('res.currency', 'Currency', |
|||
default=lambda self: self.env.user.company_id.currency_id, |
|||
required=True, |
|||
help="To add the currency type in cost") |
|||
prescribed_doctor_id = fields.Many2one(related="appointment_id.doctor_id", |
|||
string='Prescribed Doctor', |
|||
required=True, |
|||
help="Doctor who is prescribed") |
|||
prescription_date = fields.Date(related="appointment_id.date", |
|||
string='Prescription Date', |
|||
required=True, |
|||
help="Date of the prescription") |
|||
state = fields.Selection([('new', 'New'), |
|||
('done', 'Prescribed'), |
|||
('invoiced', 'Invoiced')], |
|||
default="new", |
|||
string="state", |
|||
help="state of the appointment") |
|||
medicine_ids = fields.One2many('dental.prescription_lines', |
|||
'prescription_id', |
|||
string="Medicine", |
|||
help="medicines") |
|||
invoice_data_id = fields.Many2one(comodel_name="account.move", string="Invoice Data", |
|||
help="Invoice Data") |
|||
grand_total = fields.Float(compute="_compute_grand_total", |
|||
string="Grand Total", |
|||
help="Get the grand total amount") |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
"""Function declared for creating sequence Number for patients""" |
|||
if vals.get('sequence_no', _('New')) == _('New'): |
|||
vals['sequence_no'] = self.env['ir.sequence'].next_by_code( |
|||
'dental.prescriptions') or _('New') |
|||
res = super(DentalPrescription, self).create(vals) |
|||
return res |
|||
|
|||
@api.depends('appointment_id') |
|||
def _compute_appointment_ids(self): |
|||
"""Computes and assigns the `appointment_ids` field for each record. |
|||
This method searches for all `dental.appointment` records that have |
|||
a state of `new` and a date equal to today's date. It then updates |
|||
the `appointment_ids` field of each `DentalPrescription` record |
|||
with the IDs of these found appointments.""" |
|||
for rec in self: |
|||
rec.appointment_ids = self.env['dental.appointment'].search( |
|||
[('state', '=', 'new'), ('date', '=', fields.Date.today())]).ids |
|||
|
|||
def action_prescribed(self): |
|||
"""Marks the prescription and its associated appointment as `done`. |
|||
This method updates the state of both the DentalPrescription instance |
|||
and its linked dental.appointment instance to `done`, indicating that |
|||
the prescription has been finalized and the appointment has been completed. |
|||
""" |
|||
self.state = 'done' |
|||
self.appointment_id.state = 'done' |
|||
|
|||
def create_invoice(self): |
|||
"""Create an invoice based on the patient invoice.""" |
|||
self.ensure_one() |
|||
invoice_vals = { |
|||
'move_type': 'out_invoice', |
|||
'partner_id': self.patient_id.id, |
|||
'invoice_line_ids': [ |
|||
fields.Command.create({ |
|||
'name': self.treatment_id.name, |
|||
'quantity': 1, |
|||
'price_unit': self.cost, |
|||
}) |
|||
] |
|||
} |
|||
invoice = self.env['account.move'].create(invoice_vals) |
|||
for rec in self.medicine_ids: |
|||
product_id = self.env['product.product'].search([ |
|||
('product_tmpl_id', '=', rec.medicament_id.id)]) |
|||
invoice['invoice_line_ids'] = [(0, 0, { |
|||
'product_id': product_id.id, |
|||
'name': rec.display_name, |
|||
'quantity': rec.quantity, |
|||
'price_unit': rec.price, |
|||
})] |
|||
self.invoice_data_id = invoice.id |
|||
invoice.action_post() |
|||
self.state = 'invoiced' |
|||
return { |
|||
'name': _('Customer Invoice'), |
|||
'view_mode': 'form', |
|||
'view_id': self.env.ref('account.view_move_form').id, |
|||
'res_model': 'account.move', |
|||
'context': "{'move_type':'out_invoice'}", |
|||
'type': 'ir.actions.act_window', |
|||
'res_id': self.invoice_data_id.id, |
|||
} |
|||
|
|||
def action_view_invoice(self): |
|||
"""Invoice view""" |
|||
return { |
|||
'name': _('Customer Invoice'), |
|||
'view_mode': 'form', |
|||
'view_id': self.env.ref('account.view_move_form').id, |
|||
'res_model': 'account.move', |
|||
'context': "{'move_type':'out_invoice'}", |
|||
'type': 'ir.actions.act_window', |
|||
'res_id': self.invoice_data_id.id, |
|||
} |
|||
|
|||
def _compute_grand_total(self): |
|||
"""Computes the grand total cost of the dental prescription. |
|||
|
|||
This method initializes the grand total with the cost of the treatment |
|||
and then iterates over all the prescribed medicines, adding their total |
|||
cost to the grand total. The grand total is stored in the `grand_total` |
|||
field of the `DentalPrescription` model.""" |
|||
self.grand_total = self.cost |
|||
for rec in self.medicine_ids: |
|||
self.grand_total += rec.total |
|||
|
|||
|
|||
class DentalPrescriptionLines(models.Model): |
|||
"""Prescription lines of the dental clinic prescription""" |
|||
_name = 'dental.prescription_lines' |
|||
_description = "Dental Prescriptions Lines" |
|||
_rec_name = "medicament_id" |
|||
|
|||
medicament_id = fields.Many2one('product.template', |
|||
domain="[('is_medicine', '=', True)]", |
|||
string="Medicament", |
|||
help="Name of the medicine") |
|||
generic_name = fields.Char(string="Generic Name", |
|||
related="medicament_id.generic_name", |
|||
help="Generic name of the medicament") |
|||
dosage_strength = fields.Integer(string="Dosage Strength", |
|||
related="medicament_id.dosage_strength", |
|||
help="Dosage strength of medicament") |
|||
medicament_form = fields.Selection([('tablet', 'Tablets'), |
|||
('capsule', 'Capsules'), |
|||
('liquid', 'Liquid'), |
|||
('injection', 'Injections')], |
|||
string="Medicament Form", |
|||
required=True, |
|||
help="Add the form of the medicine") |
|||
quantity = fields.Integer(string="Quantity", |
|||
required=True, |
|||
help="Quantity of medicine") |
|||
frequency_id = fields.Many2one('medicine.frequency', |
|||
string="Frequency", |
|||
required=True, |
|||
help="Frequency of medicine") |
|||
price = fields.Float(related='medicament_id.list_price', |
|||
string="Price", |
|||
help="Cost of medicine") |
|||
total = fields.Float(string="Total Price", |
|||
help="Total price of medicine") |
|||
prescription_id = fields.Many2one('dental.prescription', |
|||
help="Relate the model with dental_prescription") |
|||
|
|||
@api.onchange('quantity') |
|||
def _onchange_quantity(self): |
|||
"""Updates the total price of the medicament based on the quantity. |
|||
This method is triggered by an onchange event of the `quantity` field. |
|||
It calculates the total price by multiplying the `quantity` of the |
|||
medicament by its `price` and updates the `total` field with the new value. |
|||
""" |
|||
for rec in self: |
|||
rec.total = rec.price * rec.quantity |
@ -1,31 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class DentalSpecialist(models.Model): |
|||
"""To mention doctors Specialised field""" |
|||
_name = 'dental.specialist' |
|||
_description = "Dental Specialist" |
|||
|
|||
name = fields.Char(string="Name", help="Name of the dental specialist") |
|||
code = fields.Char(string="Code", help="Add the code for the name") |
@ -1,53 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class DentalTimeShift(models.Model): |
|||
"""Doctors time shift, different time slots""" |
|||
_name = 'dental.time.shift' |
|||
_description = "Dental Time Shift" |
|||
_rec_name = 'name' |
|||
|
|||
name = fields.Char(string='Name', readonly=True, |
|||
help="name of the time shifts") |
|||
shift_type = fields.Selection( |
|||
selection=[('morning', 'Morning'), ('day', 'Day'), |
|||
('evening', 'Evening'), ('night', 'Night')], |
|||
string="Shift Type", help="Selection field for the shift type") |
|||
start_time = fields.Float(string="Start Time", help="start time of time slot") |
|||
end_time = fields.Float(string="End Time", help="End time of time slot") |
|||
|
|||
@api.model_create_multi |
|||
def create(self, vals_list): |
|||
"""Overrides the default create method to set the `name` field of the |
|||
newly created `dental.time.shift` record(s) to a string that represents |
|||
the shift time range.""" |
|||
res = super(DentalTimeShift, self).create(vals_list) |
|||
res.name = f'{res.start_time} to {res.end_time}' |
|||
return res |
|||
|
|||
@api.onchange('start_time', 'end_time') |
|||
def _onchange_time(self): |
|||
name = f'{self.start_time} to {self.end_time}' |
|||
self.update({'name': name}) |
|||
|
@ -1,36 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class DentalTreatment(models.Model): |
|||
"""For adding Dental treatment details of the patients""" |
|||
_name = 'dental.treatment' |
|||
_description = "Dental Treatment" |
|||
_inherit = ['mail.thread'] |
|||
|
|||
name = fields.Char(string='Treatment Name', help="Date of the treatment") |
|||
treatment_categ_id = fields.Many2one('treatment.category', |
|||
string="Category", |
|||
help="name of the treatment") |
|||
cost = fields.Float(string='Cost', |
|||
help="Cost of the Treatment") |
@ -1,32 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class InsuranceCompany(models.Model): |
|||
"""To add the insurance details""" |
|||
_name = 'insurance.company' |
|||
_description = "Insurance Company" |
|||
|
|||
name = fields.Char(string="Name", help="Name of the insurance company") |
|||
phone = fields.Char(string="Phone", help="Phone number of the insurance company") |
|||
email = fields.Char(string="Email", help="Email of the insurance company") |
@ -1,38 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class MedicalQuestionnaire(models.Model): |
|||
"""Medical questions to be asked to the patients while their appointment""" |
|||
_name = 'medical.questionnaire' |
|||
_description = 'Medical Questionnaire' |
|||
|
|||
question_id = fields.Many2one('medical.questions', |
|||
string='Questions', |
|||
help="All added question") |
|||
yes_no = fields.Selection([('yes', 'Yes'), ('no', 'No')], |
|||
string='Yes or No', help="") |
|||
reason = fields.Text(string='Reason', help="Reason for the question answer") |
|||
patient_id = fields.Many2one('res.partner', |
|||
string='Patient', |
|||
help="Patient name") |
@ -1,51 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import api, fields, models |
|||
|
|||
|
|||
class MedicalQuestions(models.Model): |
|||
"""To add medical questionnaire question""" |
|||
_name = 'medical.questions' |
|||
_description = 'Medical Questions' |
|||
_rec_name = 'question' |
|||
|
|||
question = fields.Char(string='Question') |
|||
|
|||
@api.model |
|||
def create(self, vals): |
|||
"""Overrides the default create method to add a new medical question |
|||
record and automatically create a corresponding entry in the |
|||
`medical.questionnaire` model.""" |
|||
res = super(MedicalQuestions, self).create(vals) |
|||
self.env['medical.questionnaire'].create({ |
|||
'question_id': res.id |
|||
}) |
|||
return res |
|||
|
|||
def unlink(self): |
|||
"""Overrides the default unlink method to delete the current medical question record. |
|||
Before deletion, it searches for and deletes any associated records in the |
|||
`medical.questionnaire` model that reference this medical question.""" |
|||
for rec in self: |
|||
for line in self.env['medical.questionnaire'].search([('question_id', '=', rec.id)]): |
|||
line.unlink() |
|||
return super(MedicalQuestions, self).unlink() |
@ -1,33 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class MedicineFrequency(models.Model): |
|||
"""To specifing the medicine frequency, how to consume it.""" |
|||
_name = 'medicine.frequency' |
|||
_description = "Medicine Frequency" |
|||
_rec_name = "medicament_frequency" |
|||
|
|||
code = fields.Char(string="Code", help="code of medicine frequency") |
|||
medicament_frequency = fields.Char(string="Medicine Frequency", |
|||
help="Add the frquency of medicine how to eat") |
@ -1,30 +0,0 @@ |
|||
# -*- 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 AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
################################################################################ |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class TreatmentCategory(models.Model): |
|||
"""Adding the treatment category""" |
|||
_name = 'treatment.category' |
|||
_description = "Treatment Category" |
|||
|
|||
name = fields.Char(string="Name", help="Name of the treatment category") |
@ -1,14 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- Report Action of Dental Prescription Pdf --> |
|||
<record id="report_pdf_dental_prescription" model="ir.actions.report"> |
|||
<field name="name">Prescription Pdf</field> |
|||
<field name="model">dental.prescription</field> |
|||
<field name="report_type">qweb-pdf</field> |
|||
<field name="report_name">dental_clinic_management.report_prescription</field> |
|||
<field name="report_file">dental_clinic_management.report_prescription</field> |
|||
<field name="print_report_name">'Prescription Report - %s' % (object.sequence_no)</field> |
|||
<field name="binding_model_id" ref="dental_clinic_management.model_dental_prescription"/> |
|||
<field name="binding_type">report</field> |
|||
</record> |
|||
</odoo> |
@ -1,119 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- Pdf template of Prescription Report--> |
|||
<template id="report_prescription"> |
|||
<t t-call="web.html_container"> |
|||
<t t-foreach="docs" t-as="o"> |
|||
<t t-call="web.external_layout"> |
|||
<div class="page"> |
|||
<div class="oe_structure"/> |
|||
<div class="text-center"> |
|||
<h2>DENTAL PRESCRIPTION REPORT</h2> |
|||
</div> |
|||
<br></br> |
|||
<table class="table table-borderless"> |
|||
<tbody> |
|||
<tr> |
|||
<td> |
|||
Patient Name : |
|||
<span t-field="o.patient_id"/> |
|||
</td> |
|||
<td> |
|||
Doctor Name : |
|||
<span t-field="o.prescribed_doctor_id"/> |
|||
</td> |
|||
</tr> |
|||
<tr> |
|||
<td> |
|||
Appointment ID : |
|||
<span t-field="o.appointment_id"/> |
|||
</td> |
|||
<td> |
|||
Treatment : |
|||
<span t-field="o.treatment_id"/> |
|||
</td> |
|||
</tr> |
|||
<tr> |
|||
<td> |
|||
Token NO : |
|||
<span t-field="o.token_no"/> |
|||
</td> |
|||
<td> |
|||
Date : |
|||
<span t-field="o.prescription_date"/> |
|||
</td> |
|||
</tr> |
|||
</tbody> |
|||
</table> |
|||
<table class="table table-bordered mt32"> |
|||
<thead> |
|||
<tr> |
|||
<th>Sl.No</th> |
|||
<t t-set="counter" t-value="0"/> |
|||
<th class="text-center"> |
|||
<span>Medicament</span> |
|||
</th> |
|||
<th class="text-center"> |
|||
<span>Generic Name</span> |
|||
</th> |
|||
<th class="text-center"> |
|||
<span>Dosage Strength</span> |
|||
</th> |
|||
<th class="text-center"> |
|||
<span>Medicament Form</span> |
|||
</th> |
|||
<th class="text-center"> |
|||
<span>Quantity</span> |
|||
</th> |
|||
<th class="text-center"> |
|||
<span>Frequency</span> |
|||
</th> |
|||
</tr> |
|||
</thead> |
|||
<tbody> |
|||
<t t-foreach="o.medicine_ids" t-as="medicine"> |
|||
<tr class="text-center"> |
|||
<td style="text-align:center;"> |
|||
<t t-set="counter" t-value="counter + 1"/> |
|||
<t t-esc="counter"/> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.medicament_id.name"/> |
|||
</span> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.generic_name"/> |
|||
</span> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.dosage_strength"/> |
|||
</span> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.medicament_form"/> |
|||
</span> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.quantity"/> |
|||
</span> |
|||
</td> |
|||
<td style="text-align:center;"> |
|||
<span> |
|||
<t t-esc="medicine.frequency_id.medicament_frequency"/> |
|||
</span> |
|||
</td> |
|||
</tr> |
|||
</t> |
|||
</tbody> |
|||
</table> |
|||
</div> |
|||
</t> |
|||
</t> |
|||
</t> |
|||
</template> |
|||
</odoo> |
@ -1,23 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- Created the category Dental Clinic to set the Groups --> |
|||
<record id="module_category_dental_clinic" model="ir.module.category"> |
|||
<field name="name">Dental Clinic</field> |
|||
<field name="sequence">18</field> |
|||
</record> |
|||
<!-- Created the Groups as Own Documents Only and this groups will be only access their own datas --> |
|||
<record id="group_dental_doctor" model="res.groups"> |
|||
<field name="name">User: Own Documents Only</field> |
|||
<field name="category_id" ref="module_category_dental_clinic"/> |
|||
<field name="implied_ids" eval="[(4, ref('base.group_user'))]"/> |
|||
<field name="comment">the user will have access to his own data in the dental clinic application.</field> |
|||
</record> |
|||
<!-- Created the Groups as OManager and this groups can we view all the datas --> |
|||
<record id="group_dental_manager" model="res.groups"> |
|||
<field name="name">Manager</field> |
|||
<field name="comment">the user will have an access to all the dental clinic configuration.</field> |
|||
<field name="category_id" ref="module_category_dental_clinic"/> |
|||
<field name="implied_ids" eval="[(4, ref('group_dental_doctor'))]"/> |
|||
<field name="users" eval="[(4, ref('base.user_root'))]"/> |
|||
</record> |
|||
</odoo> |
@ -1,33 +0,0 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- Set the record rule for visible only the corresponding doctor appointments --> |
|||
<record id="own_dental_appointments" model="ir.rule"> |
|||
<field name="name">Own Appointments</field> |
|||
<field name="model_id" ref="model_dental_appointment"/> |
|||
<field name="domain_force">[('doctor_id.user_id', '=', user.id)]</field> |
|||
<field name="groups" |
|||
eval="[Command.link(ref('dental_clinic_management.group_dental_doctor'))]"/> |
|||
</record> |
|||
<!-- To see all the appointments for the manager --> |
|||
<record id="see_all_dental_appointments" model="ir.rule"> |
|||
<field name="name">All Appointments</field> |
|||
<field ref="model_dental_appointment" name="model_id"/> |
|||
<field name="domain_force">[(1, '=', 1)]</field> |
|||
<field name="groups" eval="[Command.link(ref('dental_clinic_management.group_dental_manager'))]"/> |
|||
</record> |
|||
<!-- Set the record rule for visible only the corresponding doctor prescriptions --> |
|||
<record id="own_dental_prescription" model="ir.rule"> |
|||
<field name="name">Own Prescriptions</field> |
|||
<field name="model_id" ref="model_dental_prescription"/> |
|||
<field name="domain_force">[('prescribed_doctor_id.user_id', '=', user.id)]</field> |
|||
<field name="groups" |
|||
eval="[Command.link(ref('dental_clinic_management.group_dental_doctor'))]"/> |
|||
</record> |
|||
<!-- To see all the prescriptions for the manager --> |
|||
<record id="see_all_dental_prescriptions" model="ir.rule"> |
|||
<field name="name">All Prescriptions</field> |
|||
<field ref="model_dental_prescription" name="model_id"/> |
|||
<field name="domain_force">[(1, '=', 1)]</field> |
|||
<field name="groups" eval="[Command.link(ref('dental_clinic_management.group_dental_manager'))]"/> |
|||
</record> |
|||
</odoo> |
|
Before Width: | Height: | Size: 36 KiB |
Before Width: | Height: | Size: 3.6 KiB |
Before Width: | Height: | Size: 310 B |
Before Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 576 B |
Before Width: | Height: | Size: 733 B |
Before Width: | Height: | Size: 911 B |
Before Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 673 B |
Before Width: | Height: | Size: 11 KiB |
Before Width: | Height: | Size: 878 B |
Before Width: | Height: | Size: 653 B |
Before Width: | Height: | Size: 905 B |
Before Width: | Height: | Size: 839 B |
Before Width: | Height: | Size: 427 B |
Before Width: | Height: | Size: 627 B |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 988 B |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 80 KiB |
Before Width: | Height: | Size: 3.2 KiB |
Before Width: | Height: | Size: 565 B |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 43 KiB |
Before Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 4.0 KiB |
Before Width: | Height: | Size: 38 KiB |
Before Width: | Height: | Size: 4.3 KiB |
Before Width: | Height: | Size: 87 KiB |
Before Width: | Height: | Size: 80 KiB |
Before Width: | Height: | Size: 95 KiB |
Before Width: | Height: | Size: 78 KiB |
Before Width: | Height: | Size: 164 KiB |
Before Width: | Height: | Size: 81 KiB |
Before Width: | Height: | Size: 80 KiB |
Before Width: | Height: | Size: 60 KiB |
Before Width: | Height: | Size: 36 KiB |
Before Width: | Height: | Size: 97 KiB |
Before Width: | Height: | Size: 122 KiB |
Before Width: | Height: | Size: 96 KiB |
Before Width: | Height: | Size: 86 KiB |
Before Width: | Height: | Size: 102 KiB |
Before Width: | Height: | Size: 102 KiB |
Before Width: | Height: | Size: 61 KiB |
Before Width: | Height: | Size: 38 KiB |
Before Width: | Height: | Size: 52 KiB |
Before Width: | Height: | Size: 90 KiB |
Before Width: | Height: | Size: 70 KiB |
Before Width: | Height: | Size: 71 KiB |
Before Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 46 KiB |
Before Width: | Height: | Size: 115 KiB |
Before Width: | Height: | Size: 40 KiB |
Before Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 80 KiB |
Before Width: | Height: | Size: 32 KiB |
Before Width: | Height: | Size: 101 KiB |
Before Width: | Height: | Size: 50 KiB |
Before Width: | Height: | Size: 41 KiB |
Before Width: | Height: | Size: 132 KiB |
Before Width: | Height: | Size: 93 KiB |
Before Width: | Height: | Size: 107 KiB |