include new fields for search request
This commit is contained in:
@@ -1,5 +1,10 @@
|
||||
const { currentSearchRequest } = require("../helpers/url");
|
||||
const { AD_CATEGORY, AD_TYPE } = require("../common/enums");
|
||||
const { AD_CATEGORY, AD_TYPE, ACCESS_ROAD_TYPE } = require("../common/enums");
|
||||
const {
|
||||
ADVANCED_BOOLEAN_FILTERS,
|
||||
ADVANCED_SEGMENT_SELECT_FILTERS,
|
||||
ADVANCED_RANGE_FILTERS
|
||||
} = require("../common/filterEnums");
|
||||
|
||||
const getFilters = async (req, res) => {
|
||||
const searchRequest = await currentSearchRequest(req);
|
||||
@@ -19,7 +24,18 @@ const getFilters = async (req, res) => {
|
||||
sizeMin,
|
||||
sizeMax,
|
||||
gardenSizeMin,
|
||||
gardenSizeMax
|
||||
gardenSizeMax,
|
||||
numberOfRoomsMin,
|
||||
numberOfRoomsMax,
|
||||
numberOfFloorsMin,
|
||||
numberOfFloorsMax,
|
||||
floorMin,
|
||||
floorMax,
|
||||
includeIncompleteAds,
|
||||
balcony,
|
||||
elevator,
|
||||
newBuilding,
|
||||
accessRoadType
|
||||
} = searchRequest;
|
||||
const category = AD_CATEGORY[realEstateType] || AD_CATEGORY.FLAT;
|
||||
|
||||
@@ -41,6 +57,40 @@ const getFilters = async (req, res) => {
|
||||
return;
|
||||
}
|
||||
|
||||
// TODO: Maybe this is slow, pay attention to this
|
||||
const filterFilters = filterObject => {
|
||||
const filterCategories = filterObject.categoriesToShow;
|
||||
return filterCategories.indexOf(category) !== -1;
|
||||
};
|
||||
|
||||
const advancedBooleanFilterObjects = ADVANCED_BOOLEAN_FILTERS.filter(
|
||||
filterFilters
|
||||
);
|
||||
const advancedSegmentSelectFilterObjects = ADVANCED_SEGMENT_SELECT_FILTERS.filter(
|
||||
filterFilters
|
||||
);
|
||||
const advancedRangeFilterObjects = ADVANCED_RANGE_FILTERS.filter(
|
||||
filterFilters
|
||||
);
|
||||
|
||||
const advancedBooleanFilterValues = {
|
||||
includeIncompleteAds,
|
||||
balcony,
|
||||
elevator,
|
||||
newBuilding
|
||||
};
|
||||
const advancedSegmentSelectFilterValues = {
|
||||
accessRoadType
|
||||
};
|
||||
const advancedRangeFilterValues = {
|
||||
numberOfFloorsMin,
|
||||
numberOfFloorsMax,
|
||||
numberOfRoomsMin,
|
||||
numberOfRoomsMax,
|
||||
floorMin,
|
||||
floorMax
|
||||
};
|
||||
|
||||
if (priceMin || priceMax) {
|
||||
priceSliderOptions.start = [priceMin, priceMax];
|
||||
}
|
||||
@@ -58,7 +108,14 @@ const getFilters = async (req, res) => {
|
||||
hasGardenSize,
|
||||
priceSliderOptions: JSON.stringify(priceSliderOptions),
|
||||
sizeSliderOptions: JSON.stringify(sizeSliderOptions),
|
||||
gardenSizeSliderOptions: JSON.stringify(gardenSizeSliderOptions)
|
||||
gardenSizeSliderOptions: JSON.stringify(gardenSizeSliderOptions),
|
||||
advancedBooleanFilterObjects,
|
||||
advancedBooleanFilterValues,
|
||||
advancedSegmentSelectFilterObjects,
|
||||
advancedSegmentSelectFilterValues,
|
||||
advancedRangeFilterObjects,
|
||||
advancedRangeFilterValues,
|
||||
includeIncompleteAds
|
||||
});
|
||||
};
|
||||
|
||||
@@ -78,13 +135,91 @@ const postFilters = async (req, res) => {
|
||||
const sizeMin = parseInt(req.body.sizeMin) || 0;
|
||||
const sizeMax = parseInt(req.body.sizeMax) || 0;
|
||||
|
||||
//TODO: Filter validation
|
||||
const advancedRangeFilters = {};
|
||||
|
||||
ADVANCED_RANGE_FILTERS.forEach(filter => {
|
||||
let parsingFunction = parseInt;
|
||||
if (filter.decimalPlaces) {
|
||||
parsingFunction = parseFloat;
|
||||
}
|
||||
|
||||
advancedRangeFilters[filter.dbFieldMin] = parsingFunction(
|
||||
req.body[filter.dbFieldMin]
|
||||
);
|
||||
advancedRangeFilters[filter.dbFieldMax] = parsingFunction(
|
||||
req.body[filter.dbFieldMax]
|
||||
);
|
||||
|
||||
advancedRangeFilters[filter.dbFieldMin] = isNaN(
|
||||
advancedRangeFilters[filter.dbFieldMin]
|
||||
)
|
||||
? null
|
||||
: advancedRangeFilters[filter.dbFieldMin];
|
||||
advancedRangeFilters[filter.dbFieldMax] = isNaN(
|
||||
advancedRangeFilters[filter.dbFieldMax]
|
||||
)
|
||||
? null
|
||||
: advancedRangeFilters[filter.dbFieldMax];
|
||||
|
||||
try {
|
||||
if (filter.decimalPlaces) {
|
||||
advancedRangeFilters[filter.dbFieldMin] = advancedRangeFilters[
|
||||
filter.dbFieldMin
|
||||
].toFixed(filter.decimalPlaces);
|
||||
advancedRangeFilters[filter.dbFieldMax] = advancedRangeFilters[
|
||||
filter.dbFieldMax
|
||||
].toFixed(filter.decimalPlaces);
|
||||
}
|
||||
} catch (e) {
|
||||
advancedRangeFilters[filter.dbFieldMin] = null;
|
||||
advancedRangeFilters[filter.dbFieldMax] = null;
|
||||
}
|
||||
|
||||
if (
|
||||
advancedRangeFilters[filter.dbFieldMin] < filter.validValueMin ||
|
||||
advancedRangeFilters[filter.dbFieldMin] > filter.validValueMax
|
||||
) {
|
||||
advancedRangeFilters[filter.dbFieldMin] = filter.validValueMin;
|
||||
}
|
||||
|
||||
if (
|
||||
advancedRangeFilters[filter.dbFieldMax] < filter.validValueMin ||
|
||||
advancedRangeFilters[filter.dbFieldMax] > filter.validValueMax
|
||||
) {
|
||||
advancedRangeFilters[filter.dbFieldMax] = filter.validValueMax;
|
||||
}
|
||||
});
|
||||
|
||||
const includeIncompleteAds = req.body.includeIncompleteAds === "on";
|
||||
|
||||
const balcony = req.body.balcony === "on";
|
||||
const elevator = req.body.elevator === "on";
|
||||
const newBuilding = req.body.newBuilding === "on";
|
||||
|
||||
const accessRoadType = req.body.accessRoadType;
|
||||
if (!ACCESS_ROAD_TYPE[accessRoadType]) {
|
||||
res.render("notFound", { title: " Greška !" });
|
||||
return;
|
||||
}
|
||||
|
||||
//TODO: Filter validation
|
||||
searchRequest.priceMin = priceMin;
|
||||
searchRequest.priceMax = priceMax;
|
||||
searchRequest.sizeMin = sizeMin;
|
||||
searchRequest.sizeMax = sizeMax;
|
||||
|
||||
for (const filter of Object.keys(advancedRangeFilters)) {
|
||||
searchRequest[filter] = advancedRangeFilters[filter];
|
||||
}
|
||||
|
||||
searchRequest.balcony = balcony;
|
||||
searchRequest.elevator = elevator;
|
||||
searchRequest.newBuilding = newBuilding;
|
||||
|
||||
searchRequest.includeIncompleteAds = includeIncompleteAds;
|
||||
|
||||
searchRequest.accessRoadType = accessRoadType;
|
||||
|
||||
if (
|
||||
req.body.gardenSizeMin !== undefined &&
|
||||
req.body.gardenSizeMax !== undefined
|
||||
|
||||
@@ -1,30 +1,69 @@
|
||||
<br>
|
||||
|
||||
<p>
|
||||
<label class="checkbox-label">
|
||||
<input type="checkbox" class="filled-in" />
|
||||
<span>Balkon</span>
|
||||
</label>
|
||||
</p>
|
||||
<% for (const filter of advancedBooleanFilterObjects){ %>
|
||||
<p>
|
||||
<label class="checkbox-label">
|
||||
<input type="checkbox" class="filled-in" name="<%= filter.dbField %>"
|
||||
<% if (advancedBooleanFilterValues[filter.dbField]) { %>
|
||||
checked
|
||||
<% } %>>
|
||||
<span><%= filter.title %></span>
|
||||
</label>
|
||||
</p>
|
||||
<% } %>
|
||||
|
||||
<p>
|
||||
<label class="checkbox-label">
|
||||
<input type="checkbox" class="filled-in" />
|
||||
<span>Novogradnja</span>
|
||||
</label>
|
||||
</p>
|
||||
<br>
|
||||
<% for (const filter of advancedRangeFilterObjects){ %>
|
||||
<div class="row">
|
||||
<p class="column-label col s5 m3 l2">
|
||||
<%= filter.title %>
|
||||
</p>
|
||||
<div class="input-field col s3 m4 l5">
|
||||
<input
|
||||
id="<%= filter.dbFieldMin %>"
|
||||
name="<%= filter.dbFieldMin %>"
|
||||
type="number"
|
||||
value="<%= advancedRangeFilterValues[filter.dbFieldMin] !== undefined ? advancedRangeFilterValues[filter.dbFieldMin] : ""%>"
|
||||
>
|
||||
<label for="<%= filter.dbFieldMin %>">Od</label>
|
||||
</div>
|
||||
<div class="input-field col s3 m4 l5">
|
||||
<input
|
||||
id="<%= filter.dbFieldMax %>"
|
||||
name="<%= filter.dbFieldMax %>"
|
||||
type="number"
|
||||
value="<%= advancedRangeFilterValues[filter.dbFieldMax] !== undefined ? advancedRangeFilterValues[filter.dbFieldMax] : ""%>"
|
||||
>
|
||||
<label for="<%= filter.dbFieldMax %>">Do</label>
|
||||
</div>
|
||||
</div>
|
||||
<% } %>
|
||||
|
||||
<p>
|
||||
<label class="checkbox-label">
|
||||
<input type="checkbox" class="filled-in" />
|
||||
<span>Lift</span>
|
||||
</label>
|
||||
</p>
|
||||
<br>
|
||||
<% for (const filter of advancedSegmentSelectFilterObjects){ %>
|
||||
<div>
|
||||
<label class="checkbox-label"><%= filter.title %>: </label><br><br>
|
||||
<span class="segmented small">
|
||||
<% for (const segmentObject of filter.values) { %>
|
||||
<label>
|
||||
<input type="radio" name="<%= filter.dbField %>" value="<%= segmentObject.id %>"
|
||||
<% if (advancedSegmentSelectFilterValues[filter.dbField] === segmentObject.id) { %>
|
||||
checked
|
||||
<% } %>>
|
||||
<span class="label"><%= segmentObject.title %></span>
|
||||
</label>
|
||||
<% } %>
|
||||
</span>
|
||||
</div>
|
||||
<% } %>
|
||||
|
||||
<br>
|
||||
<p class="distinguished">
|
||||
<label class="checkbox-label">
|
||||
<input type="checkbox" class="filled-in" />
|
||||
<span>Uključi oglase koji nemaju potpune informacije</span>
|
||||
<input type="checkbox" class="filled-in" name="includeIncompleteAds"
|
||||
<% if (includeIncompleteAds) { %>
|
||||
checked
|
||||
<% } %>>
|
||||
<span>Uključi i oglase bez potpunih informacija</span>
|
||||
</label>
|
||||
</p>
|
||||
|
||||
Reference in New Issue
Block a user