-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathfilters.py
More file actions
131 lines (111 loc) · 4.2 KB
/
filters.py
File metadata and controls
131 lines (111 loc) · 4.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
from django.db.models import QuerySet, Q, F
from django_filters import rest_framework as filters
from vacancy.models import Vacancy
from vacancy.constants import (
WorkExperience,
WorkSchedule,
WorkFormat,
)
def project_id_filter(queryset, name, value) -> QuerySet:
return queryset.filter(
**{
"project_id": value[0],
}
)
class VacancyFilter(filters.FilterSet):
"""Filter for Vacancies
Adds filtering to DRF list retrieve views
Parameters to filter by:
project_id (int),
is_active (boolean) (default to True if not set otherwise),
required_experience (multiple choise)
work_schedule (multiple choise)
work_format (multiple choise)
salary_min (int)
salary_max (int)
Examples:
?project_id=1 equals to .filter(project_id=1)
(no params passed) equals to .filter(is_active=True)
?is_active=false equals to .filter(is_active=False)
?work_schedule=full_time&work_schedule=part_time equals to .filter(required_experience__in=value)
?salary_min=100&salary_max=150 equals to .filter(salary__range=(100, 150))
"""
def __init__(self, *args, **kwargs):
"""if is_active filter is not passed, default to True"""
super().__init__(*args, **kwargs)
if self.data.get("is_active") is None:
self.data = dict(self.data)
self.data["is_active"] = True
def filter_by_experience(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
return queryset.filter(
Q(required_experience__in=value) | Q(required_experience=None)
).order_by(F("required_experience").asc(nulls_last=True))
def filter_by_schedule(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
return queryset.filter(
Q(work_schedule__in=value) | Q(work_schedule=None)
).order_by(F("work_schedule").asc(nulls_last=True))
def filter_by_format(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
return queryset.filter(Q(work_format__in=value) | Q(work_format=None)).order_by(
F("work_format").asc(nulls_last=True)
)
def filter_by_salary_min(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
try:
min_salary = int(value[0])
return queryset.filter(Q(salary__gte=min_salary) | Q(salary=None)).order_by(
F("salary").asc(nulls_last=True)
)
except ValueError:
return queryset
def filter_by_salary_max(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
try:
max_salary = int(value[0])
return queryset.filter(Q(salary__lte=max_salary) | Q(salary=None)).order_by(
F("salary").asc(nulls_last=True)
)
except ValueError:
return queryset
def filter_by_role(
self, queryset: QuerySet[Vacancy], name, value: list[str]
) -> QuerySet[Vacancy]:
if not value:
return queryset
return queryset.filter(role__icontains=value[0])
project_id = filters.Filter(method=project_id_filter)
is_active = filters.BooleanFilter(field_name="is_active")
required_experience = filters.MultipleChoiceFilter(
method="filter_by_experience",
choices=WorkExperience.choices(),
)
work_schedule = filters.MultipleChoiceFilter(
method="filter_by_schedule",
choices=WorkSchedule.choices(),
)
work_format = filters.MultipleChoiceFilter(
method="filter_by_format",
choices=WorkFormat.choices(),
)
role_contains = filters.Filter(method="filter_by_role")
salary_min = filters.Filter(method="filter_by_salary_min")
salary_max = filters.Filter(method="filter_by_salary_max")
class Meta:
model = Vacancy
fields = (
"role_contains",
"project_id",
"is_active",
"required_experience",
"work_schedule",
"work_format",
"salary_min",
"salary_max",
)