From d658eda152c7aeace836db118fade8d345ae641d Mon Sep 17 00:00:00 2001 From: Matija Nalis Date: Thu, 3 Oct 2024 21:57:04 +0200 Subject: [PATCH] (Ask to) preserve amenity details when chosen NSI preset has the same type (#5944) * we shouldAlwaysReplaceShop only if the feature type actually changed * handle cases when either new or previous Feature is not from NSI * no need to even ask about removing data if neither names nor types changed * debug NSI * make hasChangedNames work even for NSI * remove debug * consolidate to Feature.featureId * simplify with parseLocalizedNames * smplify hasChangedFeatureType Co-authored-by: Tobias Zwick --------- Co-authored-by: Tobias Zwick --- .../overlays/places/PlacesOverlayForm.kt | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/de/westnordost/streetcomplete/overlays/places/PlacesOverlayForm.kt b/app/src/main/java/de/westnordost/streetcomplete/overlays/places/PlacesOverlayForm.kt index fb9699e674..39f6346ebe 100644 --- a/app/src/main/java/de/westnordost/streetcomplete/overlays/places/PlacesOverlayForm.kt +++ b/app/src/main/java/de/westnordost/streetcomplete/overlays/places/PlacesOverlayForm.kt @@ -246,6 +246,9 @@ class PlacesOverlayForm : AbstractOverlayForm() { } } +/** return the id of the feature, without any brand stuff */ +private val Feature.featureId get() = if (isSuggestion) id.substringBeforeLast("/") else id + private suspend fun createEditAction( element: Element?, geometry: ElementGeometry, @@ -259,24 +262,32 @@ private suspend fun createEditAction( val tagChanges = StringMapChangesBuilder(element?.tags ?: emptyMap()) val hasAddedNames = previousNames.isEmpty() && newNames.isNotEmpty() - val hasChangedNames = previousNames != newNames + var hasChangedNames = previousNames != newNames val hasChangedFeature = newFeature != previousFeature + val hasChangedFeatureType = previousFeature?.featureId != newFeature.featureId val isFeatureWithName = newFeature.addTags.get("name") != null val wasFeatureWithName = previousFeature?.addTags?.get("name") != null val wasVacant = element != null && element.isDisusedPlace() val isVacant = newFeature.id == "shop/vacant" + if (newFeature.isSuggestion) { + // selecting NSI preset will always return empty newNames, even if NSI does set new name=* tag + hasChangedNames = parseLocalizedNames(newFeature.addTags) != previousNames + } + val shouldNotReplaceShop = + // if NSI added e.g. wikidata details, but neither names nor types changed (see #5940) + !hasChangedNames && !hasChangedFeatureType // only a name was added (name was missing before; user wouldn't be able to answer // if the place changed or not anyway, so rather keep previous information) - hasAddedNames && !hasChangedFeature + || hasAddedNames && !hasChangedFeature // previously: only the feature was changed, the non-empty name did not change // - see #5195 // place has been added, nothing to replace || element == null val shouldAlwaysReplaceShop = - // the feature is or was a brand feature (i.e. overwrites the name) - isFeatureWithName || wasFeatureWithName + // the feature is or was a brand feature (i.e. overwrites the name) and the type has changed + (isFeatureWithName || wasFeatureWithName) && hasChangedFeatureType // was vacant before but not anymore (-> cleans up any previous tags that may be // associated with the old place) || wasVacant && hasChangedFeature