| @ -0,0 +1,46 @@ | |||
| .. image:: https://img.shields.io/badge/license-LGPL--3-blue.svg | |||
|     :target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html | |||
|     :alt: License: LGPL-3 | |||
| 
 | |||
| Packers & Movers Management | |||
| =========================== | |||
| * Packers & Movers Management module helps Users to book the trucks through online. | |||
| 
 | |||
| Installation | |||
| ============ | |||
| 	- www.odoo.com/documentation/17.0/setup/install.html | |||
| 	- Install our custom addon | |||
| 
 | |||
| License | |||
| ------- | |||
| General Public License, Version 3 (LGPL v3). | |||
| (https://www.odoo.com/documentation/user/17.0/legal/licenses/licenses.html) | |||
| 
 | |||
| Company | |||
| ------- | |||
| * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | |||
| 
 | |||
| Credits | |||
| ------- | |||
| * Developer: (V17) Anfas Faisal K | |||
| 
 | |||
| Contacts | |||
| -------- | |||
| * Mail Contact : odoo@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 https://www.cybrosys.com | |||
| 
 | |||
| Further information | |||
| =================== | |||
| HTML Description: `<static/description/index.html>`__ | |||
| 
 | |||
| @ -0,0 +1,25 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 controllers | |||
| from . import models | |||
| from . import report | |||
| from . import wizard | |||
| @ -0,0 +1,77 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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': 'Packers & Movers Management', | |||
|     'version': '17.0.1.0.0', | |||
|     'category': 'Industries,Website', | |||
|     'summary': """Users can reserve trucks online with the help of the  | |||
|     Packers & Movers Management module.""", | |||
|     'description': """The Packers & Movers Management module helps Users to  | |||
|     book the trucks through online""", | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'website': "https://www.cybrosys.com", | |||
|     'depends': ['website', 'fleet', 'mail', 'account'], | |||
|     'data': [ | |||
|         'security/packers_and_movers_security.xml', | |||
|         'security/ir.model.access.csv', | |||
|         'data/truck_booking_sequence.xml', | |||
|         'data/website_form_data.xml', | |||
|         'data/goods_type_data.xml', | |||
|         'data/truck_type_data.xml', | |||
|         'data/fleet_truck_data.xml', | |||
|         'report/booking_form_report_templates.xml', | |||
|         'report/booking_report_templates.xml', | |||
|         'report/booking_report_views.xml', | |||
|         'views/website_page_booking_templates.xml', | |||
|         'views/goods_type_views.xml', | |||
|         'views/truck_booking_views.xml', | |||
|         'views/website_page_goods_templates.xml', | |||
|         'views/website_page_truck_templates.xml', | |||
|         'views/fleet_vehicle_model_views.xml', | |||
|         'views/res_config_settings_views.xml', | |||
|         'views/dashboard_views.xml', | |||
|         'wizard/make_truck_booking_pdf_views.xml' | |||
|     ], | |||
|     'assets': { | |||
|         'web.assets_frontend': [ | |||
|             'packers_and_movers_management/static/src/js/website_page.js', | |||
|             'packers_and_movers_management/static/src/css/website_page.css', | |||
|         ], | |||
|         'web.assets_backend': [ | |||
|             'packers_and_movers_management/static/src/css/dashboard.css', | |||
|             'packers_and_movers_management/static/src/scss/style.scss', | |||
|             'packers_and_movers_management/static/src/js/lib/chart_bundle.js', | |||
|             'packers_and_movers_management/static/src/js/dasboard_action.js', | |||
|             'packers_and_movers_management/static/src/xml/dashboard_templates.xml' | |||
|         ] | |||
|     }, | |||
|     'external_dependencies': { | |||
|         'python': ['geopy'], | |||
|     }, | |||
|     'images': ['static/description/banner.jpg'], | |||
|     'license': 'LGPL-3', | |||
|     'installable': True, | |||
|     'auto_install': False, | |||
|     'application': False, | |||
| } | |||
| @ -0,0 +1,22 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 packers_and_movers_management | |||
| @ -0,0 +1,96 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 math import cos, sin, asin, sqrt, radians | |||
| from geopy import Nominatim | |||
| from odoo import http | |||
| from odoo.http import request | |||
| 
 | |||
| 
 | |||
| class PackersAndMoversManagementController(http.Controller): | |||
|     """Class to add truck booking menu in website""" | |||
| 
 | |||
|     @http.route('/booking', auth='public', website=True) | |||
|     def truck_booking(self): | |||
|         """Function to render truck booking values to XML""" | |||
|         truck_ids = request.env['fleet.vehicle.model'].sudo().search([('vehicle_type', '=', 'truck')]) | |||
|         goods_ids = request.env['goods.type'].sudo().search([]) | |||
|         state_ids = request.env['res.country.state'].sudo().search([]) | |||
|         country_ids = request.env['res.country'].sudo().search([]) | |||
|         return http.request.render('packers_and_movers_management.truck_booking_page', | |||
|                                    {'truck_ids': truck_ids, | |||
|                                     'goods_ids': goods_ids, | |||
|                                     'state_ids': state_ids, | |||
|                                     'country_ids': country_ids}) | |||
| 
 | |||
|     @http.route('/booking/submit', type='http', auth='public', website=True) | |||
|     def booking_success_page(self, **post): | |||
|         """Function to create booking and return to success page""" | |||
|         partner_id = request.env['res.partner'].sudo().create({ | |||
|             'name': post.get('name'), | |||
|             'mobile': post.get('mobile_no'), | |||
|             'city': post.get('city'), | |||
|             'state_id': post.get('state'), | |||
|             'country_id': post.get('country') | |||
|         }) | |||
|         booking_id = request.env['truck.booking'].sudo().create({ | |||
|             'partner_id': partner_id.id, | |||
|             'from_location': post.get('pickup_location'), | |||
|             'to_location': post.get('drop_location'), | |||
|             'truck_id': post.get('truck_type'), | |||
|             'date': post.get('date'), | |||
|             'goods_type_id': post.get('goods_type'), | |||
|             'weight': post.get('weight'), | |||
|             'unit': post.get('unit') | |||
|         }) | |||
|         return request.render('packers_and_movers_management.truck_booking_success_page', | |||
|                               {'partner_id': partner_id, | |||
|                                'booking_id': booking_id}) | |||
| 
 | |||
|     @http.route('/goods', type='http', auth='public', website=True) | |||
|     def goods_type(self): | |||
|         """Function to return values to xml""" | |||
|         goods_ids = request.env['goods.type'].sudo().search([]) | |||
|         return http.request.render('packers_and_movers_management.goods_page', | |||
|                                    {'goods_ids': goods_ids}) | |||
| 
 | |||
|     @http.route('/truck', type='http', auth='public', website=True) | |||
|     def truck_details(self): | |||
|         """Function to render values to XML""" | |||
|         truck_type_ids = request.env['truck.type'].sudo().search([]) | |||
|         return http.request.render('packers_and_movers_management.truck_page', | |||
|                                    {'truck_type_ids': truck_type_ids}) | |||
| 
 | |||
|     @http.route(['/geo/<from_location>/<to_location>'], type='json', auth="none", website=False, csrf=False) | |||
|     def geo_location(self, from_location, to_location): | |||
|         """Function to Calculate distance between from and to location""" | |||
|         locator = Nominatim(user_agent="my_distance_app") | |||
|         from_location = locator.geocode(from_location) | |||
|         to_location = locator.geocode(to_location) | |||
|         from_lat = radians(from_location.latitude) | |||
|         from_long = radians(from_location.longitude) | |||
|         to_lat = radians(to_location.latitude) | |||
|         to_long = radians(to_location.longitude) | |||
|         dist_long = to_long - from_long | |||
|         dist_lat = to_lat - from_lat | |||
|         comp = sin(dist_lat / 2) ** 2 + cos(from_lat) * cos(to_lat) * sin( | |||
|             dist_long / 2) ** 2 | |||
|         return int(2 * asin(sqrt(comp)) * 6371) | |||
| @ -0,0 +1,29 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|         <record id="brand_tata" model="fleet.vehicle.model.brand"> | |||
|             <field name="name">TATA</field> | |||
|         </record> | |||
|         <record id="brand_eicher" model="fleet.vehicle.model.brand"> | |||
|             <field name="name">EICHER</field> | |||
|         </record> | |||
|         <record id="model_gold" model="fleet.vehicle.model"> | |||
|             <field name="name">Tata Ace gold</field> | |||
|             <field name="brand_id" ref="brand_tata"/> | |||
|             <field name="vehicle_type">truck</field> | |||
|             <field name="truck_type_id" ref="truck_type_data1"/> | |||
|         </record> | |||
|         <record id="model_ev" model="fleet.vehicle.model"> | |||
|             <field name="name">Tata Ace EV</field> | |||
|             <field name="brand_id" ref="brand_tata"/> | |||
|             <field name="vehicle_type">truck</field> | |||
|             <field name="truck_type_id" ref="truck_type_data1"/> | |||
|         </record> | |||
|         <record id="model_pro_3015" model="fleet.vehicle.model"> | |||
|             <field name="name">Eicher Pro 3015</field> | |||
|             <field name="brand_id" ref="brand_eicher"/> | |||
|             <field name="vehicle_type">truck</field> | |||
|             <field name="truck_type_id" ref="truck_type_data3"/> | |||
|         </record> | |||
|     </data> | |||
| </odoo> | |||
| @ -0,0 +1,26 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|         <record id="goods_type_data1" model="goods.type"> | |||
|             <field name="name">Industrial Machinery</field> | |||
|         </record> | |||
|         <record id="goods_type_data2" model="goods.type"> | |||
|             <field name="name">Household Goods</field> | |||
|         </record> | |||
|         <record id="goods_type_data3" model="goods.type"> | |||
|             <field name="name">Healthcare/Pharmacy Products/Medicines</field> | |||
|         </record> | |||
|         <record id="goods_type_data4" model="goods.type"> | |||
|             <field name="name">Electrical Wires/Cables</field> | |||
|         </record> | |||
|         <record id="goods_type_data5" model="goods.type"> | |||
|             <field name="name">Scrap</field> | |||
|         </record> | |||
|         <record id="goods_type_data6" model="goods.type"> | |||
|             <field name="name">Plants</field> | |||
|         </record> | |||
|         <record id="goods_type_data7" model="goods.type"> | |||
|             <field name="name">Other</field> | |||
|         </record> | |||
|     </data> | |||
| </odoo> | |||
| @ -0,0 +1,12 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|        <record id="truck_booking_sequence" model="ir.sequence"> | |||
|            <field name="name">Truck Booking Sequence</field> | |||
|            <field name="code">truck.booking</field> | |||
|            <field name="prefix">TR</field> | |||
|            <field name="padding">5</field> | |||
|            <field name="company_id" eval="False"/> | |||
|        </record> | |||
|     </data> | |||
| </odoo> | |||
| @ -0,0 +1,41 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|         <record id="truck_type_data1" model="truck.type"> | |||
|             <field name="name">TATA ACE</field> | |||
|             <field name="capacity">1</field> | |||
|             <field name="weight">850</field> | |||
|             <field name="unit">kg</field> | |||
|             <field name="length">7</field> | |||
|             <field name="width">4.8</field> | |||
|             <field name="height">4.8</field> | |||
|         </record> | |||
|         <record id="truck_type_data2" model="truck.type"> | |||
|             <field name="name">TATA 407</field> | |||
|             <field name="capacity">1.5</field> | |||
|             <field name="weight">2.5</field> | |||
|             <field name="unit">tons</field> | |||
|             <field name="length">9</field> | |||
|             <field name="width">5.5</field> | |||
|             <field name="height">5</field> | |||
|         </record> | |||
|         <record id="truck_type_data3" model="truck.type"> | |||
|             <field name="name">EICHER 17 FEET</field> | |||
|             <field name="capacity">2.5</field> | |||
|             <field name="weight">5</field> | |||
|             <field name="unit">tons</field> | |||
|             <field name="length">17</field> | |||
|             <field name="width">6</field> | |||
|             <field name="height">7</field> | |||
|         </record> | |||
|         <record id="truck_type_data5" model="truck.type"> | |||
|             <field name="name">CONTAINER 20 FT</field> | |||
|             <field name="capacity">4</field> | |||
|             <field name="weight">6.5</field> | |||
|             <field name="unit">tons</field> | |||
|             <field name="length">20</field> | |||
|             <field name="width">8</field> | |||
|             <field name="height">8</field> | |||
|         </record> | |||
|     </data> | |||
| </odoo> | |||
| @ -0,0 +1,23 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|         <record id="menu_booking" model="website.menu"> | |||
|             <field name="name">Booking</field> | |||
|             <field name="url">/booking</field> | |||
|             <field name="parent_id" ref="website.main_menu"/> | |||
|             <field name="sequence" type="int">50</field> | |||
|         </record> | |||
|         <record id="menu_truck" model="website.menu"> | |||
|             <field name="name">Truck</field> | |||
|             <field name="url">/truck</field> | |||
|             <field name="parent_id" ref="website.main_menu"/> | |||
|             <field name="sequence" type="int">51</field> | |||
|         </record> | |||
|         <record id="menu_goods" model="website.menu"> | |||
|             <field name="name">Goods</field> | |||
|             <field name="url">/goods</field> | |||
|             <field name="parent_id" ref="website.main_menu"/> | |||
|             <field name="sequence" type="int">52</field> | |||
|         </record> | |||
|     </data> | |||
| </odoo> | |||
| @ -0,0 +1,6 @@ | |||
| ## Module <packers_and_movers_management> | |||
| 
 | |||
| #### 09.12.2023 | |||
| #### Version 17.0.1.0.0 | |||
| #### ADD | |||
| - Initial commit for Packers & Movers Management | |||
| @ -0,0 +1,27 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 account_move | |||
| from . import fleet_vehicle_model | |||
| from . import goods_type | |||
| from . import res_config_settings | |||
| from . import truck_booking | |||
| from . import truck_type | |||
| @ -0,0 +1,40 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 models | |||
| 
 | |||
| 
 | |||
| class AccountMove(models.Model): | |||
|     """Inherit the class account_move""" | |||
|     _inherit = 'account.move' | |||
| 
 | |||
|     def action_post(self): | |||
|         """Super the action_post() to change truck_booking state into invoice""" | |||
|         res = super(AccountMove, self).action_post() | |||
|         if self: | |||
|             booking_id = self.env['truck.booking']\ | |||
|                 .browse(self.env.context.get('active_id')) | |||
|             amount = sum(self.search([ | |||
|                 ('invoice_origin', '=', booking_id.reference_no), | |||
|                 ('state', '!=', 'cancel')]).mapped('amount_untaxed_signed')) | |||
|             if booking_id.amount == amount: | |||
|                 booking_id.write({'state': 'invoice'}) | |||
|         return res | |||
| @ -0,0 +1,34 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 FleetVehicle(models.Model): | |||
|     """Inherit fleet.vehicle.model to add a vehicle type""" | |||
|     _inherit = 'fleet.vehicle.model' | |||
| 
 | |||
|     vehicle_type = fields.Selection(selection_add=[('truck', 'Truck')], | |||
|                                     ondelete={'truck': 'cascade'}, | |||
|                                     help='Select the type of the vehicle.' | |||
|                                          ' For trucks, choose "Truck".') | |||
|     truck_type_id = fields.Many2one('truck.type', string='Truck Type', | |||
|                                     required=True, help='Select truck type') | |||
| @ -0,0 +1,34 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 GoodsType(models.Model): | |||
|     """Class to add goods_type menu in the module""" | |||
|     _name = 'goods.type' | |||
|     _description = 'Goods Type' | |||
| 
 | |||
|     name = fields.Char(string='Type', help='Name of the goods') | |||
|     company_id = fields.Many2one('res.company', string='Company', | |||
|                                  default=lambda self: self.env.user.company_id.id, | |||
|                                  help='Select the company to which this ' | |||
|                                       'record belongs.') | |||
| @ -0,0 +1,52 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 ResConfigSettings(models.TransientModel): | |||
|     """Inherit the model res.config.settings to add distance amount""" | |||
|     _inherit = 'res.config.settings' | |||
| 
 | |||
|     distance_amount = fields.Float( | |||
|         string='Distance Amount/KM', | |||
|         config_parameter='packers_and_movers_management.distance_amount', | |||
|         help="Enter the distance amount/KM") | |||
|     is_extra = fields.Boolean( | |||
|         string='Apply Extra Amount', | |||
|         config_parameter='packers_and_movers_management.is_extra', | |||
|         default=False, | |||
|         help="Enable, if extra charge want to add") | |||
|     extra_amount = fields.Float( | |||
|         string='Extra Amount', | |||
|         config_parameter='packers_and_movers_management.extra_amount', | |||
|         help='Enter extra amount/KM') | |||
|     is_distance_limited = fields.Boolean( | |||
|         string='Limit Distance', | |||
|         config_parameter='packers_and_movers_management.is_distance_limited', | |||
|         default=False, | |||
|         help="Enable, if need to limit " | |||
|              "Distance") | |||
|     max_distance = fields.Float( | |||
|         string='Maximum Distance (KM)', | |||
|         config_parameter='packers_and_movers_management.max_distance', | |||
|         help='Enter the maximum distance limit in KM' | |||
|     ) | |||
| @ -0,0 +1,421 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 geopy import Nominatim | |||
| from math import cos, sin, asin, sqrt, radians | |||
| from odoo import api, fields, models, _ | |||
| from odoo.exceptions import ValidationError | |||
| from odoo.fields import Datetime | |||
| 
 | |||
| 
 | |||
| class TruckBooking(models.Model): | |||
|     """Class to add truck_booking menu to view all truck_booking""" | |||
|     _name = "truck.booking" | |||
|     _inherit = 'mail.thread', 'mail.activity.mixin' | |||
|     _description = "Truck Booking" | |||
|     _rec_name = 'reference_no' | |||
| 
 | |||
