... | ... |
@@ -133,6 +133,19 @@ |
133 | 133 |
<source>Tiefgaragenstellplatz</source> |
134 | 134 |
</trans-unit> |
135 | 135 |
|
136 |
+ <trans-unit id="REF.re_filter.numberOfRooms"> |
|
137 |
+ <source>Zimmeranzahl</source> |
|
138 |
+ </trans-unit> |
|
139 |
+ <trans-unit id="REF.re_filter.city"> |
|
140 |
+ <source>Ort</source> |
|
141 |
+ </trans-unit> |
|
142 |
+ <trans-unit id="REF.re_filter.coldRent"> |
|
143 |
+ <source>Kaltmiete</source> |
|
144 |
+ </trans-unit> |
|
145 |
+ <trans-unit id="REF.re_filter.livingSpace"> |
|
146 |
+ <source>Wohnfläche</source> |
|
147 |
+ </trans-unit> |
|
148 |
+ |
|
136 | 149 |
</body> |
137 | 150 |
</file> |
138 | 151 |
</xliff> |
... | ... |
@@ -14,15 +14,17 @@ |
14 | 14 |
<div class="content-grid"> |
15 | 15 |
<div class="fragments"> |
16 | 16 |
<form class="assets-list-filter" hx-get="{{ pageUrl is defined ? pageUrl : '' }}" hx-push-url="true" hx-headers='{"VR-Ajax": "ReAssetsList"}' hx-trigger="change, submit" hx-target="closest .module-vr-re-assets-list" hx-target="" class="filter"> |
17 |
- {% if filterOptions.rooms is defined %} |
|
18 |
- <div class="filter-wrapper"> |
|
19 |
- <select name="filter_zimmer"> |
|
20 |
- <option value="">Anzahl Zimmer</option> |
|
21 |
- {% for option in filterOptions.rooms %} |
|
22 |
- <option value="{{ option.value }}"{% if filter.rooms is defined and filter.rooms == option.value %} selected{% endif %}>{{ option.label }}</option> |
|
23 |
- {% endfor %} |
|
24 |
- </select> |
|
25 |
- </div> |
|
17 |
+ {% if filterOptions is defined and filterOptions is iterable %} |
|
18 |
+ {% for key, options in filterOptions %} |
|
19 |
+ <div class="filter-wrapper"> |
|
20 |
+ <select name="filter[{{ key }}]"> |
|
21 |
+ <option value="">{{ ('REF.re_filter.' ~ key)|trans({}, 'contao_default') }}</option> |
|
22 |
+ {% for value, label in options %} |
|
23 |
+ <option value="{{ value }}"{% if filter[key] is defined and filter[key] == value %} selected{% endif %}>{{ label }}</option> |
|
24 |
+ {% endfor %} |
|
25 |
+ </select> |
|
26 |
+ </div> |
|
27 |
+ {% endfor %} |
|
26 | 28 |
{% endif %} |
27 | 29 |
</form> |
28 | 30 |
</div> |
... | ... |
@@ -13,6 +13,7 @@ use Contao\CoreBundle\DependencyInjection\Attribute\AsFrontendModule; |
13 | 13 |
use Contao\CoreBundle\Exception\ResponseException; |
14 | 14 |
use Contao\CoreBundle\Image\Studio\Studio; |
15 | 15 |
use Contao\CoreBundle\Twig\FragmentTemplate; |
16 |
+use Contao\Input; |
|
16 | 17 |
use Contao\ModuleModel; |
17 | 18 |
use Contao\PageModel; |
18 | 19 |
use Contao\StringUtil; |
... | ... |
@@ -36,17 +37,44 @@ class RealEstateAssetsListController extends RealEstateAssetsModuleController |
36 | 37 |
$this->translator = $translator; |
37 | 38 |
} |
38 | 39 |
|
39 |
- |
|
40 | 40 |
protected function getResponse(FragmentTemplate $template, ModuleModel $model, Request $request): Response |
41 | 41 |
{ |
42 | 42 |
$arrGroups = []; |
43 |
- $arrFilterOptions = []; |
|
43 |
+ $arrFilterOptions = [ |
|
44 |
+ 'numberOfRooms' => [], |
|
45 |
+ 'coldRent' => [], |
|
46 |
+ 'livingSpace' => [], |
|
47 |
+ 'city' => [] |
|
48 |
+ ]; |
|
49 |
+ $arrFilterSelected = []; |
|
50 |
+ $arrAssetsOptions = []; |
|
44 | 51 |
|
45 | 52 |
$jumpTo = PageModel::findByPk($model->jumpTo); |
46 | 53 |
$urlGenerator = System::getContainer()->get('contao.routing.content_url_generator'); |
47 | 54 |
|
55 |
+ // Filter |
|
56 |
+ if (isset($_GET['filter']) && \is_array(Input::get('filter'))) |
|
57 |
+ { |
|
58 |
+ foreach (Input::get('filter') as $filter=>$value) |
|
59 |
+ { |
|
60 |
+ if (in_array($filter, array_keys($arrFilterOptions)) && !empty($value)) |
|
61 |
+ { |
|
62 |
+ $rawValue = StringUtil::decodeEntities($value); |
|
63 |
+ $arrFilterSelected[$filter] = $rawValue; |
|
64 |
+ |
|
65 |
+ if (preg_match('/^.*<>.*$/',$rawValue)) |
|
66 |
+ { |
|
67 |
+ list($start,$stop) = preg_split('/<>/',$rawValue, 2); |
|
68 |
+ $arrAssetsOptions['column'][] = "$filter BETWEEN $start AND $stop"; |
|
69 |
+ } else { |
|
70 |
+ $arrAssetsOptions['column'][] = "$filter = ?"; |
|
71 |
+ $arrAssetsOptions['value'][] = $rawValue; |
|
72 |
+ } |
|
73 |
+ } |
|
74 |
+ } |
|
75 |
+ } |
|
48 | 76 |
|
49 |
- if (($assets = $this->getRealEstateAssets(StringUtil::deserialize($model->vr_re_categories))) === null) |
|
77 |
+ if (($assets = $this->getRealEstateAssets(StringUtil::deserialize($model->vr_re_categories),$arrAssetsOptions)) === null) |
|
50 | 78 |
{ |
51 | 79 |
return $template->getResponse(); |
52 | 80 |
} |
... | ... |
@@ -85,14 +113,34 @@ class RealEstateAssetsListController extends RealEstateAssetsModuleController |
85 | 113 |
// Filter options |
86 | 114 |
if (!empty($asset->numberOfRooms)) |
87 | 115 |
{ |
88 |
- $arrFilterOptions['rooms'][] = ['value'=>$asset->numberOfRooms, 'label'=>$asset->numberOfRooms . ' ' . ($asset->numberOfRooms > 1 ? $this->translator->trans('MSC.re_rooms', [], 'contao_default') : $this->translator->trans('MSC.re_room', [], 'contao_default'))]; |
|
116 |
+ $arrFilterOptions['numberOfRooms'][$asset->numberOfRooms] = $asset->numberOfRooms . ' ' . ($asset->numberOfRooms > 1 ? $this->translator->trans('MSC.re_rooms', [], 'contao_default') : $this->translator->trans('MSC.re_room', [], 'contao_default')); |
|
117 |
+ } |
|
118 |
+ if (!empty($asset->city)) |
|
119 |
+ { |
|
120 |
+ $arrFilterOptions['city'][$asset->city] = $asset->city; |
|
121 |
+ } |
|
122 |
+ if (!empty($asset->coldRent)) |
|
123 |
+ { |
|
124 |
+ $rangeStart = floor($asset->coldRent / 100) * 100; |
|
125 |
+ $rangeEnd = $rangeStart + 99; |
|
126 |
+ $arrFilterOptions['coldRent'][$rangeStart.'<>'.$rangeEnd] = $rangeStart . ' - ' . $rangeEnd . ' €'; |
|
127 |
+ } |
|
128 |
+ if (!empty($asset->livingSpace)) |
|
129 |
+ { |
|
130 |
+ $rangeStart = floor($asset->livingSpace / 10) * 10; |
|
131 |
+ $rangeEnd = $rangeStart + 9; |
|
132 |
+ $arrFilterOptions['livingSpace'][$rangeStart.'<>'.$rangeEnd] = $rangeStart . ' - ' . $rangeEnd . ' m²'; |
|
89 | 133 |
} |
90 | 134 |
|
91 | 135 |
} |
92 | 136 |
|
93 |
- $arrFilterOptions = array_unique($arrFilterOptions); |
|
137 |
+ foreach (array_keys($arrFilterOptions) as $filterName) |
|
138 |
+ { |
|
139 |
+ $arrFilterOptions[$filterName] = array_unique($arrFilterOptions[$filterName]); |
|
140 |
+ } |
|
94 | 141 |
|
95 | 142 |
$template->set('filterOptions',$arrFilterOptions); |
143 |
+ $template->set('filter',$arrFilterSelected); |
|
96 | 144 |
$template->set('groups',$arrGroups); |
97 | 145 |
|
98 | 146 |
// Handle ajax |
... | ... |
@@ -21,14 +21,14 @@ abstract class RealEstateAssetsModuleController extends AbstractFrontendModuleCo |
21 | 21 |
* |
22 | 22 |
* @return RealEstateAssetsModel|RealEstateAssetsModel[]|Collection|null |
23 | 23 |
*/ |
24 |
- public function getRealEstateAssets($arrCategories) |
|
24 |
+ public function getRealEstateAssets($arrCategories, array $arrOptions=array()) |
|
25 | 25 |
{ |
26 | 26 |
if (empty($arrCategories) || !\is_array($arrCategories)) |
27 | 27 |
{ |
28 | 28 |
return null; |
29 | 29 |
} |
30 | 30 |
|
31 |
- return RealEstateAssetsModel::findPublishedByParent($arrCategories); |
|
31 |
+ return RealEstateAssetsModel::findPublishedByParent($arrCategories, 0,0,$arrOptions); |
|
32 | 32 |
} |
33 | 33 |
|
34 | 34 |
/** |