#1492 & #1556 : small corrections about those issues

This commit is contained in:
Laurent GAY 2024-10-31 10:52:47 +01:00
parent 861c445b63
commit 8044dbde86
2 changed files with 23 additions and 33 deletions

View file

@ -29,36 +29,26 @@
:placeholder="t('e.g. Nantes, Berlin, Cork, …')" :placeholder="t('e.g. Nantes, Berlin, Cork, …')"
v-on:update:modelValue="modelValueUpdate" v-on:update:modelValue="modelValueUpdate"
> >
<o-button <o-dropdown v-model="distance" position="bottom-right" v-if="distance">
v-if="distance" <template #trigger>
class="!h-auto" <o-button
icon-left="map-marker-distance" icon-left="map-marker-distance"
:title="t('Select distance')" :title="t('Select distance')"
@click="showDistance = !showDistance" />
/> </template>
<o-dropdown-item
v-for="distance_item in distanceList"
:value="distance_item.distance"
:label="distance_item.label"
:key="distance_item.distance"
/>
</o-dropdown>
</full-address-auto-complete> </full-address-auto-complete>
<o-button native-type="submit" icon-left="magnify"> <o-button native-type="submit" icon-left="magnify">
<template v-if="search">{{ t("Go!") }}</template> <template v-if="search">{{ t("Go!") }}</template>
<template v-else>{{ t("Explore!") }}</template> <template v-else>{{ t("Explore!") }}</template>
</o-button> </o-button>
</form> </form>
<div
class="border-black border-2 bg-white pt-1 pb-1 w-64 mx-auto"
v-if="showDistance"
>
<span class="mx-2 font-medium text-gray-900 dark:text-slate-100 text-left">
{{ t("Distance") }}
</span>
<select v-model="distance">
<option
v-for="distance_item in distanceList"
:value="distance_item.distance"
:key="distance_item.distance"
>
{{ distance_item.label }}
</option>
</select>
</div>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
@ -69,7 +59,7 @@ import {
getLocationFromLocal, getLocationFromLocal,
storeLocationInLocal, storeLocationInLocal,
} from "@/utils/location"; } from "@/utils/location";
import { computed, defineAsyncComponent, ref } from "vue"; import { computed, defineAsyncComponent } from "vue";
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import { useRouter, useRoute } from "vue-router"; import { useRouter, useRoute } from "vue-router";
import RouteName from "@/router/name"; import RouteName from "@/router/name";
@ -123,15 +113,12 @@ const search = computed({
}, },
}); });
const showDistance = ref(false);
const distance = computed({ const distance = computed({
get(): number { get(): number {
return props.distance; return props.distance;
}, },
set(newDistance: number) { set(newDistance: number) {
emit("update:distance", newDistance); emit("update:distance", newDistance);
showDistance.value = false;
}, },
}); });
@ -212,11 +199,11 @@ const submit = () => {
locationName: undefined, locationName: undefined,
lat: undefined, lat: undefined,
lon: undefined, lon: undefined,
search: search.value, search: undefined,
distance: undefined, distance: undefined,
}; };
if (distance.value != null) { if (search.value != "") {
search_query.distance = distance.value.toString() + "_km"; search_query.search = search.value;
} }
if (location.value) { if (location.value) {
const { lat, lon } = addressToLocation(location.value); const { lat, lon } = addressToLocation(location.value);
@ -224,6 +211,9 @@ const submit = () => {
location.value.locality ?? location.value.region; location.value.locality ?? location.value.region;
search_query.lat = lat; search_query.lat = lat;
search_query.lon = lon; search_query.lon = lon;
if (distance.value != null) {
search_query.distance = distance.value.toString() + "_km";
}
} }
router.push({ router.push({
name: RouteName.SEARCH, name: RouteName.SEARCH,

View file

@ -30,7 +30,7 @@
v-model:search="search" v-model:search="search"
v-model:location="location" v-model:location="location"
v-model:distance="distance" v-model:distance="distance"
:locationDefaultText="location?.description ?? userLocation?.name" :locationDefaultText="userLocation?.name"
v-on:update:location="updateLocation" v-on:update:location="updateLocation"
:fromLocalStorage="true" :fromLocalStorage="true"
/> />
@ -456,7 +456,7 @@ const userLocation = computed(() => {
const distance = computed({ const distance = computed({
get(): number | null { get(): number | null {
if (noLocation.value) { if (noLocation.value || !userLocation.value?.name) {
return null; return null;
} else if (current_distance.value == null) { } else if (current_distance.value == null) {
return userLocation.value?.isIPLocation ? 150 : 25; return userLocation.value?.isIPLocation ? 150 : 25;