|     reference_no = fields.Char(string='Order Reference', readonly=True, | |||
|                                default=lambda self: _('New'), copy=False, | |||
|                                help='Order reference number') | |||
|     partner_id = fields.Many2one('res.partner', string='Customer', | |||
|                                  required=True, help='Customer Name') | |||
|     company_id = fields.Many2one('res.company', string='Company', | |||
|                                  default=lambda self: self.env.user.company_id.id, | |||
|                                  help='Select the company to which this record belongs.') | |||
|     from_location = fields.Char(string='Pickup City', required=True, | |||
|                                 help='Goods source location') | |||
|     to_location = fields.Char(string='Drop City', required=True, | |||
|                               help='Goods destination location') | |||
|     distance = fields.Float(string='Distance', compute='_compute_distance', | |||
|                             store=True, help='Total distance to travel') | |||
|     truck_id = fields.Many2one('fleet.vehicle.model', string='Truck Type', | |||
|                                domain=[('vehicle_type', '=', 'truck')], | |||
|                                required=True, help='Select the truck type') | |||
|     goods_type_id = fields.Many2one('goods.type', string='Goods Type', | |||
|                                     help='Select goods type', required=True) | |||
|     weight = fields.Integer(string='Weight', help='Total weight of goods') | |||
|     amount = fields.Float(string='Amount', compute='_compute_amount', | |||
|                           store=True, | |||
|                           help='Total amount is the distance travelled by the truck') | |||
|     date = fields.Date(string='Date', help='Delivery date') | |||
|     unit = fields.Selection(selection=[('kg', 'KG'), ('tons', 'Tons')], | |||
|                             string='Unit', default='kg', help='Select unit') | |||
|     state = fields.Selection(selection=[('draft', 'Draft'), | |||
|                                         ('confirm', 'Confirm'), | |||
|                                         ('invoice', 'Invoiced')], | |||
|                              string='State', default="draft", | |||
|                              help="Booking State") | |||
|     invoice_count = fields.Integer(string="Invoice Count", | |||
|                                    compute='_compute_invoice_count', | |||
|                                    help='Total invoice count') | |||
|     invoiced_amount = fields.Float(string='Invoiced amount', | |||
|                                    compute='_compute_invoiced_amount', | |||
|                                    help='Total invoiced amount') | |||
|     hide_invoice = fields.Boolean(string='Hide Invoice', | |||
|                                   help="To hide create invoice button", | |||
|                                   default=False) | |||
| 
 | |||
|     @api.constrains('distance') | |||
|     def _check_distance_limit(self): | |||
|         """Check the distance against the configured maximum distance limit.""" | |||
|         is_distance_limited = self.env['ir.config_parameter'].sudo().get_param( | |||
|             'packers_and_movers_management.is_distance_limited', default=False) | |||
|         max_distance = float(self.env['ir.config_parameter'].sudo().get_param( | |||
|             'packers_and_movers_management.max_distance', default=0.0)) | |||
|         for record in self: | |||
|             if is_distance_limited and record.distance > max_distance: | |||
|                 raise ValidationError( | |||
|                     _("The distance of %s KM exceeds the maximum allowed " | |||
|                       "distance of %s KM. Please reduce the distance or " | |||
|                       "update the settings.") % ( | |||
|                     record.distance, max_distance)) | |||
| 
 | |||
|     @api.onchange('date') | |||
|     def _onchange_date(self): | |||
|         if self.date and self.date < Datetime.today().date(): | |||
|             raise ValidationError( | |||
|                 "Selected date cannot be before today's date.") | |||
| 
 | |||
|     @api.model | |||
|     def create(self, vals_list): | |||
|         """Function to create sequence""" | |||
|         if vals_list.get('reference_no', _('New')) == _('New'): | |||
|             vals_list['reference_no'] = self.env['ir.sequence'].next_by_code( | |||
|                 'truck.booking') or _('New') | |||
|         return super(TruckBooking, self).create(vals_list) | |||
| 
 | |||
|     def action_confirm(self): | |||
|         """Function to change state to confirm""" | |||
|         self.write({'state': 'confirm'}) | |||
| 
 | |||
|     @api.depends('from_location', 'to_location') | |||
|     def _compute_distance(self): | |||
|         """Function to calculate distance between from and to location""" | |||
|         for location in self: | |||
|             locator = Nominatim(user_agent="my_distance_app") | |||
|             from_location = locator.geocode(location.from_location) | |||
|             to_location = locator.geocode(location.to_location) | |||
|             if from_location is None or to_location is None: | |||
|                 raise ValidationError(_("Please enter valid city.")) | |||
|             else: | |||
|                 from_lat = radians(from_location.latitude) | |||
|                 from_long = radians(from_location.longitude) | |||
|                 to_lat = radians(to_location.latitude) | |||
|                 to_long = radians(to_location.longitude) | |||
|                 dist_long = to_long - from_long | |||
|                 dist_lat = to_lat - from_lat | |||
|                 comp = sin(dist_lat / 2) ** 2 + cos(from_lat) * cos(to_lat) * sin(dist_long / 2) ** 2 | |||
|                 location.distance = int(2 * asin(sqrt(comp)) * 6371) | |||
| 
 | |||
|     @api.depends('distance') | |||
|     def _compute_amount(self): | |||
|         """Function to calculate amount for booking""" | |||
|         for record in self: | |||
|             amount = record.env['ir.config_parameter'].sudo().\ | |||
|                 get_param('packers_and_movers_management.distance_amount') | |||
|             total = float(amount) * record.distance | |||
|             is_extra = record.env['ir.config_parameter'].sudo().\ | |||
|                 get_param('packers_and_movers_management.is_extra') | |||
|             if is_extra: | |||
|                 extra_amount = record.env['ir.config_parameter'].sudo(). \ | |||
|                     get_param('packers_and_movers_management.extra_amount') | |||
|                 total *= float(extra_amount) | |||
|             record.amount = total | |||
| 
 | |||
|     def action_create_invoice(self): | |||
|         """Function to create invoice for the booking""" | |||
|         invoice_id = self.env['account.move'].search( | |||
|             [('invoice_origin', '=', self.reference_no), | |||
|              ('state', '=', 'draft')]) | |||
|         if not invoice_id: | |||
|             invoice = self.env['account.move'].create([{ | |||
|                 'move_type': 'out_invoice', | |||
|                 'partner_id': self.partner_id.id, | |||
|                 'invoice_origin': self.reference_no, | |||
|                 'invoice_line_ids': [fields.Command.create({ | |||
|                     'name': "{} to {}".format(self.from_location,self.to_location), | |||
|                     'quantity': 1, | |||
|                     'price_unit': self.amount - self.invoiced_amount, | |||
|                     'price_subtotal': self.amount})]}]) | |||
|             return { | |||
|                 'name': 'Invoice', | |||
|                 'view_mode': 'form', | |||
|                 'res_id': invoice.id, | |||
|                 'res_model': 'account.move', | |||
|                 'type': 'ir.actions.act_window', | |||
|                 'target': 'current', | |||
|             } | |||
|         else: | |||
|             invoice_id.write({'invoice_line_ids': [(0, 0,{ | |||
|                 'name': "{} to {}".format(self.from_location,self.to_location), | |||
|                 'quantity': 1, | |||
|                 'price_unit': self.amount - self.invoiced_amount, | |||
|                 'price_subtotal': self.amount})]}) | |||
|             return { | |||
|                 'name': 'Invoice', | |||
|                 'view_mode': 'form', | |||
|                 'res_id': invoice_id.id, | |||
|                 'res_model': 'account.move', | |||
|                 'type': 'ir.actions.act_window', | |||
|                 'target': 'current', | |||
|             } | |||
| 
 | |||
|     def _compute_invoice_count(self): | |||
|         """Function to count invoice""" | |||
|         for record in self: | |||
|             record.invoice_count = self.env['account.move'].\ | |||
|                 search_count([('invoice_origin', '=', self.reference_no)]) | |||
| 
 | |||
|     def _compute_invoiced_amount(self): | |||
|         """Function to add invoiced amount""" | |||
|         for record in self: | |||
|             invoices = record.env['account.move'].search([ | |||
|                 ('invoice_origin', '=', record.reference_no), | |||
|                 ('state', '!=', 'cancel')]) | |||
|             record.invoiced_amount = sum(invoices.mapped('amount_untaxed_signed')) | |||
|             record.hide_invoice = sum( | |||
|                 invoices.mapped('amount_untaxed_signed')) == record.amount | |||
| 
 | |||
|     def action_view_invoice(self): | |||
|         """Smart button to view the Corresponding Invoices for the truck_booking""" | |||
|         return { | |||
|             'type': 'ir.actions.act_window', | |||
|             'name': 'Invoice', | |||
|             'view_mode': 'tree,form', | |||
|             'res_model': 'account.move', | |||
|             'target': 'current', | |||
|             'domain': [('invoice_origin', '=', self.reference_no)], | |||
|             'context': {"create": False}, | |||
|         } | |||
| 
 | |||
|     @api.model | |||
|     def get_total_booking(self): | |||
|         """Function to get total booking, distance and invoice amount details""" | |||
|         total_booking = self.env['truck.booking'].search_count([]) | |||
|         booking_ids = self.env['truck.booking'].search([]) | |||
|         invoice_ids = self.env['truck.booking'].\ | |||
|             search([('state', '=', 'invoice')]).mapped('amount') | |||
|         return {'total_booking': total_booking, | |||
|                 'total_distance_count': sum(booking_ids.mapped('distance')), | |||
|                 'total_invoice': sum(invoice_ids), | |||
|                 'total_amount': sum(booking_ids.mapped('amount'))} | |||
| 
 | |||
|     @api.model | |||
|     def get_top_truck(self): | |||
|         """Function to return top truck and customer details query to js""" | |||
|         self.env.cr.execute('''select fv.name,count(name) from truck_booking as tb | |||
|                     inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                     group by name order by count desc limit 10''') | |||
|         truck = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select pr.name,count(name) from truck_booking as tb | |||
|                            inner join res_partner as pr on pr.id = tb.partner_id | |||
|                            group by name order by count desc limit 10''') | |||
|         customer = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select tb.reference_no,pr.name,tb.date from  | |||
|                             truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             where tb.date >= '%s' and tb.state = 'invoice' | |||
|                             order by tb.date''' % fields.date.today()) | |||
|         upcoming = self.env.cr.dictfetchall() | |||
|         return {'truck': truck, 'customer': customer, 'upcoming': upcoming} | |||
| 
 | |||
|     @api.model | |||
|     def get_booking_analysis(self): | |||
|         """Function to return customer details to js for graph view""" | |||
|         self.env.cr.execute('''select pr.name,sum(tb.amount) from truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             group by name''') | |||
|         booking = self.env.cr.dictfetchall() | |||
|         count = [] | |||
|         customer = [] | |||
|         for record in booking: | |||
|             customer.append(record.get('name')) | |||
|             count.append(record.get('sum')) | |||
|         value = {'name': customer, 'count': count} | |||
|         return value | |||
| 
 | |||
|     @api.model | |||
|     def get_truck_analysis(self): | |||
|         """Function to return truck details to js for graph view""" | |||
|         self.env.cr.execute('''select fv.name,sum(tb.amount) from truck_booking as tb | |||
|                     inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                     group by name''') | |||
|         booking = self.env.cr.dictfetchall() | |||
|         count = [] | |||
|         customer = [] | |||
|         for record in booking: | |||
|             customer.append(record.get('name')) | |||
|             count.append(record.get('sum')) | |||
|         return {'name': customer, 'count': count} | |||
| 
 | |||
|     @api.model | |||
|     def get_distance(self): | |||
|         """Function to return total distance on the basis of customer and truck""" | |||
|         self.env.cr.execute('''select pr.name,sum(tb.distance) from truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             group by name''') | |||
|         customer = self.env.cr.dictfetchall() | |||
|         cust_sum = [] | |||
|         cust = [] | |||
|         for record in customer: | |||
|             cust.append(record.get('name')) | |||
|             cust_sum.append(record.get('sum')) | |||
|         self.env.cr.execute('''select fv.name,sum(tb.distance) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                             group by name''') | |||
| 
 | |||
|         truck = self.env.cr.dictfetchall() | |||
|         truck_sum = [] | |||
|         truck_name = [] | |||
|         for record in truck: | |||
|             truck_name.append(record.get('name')) | |||
|             truck_sum.append(record.get('sum')) | |||
|         return {'cust': cust, 'cust_sum': cust_sum, 'truck_name': truck_name, | |||
|                 'truck_sum': truck_sum} | |||
| 
 | |||
|     @api.model | |||
|     def get_weight(self): | |||
|         """Function to get total weight of the goods""" | |||
|         self.env.cr.execute('''select pr.name,sum(tb.weight) from truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             group by name''') | |||
|         customer = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select fv.name,sum(tb.weight) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                             group by name''') | |||
|         truck = self.env.cr.dictfetchall() | |||
|         cust_sum = [] | |||
|         cust = [] | |||
|         for record in customer: | |||
|             cust.append(record.get('name')) | |||
|             cust_sum.append(record.get('sum')) | |||
|         truck_sum = [] | |||
|         truck_name = [] | |||
|         for record in truck: | |||
|             truck_name.append(record.get('name')) | |||
|             truck_sum.append(record.get('sum')) | |||
|         return {'cust': cust, 'cust_sum': cust_sum, 'truck_name': truck_name, | |||
|                 'truck_sum': truck_sum} | |||
| 
 | |||
|     @api.model | |||
|     def get_select_filter(self,option): | |||
|         """Function to filter data on the bases of the year""" | |||
|         if option == 'year': | |||
|             create_date = '''create_date between (now() - interval '1 year') and now()''' | |||
|         elif option == 'month': | |||
|             create_date = '''create_date between (now() - interval '1 months') and now()''' | |||
|         elif option == 'week': | |||
|             create_date = '''create_date between (now() - interval '7 day') and now()''' | |||
|         elif option == 'day': | |||
|             create_date = '''create_date between (now() - interval '1 day') and now()''' | |||
| 
 | |||
|         self.env.cr.execute('''select count(*) from truck_booking  | |||
|                             where %s''' % create_date) | |||
|         booking = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select sum(distance) from truck_booking  | |||
|                             where %s''' % create_date) | |||
|         distance = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select sum(amount) from truck_booking  | |||
|                             where %s''' % create_date) | |||
|         amount = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select sum(amount) from truck_booking | |||
|                                 where state = 'invoice' and %s''' % create_date) | |||
|         invoice = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select fv.name,count(name) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                              where tb.%s | |||
|                             group by name | |||
|                             order by count desc | |||
|                             limit 10''' % create_date) | |||
|         truck = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select pr.name,count(name) from truck_booking as tb | |||
|                                    inner join res_partner as pr on pr.id = tb.partner_id | |||
|                                     where tb.%s group by name | |||
|                                    order by count desc limit 10''' % create_date) | |||
|         customer = self.env.cr.dictfetchall() | |||
|         self.env.cr.execute('''select pr.name,sum(tb.amount) from truck_booking as tb | |||
|                              inner join res_partner as pr on pr.id = tb.partner_id | |||
|                              where tb.%s group by name''' % create_date) | |||
|         cust_invoice = self.env.cr.dictfetchall() | |||
|         cust_invoice_name = [] | |||
|         cust_invoice_sum = [] | |||
|         for record in cust_invoice: | |||
|             cust_invoice_name.append(record.get('name')) | |||
|             cust_invoice_sum.append(record.get('sum')) | |||
|         self.env.cr.execute('''select fv.name,sum(tb.amount) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                             where tb.%s group by name''' % create_date) | |||
|         truck_invoice = self.env.cr.dictfetchall() | |||
|         truck_invoice_name = [] | |||
|         truck_invoice_count = [] | |||
|         for record in truck_invoice: | |||
|             truck_invoice_name.append(record.get('name')) | |||
|             truck_invoice_count.append(record.get('sum')) | |||
|         self.env.cr.execute('''select pr.name,sum(tb.distance) from truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             where tb.%s | |||
|                             group by name''' % create_date) | |||
|         cust_distance = self.env.cr.dictfetchall() | |||
|         cust_distance_name = [] | |||
|         cust_distance_count = [] | |||
|         for record in cust_distance: | |||
|             cust_distance_name.append(record.get('name')) | |||
|             cust_distance_count.append(record.get('sum')) | |||
|         self.env.cr.execute('''select fv.name,sum(tb.distance) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                             where tb.%s | |||
|                             group by name''' % create_date) | |||
|         truck_distance = self.env.cr.dictfetchall() | |||
|         truck_distance_name = [] | |||
|         truck_distance_count = [] | |||
|         for record in truck_distance: | |||
|             truck_distance_name.append(record.get('name')) | |||
|             truck_distance_count.append(record.get('sum')) | |||
|         self.env.cr.execute('''select pr.name,sum(tb.weight) from truck_booking as tb | |||
|                             inner join res_partner as pr on pr.id = tb.partner_id | |||
|                             where tb.%s group by name''' % create_date) | |||
|         cust_weight = self.env.cr.dictfetchall() | |||
|         cust_weight_name = [] | |||
|         cust_weight_count = [] | |||
|         for record in cust_weight: | |||
|             cust_weight_name.append(record.get('name')) | |||
|             cust_weight_count.append(record.get('sum')) | |||
|         self.env.cr.execute('''select fv.name,sum(tb.weight) from truck_booking as tb | |||
|                             inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                             where tb.%s group by name''' % create_date) | |||
|         truck_weight = self.env.cr.dictfetchall() | |||
|         truck_weight_name = [] | |||
|         truck_weight_count = [] | |||
|         for record in truck_weight: | |||
|             truck_weight_name.append(record.get('name')) | |||
|             truck_weight_count.append(record.get('sum')) | |||
|         return {'booking': booking, 'distance': distance, 'amount': amount, | |||
|                 'invoice': invoice, 'truck': truck,'customer': customer, | |||
|                 'cust_invoice_name': cust_invoice_name, 'cust_invoice_sum': | |||
|                     cust_invoice_sum, 'truck_invoice_name': truck_invoice_name, | |||
|                 'truck_invoice_count': truck_invoice_count, 'cust_distance_name': | |||
|                     cust_distance_name, 'cust_distance_count': cust_distance_count, | |||
|                 'truck_distance_name': truck_distance_name, | |||
|                 'truck_distance_count': truck_distance_count, | |||
|                 'cust_weight_name': cust_weight_name, 'cust_weight_count': | |||
|                     cust_weight_count, 'truck_weight_name': truck_weight_name, | |||
|                 'truck_weight_count': truck_weight_count} | |||
| @ -0,0 +1,44 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 TruckType(models.Model): | |||
|     """Add new menu truck_type model in the fleet model to select truck type""" | |||
|     _name = 'truck.type' | |||
|     _description = 'Truck Type' | |||
| 
 | |||
