forked from hans/Nominatim
Only link polygons on admin_centre is not already found a label AND if exactl search_rank match
This commit is contained in:
@@ -1484,12 +1484,14 @@ BEGIN
|
|||||||
|
|
||||||
END LOOP;
|
END LOOP;
|
||||||
|
|
||||||
|
IF NEW.centroid IS NULL THEN
|
||||||
|
|
||||||
FOR relMember IN select get_osm_rel_members(relation_members,ARRAY['admin_center','admin_centre']) as member LOOP
|
FOR relMember IN select get_osm_rel_members(relation_members,ARRAY['admin_center','admin_centre']) as member LOOP
|
||||||
|
|
||||||
select * from placex where osm_type = upper(substring(relMember.member,1,1))
|
select * from placex where osm_type = upper(substring(relMember.member,1,1))
|
||||||
and osm_id = substring(relMember.member,2,10000)::integer order by rank_search desc limit 1 into linkedPlacex;
|
and osm_id = substring(relMember.member,2,10000)::integer order by rank_search desc limit 1 into linkedPlacex;
|
||||||
|
|
||||||
IF NEW.name->'name' = linkedPlacex.name->'name' THEN
|
IF NEW.name->'name' = linkedPlacex.name->'name' AND NEW.rank_search = linkedPlacex.rank_search THEN
|
||||||
-- If we don't already have one use this as the centre point of the geometry
|
-- If we don't already have one use this as the centre point of the geometry
|
||||||
IF NEW.centroid IS NULL THEN
|
IF NEW.centroid IS NULL THEN
|
||||||
NEW.centroid := coalesce(linkedPlacex.centroid,st_centroid(linkedPlacex.geometry));
|
NEW.centroid := coalesce(linkedPlacex.centroid,st_centroid(linkedPlacex.geometry));
|
||||||
@@ -1508,6 +1510,8 @@ BEGIN
|
|||||||
|
|
||||||
END LOOP;
|
END LOOP;
|
||||||
|
|
||||||
|
END IF;
|
||||||
|
|
||||||
-- not found one yet? how about doing a name search
|
-- not found one yet? how about doing a name search
|
||||||
IF NEW.centroid IS NULL THEN
|
IF NEW.centroid IS NULL THEN
|
||||||
FOR linkedPlacex IN select placex.* from search_name join placex using (place_id) WHERE
|
FOR linkedPlacex IN select placex.* from search_name join placex using (place_id) WHERE
|
||||||
|
|||||||
Reference in New Issue
Block a user