You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

148 lines
7.3 KiB

# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Yadhukrishnan K (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
################################################################################
from 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]]
filter_list = [driver_list, vehicle_list, manufacturers_list]
return filter_list
@http.route('/fleet_dashboard/filter_data', auth='public', type='json')
def fleet_filter_data(self, **kw):
"""
Summary:
transferring data to the selection field that works as a filter
Args:
kw(dict):This parameter contain value of selection field
Returns:
type:list of lists , it contains the data for the corresponding
filter and transferring data to ui after filtration.
"""
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", '=', rec)]).id for rec in vehicle]
manufacturer = [fleet_vehicle_id.model_id.brand_id.id for
fleet_vehicle_id in
request.env['fleet.vehicle'].search([])] \
if data['manufacturer'] == 'null' else [int(data['manufacturer'])]
if data['date'] == 'null':
fleet_vehicle_odometer_ids = request.env[
'fleet.vehicle.odometer'].search(
[("vehicle_id.id", 'in', vehicle),
("vehicle_id.brand_id.id", "in", manufacturer),
("driver_id.id", "in", driver)])
fleet_vehicle_log_contract_ids = request.env[
'fleet.vehicle.log.contract'].search(
[("vehicle_id.model_id.id", 'in', vehicle),
("vehicle_id.model_id.brand_id.id", 'in', manufacturer),
("state", "not in", ['expired', 'closed']),
("purchaser_id.id", "in", driver)])
fleet_vehicle_log_services_ids = request.env[
'fleet.vehicle.log.services'].search(
[("vehicle_id.model_id.id", 'in', vehicle),
("vehicle_id.model_id.brand_id.id", 'in', manufacturer),
("purchaser_id.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.id", 'in', vehicle),
("vehicle_id.brand_id.id", "in", manufacturer),
("driver_id.id", "in", driver),
("date", ">", range_date)])
fleet_vehicle_log_contract_ids = request.env[
'fleet.vehicle.log.contract'].search(
[("vehicle_id.model_id.id", 'in', vehicle),
("vehicle_id.model_id.brand_id.id", 'in', manufacturer),
("state", "not in", ['expired', 'closed']),
("purchaser_id.id", "in", driver),
("expiration_date", ">", range_date)])
fleet_vehicle_log_services_ids = request.env[
'fleet.vehicle.log.services'].search(
[("vehicle_id.model_id.id", 'in', vehicle),
("vehicle_id.model_id.brand_id.id", 'in', manufacturer),
("purchaser_id.id", "in", driver), ("date", ">", range_date)])
# Getting total odometer value
total_odometer = sum(fleet_vehicle_odometer_ids.mapped('value'))
admin_odometer_list = [fleet_vehicle_odometer_id.id for
fleet_vehicle_odometer_id in
fleet_vehicle_odometer_ids]
# Getting total service cost
service_cost = sum(fleet_vehicle_log_services_ids.mapped('amount'))
admin_fleet_cost_list = [fleet_vehicle_log_services_id.id for
fleet_vehicle_log_services_id in
fleet_vehicle_log_services_ids]
# Getting total recurring cost
recurring_cost = sum(
fleet_vehicle_log_contract_ids.mapped('cost_generated'))
admin_recurring_list = [fleet_vehicle_log_contract_id.id for
fleet_vehicle_log_contract_id in
fleet_vehicle_log_contract_ids]
return [total_odometer, service_cost, recurring_cost,
admin_odometer_list, admin_fleet_cost_list,
admin_recurring_list, fleet_vehicle_list, vehicle,
manufacturer, len(fleet_vehicle_list)]