|     name = fields.Char(string='Truck Type', required=True, | |||
|                        help='Truck type name') | |||
|     length = fields.Float(string='Length', help='Length of the container') | |||
|     width = fields.Float(string='Width', help='Width of the container') | |||
|     height = fields.Float(string='Height', help='Height of the container') | |||
|     capacity = fields.Float(string='House Hold Capacity', required=True, | |||
|                             help='Suitable for house size') | |||
|     weight = fields.Float(string='Max Weight', required=True, | |||
|                           help='Max Load of container') | |||
|     company_id = fields.Many2one( | |||
|         'res.company', string='Company', | |||
|         default=lambda self: self.env.user.company_id.id, | |||
|         help='Select the company to which this record belongs.') | |||
|     unit = fields.Selection(selection=[('kg', 'KG'), ('tons', 'Tons')], | |||
|                             default='kg', help='Select unit', string="Unit") | |||
| @ -0,0 +1,22 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 form_truck_booking_report | |||
| @ -0,0 +1,91 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <!--    Template used to show the booking forms--> | |||
|     <template id="form_truck_booking_report"> | |||
|         <t t-call="web.html_container"> | |||
|             <t t-call="web.external_layout"> | |||
|                 <div class="page"> | |||
|                     <div> | |||
|                         <h1 style="font-size:30px"> | |||
|                             <span t-esc="report[0]['reference_no']"/> | |||
|                         </h1> | |||
|                         <h3 style="font-size:20px">Customer: | |||
|                             <span t-esc="report[0]['name']"/> | |||
|                         </h3> | |||
|                     </div> | |||
|                     <br/> | |||
|                     <br/> | |||
|                     <div class="row"> | |||
|                         <table class="table" style="height: 362px;"> | |||
|                             <tr> | |||
|                                 <th> | |||
|                                     From Location | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['from_location']"/> | |||
|                                 </td> | |||
|                                 <th> | |||
|                                     Truck Type | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['truck']"/> | |||
|                                 </td> | |||
|                             </tr> | |||
|                             <tr> | |||
|                                 <th> | |||
|                                     To Location | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['to_location']"/> | |||
|                                 </td> | |||
|                                 <th> | |||
|                                     Goods Type | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['goods']"/> | |||
|                                 </td> | |||
|                             </tr> | |||
|                             <tr> | |||
|                                 <th> | |||
|                                     Date | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['date']"/> | |||
|                                 </td> | |||
|                                 <th> | |||
|                                     Distance | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['distance']"/>KM | |||
|                                 </td> | |||
|                             </tr> | |||
|                             <tr> | |||
|                                 <th> | |||
|                                     Weight / Unit | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['weight']"/>/ | |||
|                                     <span t-esc="report[0]['unit']"/> | |||
|                                 </td> | |||
|                                 <th> | |||
|                                     Total Amount | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['amount']"/> | |||
|                                 </td> | |||
|                             </tr> | |||
|                             <tr> | |||
|                                 <th> | |||
|                                     State | |||
|                                 </th> | |||
|                                 <td> | |||
|                                     <span t-esc="report[0]['state']"/> | |||
|                                 </td> | |||
|                             </tr> | |||
|                         </table> | |||
|                     </div> | |||
|                 </div> | |||
|             </t> | |||
|         </t> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,99 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <!--    Template used to create form for the booking report--> | |||
|     <template id="report_truck_booking"> | |||
|         <t t-call="web.html_container"> | |||
|             <t t-call="web.external_layout"> | |||
|                 <div class="page"> | |||
|                     <div class="text-center"> | |||
|                         <h1 style="font-size:30px">Packers And Movers | |||
|                             Management | |||
|                         </h1> | |||
|                     </div> | |||
|                     <br/> | |||
|                     <br/> | |||
|                     <div class="row"> | |||
|                         <table class="table"> | |||
|                             <thead> | |||
|                                 <tr> | |||
|                                     <th> | |||
|                                         References | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Date | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Customer | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         From Location | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         To Location | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Distance | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Truck Type | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Goods Type | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Weight / Unit | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         Total Amount | |||
|                                     </th> | |||
|                                     <th> | |||
|                                         State | |||
|                                     </th> | |||
|                                 </tr> | |||
|                             </thead> | |||
|                             <t t-foreach="report" t-as="line"> | |||
|                                 <tr> | |||
|                                     <td> | |||
|                                         <span t-esc="line_index + 1"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['date']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['name']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['from_location']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['to_location']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['distance']"/> | |||
|                                         KM | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['truck']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['goods']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['weight']"/>/ | |||
|                                         <span t-esc="line['unit']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['amount']"/> | |||
|                                     </td> | |||
|                                     <td> | |||
|                                         <span t-esc="line['state']"/> | |||
|                                     </td> | |||
|                                 </tr> | |||
|                             </t> | |||
|                         </table> | |||
|                     </div> | |||
|                 </div> | |||
|             </t> | |||
|         </t> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,24 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <!--    Generate the Booking report as pdf Format--> | |||
|     <record id="action_report_booking" model="ir.actions.report"> | |||
|         <field name="name">Truck Booking</field> | |||
|         <field name="model">make.truck.booking.pdf</field> | |||
|         <field name="report_type">qweb-pdf</field> | |||
|         <field name="report_name">packers_and_movers_management.report_truck_booking</field> | |||
|         <field name="report_file">packers_and_movers_management.report_truck_booking</field> | |||
|     </record> | |||
|     <record id="action_report_truck_booking_form" model="ir.actions.report"> | |||
|         <field name="name">Truck Booking</field> | |||
|         <field name="model">truck.booking</field> | |||
|         <field name="report_type">qweb-pdf</field> | |||
|         <field name="report_name"> | |||
|             report.packers_and_movers_management.form_truck_booking_report | |||
|         </field> | |||
|         <field name="report_file"> | |||
|             report.packers_and_movers_management.form_truck_booking_report | |||
|         </field> | |||
|         <field name="binding_model_id" ref="model_truck_booking"/> | |||
|         <field name="binding_type">report</field> | |||
|     </record> | |||
| </odoo> | |||
| @ -0,0 +1,42 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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, models | |||
| 
 | |||
| 
 | |||
| class TruckFormReport(models.AbstractModel): | |||
|     """Class is used to print pdf report for the truck_booking module form | |||
|     view""" | |||
|     _name = 'report.packers_and_movers_management.form_truck_booking_report' | |||
| 
 | |||
|     @api.model | |||
|     def _get_report_values(self, docids, data=None): | |||
|         """Function to return values for the report, | |||
|         docids: it will provide the current id the model""" | |||
|         query = """select tb.reference_no,pr.name,fv.name as truck,gt.name as goods,tb.from_location,tb.to_location, | |||
|                 tb.distance,tb.weight,tb.unit,amount,tb.date,tb.state from truck_booking as tb | |||
|                 inner join res_partner as pr on pr.id = tb.partner_id | |||
|                 inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                 inner join goods_type as gt on gt.id = tb.goods_type_id | |||
|                 where tb.id = %d""" % docids | |||
|         self.env.cr.execute(query) | |||
|         report = self.env.cr.dictfetchall() | |||
|         return {'doc_ids': docids, 'report': report} | |||
| 
 | 
| @ -0,0 +1,20 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <data noupdate="1"> | |||
|         <record id="truck_booking_rule_company" model="ir.rule"> | |||
|             <field name="name">Truck Booking multi company rule</field> | |||
|             <field name="model_id" ref="model_truck_booking"/> | |||
|             <field name="domain_force">['|',('company_id','=',False),('company_id', 'in', company_ids)]</field> | |||
|         </record> | |||
|         <record id="goods_type_rule_company" model="ir.rule"> | |||
|             <field name="name">Goods Type multi company rule</field> | |||
|             <field name="model_id" ref="model_goods_type"/> | |||
|             <field name="domain_force">['|',('company_id','=',False),('company_id', 'in', company_ids)]</field> | |||
|         </record> | |||
|         <record id="truck_type_rule_company" model="ir.rule"> | |||
|             <field name="name">Truck Type multi company rule</field> | |||
|             <field name="model_id" ref="model_truck_type"/> | |||
|             <field name="domain_force">['|',('company_id','=',False),('company_id', 'in', company_ids)]</field> | |||
|         </record> | |||
|     </data> | |||
| </odoo> | |||
| After Width: | Height: | Size: 36 KiB | 
| After Width: | Height: | Size: 3.6 KiB | 
| After Width: | Height: | Size: 310 B | 
| After Width: | Height: | Size: 1.3 KiB | 
| After Width: | Height: | Size: 1.4 KiB | 
| After Width: | Height: | Size: 576 B | 
| After Width: | Height: | Size: 733 B | 
| After Width: | Height: | Size: 911 B | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 673 B | 
| After Width: | Height: | Size: 11 KiB | 
| After Width: | Height: | Size: 878 B | 
| After Width: | Height: | Size: 653 B | 
| After Width: | Height: | Size: 905 B | 
| After Width: | Height: | Size: 839 B | 
| After Width: | Height: | Size: 427 B | 
| After Width: | Height: | Size: 627 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 988 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 80 KiB | 
| After Width: | Height: | Size: 3.2 KiB | 
| After Width: | Height: | Size: 565 B | 
| After Width: | Height: | Size: 26 KiB | 
| After Width: | Height: | Size: 43 KiB | 
| After Width: | Height: | Size: 1.4 KiB | 
| After Width: | Height: | Size: 4.0 KiB | 
| After Width: | Height: | Size: 38 KiB | 
| After Width: | Height: | Size: 4.3 KiB | 
| After Width: | Height: | Size: 47 KiB | 
| After Width: | Height: | Size: 81 KiB | 
| After Width: | Height: | Size: 86 KiB | 
| After Width: | Height: | Size: 85 KiB | 
| After Width: | Height: | Size: 88 KiB | 
| After Width: | Height: | Size: 82 KiB | 
| After Width: | Height: | Size: 377 KiB | 
| After Width: | Height: | Size: 56 KiB | 
| After Width: | Height: | Size: 61 KiB | 
| After Width: | Height: | Size: 192 KiB | 
| After Width: | Height: | Size: 91 KiB | 
| After Width: | Height: | Size: 68 KiB | 
| After Width: | Height: | Size: 55 KiB | 
| After Width: | Height: | Size: 52 KiB | 
| After Width: | Height: | Size: 62 KiB | 
| After Width: | Height: | Size: 68 KiB | 
| After Width: | Height: | Size: 48 KiB | 
| After Width: | Height: | Size: 48 KiB | 
| After Width: | Height: | Size: 35 KiB | 
| After Width: | Height: | Size: 40 KiB | 
| After Width: | Height: | Size: 76 KiB | 
| After Width: | Height: | Size: 193 KiB | 
| After Width: | Height: | Size: 95 KiB | 
| After Width: | Height: | Size: 15 KiB | 
| @ -0,0 +1,763 @@ | |||
| <!DOCTYPE html> | |||
| <html lang="en"> | |||
| 
 | |||
| <head> | |||
|     <meta charset="UTF-8"> | |||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |||
|     <title>Odoo App 3 Index</title> | |||
|     <!-- Bootstrap CSS --> | |||
|     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css" | |||
|         integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous"> | |||
|     <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css"> | |||
|     <link rel="preconnect" href="https://fonts.googleapis.com"> | |||
|     <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> | |||
|     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap" rel="stylesheet"> | |||
| </head> | |||
| <body> | |||
|     <section> | |||
|         <div class="container" style="font-family: 'Inter', sans-serif !important;background-color: #fff !important;"> | |||
|             <div class="row"> | |||
|                 <div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between flex-wrap align-items-sm-center" | |||
|                     style="border-bottom:1px solid rgba(0, 0, 0, 0.22)"> | |||
|                     <div class="my-3"> | |||
|                         <img src="assets/misc/Cybrosys R.png" style="width:auto !important; height:40px !important"> | |||
|                     </div> | |||
|                     <div class="my-3 d-flex align-items-center"> | |||
|                         <div class="text-center" | |||
|                             style="background-color:#017E84 !important;font-size: 0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> | |||
|                             Community | |||
|                         </div> | |||
|                         <div class="text-center" | |||
|                             style="background-color:#875A7B !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important;min-width: 120px !important;"> | |||
|                             Enterprise | |||
|                         </div> | |||
|                         <div class="text-center" | |||
|                             style="background-color:#7C7BAD !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;"> | |||
|                             Odoo.sh | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="row"> | |||
|                 <div class="col-sm-12 col-md-12 col-lg-12 text-center d-flex align-items-center flex-column" | |||
|                     style="margin: 80px 0px !important;"> | |||
|                     <h1 style="font-size: 2.8rem;font-weight: 700; color:  | |||
|                     #1A202C;"> | |||
|                          Packers & Movers Management</h1> | |||
|                     <p class="my-3 mb-4" | |||
|                         style="max-width: 80%; font-weight: 400 !important; line-height: 32px; color: #718096;"> | |||
|                         Detailed Packers & Movers Management View. | |||
|                     </p> | |||
|                     <div style="width: 80%; margin-top: 3rem;"> | |||
|                         <img src="assets/screenshots/hero-v17.gif" class="img-responsive" width="100%" height="auto"> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container mt-5 mb-5"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> | |||
|                     <p class="m-0" style="font-weight: 600; font-size: 24px; color:#714b67 !important">Key Highlights | |||
|                     </p> | |||
|                 </div> | |||
|                 <div class="row py-4"> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0;"> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Dedicated Website Views for Users</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0;"> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Users can Easily Book Truck</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0;"> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Truck Type and Goods Menu in Website</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0; "> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Distance/KM Amount can set in Configuration Settings</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0; "> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Dashboard View</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 col-sm-12 p-3"> | |||
|                         <div class="d-flex   h-100" style="padding: 30px;border-radius: 12px; | |||
|                                     background: #FFF; | |||
|                                     box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); "> | |||
|                             <div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67; | |||
|                                     display: flex; justify-content: center; align-items: center; | |||
|                                     margin-right: 10px; flex-shrink: 0; "> | |||
|                                 <i class="fa-solid fa-star  " style="color: #fff;font-size:14px;"></i> | |||
|                             </div> | |||
|                             <div> | |||
|                                 <p style="color: #1A202C;font-weight: 600;  | |||
|                                       font-size: 1.2rem; margin-bottom: 2px;">Print PDF Report</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container rounded" > | |||
|                 <ul class="nav nav-tabs d-flex" style="width: fit-content;margin: 0 auto;gap: 1rem;"> | |||
|                     <li class="col text-center py-2 text-nowrap " | |||
|                         style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a | |||
|                             class="active show" data-toggle="tab" href="#tab1" | |||
|                             style="color: #fff;font-weight: 500; background-color: #714B67; text-decoration: none;"> | |||
|                             <i class="fa-regular fa-image  pr-2" style="color: #fff;"></i> | |||
|                             Screenshots</a></li> | |||
|                     <li class="col text-center py-2 text-nowrap " | |||
|                         style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a | |||
|                             data-toggle="tab" href="#tab2" | |||
|                             style="color: #fff;font-weight: 500;  text-decoration: none;"><i | |||
|                                 class="fa-solid fa-star  pr-2" style="color: #fff;"></i>Features</a></li> | |||
|                     <li class="col text-center py-2 text-nowrap " | |||
|                         style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;"><a | |||
|                             data-toggle="tab" href="#tab3" | |||
|                             style="color: #fff;font-weight: 500; text-decoration: none; background-color: #714B67;"><i | |||
|                                 class="fa-solid fa-book-open  pr-2" style="color: #fff;"></i>Released Notes</a></li> | |||
|                 </ul> | |||
|                 <div class="tab-content" style="background-color: rgba(121, 113, 119, 0.04);"> | |||
|                     <div id="tab1" class="tab-pane fade in active show"> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/1.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Dashboard view with filtration.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/2.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         In Configuration Settings you can set the amount per KM, and if you have any extra amount you can add in extra amount field.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/3.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Truck Booking Tree view.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/4.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Truck Booking Form view.</h4> | |||
|                                         <p style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> | |||
|                                             Add the Customer name and the pickup city and the drop city. then automatically calculate the distance and amount. set the date, truck, goods type and weight, and it's unit. | |||
|                                         </p> | |||
|                                 </div> | |||
|                             </div> | |||
|                              | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/5.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Create Goods Type.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/6.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Create Truck Type.</h4> | |||
|                                         <p style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> | |||
|                                             Add truck type and length, width and height of the container. | |||
|                                         </p> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/8.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Create Truck.</h4> | |||
|                                         <p style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> | |||
|                                             Create model in fleet module and set vehicle type truck. And in information page set truck type.                                        </p> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/10.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Print PDF report.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
| 
 | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/11.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         PDF Report.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/13.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/14.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Truck Booking Form.</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                             </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/15.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Truck Type Menu</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-12 py-2" style="padding: 1rem 4rem !important;"> | |||
|                             <div | |||
|                                 style="border: 1px solid #d8d6d6; border-radius: 4px;  background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="row justify-content-center p-3 w-100 m-0"> | |||
|                                     <img src="assets/screenshots/16.png" class="img-responsive" width="100%" height="auto"> | |||
|                                 </div> | |||
|                                 <div class="px-3"> | |||
|                                     <h4 class="mt-2" | |||
|                                         style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important"> | |||
|                                         Goods Type Menu</h4> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div id="tab2" class="tab-pane fade"> | |||
|                         <div class="col-mg-12" style="padding: 1rem 4rem;"> | |||
|                             <ul style="list-style: none; padding: 1rem 0;font-weight: 500;"> | |||
|                                 <li class="py-3" | |||
|                                     style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                     <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                             width="16px"></span>Dedicated Website Views for Users                                             | |||
|                                 </li> | |||
|                                 <li class="py-3" | |||
|                                     style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                     <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                             width="16px"></span>Users can Easily Book Truck                                             | |||
|                                 </li> | |||
|                                 <li class="py-3" | |||
|                                     style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                     <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                             width="16px"></span>Truck Type and Goods Menu in Website | |||
|                                              | |||
|                                 </li> | |||
|                                 <li class="py-3" | |||
|                                 style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                         width="16px"></span>Distance/KM Amount can set in Configuration Settings | |||
|                                          | |||
|                                  </li> | |||
|                             <li class="py-3" | |||
|                             style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                             <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                     width="16px"></span>Dashboard View | |||
|                                      | |||
|                         </li> | |||
|                         <li class="py-3" | |||
|                         style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                         <span style="margin-right: 12px;"><img src="assets/misc/star (1) 2.svg" alt="" | |||
|                                 width="16px"></span>Print PDF Report | |||
| 
 | |||
| 
 | |||
|                                  | |||
|                     </li> | |||
| 
 | |||
