2023-12-01 15:36:51 +05:30
|
|
|
"""
|
|
|
|
|
filters.py
|
|
|
|
|
"""
|
|
|
|
|
import uuid
|
2023-05-10 15:06:57 +05:30
|
|
|
import django_filters
|
|
|
|
|
from django import forms
|
2024-01-29 15:05:27 +05:30
|
|
|
from django.db import models
|
2023-12-01 15:36:51 +05:30
|
|
|
from base.methods import reload_queryset
|
2024-01-29 15:05:27 +05:30
|
|
|
from django_filters.filterset import FILTER_FOR_DBFIELD_DEFAULTS
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
FILTER_FOR_DBFIELD_DEFAULTS[models.ForeignKey]["filter_class"]=django_filters.ModelMultipleChoiceFilter
|
2023-05-10 15:06:57 +05:30
|
|
|
|
|
|
|
|
def filter_by_name(queryset, name, value):
|
|
|
|
|
"""
|
|
|
|
|
Filter queryset by first name or last name.
|
|
|
|
|
"""
|
|
|
|
|
# Split the search value into first name and last name
|
|
|
|
|
parts = value.split()
|
|
|
|
|
first_name = parts[0]
|
|
|
|
|
last_name = ' '.join(parts[1:]) if len(parts) > 1 else ''
|
|
|
|
|
|
|
|
|
|
# Filter the queryset by first name and last name
|
|
|
|
|
if first_name and last_name:
|
|
|
|
|
queryset = queryset.filter(employee_id__employee_first_name__icontains=first_name, employee_id__employee_last_name__icontains=last_name)
|
|
|
|
|
elif first_name:
|
|
|
|
|
queryset = queryset.filter(employee_id__employee_first_name__icontains=first_name)
|
|
|
|
|
elif last_name:
|
|
|
|
|
queryset = queryset.filter(employee_id__employee_last_name__icontains=last_name)
|
|
|
|
|
|
|
|
|
|
return queryset
|
|
|
|
|
|
|
|
|
|
class FilterSet(django_filters.FilterSet):
|
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
|
super().__init__(*args, **kwargs)
|
2023-12-01 15:36:51 +05:30
|
|
|
reload_queryset(self.form.fields)
|
|
|
|
|
for field_name, field in self.form.fields.items():
|
2023-05-10 15:06:57 +05:30
|
|
|
filter_widget = self.filters[field_name]
|
|
|
|
|
widget = filter_widget.field.widget
|
|
|
|
|
if isinstance(widget, (forms.NumberInput, forms.EmailInput,forms.TextInput)):
|
2023-12-01 15:36:51 +05:30
|
|
|
field.widget.attrs.update({'class': 'oh-input w-100'})
|
2023-05-10 15:06:57 +05:30
|
|
|
elif isinstance(widget,(forms.Select,)):
|
2023-12-01 15:36:51 +05:30
|
|
|
field.widget.attrs.update({'class': 'oh-select oh-select-2 select2-hidden-accessible','id':uuid.uuid4()})
|
2023-05-10 15:06:57 +05:30
|
|
|
elif isinstance(widget,(forms.Textarea)):
|
2023-12-01 15:36:51 +05:30
|
|
|
field.widget.attrs.update({'class': 'oh-input w-100'})
|
2023-05-10 15:06:57 +05:30
|
|
|
elif isinstance(widget, (forms.CheckboxInput,forms.CheckboxSelectMultiple,)):
|
2023-12-01 15:36:51 +05:30
|
|
|
field.widget.attrs.update({'class': 'oh-switch__checkbox'})
|
2023-05-10 15:06:57 +05:30
|
|
|
elif isinstance(widget,(forms.ModelChoiceField)):
|
2023-12-01 15:36:51 +05:30
|
|
|
field.widget.attrs.update({'class': 'oh-select oh-select-2 select2-hidden-accessible',})
|