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
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)]
|
|
|