|                             </ul> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div id="tab3" class="tab-pane fade"> | |||
|                         <div class="col-mg-12 active" style="padding: 1rem 4rem;"> | |||
|                             <div class="py-3" | |||
|                                 style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);"> | |||
|                                 <div class="d-flex mb-3" style="font-size: 0.8rem; font-weight: 500;"><span>Version | |||
|                                         17.0.1.0.0</span><span class="px-2">|</span><span | |||
|                                         style="color: #714B67;font-weight: 600;">Released on:25th May 2023</span> | |||
|                                 </div> | |||
|                                 <p class="m-0" | |||
|                                     style=" color:#718096!important; font-size:1rem !important;line-height: 28px;"> | |||
| 
 | |||
|                                     Initial Commit for Packers & Movers Management.</p> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container mt-5"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> | |||
|                     <p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Related Products</p> | |||
|                 </div> | |||
|             </div> | |||
|             <div id="myCarousel" class="carousel slide py-3" data-ride="carousel"> | |||
|                 <div class="carousel-inner"> | |||
|                     <div class="carousel-item active"> | |||
|                         <div class="row p-4"> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/project_dashboard_odoo/" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px; "> | |||
|                                                 <img src="assets/modules/1.png" alt="" width="100%" height="auto"> | |||
| 
 | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">Project Dashboard                                            </p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/odoo_parking_management/" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px; "> | |||
|                                                 <img src="assets/modules/2.jpg" alt="" width="100%" height="auto"> | |||
| 
 | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">Parking Management                                            </p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/gym_mgmt_system/#" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px; "> | |||
|                                                 <img src="assets/modules/3.jpg" alt="" width="100%" height="auto"> | |||
| 
 | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">GYM Management System                                            </p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="carousel-item"> | |||
|                         <div class="row p-4"> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/legal_case_management/" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px; "> | |||
|                                                 <img src="assets/modules/4.jpg" alt="" width="100%" height="auto"> | |||
| 
 | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">Legal Case Management                                            </p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/mobile_service_shop/" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px;"> | |||
|                                                 <img src="assets/modules/5.jpg" alt="" width="100%" height="auto"> | |||
| 
 | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">BOM Multiple Product Selection</p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col"> | |||
|                                 <div class="p-3"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/17.0/kanban_fixed_header/" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border:1px solid #CBCBCB !important;border-radius: 4px;"> | |||
|                                             <div style="width: 300px;"> | |||
|                                                 <img src="assets/modules/6.jpg" alt="" width="100%" height="auto"> | |||
|                                             </div> | |||
|                                             <p class="text-center pt-2 text-black font-weight-bold">Kanban Fixed Header | |||
|                                             </p> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|                 <a class="carousel-control-prev" href="#myCarousel" data-slide="prev" style="width: 35px; color: #000;"> | |||
|                     <span class="carousel-control-prev-icon"> | |||
|                         <i class="fa fa-chevron-left" style="font-size: 24px;"></i> | |||
|                     </span> | |||
|                 </a> | |||
|                 <a class="carousel-control-next" href="#myCarousel" data-slide="next" style="width: 35px; color: #000;"> | |||
|                     <span class="carousel-control-next-icon"> | |||
|                         <i class="fa fa-chevron-right" style="font-size: 24px;"></i> | |||
|                     </span> | |||
|                 </a> | |||
|             </div> | |||
|             <div class="container mt-5"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> | |||
|                     <p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Services</p> | |||
| 
 | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container my-5"> | |||
|                 <div class="row py-3"> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#13EA36 ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/cogs.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Customization</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#DBC711; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/wrench.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#FF6B6B ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/lifebuoy.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Support</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#FFA801 ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/user.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Hire Odoo Developer</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;"> | |||
| 
 | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#54A0FF; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/puzzle.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Integration</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#6D7680 ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/update.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Migration</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#786FA6 ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/consultation.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Consultancy</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#F8A5C2 ; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/training.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Implementation</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-4 col-sm-6 px-4 py-4"> | |||
|                         <div | |||
|                             style="background-color: #fff; padding: 25px; text-align: center;  box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;"> | |||
|                             <div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);"> | |||
|                                 <div style="background-color:#E6BE26; border-radius: 50%; padding: 15px;    width: 68px; | |||
|                                     height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);"> | |||
|                                     <img src="assets/icons/license.png" alt="service-icon" width="38px" height="auto"> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <p style="margin-top: 20px; font-weight: bold;">Odoo Licensing Consultancy</p> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container mt-5"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4"> | |||
|                     <p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Our Industries</p> | |||
| 
 | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container"> | |||
|                 <div class="row my-5 py-4"> | |||
|                     <div class="col-md-3 col-sm-6 p-0"> | |||
|                         <div class="d-flex flex-column h-100 " | |||
|                             style="border-right: 1px solid rgb(209, 209, 209); border-bottom: 1px solid  rgb(209, 209, 209); padding: 30px; box-shadow: 6px 0 10px rgba(228, 227, 227, 0.373);"> | |||
|                             <img src="assets/icons/trading-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                            font-size: 1.2rem; margin-bottom: 2px;">Trading</p> | |||
|                             <p>Easily procure and sell your products</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6  p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid  rgb(209, 209, 209); padding: 30px;"> | |||
|                             <img src="assets/icons/pos-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">POS</p> | |||
|                             <p>Easy configuration and convivial experience</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6  p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-right: 1px solid  rgb(209, 209, 209);border-bottom: 1px solid   rgba(0, 0, 0, 0.2); padding: 30px; box-shadow: 0 5px 10px  rgba(228, 227, 227, 0.373)"> | |||
|                             <img src="assets/icons/education-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">Education</p> | |||
|                             <p>A platform for educational management</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6  p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-bottom: 1px solid  rgb(209, 209, 209); padding: 30px; "> | |||
|                             <img src="assets/icons/manufacturing-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">Manufacturing</p> | |||
|                             <p>Plan, track and schedule your operations</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6 p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-right: 1px solid  rgb(209, 209, 209); padding: 30px;"> | |||
|                             <img src="assets/icons/ecom-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">E-commerce & Website</p> | |||
|                             <p>Mobile friendly, awe-inspiring product pages</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6   p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-right: 1px solid  rgb(209, 209, 209); padding: 30px;box-shadow: 0 -5px 10px  rgba(228, 227, 227, 0.373);"> | |||
|                             <img src="assets/icons/service-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">Service Management</p> | |||
|                             <p>Keep track of services and invoice</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6    p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style="border-right: 1px solid  rgb(209, 209, 209); padding: 30px; "> | |||
|                             <img src="assets/icons/restaurant-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">Restaurant</p> | |||
|                             <p>Run your bar or restaurant methodically</p> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-3 col-sm-6   p-0"> | |||
|                         <div class="d-flex flex-column h-100" | |||
|                             style=" padding: 30px;box-shadow: -5px 0 10px  rgba(228, 227, 227, 0.373);"> | |||
|                             <img src="assets/icons/hotel-black.png" width="42px" height="auto" alt=""> | |||
|                             <p style="color: #714B67;font-weight: 600; margin-top: 10px; | |||
|                             font-size: 1.2rem; margin-bottom: 2px;">Hotel Management</p> | |||
|                             <p>An all-inclusive hotel management application</p> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container mt-5"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5"> | |||
|                     <p class="m-0" style="font-weight: 600; font-size: 24px; color:#000 !important">Support</p> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="container my-5"> | |||
|                 <div class="row" style="background-color: #FFFAFE;"> | |||
|                     <div class="col-md-6 pb-4  d-flex align-items-center justify-content-center" | |||
|                         style="border-right: 1px solid #D9D9D9;"> | |||
|                         <div style="padding: 30px;"> | |||
|                             <div class="d-flex align-items-center"> | |||
|                                 <img src="assets/misc/support (1) 1.svg" alt="" width="60px" style="margin-right: 12px;"> | |||
|                                 <div style="padding: 0px 8px;"> | |||
|                                     <span | |||
|                                         style="color: #714B67;font-size: 24px;font-weight: 600;padding-bottom: 1rem;">Need | |||
|                                         Help?</span> | |||
|                                     <p class="m-0" style="color:#718096;">Got questions or need help? Get in touch.</p> | |||
|                                     <div style="font-weight: 400;"><span><img src="assets/misc/support-email.svg" alt="" | |||
|                                                 width="18px" | |||
|                                                 style="filter: invert(1);margin-right: 0.8rem;"></span>odoo@cybrosys.com | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="col-md-6 pb-4 d-flex align-items-center justify-content-center"> | |||
|                         <div style="padding: 30px;"> | |||
|                             <div class="d-flex align-items-center"> | |||
|                                 <img src="assets/misc/whatsapp 1.svg" alt="" width="60px" style="margin-right: 12px;"> | |||
|                                 <div> | |||
|                                     <span style="color: #714B67;font-size: 24px;font-weight: 600;">WhatsApp</span> | |||
|                                     <p class="m-0" style="color:#718096;">Say hi to us on WhatsApp!</p> | |||
|                                     <div style="font-weight: 400; font-size: 16px;"><span><img src="assets/misc/phone.svg" | |||
|                                                 alt="" width="14px" | |||
|                                                 style="filter: invert(1); margin-right: 0.8rem;"></span>+91 | |||
|                                         99456767686</div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|         </div> | |||
|     </section> | |||
|     <!-- Optional JavaScript --> | |||
|     <!-- jQuery first, then Popper.js, then Bootstrap JS --> | |||
|     <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> | |||
|     <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> | |||
| </body> | |||
| </html> | |||
| @ -0,0 +1,102 @@ | |||
| 
 | |||
| .o_action_manager { | |||
|     overflow: auto !important; | |||
| } | |||
| 
 | |||
| .help_dashboards { | |||
|     padding-top: 10px; | |||
|     background-color: #f8faff !important; | |||
| } | |||
| 
 | |||
| .dashboard_card h4 { | |||
| font-size: 21px; | |||
| } | |||
| 
 | |||
| .main-section { | |||
|     margin-left: 6px; | |||
| } | |||
| 
 | |||
| .breadcrumbs { | |||
|     margin-top: 0; | |||
| } | |||
| 
 | |||
| /*    Widget One | |||
| ---------------------------*/ | |||
| .stat-content { | |||
|     display: inline-block; | |||
|     width: 66%; | |||
| } | |||
| 
 | |||
| .stat-icon { | |||
|     display: inline-block; | |||
| } | |||
| 
 | |||
| .stat-widget-one .stat-icon { | |||
|     vertical-align: top; | |||
|     margin: auto; | |||
|     width: 100%; | |||
|     color: #01c490; | |||
| } | |||
| 
 | |||
| .stat-widget-one .stat-text { | |||
|     font-size: 11px; | |||
|     color: #868e96; | |||
|     font-weight: bold; | |||
| } | |||
| 
 | |||
| .stat-widget-one .stat-digit { | |||
|     font-size: 24px; | |||
|     color: #02448b; | |||
| } | |||
| 
 | |||
| /*=====================Dashboard===========================*/ | |||
| 
 | |||
| .customer{ | |||
| margin-top: 15px; | |||
| backgroud: #fff; | |||
| transition: transform 0.2s ease, box-shadow 0.2s ease; | |||
| will-change: transform, box-shadow; | |||
| box-shadow: 0 10px 40px 0 rgba(62,57,107,0.07), 0 2px 9px 0 rgba(62,57,107,0.06); | |||
| height: 316px; | |||
| overflow-y: auto; | |||
| margin-bottom: 15px; | |||
| border-radius:10px; | |||
| } | |||
| 
 | |||
| .customer_head{ | |||
| font-size: 17px; | |||
| padding: 12px; | |||
| color: #7d7eaf; | |||
| background-color: #e5e5ef; | |||
| } | |||
| .padding{ | |||
| margin-bottom:75px; | |||
| } | |||
| .graph{ | |||
| padding: 10px; | |||
| box-shadow: 0 10px 40px 0 rgba(62,57,107,0.07), 0 2px 9px 0 rgba(62,57,107,0.06); | |||
| background: #fff; | |||
| margin-bottom: 15px; | |||
| border-radius:15px; | |||
| } | |||
| .left{ | |||
|     margin-top: -740px; | |||
|     margin-left: 800px; | |||
| } | |||
| .circle{ | |||
| border-radius: 50%; | |||
| border-color:#fff; | |||
|     padding: 10px; | |||
|     color: #7d7eaf; | |||
|     background-color: #e5e5ef; | |||
|     font: 20px arial, sans-serif; | |||
|     height: 44px; | |||
|     width: 44px; | |||
|     text-align:center; | |||
|     margin:auto; | |||
| } | |||
| .head{ | |||
| font-size: 18px; | |||
| color: #7d7eaf; | |||
| font-family: cursive; | |||
| } | |||
| @ -0,0 +1,125 @@ | |||
| #loader{ | |||
| height:137px; | |||
| width:131px; | |||
| margin-top:-42px; | |||
| margin-left:143px; | |||
| margin-bottom:-66px; | |||
| background-image:url("/packers_and_movers_management/static/src/img/loader2.gif"); | |||
| background-repeat:no-repeat; | |||
| background-size:cover; | |||
| } | |||
| .head{ | |||
| margin-top:25px; | |||
| margin-left:20px; | |||
| } | |||
| .image{ | |||
| background-image:url("/packers_and_movers_management/static/src/img/order_track.jpg"); | |||
| background-size:cover; | |||
| height:300px; | |||
| width:600px; | |||
| margin-left:-20px; | |||
| } | |||
| h1{ | |||
| color:gray; | |||
| font-family:"Lucida consol","Courier Nem",monospace; | |||
| } | |||
| .body{ | |||
| margin-top:-365px; | |||
| margin-left:875px; | |||
| margin-bottom:10px; | |||
| } | |||
| .select{ | |||
| position:relative; | |||
| } | |||
| .unit{ | |||
| position:absolute; | |||
| right:145px; | |||
| top:0; | |||
| height: 50px; | |||
| border-color:#ed8115; | |||
| } | |||
| .link-style{ | |||
| width:500px; | |||
| height:50px; | |||
| border-color:#ed8115; | |||
| } | |||
| .button{ | |||
| width:500px; | |||
| height:50px; | |||
| background-color:#ed8115; | |||
| color:white; | |||
| border-color:#ed8115; | |||
| } | |||
| .input{ | |||
| width:500px; | |||
| height:50px; | |||
| border-color:#ed8115; | |||
| } | |||
| table{ | |||
| border-collapse:collapse; | |||
| width:100%; | |||
| } | |||
| th,td{ | |||
| text_align:left; | |||
| padding:8px; | |||
| border: 1px solid white; | |||
| } | |||
| thead{ | |||
| background-color:#ed8115; | |||
| color:#fcfcfc; | |||
| } | |||
| tr:nth-child(even){ | |||
| background-color:#a9aaab; | |||
| } | |||
| .success{ | |||
| font-size:20px; | |||
| color:white; | |||
| text-align:center; | |||
| background-color:#ed8115; | |||
| height:75px; | |||
| padding:15px; | |||
| margin-bottom:10px; | |||
| } | |||
| .link{ | |||
| color:#ed8115; | |||
| } | |||
| .form-group{ | |||
| padding-bottom:10px; | |||
| padding-top:10px; | |||
| } | |||
| .wrap{ | |||
| min-height: 450px; | |||
| overflow:auto; | |||
| } | |||
| 
 | |||
| @media(max-width:790px){ | |||
| 
 | |||
| .head{ | |||
| margin-top:15px; | |||
| margin-left:11px; | |||
| } | |||
| .image{ | |||
| height:190px; | |||
| width:360px; | |||
| margin-left:-21px; | |||
| } | |||
| .body{ | |||
| margin-top:25px; | |||
| margin-left:2px; | |||
| } | |||
| .input{ | |||
| width:332px; | |||
| } | |||
| .button{ | |||
| width:332px; | |||
| } | |||
| .link-style{ | |||
| width:332px; | |||
| } | |||
| .unit{ | |||
| right:-7px; | |||
| } | |||
| #loader{ | |||
| margin-left:64px; | |||
| } | |||
| } | |||
| After Width: | Height: | Size: 174 KiB | 
| After Width: | Height: | Size: 89 KiB | 
| @ -0,0 +1,841 @@ | |||
| /** @odoo-module */ | |||
| import { registry} from '@web/core/registry'; | |||
| import { loadBundle } from "@web/core/assets"; | |||
| import { useService } from "@web/core/utils/hooks"; | |||
| const { Component, onWillStart, onMounted} = owl | |||
| import { jsonrpc } from "@web/core/network/rpc_service"; | |||
| import { _t } from "@web/core/l10n/translation"; | |||
| const { useRef } = owl; | |||
| 
 | |||
