From c5c21660bbecaaa6853915ba07a6ff4e1f80235d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-=C3=89tienne=20Lord?= Date: Fri, 25 Oct 2019 13:01:53 -0400 Subject: [PATCH 1/3] fix(coordinate) preproj of projected coord and UTM --- packages/geo/src/lib/map/shared/map.utils.ts | 43 ++++++++++++-------- 1 file changed, 25 insertions(+), 18 deletions(-) diff --git a/packages/geo/src/lib/map/shared/map.utils.ts b/packages/geo/src/lib/map/shared/map.utils.ts index b69a5b1e31..42e7751da0 100644 --- a/packages/geo/src/lib/map/shared/map.utils.ts +++ b/packages/geo/src/lib/map/shared/map.utils.ts @@ -54,8 +54,8 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu const dmsCoordPattern = `${dmsCoord}([N|S]),?\\s*${dmsCoord}([E|W])`; const dmsRegex = new RegExp(`^${dmsCoordPattern}`, 'gi'); - const patternUtmMtm = '(UTM|MTM)\-?(\\d{1,2})[\\s,.]*(\\d+[\\s.,]?\\d+)[\\s,.]+(\\d+[\\s.,]?\\d+)'; - const utmMtmRegex = new RegExp(`^${patternUtmMtm}`, 'gi'); + const patternUtm = '(UTM)\-?(\\d{1,2})[\\s,.]*(\\d+[\\s.,]?\\d+)[\\s,.]+(\\d+[\\s.,]?\\d+)'; + const utmRegex = new RegExp(`^${patternUtm}`, 'gi'); const ddCoord = '([-+])?(\\d{1,3})[,.](\\d+)'; const patternDd = `${ddCoord}[,.]?\\s*${ddCoord}`; @@ -73,8 +73,9 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu const mmPattern = `${mmCoord}[\\s,.]\\s*${mmCoord}`; const mmRegex = new RegExp(`^${mmPattern}$`, 'g'); - str = str.toLocaleUpperCase(); + let isXYCoords = false; + str = str.toLocaleUpperCase().trim(); // Extract projection if (projectionRegex.test(str)) { [coordStr, projectionStr] = str.split(';'); @@ -110,9 +111,10 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu lon = convertDMSToDD(parseFloat(degreesLon), parseFloat(minutesLon), parseFloat(secondsLon), directionLon); lat = convertDMSToDD(parseFloat(degreesLat), parseFloat(minutesLat), parseFloat(secondsLat), directionLat); - - } else if (utmMtmRegex.test(coordStr)) { - [, pattern, timeZone, lon, lat] = coordStr.match(patternUtmMtm); + + } else if (utmRegex.test(coordStr)) { + isXYCoords = true; + [, pattern, timeZone, lon, lat] = coordStr.match(patternUtm); const utm = '+proj=' + pattern + ' +zone=' + timeZone; const wgs84 = '+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs'; [lon, lat] = proj4(utm.toLocaleLowerCase(), wgs84, [parseFloat(lon), parseFloat(lat)]); @@ -179,8 +181,9 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu } else { lat = convertDMSToDD(parseFloat(degreesLat), parseFloat(minutesLat), parseFloat(secondsLat), directionLat); } - + } else if (mmRegex.test(coordStr)) { + isXYCoords = true; [, lon, decimalLon, lat, decimalLat] = coordStr.match(mmPattern); if (decimalLon) { @@ -195,20 +198,24 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu return {lonLat: undefined, message: '', radius: undefined, conf: undefined}; } - // Set a negative coordinate for North America zone - if (lon > 0 && lat > 0) { - if (lon > lat) { - lon = -lon; - } else { - lat = -lat; + if (!isXYCoords) { + // Set a negative coordinate for North America zone + if (lon > 0 && lat > 0) { + if (lon > lat) { + lon = -lon; + } else { + lat = -lat; + } } - } - // Reverse coordinate to respect lonLat convention - if (lon < lat) { - lonLat = [lon, lat] as [number, number]; + // Reverse coordinate to respect lonLat convention + if (lon < lat) { + lonLat = [lon, lat] as [number, number]; + } else { + lonLat = [lat, lon] as [number, number]; + } } else { - lonLat = [lat, lon] as [number, number]; + lonLat = [lon, lat] as [number, number]; } // Reproject the coordinate if projection parameter have been set and coord is not 4326 From be3aab5485d7f548dd9bf2e30840bc9b35d4af87 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-=C3=89tienne=20Lord?= Date: Fri, 25 Oct 2019 13:02:34 -0400 Subject: [PATCH 2/3] refactor(coordinates) round to 5 decimal --- packages/geo/src/lib/search/shared/sources/coordinates.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/geo/src/lib/search/shared/sources/coordinates.ts b/packages/geo/src/lib/search/shared/sources/coordinates.ts index 8a0085b5e9..567291acc0 100644 --- a/packages/geo/src/lib/search/shared/sources/coordinates.ts +++ b/packages/geo/src/lib/search/shared/sources/coordinates.ts @@ -85,7 +85,7 @@ export class CoordinatesReverseSearchSource extends SearchSource extent: undefined, properties: { type: 'point', - coordonnees: String(data[0]) + ', ' + String(data[1]), + coordonnees: String(data[0].toFixed(5)) + ', ' + String(data[1].toFixed(5)), format: 'degrés decimaux', systemeCoordonnees: 'WGS84', GoogleMaps: GoogleLinks.getGoogleMapsLink(data[0], data[1]), @@ -96,13 +96,13 @@ export class CoordinatesReverseSearchSource extends SearchSource }, meta: { id: '1', - title: String(data[0]) + ', ' + String(data[1]) + title: String(data[0].toFixed(5)) + ', ' + String(data[1].toFixed(5)) } }, meta: { dataType: FEATURE, id: '1', - title: String(data[0]) + ', ' + String(data[1]), + title: String(data[0].toFixed(5)) + ', ' + String(data[1].toFixed(5)), icon: 'map-marker' } }; From 3987ca54c514c3ce813acdf4b658abb65c5ad19b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pierre-=C3=89tienne=20Lord?= Date: Fri, 25 Oct 2019 14:10:58 -0400 Subject: [PATCH 3/3] lint --- packages/geo/src/lib/map/shared/map.utils.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/geo/src/lib/map/shared/map.utils.ts b/packages/geo/src/lib/map/shared/map.utils.ts index 42e7751da0..3b568eacc3 100644 --- a/packages/geo/src/lib/map/shared/map.utils.ts +++ b/packages/geo/src/lib/map/shared/map.utils.ts @@ -111,7 +111,7 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu lon = convertDMSToDD(parseFloat(degreesLon), parseFloat(minutesLon), parseFloat(secondsLon), directionLon); lat = convertDMSToDD(parseFloat(degreesLat), parseFloat(minutesLat), parseFloat(secondsLat), directionLat); - + } else if (utmRegex.test(coordStr)) { isXYCoords = true; [, pattern, timeZone, lon, lat] = coordStr.match(patternUtm); @@ -181,7 +181,7 @@ export function stringToLonLat(str: string, mapProjection: string): {lonLat: [nu } else { lat = convertDMSToDD(parseFloat(degreesLat), parseFloat(minutesLat), parseFloat(secondsLat), directionLat); } - + } else if (mmRegex.test(coordStr)) { isXYCoords = true; [, lon, decimalLon, lat, decimalLat] = coordStr.match(mmPattern);