# -*- coding: utf-8 -*- ################################################################################ # # Cybrosys Technologies Pvt. Ltd. # # Copyright (C) 2024-TODAY Cybrosys Technologies(). # Author: Ajith V (odoo@cybrosys.com) # # You can modify it under the terms of the GNU AFFERO # GENERAL PUBLIC LICENSE (AGPL v3), Version 3. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. # # You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE # (AGPL v3) along with this program. # If not, see . ################################################################################ from datetime import date, timedelta from odoo import http from odoo.http import request class FleetFilter(http.Controller): """ The FleetFilter class provides the filter option to the js. When applying the filter return the corresponding data. Methods: fleet_filter(self): when the page is loaded adding filter options to the selection field. return a list variable. fleet_filter_data(self,**kw): after applying the filter receiving the values and return the filtered data. """ @http.route('/fleet/filter', auth='public', type='json') def fleet_filter(self): """ Summary: transferring data to the selection field that works as a filter Returns: type:list of lists , it contains the data for the corresponding filter. """ fleet_vehicle_ids = request.env['fleet.vehicle'].search([]) driver_list = request.env['res.partner'].search_read([], ['name']) # Getting vehicles model data vehicle_list = [{'id': fleet_vehicle_id.model_id.id, 'name': fleet_vehicle_id.model_id.name} for fleet_vehicle_id in fleet_vehicle_ids] vehicle_list = [vehicle for n, vehicle in enumerate(vehicle_list) if vehicle not in vehicle_list[:n]] # Getting vehicles brand data manufacturers_list = [{'id': fleet_vehicle_id.model_id.brand_id.id, 'name': fleet_vehicle_id.model_id.brand_id.name} for fleet_vehicle_id in fleet_vehicle_ids] manufacturers_list = [manufacturer for n, manufacturer in enumerate(manufacturers_list) if manufacturer not in manufacturers_list[:n]] return {'drivers': driver_list, 'vehicles': vehicle_list, 'manufactures': manufacturers_list} @http.route('/fleet_advanced_dashboard/filter_data', auth='public', type='json') def fleet_filter_data(self, **kw): data = kw.get('data') driver = [partner.id for partner in request.env['res.partner'].search([])] \ if data['driver'] == 'null' else [int(data['driver'])] vehicle = [fleet_vehicle_id.id for fleet_vehicle_id in request.env['fleet.vehicle.model'].search([])] \ if data['vehicle'] == 'null' else [int(data['vehicle'])] fleet_vehicle_list = request.env['fleet.vehicle'].search( [("model_id", 'in', vehicle)]) manufacturer = [fleet_vehicle_id.model_id.brand_id.id for fleet_vehicle_id in fleet_vehicle_list] \ if data['manufacturer'] == 'null' else [int(data['manufacturer'])] if data['date'] == 'null': fleet_vehicle_odometer_ids = request.env[ 'fleet.vehicle.odometer'].search( [("vehicle_id", 'in', fleet_vehicle_list.ids), ("vehicle_id.brand_id", "in", manufacturer), ("driver_id", "in", driver)]) fleet_vehicle_log_contract_ids = request.env[ 'fleet.vehicle.log.contract'].search( [("vehicle_id.model_id", 'in', vehicle), ("vehicle_id.model_id.brand_id", 'in', manufacturer), ("state", "not in", ['expired', 'closed']), ("purchaser_id", "in", driver)]) fleet_vehicle_log_services_ids = request.env[ 'fleet.vehicle.log.services'].search( [("vehicle_id.model_id", 'in', vehicle), ("vehicle_id.model_id.brand_id", 'in', manufacturer), ("purchaser_id", "in", driver)]) else: range_date = date.today() - timedelta(days=int(data['date'])) fleet_vehicle_odometer_ids = request.env[ 'fleet.vehicle.odometer'].search( [("vehicle_id", 'in', fleet_vehicle_list.ids), ("vehicle_id.brand_id", "in", manufacturer), ("driver_id", "in", driver), ("date", ">", range_date)]) fleet_vehicle_log_contract_ids = request.env[ 'fleet.vehicle.log.contract'].search( [("vehicle_id.model_id", 'in', vehicle), ("vehicle_id.model_id.brand_id", 'in', manufacturer), ("state", "not in", ['expired', 'closed']), ("purchaser_id", "in", driver), ("expiration_date", ">", range_date)]) fleet_vehicle_log_services_ids = request.env[ 'fleet.vehicle.log.services'].search( [("vehicle_id.model_id", 'in', vehicle), ("vehicle_id.model_id.brand_id", 'in', manufacturer), ("purchaser_id", "in", driver), ("date", ">", range_date)]) total_odometer = sum(fleet_vehicle_odometer_ids.mapped('value')) admin_odometer_list = fleet_vehicle_odometer_ids.ids service_cost = sum(fleet_vehicle_log_services_ids.mapped('amount')) admin_fleet_cost_list = fleet_vehicle_log_services_ids.ids recurring_cost = sum( fleet_vehicle_log_contract_ids.mapped('cost_generated')) admin_recurring_list = fleet_vehicle_log_contract_ids.ids return [total_odometer, service_cost, recurring_cost, admin_odometer_list, admin_fleet_cost_list, admin_recurring_list, fleet_vehicle_list.ids, vehicle, manufacturer, len(fleet_vehicle_list.ids)]