| export class PackersManagement extends Component { | |||
|         setup() { | |||
|               this.booking = useRef('BookingCanvas') | |||
|               this.truckAnalysis = useRef('CanvasTruck') | |||
|               this.distance = useRef('CanvasDistance') | |||
|               this.truckDistance = useRef('TruckDistance') | |||
|               this.CustWeight = useRef('CustomerWeight') | |||
|               this.TruckWeight = useRef('TruckWeight') | |||
|               this.Total = useRef('Total') | |||
|               this.TotalTwo = useRef('Total_two') | |||
|               this.TotalThree = useRef('Total_three') | |||
|               this.TotalFour = useRef('Total_four') | |||
|               this.BookingYear = useRef('BookingThisYear') | |||
|               this.BookingDay = useRef('BookingThisDay') | |||
|               this.BookingMonth = useRef('BookingThisMonth') | |||
|               this.BookingWeek = useRef('BookingThisWeek') | |||
|               this.DistanceYear = useRef('DistanceThisYear') | |||
|               this.DistanceMonth = useRef('DistanceThisMonth') | |||
|               this.DistanceDay = useRef('DistanceThisDay') | |||
|               this.DistanceWeek = useRef('DistanceThisWeek') | |||
|               this.InvoiceYear = useRef('InvoiceThisYear') | |||
|               this.InvoiceMonth = useRef('InvoiceThisMonth') | |||
|               this.InvoiceDay = useRef('InvoiceThisDay') | |||
|               this.InvoiceWeek = useRef('InvoiceThisWeek') | |||
|               this.AmountYear = useRef('AmountThisYear') | |||
|               this.AmountDay = useRef('AmountThisDay') | |||
|               this.AmountMonth = useRef('AmountThisMonth') | |||
|               this.AmountWeek = useRef('AmountThisWeek') | |||
|               this.action = useService('action') | |||
|             onWillStart(async () => await this.onWillStart()); | |||
|             onMounted(() => { | |||
|             this.onclick_this_month('month') | |||
| 
 | |||
|         }); | |||
|         } | |||
| 
 | |||
| 	stock_selection(e){ | |||
|         e.stopPropagation(); | |||
|         var value = $(e.target).val(); | |||
|         if (value=="year"){ | |||
|             this.onclick_this_year(value); | |||
|         }else if (value=="day"){ | |||
|             this.onclick_this_day(value); | |||
|         }else if (value=="month"){ | |||
|             this.onclick_this_month(value); | |||
|         }else if (value=="week"){ | |||
|             this.onclick_this_week(value); | |||
|         } | |||
|         } | |||
| 
 | |||
| 
 | |||
|        async onWillStart() {// returns the function fetch_data when page load.
 | |||
|        var self = this; | |||
|        return $.when(loadBundle(this)).then(function() { | |||
|            return self.fetch_data() | |||
|            ; | |||
|             }); | |||
|         } | |||
| 
 | |||
|        fetch_data() {//function to call rpc query to fetch data fom python
 | |||
|        self = this; | |||
|        var def1 =  jsonrpc('/web/dataset/call_kw/truck.booking/get_total_booking',{ | |||
|            model: 'truck.booking', | |||
|            method: 'get_total_booking', | |||
|            args:{}, | |||
|            kwargs:{} | |||
|        }).then(function(result) | |||
|         { | |||
|           self.booking_count = result.total_booking, | |||
|           self.distance_count = result.total_distance_count, | |||
|           self.total_invoice = result.total_invoice | |||
|           self.total_amount = result.total_amount | |||
|         }); | |||
|        var def2 =  jsonrpc('/web/dataset/call_kw/truck.booking/get_top_truck',{ | |||
|            model: 'truck.booking', | |||
|            method: 'get_top_truck', | |||
|            args:{}, | |||
|            kwargs:{} | |||
|        }).then(function(result) | |||
|         { | |||
|         self.truck = result['truck'] | |||
|         self.customer = result['customer'] | |||
|         self.upcoming = result['upcoming'] | |||
|    }); | |||
|        return $.when(def1,def2); | |||
|    } | |||
| 
 | |||
|        render_booking (){//Function to add booking chart on the basis of customer
 | |||
|         self = this; | |||
|         jsonrpc('/web/dataset/call_kw/truck.booking/get_booking_analysis',{ | |||
|             model: "truck.booking", | |||
|             method: "get_booking_analysis", | |||
|             args:{}, | |||
|            kwargs:{} | |||
|         }).then(function (result) { | |||
|             new Chart(self.booking.el, { | |||
|                 type: 'bar', | |||
|                 data: { | |||
|                     labels: result.name, | |||
|                     datasets: [{ | |||
|                         label: 'Count', | |||
|                         data: result.count, | |||
|                         backgroundColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         borderColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, | |||
|                         type: 'bar', | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, | |||
|                 } | |||
|             }); | |||
|         }); | |||
|     } | |||
| 
 | |||
|     render_weight(){//Function to add total goods weight chart on the basis of customer and truck
 | |||
|         jsonrpc('/web/dataset/call_kw/truck.booking/get_weight',{ | |||
|             model: "truck.booking", | |||
|             method: "get_weight", | |||
|            args:{}, | |||
|            kwargs:{} | |||
|         }).then(function (result) { | |||
|              new Chart(self.CustWeight.el, { | |||
|                         type: 'line', | |||
|                     data: { | |||
|                         labels: result.cust,//x axis
 | |||
|                         datasets: [{ | |||
|                             label: 'count', // Name the series
 | |||
|                             data: result.cust_sum, // Specify the data values array
 | |||
|                             backgroundColor: '#003f5c', | |||
|                             borderColor: '#003f5c', | |||
|                             barPercentage: 0.5, | |||
|                             barThickness: 6, | |||
|                             maxBarThickness: 8, | |||
|                             minBarLength: 0, | |||
|                             borderWidth: 1, // Specify bar border width
 | |||
|                             type: 'line', // Set this data to a line chart
 | |||
|                             fill: false | |||
|                         }] | |||
|                     }, | |||
|                     options: { | |||
|                         scales: { | |||
|                             y: { | |||
|                                 beginAtZero: true | |||
|                             }, | |||
|                         }, | |||
|                         responsive: true, // Instruct chart js to respond nicely.
 | |||
|                         maintainAspectRatio: false, // Add to prevent default behaviour of full-width/height
 | |||
|                     } | |||
|                     }); | |||
|              new Chart(self.CustWeight.el, { | |||
|                 type: 'bar', | |||
|                 data: { | |||
|                     labels: result.truck_name, | |||
|                     datasets: [{ | |||
|                         label: 'Count', | |||
|                         data: result.truck_sum, | |||
|                         backgroundColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
| 
 | |||
|                         ], | |||
|                         borderColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, | |||
|                         type: 'bar', | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, | |||
|                     maintainAspectRatio: false, | |||
|                 } | |||
|             }); | |||
| 
 | |||
|         }); | |||
|     } | |||
| 
 | |||
|     render_truck(){//Function to add booking chart on the basis of truck
 | |||
|         jsonrpc('/web/dataset/call_kw/truck.booking/get_truck_analysis',{ | |||
|             model: "truck.booking", | |||
|             method: "get_truck_analysis", | |||
|             args:{}, | |||
|             kwargs:{} | |||
|         }).then(function (result) { | |||
|             new Chart(self.truckAnalysis.el, { | |||
|                 type: 'doughnut', | |||
|                 data: { | |||
|                     labels: result.name, | |||
|                     datasets: [{ | |||
|                         label: 'Count', | |||
|                         data: result.count, | |||
|                         backgroundColor: [ | |||
|                             "#665191", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#d45087", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF", | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                         ], | |||
|                         borderColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, | |||
|                         type: 'pie', | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, | |||
|                 } | |||
|             }); | |||
|         }); | |||
|     } | |||
| 
 | |||
|     render_distance(){//Function to add total distance chart on the basis of customer and truck
 | |||
|     jsonrpc('/web/dataset/call_kw/truck.booking/get_distance',{ | |||
|         model: "truck.booking", | |||
|         method: "get_distance", | |||
|         args:{}, | |||
|         kwargs:{} | |||
|     }).then(function (result) { | |||
|         new Chart(self.distance.el, { | |||
|             type: 'doughnut', | |||
|             data: { | |||
|                 labels: result.cust, | |||
|                 datasets: [{ | |||
|                     label: 'Count', | |||
|                     data: result.cust_sum, | |||
|                     backgroundColor: [ | |||
|                         "#665191", | |||
|                         "#ff7c43", | |||
|                         "#ffa600", | |||
|                         "#d45087", | |||
|                         "#a05195", | |||
|                         "#6d5c16", | |||
|                         "#CCCCFF", | |||
|                         "#003f5c", | |||
|                         "#2f4b7c", | |||
|                         "#f95d6a", | |||
|                     ], | |||
|                     borderColor: [ | |||
|                         "#003f5c", | |||
|                         "#2f4b7c", | |||
|                         "#f95d6a", | |||
|                         "#665191", | |||
|                         "#d45087", | |||
|                         "#ff7c43", | |||
|                         "#ffa600", | |||
|                         "#a05195", | |||
|                         "#6d5c16", | |||
|                         "#CCCCFF" | |||
|                     ], | |||
|                     barPercentage: 0.5, | |||
|                     barThickness: 6, | |||
|                     maxBarThickness: 8, | |||
|                     minBarLength: 0, | |||
|                     borderWidth: 1, | |||
|                     type: 'pie', | |||
|                     fill: false | |||
|                 }] | |||
|             }, | |||
|             options: { | |||
|                 scales: { | |||
|                     y: { | |||
|                         beginAtZero: true | |||
|                     }, | |||
|                 }, | |||
|                 responsive: true, | |||
|             } | |||
|         }); | |||
|         new Chart(self.truckDistance.el, { | |||
|                     type: 'line', | |||
|                 data: { | |||
|                     labels: result.truck_name,//x axis
 | |||
|                     datasets: [{ | |||
|                         label: 'count', // Name the series
 | |||
|                         data: result.truck_sum, // Specify the data values array
 | |||
|                         backgroundColor: '#003f5c', | |||
|                         borderColor: '#003f5c', | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, // Specify bar border width
 | |||
|                         type: 'line', // Set this data to a line chart
 | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, // Instruct chart js to respond nicely.
 | |||
|                 } | |||
|                 }); | |||
|         }); | |||
|     } | |||
| 
 | |||
|     onclick_this_week (ev) {//Function shows week filtered dashboard.
 | |||
|             self = this; | |||
|             jsonrpc('/web/dataset/call_kw/truck.booking/get_select_filter',{ | |||
|                model: 'truck.booking', | |||
|                 method: 'get_select_filter', | |||
|                 args: [ev], | |||
|                 kwargs:{} | |||
|             }) | |||
|             .then(function (result) { | |||
|                 $('.total').hide(); | |||
|                 $('#booking_this_month').hide(); | |||
|                 $('#distance_this_month').hide(); | |||
|                 $('#amount_this_month').hide(); | |||
|                 $('#invoice_this_month').hide(); | |||
|                 $('#booking_this_year').hide(); | |||
|                 $('#distance_this_year').hide(); | |||
|                 $('#amount_this_year').hide(); | |||
|                 $('#invoice_this_year').hide(); | |||
|                 $('#booking_this_day').hide(); | |||
|                 $('#distance_this_day').hide(); | |||
|                 $('#amount_this_day').hide(); | |||
|                 $('#invoice_this_day').hide(); | |||
|                 $('#booking_this_week').show(); | |||
|                 $('#distance_this_week').show(); | |||
|                 $('#amount_this_week').show(); | |||
|                 $('#invoice_this_week').show(); | |||
|                 $(self.BookingWeek.el).empty(); | |||
|                 $(self.DistanceWeek.el).empty(); | |||
|                 $(self.InvoiceWeek.el).empty(); | |||
|                 $(self.AmountWeek.el).empty(); | |||
|                 $(self.BookingWeek.el).append('<span>' + result['booking'][0]['count'] + '</span>'); | |||
|                 $(self.DistanceWeek.el).append('<span>' + (result['distance'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.AmountWeek.el).append('<span>' + (result['amount'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.InvoiceWeek.el).append('<span>' + (result['invoice'][0]['sum'] || 0) + '</span>'); | |||
|                 self.get_cust_invoice(result); | |||
|                 self.get_truck_invoice(result); | |||
|                 self.get_cust_distance(result); | |||
|                 self.get_truc_distance(result); | |||
|                 self.get_cust_weight(result); | |||
|                 self.get_truck_weight(result); | |||
|             }) | |||
|         } | |||
| 
 | |||
|     onclick_this_day(ev) {//Function shows day filtered dashboard.
 | |||
|             self = this; | |||
|             jsonrpc('/web/dataset/call_kw/truck.booking/get_select_filter',{ | |||
|                model: 'truck.booking', | |||
|                 method: 'get_select_filter', | |||
|                 args: [ev], | |||
|                 kwargs:{} | |||
|             }) | |||
|             .then(function (result) { | |||
|                 $('.total').hide(); | |||
|                 $('#booking_this_month').hide(); | |||
|                 $('#distance_this_month').hide(); | |||
|                 $('#amount_this_month').hide(); | |||
|                 $('#invoice_this_month').hide(); | |||
|                 $('#booking_this_week').hide(); | |||
|                 $('#distance_this_week').hide(); | |||
|                 $('#amount_this_week').hide(); | |||
|                 $('#invoice_this_week').hide(); | |||
|                 $('#booking_this_year').hide(); | |||
|                 $('#distance_this_year').hide(); | |||
|                 $('#amount_this_year').hide(); | |||
|                 $('#invoice_this_year').hide(); | |||
|                 $('#booking_this_day').show(); | |||
|                 $('#distance_this_day').show(); | |||
|                 $('#amount_this_day').show(); | |||
|                 $('#invoice_this_day').show(); | |||
|                 $(self.BookingDay.el).empty(); | |||
|                 $(self.DistanceDay.el).empty(); | |||
|                 $(self.AmountDay.el).empty(); | |||
|                 $(self.InvoiceDay.el).empty(); | |||
|                 $(self.BookingDay.el).append('<span>' + result['booking'][0]['count'] + '</span>'); | |||
|                 $(self.DistanceDay.el).append('<span>' + (result['distance'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.AmountDay.el).append('<span>' + (result['amount'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.InvoiceDay.el).append('<span>' + (result['invoice'][0]['sum'] || 0)+ '</span>'); | |||
|                 self.get_cust_invoice(result); | |||
|                 self.get_truck_invoice(result); | |||
|                 self.get_cust_distance(result); | |||
|                 self.get_truc_distance(result); | |||
|                 self.get_cust_weight(result); | |||
|                 self.get_truck_weight(result); | |||
|             }) | |||
|         } | |||
| 
 | |||
|     onclick_this_year(ev) {//Function shows a year filtered dashboard
 | |||
|             self = this; | |||
|             jsonrpc('/web/dataset/call_kw/truck.booking/get_select_filter',{ | |||
|                 model: 'truck.booking', | |||
|                 method: 'get_select_filter', | |||
|                 args: [ev], | |||
|                 kwargs:{} | |||
|             }) | |||
|             .then(function (result) { | |||
|                 $('#booking_this_day').hide(); | |||
|                 $('#distance_this_day').hide(); | |||
|                 $('#amount_this_day').hide(); | |||
|                 $('#invoice_this_day').hide(); | |||
|                 $('#booking_this_month').hide(); | |||
|                 $('#distance_this_month').hide(); | |||
|                 $('#amount_this_month').hide(); | |||
|                 $('#invoice_this_month').hide(); | |||
|                 $('#booking_this_week').hide(); | |||
|                 $('#distance_this_week').hide(); | |||
|                 $('#amount_this_week').hide(); | |||
|                 $('#invoice_this_week').hide(); | |||
|                 $('.total').hide(); | |||
|                 $('#booking_this_year').show(); | |||
|                 $('#distance_this_year').show(); | |||
|                 $('#amount_this_year').show(); | |||
|                 $('#invoice_this_year').show(); | |||
|                 $(self.BookingYear.el).empty(); | |||
|                 $(self.DistanceYear.el).empty(); | |||
|                 $(self.AmountYear.el).empty(); | |||
|                 $(self.InvoiceYear.el).empty(); | |||
|                 $(self.BookingYear.el).append('<span>' + result['booking'][0]['count'] + '</span>'); | |||
|                 $(self.DistanceYear.el).append('<span>' + (result['distance'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.AmountYear.el).append('<span>' + (result['amount'][0]['sum']  || 0) + '</span>'); | |||
|                 $(self.InvoiceYear.el).append('<span>' + (result['invoice'][0]['sum'] || 0) + '</span>'); | |||
|                 self.get_cust_invoice(result); | |||
|                 self.get_truck_invoice(result); | |||
|                 self.get_cust_distance(result); | |||
|                 self.get_truc_distance(result); | |||
|                 self.get_cust_weight(result); | |||
|                 self.get_truck_weight(result); | |||
|             }) | |||
|         } | |||
| 
 | |||
|     onclick_this_month(ev) {//Function shows month filtered dashboard.
 | |||
|             self = this; | |||
|             jsonrpc('/web/dataset/call_kw/truck.booking/get_select_filter',{ | |||
|                model: 'truck.booking', | |||
|                method: 'get_select_filter', | |||
|                args: [ev], | |||
|                kwargs:{} | |||
|             }) | |||
|             .then(function (result) { | |||
|                 $('.total').hide(); | |||
|                 $('#booking_this_year').hide(); | |||
|                 $('#distance_this_year').hide(); | |||
|                 $('#amount_this_year').hide(); | |||
|                 $('#invoice_this_year').hide(); | |||
|                 $('#booking_this_day').hide(); | |||
|                 $('#distance_this_day').hide(); | |||
|                 $('#amount_this_day').hide(); | |||
|                 $('#invoice_this_day').hide(); | |||
|                 $('#booking_this_week').hide(); | |||
|                 $('#distance_this_week').hide(); | |||
|                 $('#amount_this_week').hide(); | |||
|                 $('#invoice_this_week').hide(); | |||
|                 $('#booking_this_month').show(); | |||
|                 $('#distance_this_month').show(); | |||
|                 $('#amount_this_month').show(); | |||
|                 $('#invoice_this_month').show(); | |||
| 
 | |||
|                 $(self.BookingMonth.el).empty(); | |||
|                 $(self.DistanceMonth.el).empty(); | |||
|                 $(self.AmountMonth.el).empty(); | |||
|                 $(self.InvoiceMonth.el).empty(); | |||
| 
 | |||
|                 $(self.BookingMonth.el).append('<span>' + result['booking'][0]['count'] + '</span>'); | |||
|                 $(self.DistanceMonth.el).append('<span>' + (result['distance'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.AmountMonth.el).append('<span>' + (result['amount'][0]['sum'] || 0) + '</span>'); | |||
|                 $(self.InvoiceMonth.el).append('<span>' + (result['invoice'][0]['sum'] || 0) + '</span>'); | |||
| 
 | |||
|                 self.get_cust_invoice(result); | |||
|                 self.get_truck_invoice(result); | |||
|                 self.get_cust_distance(result); | |||
|                 self.get_truc_distance(result); | |||
|                 self.get_cust_weight(result); | |||
|                 self.get_truck_weight(result); | |||
|             }) | |||
|         } | |||
| 
 | |||
|         get_cust_invoice(result) { | |||
|         //function to create a chart which shows the total invoice according to the customer
 | |||
|         new Chart($("#booking"), { | |||
|                     type: 'bar', | |||
|                     data: { | |||
|                         labels: result.cust_invoice_name, | |||
|                         datasets: [{ | |||
|                             label: 'Count', | |||
|                             data: result.cust_invoice_sum, | |||
|                             backgroundColor: [ | |||
|                                 "#003f5c", | |||
|                                 "#2f4b7c", | |||
|                                 "#f95d6a", | |||
|                                 "#665191", | |||
|                                 "#d45087", | |||
|                                 "#ff7c43", | |||
|                                 "#ffa600", | |||
|                                 "#a05195", | |||
|                                 "#6d5c16", | |||
|                                 "#CCCCFF" | |||
|                             ], | |||
|                             borderColor: [ | |||
|                                 "#003f5c", | |||
|                                 "#2f4b7c", | |||
|                                 "#f95d6a", | |||
|                                 "#665191", | |||
|                                 "#d45087", | |||
|                                 "#ff7c43", | |||
|                                 "#ffa600", | |||
|                                 "#a05195", | |||
|                                 "#6d5c16", | |||
|                                 "#CCCCFF" | |||
|                             ], | |||
|                             barPercentage: 0.5, | |||
|                             barThickness: 6, | |||
|                             maxBarThickness: 8, | |||
|                             minBarThickness:6, | |||
|                             minBarLength: 0, | |||
|                             borderWidth: 1, | |||
|                             type: 'bar', | |||
|                             fill: false | |||
|                         }] | |||
|                     }, | |||
|                     options: { | |||
|                         scales: { | |||
|                             y: { | |||
|                                 beginAtZero: true | |||
|                             }, | |||
|                         }, | |||
|                         responsive: true, | |||
|                     } | |||
|                 }); | |||
|     } | |||
| 
 | |||
|     get_truck_invoice(result){//function to create a chart which shows the total invoice according to the truck.
 | |||
|         new Chart($("#truck"), { | |||
|                 type: 'doughnut', | |||
|                 data: { | |||
|                     labels: result.truck_invoice_name, | |||
|                     datasets: [{ | |||
|                         label: 'Count', | |||
|                         data: result.truck_invoice_count, | |||
|                         backgroundColor: [ | |||
|                             "#665191", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#d45087", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF", | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
| 
 | |||
|                         ], | |||
|                         borderColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, | |||
|                         type: 'pie', | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, | |||
|                 } | |||
|             }); | |||
|     } | |||
| 
 | |||
|     get_cust_distance(result){//function to create a graph which shows the distance according to the customer
 | |||
|         new Chart($("#cust_distance"), { | |||
|                 type: 'doughnut', | |||
|                 data: { | |||
|                     labels: result.cust_distance_name, | |||
|                     datasets: [{ | |||
|                         label: 'Count', | |||
|                         data: result.cust_distance_count, | |||
|                         backgroundColor: [ | |||
|                             "#665191", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#d45087", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF", | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
| 
 | |||
|                         ], | |||
|                         borderColor: [ | |||
|                             "#003f5c", | |||
|                             "#2f4b7c", | |||
|                             "#f95d6a", | |||
|                             "#665191", | |||
|                             "#d45087", | |||
|                             "#ff7c43", | |||
|                             "#ffa600", | |||
|                             "#a05195", | |||
|                             "#6d5c16", | |||
|                             "#CCCCFF" | |||
|                         ], | |||
|                         barPercentage: 0.5, | |||
|                         barThickness: 6, | |||
|                         maxBarThickness: 8, | |||
|                         minBarLength: 0, | |||
|                         borderWidth: 1, | |||
|                         type: 'pie', | |||
|                         fill: false | |||
|                     }] | |||
|                 }, | |||
|                 options: { | |||
|                     scales: { | |||
|                         y: { | |||
|                             beginAtZero: true | |||
|                         }, | |||
|                     }, | |||
|                     responsive: true, | |||
|                 } | |||
|             }); | |||
|     } | |||
| 
 | |||
|     get_truc_distance(result){//function to create a graph which shows the distance according to the truck
 | |||
|         new Chart($("#truck_distance"), { | |||
|                         type: 'line', | |||
|                     data: { | |||
|                         labels: result.truck_distance_name,//x axis
 | |||
|                         datasets: [{ | |||
|                             label: 'count', // Name the series
 | |||
|                             data: result.truck_distance_count, // Specify the data values array
 | |||
|                             backgroundColor: '#003f5c', | |||
|                             borderColor: '#003f5c', | |||
|                             barPercentage: 0.5, | |||
|                             barThickness: 6, | |||
|                             maxBarThickness: 8, | |||
|                             minBarLength: 0, | |||
|                             borderWidth: 1, // Specify bar border width
 | |||
|                             type: 'line', // Set this data to a line chart
 | |||
|                             fill: false | |||
|                         }] | |||
|                     }, | |||
|                     options: { | |||
|                         scales: { | |||
|                             y: { | |||
|                                 beginAtZero: true | |||
|                             }, | |||
|                         }, | |||
|                         responsive: true, // Instruct chart js to respond nicely.
 | |||
|                     } | |||
|                     }); | |||
|     } | |||
| 
 | |||
|     get_cust_weight(result){//function to create a chart which shows the total goods weight according to the customer
 | |||
|         new Chart($("#cust_weight"), { | |||
|                         type: 'line', | |||
|                     data: { | |||
|                         labels: result.cust_weight_name,//x axis
 | |||
|                         datasets: [{ | |||
|                             label: 'count', // Name the series
 | |||
|                             data: result.cust_weight_count, // Specify the data values array
 | |||
|                             backgroundColor: '#003f5c', | |||
|                             borderColor: '#003f5c', | |||
|                             barPercentage: 0.5, | |||
|                             barThickness: 6, | |||
|                             maxBarThickness: 8, | |||
|                             minBarLength: 0, | |||
|                             borderWidth: 1, // Specify bar border width
 | |||
|                             type: 'line', // Set this data to a line chart
 | |||
|                             fill: false | |||
|                         }] | |||
|                     }, | |||
|                     options: { | |||
|                         scales: { | |||
|                             y: { | |||
|                                 beginAtZero: true | |||
|                             }, | |||
|                         }, | |||
|                         responsive: true, // Instruct chart js to respond nicely.
 | |||
|                     } | |||
|                     }); | |||
|     } | |||
| 
 | |||
|     get_truck_weight (result){//function to create a chart which shows the total goods weight according to the truck
 | |||
|     new Chart($("#truck_weight"), { | |||
|             type: 'bar', | |||
|             data: { | |||
|                 labels: result.truck_weight_name, | |||
|                 datasets: [{ | |||
|                     label: 'Count', | |||
|                     data: result.truck_weight_count, | |||
|                     backgroundColor: [ | |||
|                         "#003f5c", | |||
|                         "#2f4b7c", | |||
|                         "#f95d6a", | |||
|                         "#665191", | |||
|                         "#d45087", | |||
|                         "#ff7c43", | |||
|                         "#ffa600", | |||
|                         "#a05195", | |||
|                         "#6d5c16", | |||
|                         "#CCCCFF" | |||
| 
 | |||
|                     ], | |||
|                     borderColor: [ | |||
|                         "#003f5c", | |||
|                         "#2f4b7c", | |||
|                         "#f95d6a", | |||
|                         "#665191", | |||
|                         "#d45087", | |||
|                         "#ff7c43", | |||
|                         "#ffa600", | |||
|                         "#a05195", | |||
|                         "#6d5c16", | |||
|                         "#CCCCFF" | |||
|                     ], | |||
|                     barPercentage: 0.5, | |||
|                     barThickness: 6, | |||
|                     maxBarThickness: 8, | |||
|                     minBarLength: 0, | |||
|                     borderWidth: 1, | |||
|                     type: 'bar', | |||
|                     fill: false | |||
|                 }] | |||
|             }, | |||
|             options: { | |||
|                 scales: { | |||
|                     y: { | |||
|                         beginAtZero: true | |||
|                     }, | |||
|                 }, | |||
|                 responsive: true, | |||
|             } | |||
|         }); | |||
|     } | |||
| } | |||
| PackersManagement.template = "CustomDashBoard" | |||
| registry.category("actions").add("dash_tags", PackersManagement) | |||
| @ -0,0 +1,42 @@ | |||
| /** @odoo-module */ | |||
| import publicWidget from "@web/legacy/js/public/public_widget"; | |||
| import { jsonrpc } from "@web/core/network/rpc_service"; | |||
| import { _t } from "@web/core/l10n/translation"; | |||
| 
 | |||
|  publicWidget.registry.PackersAndMoversWidget = publicWidget.Widget.extend({ | |||
|     //Extends the publicWidget.Widget class to hide and show the button and calculate the distance between locations.
 | |||
|         selector: '.packers-and-movers-widget', | |||
|         events: { | |||
|             'click #check': '_onCheckClick', | |||
|             'click #next': '_onNextClick', | |||
|         }, | |||
| 
 | |||
|         _onCheckClick(ev) {//Click function to fetch from and to location value and calculate the distance.
 | |||
|             var self = this | |||
|             var from_location = this.el.querySelector('#from').value | |||
|             var to_location = this.el.querySelector('#to').value | |||
|             if (from_location!='' && to_location!='') | |||
|             { | |||
|             this.el.querySelector('#loader').classList.remove("d-none"); | |||
|             jsonrpc('/geo/'+ from_location + '/' +  to_location, { | |||
|                         }).then(function(data){ // success callback
 | |||
|                         self.$('#distance').val(data); | |||
|                         self.el.querySelector('#loader').classList.add("d-none"); | |||
|                         self.el.querySelector('#details').classList.remove("d-none"); | |||
|             }).catch(function (data) { | |||
|                 self.el.querySelector('#loader').classList.add("d-none"); | |||
|                 alert("Please enter valid city"); | |||
|                 return false; | |||
|             }); | |||
|             } | |||
|             else | |||
|             { | |||
|                 alert("Add Pickup city and drop City"); | |||
|                 return false; | |||
|             } | |||
|         }, | |||
|         _onNextClick: function (ev) {//Function to show the customer details form view
 | |||
|             this.el.querySelector('#customer').classList.remove("d-none"); | |||
|         }, | |||
|     }); | |||
| 
 | |||
| @ -0,0 +1,237 @@ | |||
| :root { | |||
|     /* Primary */ | |||
|     --mauve: #7D7EAF; | |||
|     --pink-dark: #BD85BA; | |||
|     --pink: #F78EAD; | |||
|     --peach: #FFA48E; | |||
|     --orange: #FFCA71; | |||
|     --gold: #CEA716; | |||
|     --green: #1EC198; | |||
|     --grey: #a0a0a0; | |||
|     /* Light */ | |||
|     --mauve-light: #e5e5ef; | |||
|     --pink-dark-light: #f2e7f1; | |||
|     --pink-light: #fde8ef; | |||
|     --peach-light: #ffede8; | |||
|     --orange-light: #fff4e3; | |||
|     --gold-light: #faf6e8; | |||
|     --green-light: #e9f9f5; | |||
|     --grey-light: #e0e0e0; | |||
| 
 | |||
|     /*Lighter*/ | |||
|     --grey-lighter: #fafafa; | |||
|     --grey-dark-lighter: #f3f3f3; | |||
| } | |||
| 
 | |||
| /* Background */ | |||
| .bg-mauve-light { | |||
|     background-color: var(--mauve-light); | |||
| } | |||
| 
 | |||
| .bg-pink-dark-light { | |||
|     background-color: var(--pink-dark-light); | |||
| } | |||
| 
 | |||
| .bg-pink-light { | |||
|     background-color: var(--pink-light); | |||
| } | |||
| 
 | |||
| .bg-peach-light { | |||
|     background-color: var(--peach-light); | |||
| } | |||
| 
 | |||
| .bg-orange-light { | |||
|     background-color: var(--orange-light); | |||
| } | |||
| 
 | |||
| .bg-gold-light { | |||
|     background-color: var(--gold-light); | |||
| } | |||
| 
 | |||
| .bg-green-light { | |||
|     background-color: var(--green-light); | |||
| } | |||
| 
 | |||
| /* Text */ | |||
| .text-mauve { | |||
|     color: var(--mauve); | |||
| } | |||
| 
 | |||
| .text-pink-dark { | |||
|     color: var(--pink-dark); | |||
| } | |||
| 
 | |||
| .text-pink { | |||
|     color: var(--pink); | |||
| } | |||
| 
 | |||
| .text-peach { | |||
|     color: var(--peach); | |||
| } | |||
| 
 | |||
| .text-orange { | |||
|     color: var(--orange); | |||
| } | |||
| 
 | |||
| .text-gold { | |||
|     color: var(--gold); | |||
| } | |||
| 
 | |||
| .text-green { | |||
|     color: var(--green); | |||
| } | |||
| 
 | |||
| /* Cards */ | |||
| 
 | |||
| .dashboard-card { | |||
|     border-radius: 0.3rem; | |||
|     display: flex; | |||
|     justify-content: center; | |||
|     padding: 1.7rem 1.5rem 1.5rem 1.5rem; | |||
|     margin: 1rem auto; | |||
|     height: 90px; | |||
| } | |||
| 
 | |||
| .dashboard-card__icon-container { | |||
|     height: 50px; | |||
|     width: 50px; | |||
|     border-radius: 50%; | |||
| } | |||
| 
 | |||
| .dashboard-card__icon-container i { | |||
| 	font-size: 20px; | |||
| } | |||
| 
 | |||
| .dashboard-card__details { | |||
|     margin-left: 1rem; | |||
|     max-width: 120px; | |||
| } | |||
| 
 | |||
| .dashboard-card__details h3 { | |||
|     font-weight: 700; | |||
|     font-size: 1.5rem; | |||
| } | |||
| 
 | |||
| .dashboard-card__details h4 { | |||
|     font-weight: 700; | |||
|     font-size: 0.7rem; | |||
|     color: var(--grey); | |||
|     margin-top: -5px; | |||
| } | |||
| 
 | |||
| h2.section-header { | |||
|     font-weight: 700; | |||
|     font-size: 1.5rem; | |||
| } | |||
| 
 | |||
| .chart-container { | |||
|     border-radius: 0.3rem; | |||
|     padding: 1rem; | |||
|     margin: 1rem auto; | |||
| } | |||
| 
 | |||
| .chart-container.card-shadow { | |||
|     height: 100%; | |||
| } | |||
| 
 | |||
| .half_chart.chart-container.card-shadow { | |||
| 	height: 49%; | |||
| } | |||
| 
 | |||
| .chart-container h2 { | |||
|     font-weight: 700; | |||
|     font-size: 1.125rem; | |||
| } | |||
| 
 | |||
| .item-container { | |||
|     background-color: var(--grey-lighter); | |||
|     border-radius: 0.3rem; | |||
|     padding: 1.2rem 1rem; | |||
|     margin: 1rem auto; | |||
| } | |||
| 
 | |||
| .item-container:hover { | |||
|     background-color: var(--grey-dark-lighter); | |||
|     transition: all 0.3s ease-in-out; | |||
|     cursor: pointer; | |||
| } | |||
| 
 | |||
| .count-container { | |||
|     font-weight: 700; | |||
|     font-size: 1.7rem; | |||
|     background-color: var(--mauve-light); | |||
|     color: var(--mauve); | |||
|     height: 50px; | |||
|     width: 50px; | |||
|     border-radius: 50%; | |||
|     display: flex; | |||
|     justify-content: center; | |||
|     align-items: center; | |||
| } | |||
| 
 | |||
| .item-header { | |||
|     display: flex; | |||
|     align-items: flex-start; | |||
| } | |||
| 
 | |||
| .item-title h3 { | |||
|     font-size: 1.3rem; | |||
|     font-weight: 700; | |||
| } | |||
| 
 | |||
| .item-content ul { | |||
|     list-style: none; | |||
|     padding-left: 0px; | |||
| } | |||
| 
 | |||
| .item-content ul>li { | |||
|     font-size: 0.9rem; | |||
|     color: var(--grey); | |||
|     font-weight: 700; | |||
| } | |||
| 
 | |||
| /* Misc */ | |||
| .card-shadow { | |||
|     -webkit-box-shadow: 1px 3px 5px 0px rgba(222, 222, 222, 1); | |||
|     -moz-box-shadow: 1px 3px 5px 0px rgba(222, 222, 222, 1); | |||
|     box-shadow: 1px 3px 5px 0px rgba(222, 222, 222, 1); | |||
| } | |||
| 
 | |||
| /* Table */ | |||
| thead { | |||
|     background-color: #e9ecf0; | |||
|     border-bottom: none; | |||
| } | |||
| 
 | |||
| .table thead th { | |||
|     border-bottom: none; | |||
| } | |||
| 
 | |||
| .table td, | |||
| .table th { | |||
|     border-top: 1px solid #eceff2; | |||
| } | |||
| 
 | |||
| .crm_scroll_table { | |||
| 	max-height: 395px; | |||
| 	overflow-y: auto; | |||
| } | |||
| .recent_activity_div .crm_scroll_table { | |||
| 	max-height: 435px; | |||
| } | |||
| 
 | |||
| .crm_scroll_table thead { | |||
|     position: sticky; | |||
|     top: 0; | |||
| } | |||
| 
 | |||
| .crm_scroll_table .count-container { | |||
|     height: 45px; | |||
|     width: 130px; | |||
|     border-radius: 50px; | |||
|     margin-right: 10px; | |||
| } | |||
| 
 | |||
| .crm_scroll_table .item-content ul > li { | |||
| 	font-size: 1.1rem; | |||
| } | |||
| @ -0,0 +1,349 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <!--This template defines a custom dashboard for Packers and Movers Management. | |||
| The dashboard displays various statistics and graphs related to truck bookings, | |||
| distances, revenue, and customer analysis. It also includes tables showing | |||
| upcoming events, top customers, and top trucks.--> | |||
| <template> | |||
|     <t t-name="CustomDashBoard"> | |||
|         <!-- This template defines a custom dashboard. --> | |||
|         <div class="oh_dashboards" style="margin-top: 20px;"> | |||
|             <div class="container-fluid o_pj_dashboard"> | |||
|                 <div class="scrollbar" id="style-1"> | |||
|                     <div class="col-xs-12"> | |||
|                         <div class="row" style="margin:0px;"> | |||
|                             <h2 class="section-header" | |||
|                                 style="font-size: 2em; color: #7d7eaf;">Packers | |||
|                                 And | |||
|                                 Movers Management | |||
|                                 Dashboard | |||
|                             </h2> | |||
|                             <div class="select" id="top_product_button"> | |||
|                                 <t t-log="this">This</t> | |||
|                                 <select name="filter" style="width: 283px; height: 30px; | |||
|                                    border-color:#7d7eaf; background-color: #fff; border-radius: 10px;" | |||
|                                         t-on-click="stock_selection"> | |||
|                                     <option id="day" value="day">Day</option> | |||
|                                     <option id="month" value="month" | |||
|                                             selected="">Month | |||
|                                     </option> | |||
|                                     <option id="week" value="week">Week</option> | |||
|                                     <option id="year" value="year">Year</option> | |||
|                                 </select> | |||
|                             </div> | |||
|                             <div class="crm_dash_cards row"> | |||
|                                 <div class="col-sm-12 col-md-3"> | |||
|                                     <div class="dashboard-card card-shadow my_lead"> | |||
|                                         <div class="dashboard-card__icon-container bg-mauve-light d-flex justify-content-center align-items-center"> | |||
|                                             <i class="fa fa-line-chart text-mauve"/> | |||
|                                         </div> | |||
|                                         <div class="dashboard-card__details"> | |||
|                                             <h3> | |||
|                                                 <div class="total" | |||
|                                                      t-ref="Total"> | |||
|                                                     <t t-esc="booking_count"/> | |||
|                                                 </div> | |||
|                                                 <span> | |||
|                                                     <div id="booking_this_year" | |||
|                                                          t-ref="BookingThisYear"/> | |||
|                                                     <div id="booking_this_day" | |||
|                                                          t-ref="BookingThisDay"/> | |||
|                                                     <div id="booking_this_month" | |||
|                                                          t-ref="BookingThisMonth"/> | |||
|                                                     <div id="booking_this_week" | |||
|                                                          t-ref="BookingThisWeek"/> | |||
|                                                 </span> | |||
|                                             </h3> | |||
|                                             <h4>Total Booking</h4> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                                 <div class="col-sm-12 col-md-3"> | |||
|                                     <div class="dashboard-card card-shadow opportunity"> | |||
|                                         <div class="dashboard-card__icon-container bg-mauve-light d-flex justify-content-center align-items-center"> | |||
|                                             <i class="fa fa-map-marker text-mauve"/> | |||
|                                         </div> | |||
|                                         <div class="dashboard-card__details"> | |||
|                                             <h3> | |||
|                                                 <span> | |||
|                                                     <div class="total" | |||
|                                                          t-ref="Total_two"> | |||
|                                                         <t t-esc="distance_count"/> | |||
|                                                     </div> | |||
|                                                     <div id="distance_this_year" | |||
|                                                          t-ref="DistanceThisYear"/> | |||
|                                                     <div id="distance_this_day" | |||
|                                                          t-ref="DistanceThisDay"/> | |||
|                                                     <div id="distance_this_month" | |||
|                                                          t-ref="DistanceThisMonth"/> | |||
|                                                     <div id="distance_this_week" | |||
|                                                          t-ref="DistanceThisWeek"/> | |||
|                                                 </span> | |||
|                                             </h3> | |||
|                                             <h4>Total Distance</h4> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                                 <div class="col-sm-12 col-md-3"> | |||
|                                     <div class="dashboard-card card-shadow exp_revenue"> | |||
|                                         <div | |||
|                                                 class="dashboard-card__icon-container bg-mauve-light d-flex justify-content-center align-items-center"> | |||
|                                             <i class="fa fa-usd text-mauve"/> | |||
|                                         </div> | |||
|                                         <div class="dashboard-card__details"> | |||
|                                             <h3> | |||
|                                                 <div class="total" | |||
|                                                      t-ref="Total_three"> | |||
|                                                     <t t-esc="total_amount"/> | |||
|                                                 </div> | |||
|                                                 <span> | |||
|                                                     <div id="amount_this_year" | |||
|                                                          t-ref="AmountThisYear"/> | |||
|                                                     <div id="amount_this_day" | |||
|                                                          t-ref="AmountThisDay"/> | |||
|                                                     <div id="amount_this_month" | |||
|                                                          t-ref="AmountThisMonth"/> | |||
|                                                     <div id="amount_this_week" | |||
|                                                          t-ref="AmountThisWeek"/> | |||
|                                                 </span> | |||
|                                             </h3> | |||
|                                             <h4>Total Amount</h4> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                                 <div class="col-sm-12 col-md-3"> | |||
|                                     <div class="dashboard-card card-shadow revenue_card revenue_card"> | |||
|                                         <div | |||
|                                                 class="dashboard-card__icon-container bg-mauve-light d-flex justify-content-center align-items-center"> | |||
|                                             <i class="fa fa-usd text-mauve"/> | |||
|                                         </div> | |||
|                                         <div class="dashboard-card__details"> | |||
|                                             <h3> | |||
|                                                 <div class="total" | |||
|                                                      t-ref="Total_four"> | |||
|                                                     <t t-esc="total_invoice"/> | |||
|                                                 </div> | |||
|                                                 <span> | |||
|                                                     <div id="invoice_this_year" | |||
|                                                          t-ref="InvoiceThisYear"/> | |||
|                                                     <div id="invoice_this_day" | |||
|                                                          t-ref="InvoiceThisDay"/> | |||
|                                                     <div id="invoice_this_month" | |||
|                                                          t-ref="InvoiceThisMonth"/> | |||
|                                                     <div id="invoice_this_week" | |||
|                                                          t-ref="InvoiceThisWeek"/> | |||
|                                                 </span> | |||
|                                             </h3> | |||
|                                             <h4>Invoiced Amount</h4> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6"> | |||
|                                 <div class="oh-card text-color graph" | |||
|                                      style="height: 94%"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Customer Analysis By Invoice | |||
|                                         </h4> | |||
|                                         <hr/> | |||
|                                     </div> | |||
|                                     <canvas id="booking" t-ref="BookingCanvas" | |||
|                                             width="200" height="100"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6 head"> | |||
|                                 <div class="oh-card text-color graph"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Truck Analysis By Invoice | |||
|                                         </h4> | |||
|                                     </div> | |||
|                                     <hr/> | |||
|                                     <canvas id="truck" t-ref="CanvasTruck" | |||
|                                             width="300" height="200"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6"> | |||
|                                 <div class="oh-card text-color graph"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Customer Analysis By Distance | |||
|                                         </h4> | |||
|                                         <hr/> | |||
|                                     </div> | |||
|                                     <canvas id="cust_distance" | |||
|                                             t-ref="CanvasDistance" width="300" | |||
|                                             height="200"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6 head"> | |||
|                                 <div class="oh-card text-color graph"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Truck Analysis By Distance | |||
|                                         </h4> | |||
|                                     </div> | |||
|                                     <hr/> | |||
|                                     <canvas id="truck_distance" | |||
|                                             t-ref="TruckDistance" width="300" | |||
|                                             height="200"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6"> | |||
|                                 <div class="oh-card text-color graph"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Customer Analysis By Weight | |||
|                                         </h4> | |||
|                                         <hr/> | |||
|                                     </div> | |||
|                                     <canvas id="cust_weight" | |||
|                                             t-ref="CustomerWeight" width="300" | |||
|                                             height="200"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-sm-6 col-lg-6 head"> | |||
|                                 <div class="oh-card text-color graph"> | |||
|                                     <div class="oh-card-body pb-0"> | |||
|                                         <h4 class="head"> | |||
|                                             Truck Analysis By Weight | |||
|                                         </h4> | |||
|                                     </div> | |||
|                                     <hr/> | |||
|                                     <canvas id="truck_weight" | |||
|                                             t-ref="TruckWeight" width="300" | |||
|                                             height="200"/> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-md-4 col-lg-4"> | |||
|                                 <div class="customer"> | |||
|                                     <div class="customer_head"> | |||
|                                         Upcoming | |||
|                                     </div> | |||
|                                     <div class="col-sm-12 col-lg-12" | |||
|                                          style="padding:0;"> | |||
|                                         <div class="text-color"> | |||
|                                             <table class="table table-sm"> | |||
|                                                 <thead> | |||
|                                                     <tr> | |||
|                                                         <th rowspan="14"> | |||
|                                                             Sequence.No | |||
|                                                         </th> | |||
|                                                         <th rowspan="14"> | |||
|                                                             Customer Name | |||
|                                                         </th> | |||
|                                                         <th rowspan="14">Date | |||
|                                                         </th> | |||
|                                                     </tr> | |||
|                                                 </thead> | |||
|                                                 <tbody> | |||
|                                                     <t t-foreach="upcoming" | |||
|                                                        t-as="upcomings" | |||
|                                                        t-key="upcomings"> | |||
|                                                         <tr> | |||
|                                                             <td> | |||
|                                                                 <t t-esc="upcomings['reference_no']"/> | |||
|                                                             </td> | |||
|                                                             <td> | |||
|                                                                 <t t-esc="upcomings['name']"/> | |||
|                                                             </td> | |||
|                                                             <td> | |||
|                                                                 <t t-esc="upcomings['date']"/> | |||
|                                                             </td> | |||
|                                                         </tr> | |||
|                                                     </t> | |||
|                                                 </tbody> | |||
|                                             </table> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-md-4 col-lg-4"> | |||
|                                 <div class="customer"> | |||
|                                     <div class="customer_head"> | |||
|                                         Top 10 Customers | |||
|                                     </div> | |||
|                                     <div class="col-sm-12 col-lg-12" | |||
|                                          style="padding:0;"> | |||
|                                         <div class="text-color"> | |||
|                                             <table class="table table-sm"> | |||
|                                                 <thead> | |||
|                                                     <tr> | |||
|                                                         <th rowspan="14" | |||
|                                                             style="text-align:center;"> | |||
|                                                             S.NO | |||
|                                                         </th> | |||
|                                                         <th rowspan="14">Truck | |||
|                                                             Type | |||
|                                                         </th> | |||
|                                                     </tr> | |||
|                                                 </thead> | |||
|                                                 <tbody> | |||
|                                                     <t t-foreach="customer" | |||
|                                                        t-as="customers" | |||
|                                                        t-key="customers"> | |||
|                                                         <tr> | |||
|                                                             <td> | |||
|                                                                 <div class="circle"> | |||
|                                                                     <t t-esc="customers_index + 1"/> | |||
|                                                                 </div> | |||
|                                                             </td> | |||
|                                                             <td> | |||
|                                                                 <t t-esc="customers['name']"/> | |||
|                                                             </td> | |||
|                                                         </tr> | |||
|                                                     </t> | |||
|                                                 </tbody> | |||
|                                             </table> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="col-md-4 col-lg-4"> | |||
|                                 <div class="customer"> | |||
|                                     <div class="customer_head"> | |||
|                                         Top 10 Truck | |||
|                                     </div> | |||
|                                     <div class="col-sm-12 col-lg-12" | |||
|                                          style="padding:0;"> | |||
|                                         <div class="text-color"> | |||
|                                             <table class="table table-sm"> | |||
|                                                 <thead> | |||
|                                                     <tr> | |||
|                                                         <th rowspan="14" | |||
|                                                             style="text-align:center;"> | |||
|                                                             Count | |||
|                                                         </th> | |||
|                                                         <th rowspan="14">Truck | |||
|                                                             Type | |||
|                                                         </th> | |||
|                                                     </tr> | |||
|                                                 </thead> | |||
|                                                 <tbody> | |||
|                                                     <t t-foreach="truck" | |||
|                                                        t-as="trucks" | |||
|                                                        t-key="trucks"> | |||
|                                                         <tr> | |||
|                                                             <td> | |||
|                                                                 <div class="circle"> | |||
|                                                                     <t t-esc="trucks_index + 1"/> | |||
|                                                                 </div> | |||
|                                                             </td> | |||
|                                                             <td> | |||
|                                                                 <t t-esc="trucks['name']"/> | |||
|                                                             </td> | |||
|                                                         </tr> | |||
|                                                     </t> | |||
|                                                 </tbody> | |||
|                                             </table> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|         </div> | |||
|     </t> | |||
| </template> | |||
| @ -0,0 +1,12 @@ | |||
| <?xml version="1.0" encoding="utf-8" ?> | |||
| <odoo> | |||
|     <!--    The client action record to view the Dashboard--> | |||
|     <record id="dashboard_view_action" model="ir.actions.client"> | |||
|         <field name="name">Dashboard</field> | |||
|         <field name="tag">dash_tags</field> | |||
|     </record> | |||
| 
 | |||
|     <menuitem id="dashboard_view_menu_action" action="dashboard_view_action" | |||
|               parent="packers_and_movers_management.truck_booking_menu_root" | |||
|               sequence="0"/> | |||
| </odoo> | |||
| @ -0,0 +1,68 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--Inherited the fleet form to add Additional information--> | |||
|     <record id="fleet_vehicle_model_view_form" model="ir.ui.view"> | |||
|         <field name="name"> | |||
|             fleet.vehicle.model.view.form.inherit.packers.and.movers.management | |||
|         </field> | |||
|         <field name="model">fleet.vehicle.model</field> | |||
|         <field name="inherit_id" ref="fleet.fleet_vehicle_model_view_form"/> | |||
|         <field name="arch" type="xml"> | |||
|             <field name="vehicle_type" position="inside"/> | |||
|             <page name="information" position="inside"> | |||
|                 <group> | |||
|                     <group string="Truck Information" invisible="vehicle_type != 'truck'"> | |||
|                         <field name="truck_type_id"/> | |||
|                     </group> | |||
|                 </group> | |||
|             </page> | |||
|         </field> | |||
|     </record> | |||
|     <!--Creation action of the truck type model--> | |||
|     <record id="truck_type_action" model="ir.actions.act_window"> | |||
|         <field name="name">Truck Type Action</field> | |||
|         <field name="res_model">truck.type</field> | |||
|         <field name="view_mode">tree,form</field> | |||
|     </record> | |||
|     <!--The tree for the truck type--> | |||
|     <record id="truck_type_view_tree" model="ir.ui.view"> | |||
|         <field name="name">truck.type.view.tree</field> | |||
|         <field name="model">truck.type</field> | |||
|         <field name="arch" type="xml"> | |||
|             <tree string="truck.type"> | |||
|                 <field name="name"/> | |||
|             </tree> | |||
|         </field> | |||
|     </record> | |||
|     <!-- Form view for the Truck types--> | |||
|     <record id="truck_type_view_form" model="ir.ui.view"> | |||
|         <field name="name">truck.type.view.form</field> | |||
|         <field name="model">truck.type</field> | |||
|         <field name="arch" type="xml"> | |||
|             <form string="truck_type"> | |||
|                 <sheet> | |||
|                     <group> | |||
|                         <group> | |||
|                             <field name="name"/> | |||
|                             <field name="capacity"/> | |||
|                             <field name="weight"/> | |||
|                             <field name="unit"/> | |||
|                         </group> | |||
|                         <group> | |||
|                             <field name="length" placeholder="Length..."/> | |||
|                             <field name="width" placeholder="Breadth..."/> | |||
|                             <field name="height" placeholder="Height.."/> | |||
|                             <field name="company_id" invisible="1"/> | |||
|                         </group> | |||
|                     </group> | |||
|                 </sheet> | |||
|             </form> | |||
|         </field> | |||
|     </record> | |||
|     <!--    Menu to add the truck details in parent menus--> | |||
|     <menuitem id="truck_type_fleet_menu_action" action="truck_type_action" | |||
|               parent="fleet.fleet_configuration"/> | |||
|     <menuitem id="truck_type_menu_action" action="truck_type_action" | |||
|               parent="packers_and_movers_management.master_data_menu"/> | |||
| 
 | |||
| </odoo> | |||
| @ -0,0 +1,50 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--    Action specified for the goods type--> | |||
|     <record id="goods_type_action" model="ir.actions.act_window"> | |||
|         <field name="name">Goods Type</field> | |||
|         <field name="res_model">goods.type</field> | |||
|         <field name="view_mode">tree</field> | |||
|     </record> | |||
|     <!--    Tree of the goods type--> | |||
|     <record id="goods_type_view_tree" model="ir.ui.view"> | |||
|         <field name="name">goods.type.view.tree</field> | |||
|         <field name="model">goods.type</field> | |||
|         <field name="arch" type="xml"> | |||
|             <tree string="Goods Type" editable="bottom"> | |||
|                 <field name="name"/> | |||
|                 <field name="company_id" invisible="1"/> | |||
|             </tree> | |||
|         </field> | |||
|     </record> | |||
|     <!--Form view of the goods type--> | |||
|     <record id="goods_type_view_form" model="ir.ui.view"> | |||
|         <field name="name">goods.type.view.form</field> | |||
|         <field name="model">goods.type</field> | |||
|         <field name="arch" type="xml"> | |||
|             <form string="goods_type"> | |||
|                 <sheet> | |||
|                     <group> | |||
|                         <group> | |||
|                             <field name="name"/> | |||
|                             <field name="company_id" invisible="1"/> | |||
|                         </group> | |||
|                     </group> | |||
|                 </sheet> | |||
|             </form> | |||
|         </field> | |||
|     </record> | |||
|     <!--Menu used to add the Good type details--> | |||
|     <menuitem id="truck_booking_menu_root" name="Packers And Movers" | |||
|               web_icon="packers_and_movers_management,static/description/icon.png"/> | |||
|     <menuitem id="master_data_menu" name="Master Data" | |||
|               parent="packers_and_movers_management.truck_booking_menu_root" | |||
|               sequence='2'/> | |||
|     <menuitem id="customer_menu_action" | |||
|               action="base.action_partner_customer_form" | |||
|               parent="packers_and_movers_management.master_data_menu" | |||
|               sequence="0"/> | |||
|     <menuitem id="goods_type_menu_action" action="goods_type_action" | |||
|               parent="packers_and_movers_management.master_data_menu"/> | |||
| 
 | |||
| </odoo> | |||
| @ -0,0 +1,75 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <odoo> | |||
|     <!--    Config Settings Inherited form view used to add additional datas in the form--> | |||
|     <record id="res_config_settings_view_form" model="ir.ui.view"> | |||
|         <field name="name"> | |||
|             res.config.settings.view.form.inherit.packers.and.movers.management | |||
|         </field> | |||
|         <field name="model">res.config.settings</field> | |||
|         <field name="priority" eval="15"/> | |||
|         <field name="inherit_id" ref="base.res_config_settings_view_form"/> | |||
|         <field name="arch" type="xml"> | |||
|             <xpath expr="//form" position="inside"> | |||
|                 <app data-string="Packers And Movers" id="PackersAndMovers" string="PackersAndMovers" name="packers_and_movers_management"> | |||
|                     <block title="Pricing" id="distance_amount"> | |||
|                         <setting string="Distance Amount/KM"> | |||
|                             <div class="text-muted content-group mt16"> | |||
|                                 <span>Distance amount per 1 kilometer</span> | |||
|                                 <field name="distance_amount" | |||
|                                        class="text-center" | |||
|                                        style="width: 10%; min-width: 4rem;"/> | |||
|                             </div> | |||
|                             <div class="text-muted content-group mt16"> | |||
|                                 <span>Apply Extra Amount</span> | |||
|                                 <field name="is_extra" | |||
|                                        class="text-center" | |||
|                                        style="width: 10%; min-width: 4rem;"/> | |||
|                             </div> | |||
|                             <div class="text-muted content-group mt16" invisible="not is_extra"> | |||
|                                 <span>Extra Amount</span> | |||
|                                 <field name="extra_amount" | |||
|                                        class="text-center" | |||
|                                        style="width: 10%; min-width: 4rem;"/> | |||
|                             </div> | |||
|                         </setting> | |||
|                     </block> | |||
|                     <block title="Distance Limitation Settings" id="max_distance"> | |||
|                         <setting> | |||
|                             <div class="text-muted content-group mt16"> | |||
|                                 <span>Distance Limitation</span> | |||
|                                 <field name="is_distance_limited" | |||
|                                        class="text-center" | |||
|                                        style="width: 10%; min-width: 4rem;"/> | |||
|                             </div> | |||
|                             <div class="text-muted content-group mt16" invisible="not is_distance_limited"> | |||
|                                 <span>Maximum Distance (KM)</span> | |||
|                                 <field name="max_distance" | |||
|                                        class="text-center" | |||
|                                        style="width: 10%; min-width: 4rem;"/> | |||
|                             </div> | |||
|                         </setting> | |||
|                     </block> | |||
| 
 | |||
| 
 | |||
|                 </app> | |||
|             </xpath> | |||
|         </field> | |||
|     </record> | |||
|     <!--    Action used in the config settings model--> | |||
|     <record id="res_config_settings_action" model="ir.actions.act_window"> | |||
|         <field name="name">Configuration Action</field> | |||
|         <field name="res_model">res.config.settings</field> | |||
|         <field name="view_mode">form</field> | |||
|         <field name="view_id" ref="res_config_settings_view_form"/> | |||
|         <field name="target">inline</field> | |||
|         <field name="context">{'module' : 'packers_and_movers_management', 'bin_size': False}</field> | |||
| 
 | |||
|     </record> | |||
|     <!--    Menu used in the Truck booking root and the Config Settings--> | |||
|     <menuitem id="configuration_menu" name="Configuration" | |||
|               parent="packers_and_movers_management.truck_booking_menu_root"/> | |||
|     <menuitem id="res_config_settings_menu_action" name="Settings" | |||
|               parent="packers_and_movers_management.configuration_menu" | |||
|               sequence="0" | |||
|               action="res_config_settings_action"/> | |||
| </odoo> | |||
| @ -0,0 +1,125 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--    Action specified for the truck booking--> | |||
|     <record id="truck_booking_action" model="ir.actions.act_window"> | |||
|         <field name="name">Truck Booking</field> | |||
|         <field name="res_model">truck.booking</field> | |||
|         <field name="view_mode">tree,form</field> | |||
|     </record> | |||
|     <!--Search view records used in the truck booking --> | |||
|     <record id='truck_booking_view_search' model='ir.ui.view'> | |||
|         <field name="name">truck.booking.view.search</field> | |||
|         <field name="model">truck.booking</field> | |||
|         <field name="arch" type="xml"> | |||
|             <search string="Truck Booking"> | |||
|                 <field name="reference_no"/> | |||
|                 <field name="partner_id"/> | |||
|                 <field name="truck_id"/> | |||
|                 <field name="goods_type_id"/> | |||
|                 <field name="state"/> | |||
|                 <separator/> | |||
|                 <filter string="Confirm" name="confirm" | |||
|                         domain="[('state', '=', 'confirm')]"/> | |||
|                 <filter string="Invoiced" name="invoiced" | |||
|                         domain="[('state', '=', 'invoice')]"/> | |||
|                 <filter string="Draft" name="draft" | |||
|                         domain="[('state', '=', 'draft')]"/> | |||
|                 <group expand="1" string="Group By"> | |||
|                     <filter string="Customer" name="groupby_partner_id" | |||
|                             context="{'group_by': 'partner_id'}"/> | |||
|                     <filter string="Truck Type" name="groupby_truck_id" | |||
|                             context="{'group_by': 'truck_id'}"/> | |||
|                     <filter string="goods Type" name="groupby_goods_type_id" | |||
|                             context="{'group_by': 'goods_type_id'}"/> | |||
|                     <filter string="State" name="groupby_state" | |||
|                             context="{'group_by': 'state'}"/> | |||
|                 </group> | |||
|             </search> | |||
|         </field> | |||
|     </record> | |||
|     <!--Tree view of the truck booking--> | |||
|     <record id="truck_booking_view_tree" model="ir.ui.view"> | |||
|         <field name="name">truck.booking.view.tree</field> | |||
|         <field name="model">truck.booking</field> | |||
|         <field name="arch" type="xml"> | |||
|             <tree string="truck.booking"> | |||
|                 <field name="reference_no"/> | |||
|                 <field name="partner_id"/> | |||
|                 <field name="from_location"/> | |||
|                 <field name="to_location"/> | |||
|                 <field name="state"/> | |||
|             </tree> | |||
|         </field> | |||
|     </record> | |||
|     <!--form view of the truck booking--> | |||
|     <record id="truck_booking_view_form" model="ir.ui.view"> | |||
|         <field name="name">truck.booking.view.form</field> | |||
|         <field name="model">truck.booking</field> | |||
|         <field name="arch" type="xml"> | |||
|             <form string="truck_booking"> | |||
|                 <header> | |||
|                     <button name="action_confirm" string='Confirm' | |||
|                             class="btn-primary" | |||
|                             invisible="state not in ['draft']" type="object"/> | |||
|                     <button name="action_create_invoice" | |||
|                             string='Create Invoice' class="btn-primary" | |||
|                             invisible="hide_invoice or state != 'confirm'" | |||
|                             type="object"/> | |||
|                     <field name="state" widget="statusbar" string="Status"/> | |||
|                 </header> | |||
|                 <sheet> | |||
|                     <div name="button_box" position="inside"> | |||
|                         <button class="oe_stat_button" type="object" | |||
|                                 name="action_view_invoice" | |||
|                                 icon="fa-pencil-square-o" | |||
|                                 invisible="invoice_count == 0"> | |||
|                             <field string="Invoice" name="invoice_count" | |||
|                                    widget="statinfo"/> | |||
|                         </button> | |||
|                     </div> | |||
|                     <group> | |||
|                         <widget name="web_ribbon" title="INVOICED" | |||
|                                 bg_color="bg-success" | |||
|                                 invisible="state != 'invoice'"/> | |||
|                     </group> | |||
|                     <div class="oe_title"> | |||
|                         <h1> | |||
|                             <field name="reference_no"/> | |||
|                         </h1> | |||
|                     </div> | |||
|                     <group> | |||
|                         <group> | |||
|                             <field name="partner_id"/> | |||
|                             <field name="from_location"/> | |||
|                             <field name="to_location"/> | |||
|                             <field name="distance"/> | |||
|                             <field name="amount"/> | |||
|                             <field name="hide_invoice" invisible="1"/> | |||
|                         </group> | |||
|                         <group> | |||
|                             <field name="date"/> | |||
|                             <field name="truck_id"/> | |||
|                             <field name="goods_type_id"/> | |||
|                             <field name="weight"/> | |||
|                             <field name="unit"/> | |||
|                             <field name="invoiced_amount" invisible="1"/> | |||
|                             <field name="company_id" invisible="1"/> | |||
|                         </group> | |||
|                     </group> | |||
|                 </sheet> | |||
|                 <div class="oe_chatter"> | |||
|                     <field name="message_follower_ids"/> | |||
|                     <field name="message_ids"/> | |||
|                     <field name="activity_ids"/> | |||
|                 </div> | |||
|             </form> | |||
|         </field> | |||
|     </record> | |||
|     <!--Menus used as the parent and submenu for the truck booking--> | |||
|     <menuitem id="operation_menu" name="Operations" | |||
|               parent="packers_and_movers_management.truck_booking_menu_root" | |||
|               sequence='1'/> | |||
|     <menuitem id="truck_booking_menu_action" action="truck_booking_action" | |||
|               parent="packers_and_movers_management.operation_menu"/> | |||
| 
 | |||
| </odoo> | |||
| @ -0,0 +1,166 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--    Template for the Truck booking page--> | |||
|     <template id="truck_booking_page" name="Booking"> | |||
|         <t t-call="website.layout"> | |||
|             <div id="wrap" class="wrap packers-and-movers-widget"> | |||
|                 <div class="container"> | |||
|                     <div class="col-md-6"> | |||
|                         <h1 class="head"> | |||
|                             <b>Packers And Movers</b> | |||
|                         </h1> | |||
|                         <div class="image"/> | |||
|                     </div> | |||
|                     <div class="col-md-6 body" t-ref="body"> | |||
|                         <form action="/booking/submit"> | |||
|                             <div id="location"> | |||
|                                 <div class="form-group"> | |||
|                                     <input type="text" | |||
|                                            placeholder='Pick Up City Location' | |||
|                                            id="from" | |||
|                                            name="pickup_location" | |||
|                                            class="link-style" required="true"/> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <input type="text" | |||
|                                            placeholder='Drop City Location' | |||
|                                            id="to" | |||
|                                            name="drop_location" | |||
|                                            class="link-style" required="true"/> | |||
|                                 </div> | |||
|                                 <button type="submit" id="check" | |||
|                                         class="button">Check Fare | |||
|                                 </button> | |||
|                             </div> | |||
|                             <div id="loader" class="d-none"/> | |||
|                             <div id="details" class="d-none"> | |||
|                                 <div class="form-group"> | |||
|                                     <label for="distance">Distance</label> | |||
|                                     <input type="text" | |||
|                                            class="form-control link-style" | |||
|                                            name="distance" | |||
|                                            id="distance" autocomplete="off" | |||
|                                            required="true" readonly="1"/> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label>Date</label> | |||
|                                     <input type="date" name="date" | |||
|                                            class="form-control link-style" | |||
|                                            required="true"/> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label>Truck Type</label> | |||
|                                     <select name="truck_type" | |||
|                                             class="form-control link-style" | |||
|                                             required="true"> | |||
|                                         <option value="">select truck</option> | |||
|                                         <t t-foreach="truck_ids" | |||
|                                            t-as="truck_id"> | |||
|                                             <option t-esc="truck_id.name" | |||
|                                                     t-att-value="truck_id.id"/> | |||
|                                         </t> | |||
|                                     </select> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label>Goods Type</label> | |||
|                                     <select name="goods_type" | |||
|                                             class="form-control link-style" | |||
|                                             required="true"> | |||
|                                         <option value="">Select Goods</option> | |||
|                                         <t t-foreach="goods_ids" | |||
|                                            t-as="goods_id"> | |||
|                                             <option t-esc="goods_id.name" | |||
|                                                     t-att-value="goods_id.id"/> | |||
|                                         </t> | |||
|                                     </select> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label>Enter weight</label> | |||
|                                     <div class="select"> | |||
|                                         <input type="number" | |||
|                                                placeholder='Approx Weight(1Ton =1000KG)' | |||
|                                                name="weight" | |||
|                                                class="form-control link-style" | |||
|                                                id="weight" required="true"/> | |||
|                                         <select name="unit" class="unit"> | |||
|                                             <option value="kg" | |||
|                                                     selected="selected">KG | |||
|                                             </option> | |||
|                                             <option value="tons">Tons</option> | |||
|                                         </select> | |||
|                                     </div> | |||
|                                 </div> | |||
|                                 <button type="submit" id="next" class="button"> | |||
|                                     Next | |||
|                                 </button> | |||
|                             </div> | |||
|                             <div id="customer" class="d-none"> | |||
|                                 <div class="form-group"> | |||
|                                     <label for="name">Name</label> | |||
|                                     <input type="text" placeholder='Enter Name' | |||
|                                            class="form-control link-style" | |||
|                                            name="name" required="true"/> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label for="city">City</label> | |||
|                                     <input type="text" placeholder='City' | |||
|                                            class="form-control link-style" | |||
|                                            name="city" | |||
|                                            required="true"/> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label for="state">State</label> | |||
|                                     <select name="state" | |||
|                                             class="form-control link-style" | |||
|                                             required="true"> | |||
|                                         <t t-foreach="state_ids" | |||
|                                            t-as="state_id"> | |||
|                                             <option t-esc="state_id.name" | |||
|                                                     t-att-value="state_id.id"/> | |||
|                                         </t> | |||
|                                     </select> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label for="country">Country</label> | |||
|                                     <select name="country" | |||
|                                             class="form-control link-style" | |||
|                                             required="true"> | |||
|                                         <t t-foreach="country_ids" | |||
|                                            t-as="country_id"> | |||
|                                             <option t-esc="country_id.name" | |||
|                                                     t-att-value="country_id.id"/> | |||
|                                         </t> | |||
|                                     </select> | |||
|                                 </div> | |||
|                                 <div class="form-group"> | |||
|                                     <label>Enter Mobile No</label> | |||
|                                     <input type="tel" | |||
|                                            placeholder='Mobile Number' | |||
|                                            class="form-control link-style" | |||
|                                            name="mobile_no"/> | |||
|                                 </div> | |||
|                                 <button type="submit" class="button">Confirm | |||
|                                 </button> | |||
|                             </div> | |||
|                         </form> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|         </t> | |||
|     </template> | |||
|     <!-- Template used to redirect the booking page into success--> | |||
|     <template id="truck_booking_success_page" name="Truck Booking"> | |||
|         <t t-call="website.layout"> | |||
|             <div id="wrap"> | |||
|                 <div class="container"> | |||
|                     <div class="col-md-12"> | |||
|                         <div class="success"> | |||
|                             Booking have been Created Successfully. | |||
|                         </div> | |||
|                     </div> | |||
|                     <a href="/booking" class="link">Back to Booking</a> | |||
|                 </div> | |||
|             </div> | |||
|         </t> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,39 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--    Template for showing the goods type details--> | |||
|     <template id="goods_page" name="Goods"> | |||
|         <t t-call="website.layout"> | |||
|             <div id="wrap"> | |||
|                 <h1 align='center'>Goods Type</h1> | |||
|                 <div class="container"> | |||
|                     <div class="col-md-12"> | |||
|                         <div class="row"> | |||
|                             <table class="table"> | |||
|                                 <thead> | |||
|                                     <tr> | |||
|                                         <th> | |||
|                                             S.NO | |||
|                                         </th> | |||
|                                         <th> | |||
|                                             Goods Type | |||
|                                         </th> | |||
|                                     </tr> | |||
|                                 </thead> | |||
|                                 <t t-foreach='goods_ids' t-as="goods_id"> | |||
|                                     <tr> | |||
|                                         <td> | |||
|                                             <t t-esc="goods_id_index + 1"/> | |||
|                                         </td> | |||
|                                         <td> | |||
|                                             <t t-esc="goods_id.name"/> | |||
|                                         </td> | |||
|                                     </tr> | |||
|                                 </t> | |||
|                             </table> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|         </t> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,59 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <!--    Template for the truck details--> | |||
|     <template id="truck_page" name="Truck"> | |||
|         <t t-call="website.layout"> | |||
|             <div id="wrap"> | |||
|                 <h1 align='center'>Trucks</h1> | |||
|                 <div class="container"> | |||
|                     <div class="col-md-12"> | |||
|                         <div class="row"> | |||
|                             <table class="table"> | |||
|                                 <thead> | |||
|                                     <tr> | |||
|                                         <th> | |||
|                                             TRUCK TYPE | |||
|                                         </th> | |||
|                                         <th> | |||
|                                             SIZE(FT) | |||
|                                         </th> | |||
|                                         <th> | |||
|                                             HOUSE HOLD CAPACITY | |||
|                                         </th> | |||
|                                         <th> | |||
|                                             MAX WEIGHT | |||
|                                         </th> | |||
|                                     </tr> | |||
|                                 </thead> | |||
|                                 <t t-foreach='truck_type_ids' | |||
|                                    t-as="truck_type_id"> | |||
|                                     <tr> | |||
|                                         <td> | |||
|                                             <t t-esc="truck_type_id.name"/> | |||
|                                         </td> | |||
|                                         <td> | |||
|                                             <t t-esc="truck_type_id.length"/>L | |||
|                                             X | |||
|                                             <t t-esc="truck_type_id.width"/>W X | |||
|                                             <t t-esc="truck_type_id.height"/>H | |||
|                                         </td> | |||
|                                         <td> | |||
|                                             <t t-esc="truck_type_id.capacity"/> | |||
|                                             BHK | |||
|                                         </td> | |||
|                                         <td> | |||
|                                             Max Load | |||
|                                             <t t-esc="truck_type_id.weight"/> | |||
|                                             <t t-esc="truck_type_id.unit"/> | |||
|                                         </td> | |||
|                                     </tr> | |||
|                                 </t> | |||
|                             </table> | |||
|                         </div> | |||
| 
 | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|         </t> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,22 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 make_truck_booking_pdf | |||
| @ -0,0 +1,60 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Anfas Faisal K (odoo@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 TruckBookingMake(models.TransientModel): | |||
|     """Wizard to print pdf report of booking""" | |||
|     _name = 'make.truck.booking.pdf' | |||
|     _description = "Truck Booking PDF" | |||
| 
 | |||
|     from_date = fields.Date(string='From Date', help='Add the start date') | |||
|     to_date = fields.Date(string='To Date', help='Add the end date') | |||
|     truck_id = fields.Many2one('fleet.vehicle.model', string='Track Type', | |||
|                                domain=[('vehicle_type', '=', 'truck')], | |||
|                                help='Select the truck type') | |||
|     goods_type_id = fields.Many2one('goods.type', string='Goods Type', | |||
|                                     help='Select the goods type') | |||
|     partner_id = fields.Many2one('res.partner', string='Customer', | |||
|                                  required=True, | |||
|                                  help='Select the customer') | |||
| 
 | |||
|     def action_report_truck_booking(self): | |||
|         """Function to print PDF report""" | |||
|         query = """select pr.name,fv.name as truck,gt.name as goods,tb.from_location,tb.to_location,tb.distance, | |||
|                 tb.weight,tb.unit,amount,tb.date,tb.state from truck_booking as tb | |||
|                 inner join res_partner as pr on pr.id = tb.partner_id | |||
|                 inner join fleet_vehicle_model as fv on fv.id = tb.truck_id | |||
|                 inner join goods_type as gt on gt.id = tb.goods_type_id | |||
|                 where pr.id = %d """ % self.partner_id.id | |||
|         if self.truck_id: | |||
|             query += """ and fv.id = %d """ % self.truck_id.id | |||
|         if self.goods_type_id: | |||
|             query += """ and gt.id = %d """ % self.goods_type_id.id | |||
|         if self.from_date: | |||
|             query += """ and tb.date >= '%s' """ % self.from_date | |||
|         if self.to_date: | |||
|             query += """ and tb.date <= '%s' """ % self.to_date | |||
|         self.env.cr.execute(query) | |||
|         report = self.env.cr.dictfetchall() | |||
|         data = {'date': self.read()[0],'report': report} | |||
|         return self.env.ref('packers_and_movers_management.action_report_booking').report_action(None, data=data) | |||