Subversion Repositories eFlore/Applications.cel

Rev

Go to most recent revision | Blame | Last modification | View Log | RSS feed

(window["webpackJsonp"] = window["webpackJsonp"] || []).push([["main"],{

/***/ "./dist/tb-geoloc-lib/fesm5/tb-geoloc-lib.js":
/*!***************************************************!*\
  !*** ./dist/tb-geoloc-lib/fesm5/tb-geoloc-lib.js ***!
  \***************************************************/
/*! exports provided: TbGeolocLibModule, TbGeolocLibComponent, MapComponent, GeocodingService, ElevationService, ɵa */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TbGeolocLibModule", function() { return TbGeolocLibModule; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TbGeolocLibComponent", function() { return TbGeolocLibComponent; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MapComponent", function() { return MapComponent; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GeocodingService", function() { return GeocodingService; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ElevationService", function() { return ElevationService; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ɵa", function() { return OsmPlaceReadableAddressPipe; });
/* harmony import */ var _angular_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @angular/core */ "./node_modules/@angular/core/fesm5/core.js");
/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! leaflet */ "./node_modules/leaflet/dist/leaflet-src.js");
/* harmony import */ var leaflet__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(leaflet__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _angular_common_http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @angular/common/http */ "./node_modules/@angular/common/fesm5/http.js");
/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! rxjs */ "./node_modules/rxjs/_esm5/index.js");
/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! rxjs/operators */ "./node_modules/rxjs/_esm5/operators/index.js");
/* harmony import */ var _angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @angular/compiler/src/util */ "./node_modules/@angular/compiler/src/util.js");
/* harmony import */ var _angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _angular_forms__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @angular/forms */ "./node_modules/@angular/forms/fesm5/forms.js");
/* harmony import */ var leaflet_draw__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! leaflet-draw */ "./node_modules/leaflet-draw/dist/leaflet.draw.js");
/* harmony import */ var leaflet_draw__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(leaflet_draw__WEBPACK_IMPORTED_MODULE_7__);
/* harmony import */ var _angular_common__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @angular/common */ "./node_modules/@angular/common/fesm5/common.js");
/* harmony import */ var _angular_platform_browser_animations__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @angular/platform-browser/animations */ "./node_modules/@angular/platform-browser/fesm5/animations.js");
/* harmony import */ var _angular_platform_browser__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @angular/platform-browser */ "./node_modules/@angular/platform-browser/fesm5/platform-browser.js");
/* harmony import */ var _angular_material__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! @angular/material */ "./node_modules/@angular/material/esm5/material.es5.js");
/* harmony import */ var _asymmetrik_ngx_leaflet__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! @asymmetrik/ngx-leaflet */ "./node_modules/@asymmetrik/ngx-leaflet/dist/index.js");
/* harmony import */ var _asymmetrik_ngx_leaflet_draw__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @asymmetrik/ngx-leaflet-draw */ "./node_modules/@asymmetrik/ngx-leaflet-draw/dist/index.js");















/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
var TbGeolocLibComponent = /** @class */ (function () {
    function TbGeolocLibComponent() {
    }
    /**
     * @return {?}
     */
    TbGeolocLibComponent.prototype.ngOnInit = /**
     * @return {?}
     */
    function () {
    };
    TbGeolocLibComponent.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Component"], args: [{
                    selector: 'tb-geoloc-tb-geoloc-lib',
                    template: "",
                    styles: []
                },] },
    ];
    /** @nocollapse */
    TbGeolocLibComponent.ctorParameters = function () { return []; };
    return TbGeolocLibComponent;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
/**
 * GeoPoint
 *
 * https://github.com/perfectline/geopoint
 *
 * Authors :
 * Tanel Suurhans (http://twitter.com/tanelsuurhans)
 * Tarmo Lehtpuu (http://twitter.com/tarmolehtpuu)
 *
 * License :
 * Copyright 2011 by PerfectLine LLC (http://www.perfectline.ee) and is released under the MIT license.
 */
/** @type {?} */
var GeoPoint = function (lon, lat) {
    switch (typeof (lon)) {
        case 'number':
            this.lonDeg = this.dec2deg(lon, this.MAX_LON);
            this.lonDec = lon;
            break;
        case 'string':
            if (this.decode(lon)) {
                this.lonDeg = lon;
            }
            this.lonDec = this.deg2dec(lon, this.MAX_LON);
            break;
    }
    switch (typeof (lat)) {
        case 'number':
            this.latDeg = this.dec2deg(lat, this.MAX_LAT);
            this.latDec = lat;
            break;
        case 'string':
            if (this.decode(lat)) {
                this.latDeg = lat;
            }
            this.latDec = this.deg2dec(lat, this.MAX_LAT);
            break;
    }
};
GeoPoint.prototype = {
    CHAR_DEG: '\u00B0',
    CHAR_MIN: '\u0027',
    CHAR_SEC: '\u0022',
    CHAR_SEP: '\u0020',
    MAX_LON: 180,
    MAX_LAT: 90,
    // decimal
    lonDec: NaN,
    latDec: NaN,
    // degrees
    lonDeg: NaN,
    latDeg: NaN,
    dec2deg: function (value, max) {
        /** @type {?} */
        var sign = value < 0 ? -1 : 1;
        /** @type {?} */
        var abs = Math.abs(Math.round(value * 1000000));
        if (abs > (max * 1000000)) {
            return NaN;
        }
        /** @type {?} */
        var dec = abs % 1000000 / 1000000;
        /** @type {?} */
        var deg = Math.floor(abs / 1000000) * sign;
        /** @type {?} */
        var min = Math.floor(dec * 60);
        /** @type {?} */
        var sec = (dec - min / 60) * 3600;
        /** @type {?} */
        var result = '';
        result += deg;
        result += this.CHAR_DEG;
        result += this.CHAR_SEP;
        result += min;
        result += this.CHAR_MIN;
        result += this.CHAR_SEP;
        result += sec.toFixed(2);
        result += this.CHAR_SEC;
        return result;
    },
    deg2dec: function (value) {
        /** @type {?} */
        var matches = this.decode(value);
        if (!matches) {
            return NaN;
        }
        /** @type {?} */
        var deg = parseFloat(matches[1]);
        /** @type {?} */
        var min = parseFloat(matches[2]);
        /** @type {?} */
        var sec = parseFloat(matches[3]);
        if (isNaN(deg) || isNaN(min) || isNaN(sec)) {
            return NaN;
        }
        return deg + (min / 60.0) + (sec / 3600);
    },
    decode: function (value) {
        /** @type {?} */
        var pattern = '';
        // deg
        pattern += '(-?\\d+)';
        pattern += this.CHAR_DEG;
        pattern += '\\s*';
        // min
        pattern += '(\\d+)';
        pattern += this.CHAR_MIN;
        pattern += '\\s*';
        // sec
        pattern += '(\\d+(?:\\.\\d+)?)';
        pattern += this.CHAR_SEC;
        return value.match(new RegExp(pattern));
    },
    getLonDec: function () {
        return this.lonDec;
    },
    getLatDec: function () {
        return this.latDec;
    },
    getLonDeg: function () {
        return this.lonDeg;
    },
    getLatDeg: function () {
        return this.latDeg;
    }
};

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
/** *
 *
 * \@param lat
 * \@param lng
 * \@param dragend callback
  @type {?} */
var draggableMarker = function (lat, lng, dragend) {
    /** @type {?} */
    var simpleIcon = simpleIconMarker();
    /** @type {?} */
    var marker$$1 = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["marker"])([lat, lng], { icon: simpleIcon, draggable: true });
    marker$$1.on('dragend', function (event) { return dragend(event); });
    return marker$$1;
};
/** *
 *
  @type {?} */
var simpleIconMarker = function () {
    return Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["icon"])({
        iconUrl: './assets/img/map/marker-icon.png',
        shadowUrl: './assets/img/map/marker-shadow.png',
        iconAnchor: [13, 40]
    });
};
/** *
 *
  @type {?} */
var drawControlPanel = new leaflet__WEBPACK_IMPORTED_MODULE_1__["Control"].Draw({
    position: 'topleft',
    draw: {
        marker: { icon: simpleIconMarker() },
        polyline: {},
        polygon: { showArea: true, metric: false },
        rectangle: false,
        circle: false,
        circlemarker: false
    }
});
/**
 *
 * @param {?} editedLayer
 * @return {?}
 */
function drawControlEditPanel(editedLayer) {
    return new leaflet__WEBPACK_IMPORTED_MODULE_1__["Control"].Draw({
        position: 'topleft',
        draw: {
            marker: false,
            polyline: false,
            polygon: false,
            rectangle: false,
            circle: false,
            circlemarker: false
        },
        edit: {
            featureGroup: editedLayer,
            // this panel id editing editedLayer
            edit: {},
            remove: {}
        }
    });
}
/** *
 *
  @type {?} */
var circleMarkerStyle = {
    radius: 6,
    fillColor: '#ff7800',
    color: '#000',
    weight: 1,
    opacity: 1,
    fillOpacity: 0.8
};
/** *
 *
  @type {?} */
var cityStyle = {
    color: '#ff7800',
    weight: 5,
    opacity: 0.65
};
/** *
 *
  @type {?} */
var gpsPhotoMarkerIcon = function () {
    return Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["icon"])({
        iconUrl: './assets/img/map/photo-marker-icon.png',
        shadowUrl: './assets/img/map/marker-shadow.png',
        iconSize: [33, 41],
        // size of the icon
        // shadowSize:   [50, 64], // size of the shadow
        iconAnchor: [13, 40],
        // point of the icon which will correspond to marker's location
        // shadowAnchor: [4, 62],  // the same for the shadow
        popupAnchor: [5, -41] // point from which the popup should open relative to the iconAnchor
    });
};

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
/**
 * Auto format a DMS coordinates
 * eg. user can enter 43 0 14.77
 * and the formatter returns 43° 0' 14.77"
 * + avoid enter non numeric (or . ,) characters
 * + force entire numbers for degrees and minutes
 * @param {?} dmsStr
 * @return {?}
 */
function dmsFormatter(dmsStr) {
    try {
        // replace multiples spaces
        dmsStr = dmsStr.replace(/\s\s+/g, ' ');
        // replace space at first position
        if (dmsStr.charAt(0) === ' ') {
            dmsStr = dmsStr.slice(1, dmsStr.length - 1);
        }
        // replace , by .
        dmsStr = dmsStr.replace(',', '.');
        // delete all non numeric characters
        dmsStr = dmsStr.replace(/[^0-9\-.,°\'"\s]/g, '');
        /** @type {?} */
        var nbSpaces = void 0;
        /** @type {?} */
        var degChr = '';
        /** @type {?} */
        var minChr = '';
        /** @type {?} */
        var secChr = '';
        /** @type {?} */
        var v = dmsStr.split(' ');
        // remove last space od input string
        if (dmsStr.charAt(dmsStr.length - 1) === ' ') {
            v = v.slice(0, v.length - 1);
        }
        // remove last item of v array if it's empty
        if (v[v.length - 1] === '') {
            v = v.slice(0, v.length - 1);
        }
        if (v.length === 1) {
            degChr = v[0];
            // degChr must be an entire number
            if (degChr.indexOf('.') !== -1) {
                degChr = degChr.slice(0, degChr.indexOf('.'));
            }
            // between -90 & +90
            if (Number(degChr) < -90) {
                degChr = '-90';
            }
            if (Number(degChr) > 90) {
                degChr = '90';
            }
        }
        if (v.length === 2) {
            degChr = v[0];
            minChr = v[1];
            if (degChr.indexOf('.') !== -1) {
                degChr = degChr.slice(0, degChr.indexOf('.'));
            }
            if (minChr.indexOf('.') !== -1) {
                minChr = minChr.slice(0, degChr.indexOf('.'));
            }
            if (Number(degChr) < -90) {
                degChr = '-90';
            }
            if (Number(degChr) > 90) {
                degChr = '90';
            }
            if (Number(minChr) < -90) {
                minChr = '-90';
            }
            if (Number(minChr) > 90) {
                minChr = '90';
            }
        }
        if (v.length === 3) {
            degChr = v[0];
            minChr = v[1];
            secChr = v[2];
            if (degChr.indexOf('.') !== -1) {
                degChr = degChr.slice(0, degChr.indexOf('.'));
            }
            if (minChr.indexOf('.') !== -1) {
                minChr = minChr.slice(0, degChr.indexOf('.'));
            }
            if (Number(degChr) < -90) {
                degChr = '-90';
            }
            if (Number(degChr) > 90) {
                degChr = '90';
            }
            if (Number(minChr) < -90) {
                minChr = '-90';
            }
            if (Number(minChr) > 90) {
                minChr = '90';
            }
        }
        if (v.length >= 4) {
            v = v.slice(0, 2);
            if (degChr.indexOf('.') !== -1) {
                degChr = degChr.slice(0, degChr.indexOf('.'));
            }
            if (minChr.indexOf('.') !== -1) {
                minChr = minChr.slice(0, degChr.indexOf('.'));
            }
            if (Number(degChr) < -90) {
                degChr = '-90';
            }
            if (Number(degChr) > 90) {
                degChr = '90';
            }
            if (Number(minChr) < -90) {
                minChr = '-90';
            }
            if (Number(minChr) > 90) {
                minChr = '90';
            }
        }
        try {
            nbSpaces = dmsStr.match(/\s/g).length;
        }
        catch (e) {
            nbSpaces = 0;
        }
        if (nbSpaces === 0 && v.length === 1) ;
        else if (nbSpaces === 1 && v.length >= 1) {
            degChr = degChr.replace(' ', '');
            if (degChr.slice(degChr.length - 1, degChr.length) !== '°') {
                degChr += '° ';
            }
            else {
                degChr += ' ';
            }
        }
        else if (nbSpaces === 2 && v.length >= 2) {
            degChr = degChr.replace(' ', '');
            minChr = minChr.replace(' ', '');
            if (degChr.slice(degChr.length - 1, degChr.length) !== '°') {
                degChr += '° ';
            }
            else {
                degChr += ' ';
            }
            if (minChr.slice(minChr.length - 1, minChr.length) !== '\'') {
                minChr += '\' ';
            }
            else {
                minChr += ' ';
            }
        }
        else if (nbSpaces === 3 && v.length >= 3) {
            degChr = degChr.replace(' ', '');
            minChr = minChr.replace(' ', '');
            secChr = secChr.replace(' ', '');
            if (degChr.slice(degChr.length - 1, degChr.length) !== '°') {
                degChr += '° ';
            }
            else {
                degChr += ' ';
            }
            if (minChr.slice(minChr.length - 1, minChr.length) !== '\'') {
                minChr += '\' ';
            }
            else {
                minChr += ' ';
            }
            if (secChr.slice(secChr.length - 1, secChr.length) !== '"') {
                secChr += '"';
            }
        }
        else {
            throw { error: 'Can\'t manage input string.' };
        }
        return degChr + minChr + secChr;
    }
    catch (e) {
        return dmsStr;
    }
}

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
var GeocodingService = /** @class */ (function () {
    function GeocodingService(http) {
        this.http = http;
    }
    /**
     * @param {?} address
     * @return {?}
     */
    GeocodingService.prototype.geocode = /**
     * @param {?} address
     * @return {?}
     */
    function (address) {
        if (address === null) {
            return Object(rxjs__WEBPACK_IMPORTED_MODULE_3__["empty"])();
        }
        /** @type {?} */
        var url = "https://nominatim.openstreetmap.org/?format=json&addressdetails=1&q=" + address + "&format=json&limit=10&polygon_geojson=1";
        return this.http.get(url).pipe(Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["map"])(function (obj) { return obj; }));
    };
    /**
     * @param {?} lat
     * @param {?} lng
     * @return {?}
     */
    GeocodingService.prototype.reverse = /**
     * @param {?} lat
     * @param {?} lng
     * @return {?}
     */
    function (lat, lng) {
        /** @type {?} */
        var url = "https://nominatim.openstreetmap.org/reverse?format=json&lat=" + lat + "&lon=" + lng + "&polygon_geojson=1";
        return this.http.get(url).pipe(Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["map"])(function (obj) { return obj; }));
    };
    /**
     * @param {?} osmPlaceResult
     * @return {?}
     */
    GeocodingService.prototype.getReadbleAddress = /**
     * @param {?} osmPlaceResult
     * @return {?}
     */
    function (osmPlaceResult) {
        /** @type {?} */
        var locality = null;
        /** @type {?} */
        var subLocality = null;
        /** @type {?} */
        var road = null;
        /** @type {?} */
        var neighbourhood = null;
        // Get "city" information (I mean city or something similar like village)
        if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.city)) {
            locality = osmPlaceResult.address.city;
        }
        else if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.town)) {
            locality = osmPlaceResult.address.town;
        }
        else if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.village)) {
            locality = osmPlaceResult.address.village;
        }
        else if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.hamlet)) {
            locality = osmPlaceResult.address.hamlet;
        }
        // Get suburbr & if not defined : postcode
        if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.suburb) && Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.postcode) && locality !== null) {
            subLocality = osmPlaceResult.address.suburb + ', ' + osmPlaceResult.address.postcode;
        }
        else if (!Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.suburb) && Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.postcode) && locality !== null) {
            subLocality = osmPlaceResult.address.postcode;
        }
        // Get "road"
        if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.road)) {
            road = osmPlaceResult.address.road;
        }
        else if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.pedestrian)) {
            road = osmPlaceResult.address.pedestrian;
        }
        // Get neighbourhood
        if (Object(_angular_compiler_src_util__WEBPACK_IMPORTED_MODULE_5__["isDefined"])(osmPlaceResult.address.neighbourhood)) {
            neighbourhood = osmPlaceResult.address.neighbourhood;
        }
        // Return
        if (road && neighbourhood && subLocality && locality) {
            return road + ' (' + neighbourhood + ') ' + subLocality + ' ' + locality;
        }
        else if (road && !neighbourhood && subLocality && locality) {
            return road + ' ' + subLocality + ' ' + locality;
        }
        else if (!road && neighbourhood && subLocality && locality) {
            return neighbourhood + ' ' + subLocality + ' ' + locality;
        }
        else if (!road && !neighbourhood && subLocality && locality) {
            return subLocality + ' ' + locality;
        }
        else if (!road && !neighbourhood && !subLocality && locality) {
            return locality;
        }
        else {
            return osmPlaceResult.display_name;
        }
    };
    /**
     * @param {?} osmClassFilter
     * @param {?} osmResults
     * @return {?}
     */
    GeocodingService.prototype.osmClassFilter = /**
     * @param {?} osmClassFilter
     * @param {?} osmResults
     * @return {?}
     */
    function (osmClassFilter, osmResults) {
        /** @type {?} */
        var osmFilteredResults = [];
        if (osmClassFilter.length > 0 && osmResults.length > 0) {
            osmResults.forEach(function (osmItem) {
                /** @type {?} */
                var filterMatchOccurence = 0;
                /** @type {?} */
                var removeOccurence = false;
                osmClassFilter.forEach(function (osmFilterItem) {
                    /** @type {?} */
                    var _class = osmFilterItem.split(':')[0];
                    /** @type {?} */
                    var _type = osmFilterItem.split(':')[1];
                    if (_type === '*') {
                        if (osmItem.class === _class) {
                            filterMatchOccurence++;
                        }
                    }
                    else {
                        // if !, remove
                        if (_type.substr(0, 1) === '!') {
                            if (osmItem.class === _class && '!' + osmItem.type === _type) {
                                removeOccurence = true;
                            }
                        }
                        else {
                            if (osmItem.class === _class && osmItem.type === _type) {
                                filterMatchOccurence++;
                            }
                        }
                    }
                });
                if (filterMatchOccurence > 0 && !removeOccurence) {
                    osmFilteredResults.push(osmItem);
                }
            });
            return Object(rxjs__WEBPACK_IMPORTED_MODULE_3__["of"])(osmFilteredResults);
        }
        else {
            return Object(rxjs__WEBPACK_IMPORTED_MODULE_3__["of"])(osmResults);
        }
    };
    /**
     * @param {?} coordinatesArray
     * @return {?}
     */
    GeocodingService.prototype.reverseCorrdinatesArray = /**
     * @param {?} coordinatesArray
     * @return {?}
     */
    function (coordinatesArray) {
        if (coordinatesArray.length > 0) {
            coordinatesArray.forEach(function (item) {
                item.reverse();
            });
            return coordinatesArray;
        }
    };
    /**
     * @param {?} coordinatesArray
     * @return {?}
     */
    GeocodingService.prototype.simplifyPolyline = /**
     * @param {?} coordinatesArray
     * @return {?}
     */
    function (coordinatesArray) {
        if (coordinatesArray.length > 1) {
            /** @type {?} */
            var firstCoordinate = coordinatesArray[0];
            /** @type {?} */
            var lastCoordinate = coordinatesArray[coordinatesArray.length - 1];
            return [firstCoordinate, lastCoordinate];
        }
        else {
            return coordinatesArray;
        }
    };
    GeocodingService.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Injectable"], args: [{
                    providedIn: 'root'
                },] },
    ];
    /** @nocollapse */
    GeocodingService.ctorParameters = function () { return [
        { type: _angular_common_http__WEBPACK_IMPORTED_MODULE_2__["HttpClient"] }
    ]; };
    /** @nocollapse */ GeocodingService.ngInjectableDef = Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["defineInjectable"])({ factory: function GeocodingService_Factory() { return new GeocodingService(Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["inject"])(_angular_common_http__WEBPACK_IMPORTED_MODULE_2__["HttpClient"])); }, token: GeocodingService, providedIn: "root" });
    return GeocodingService;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
var ElevationService = /** @class */ (function () {
    function ElevationService(http) {
        this.http = http;
    }
    /**
     * @param {?} lat
     * @param {?} lng
     * @return {?}
     */
    ElevationService.prototype.getElevation = /**
     * @param {?} lat
     * @param {?} lng
     * @return {?}
     */
    function (lat, lng) {
        /** @type {?} */
        var apiUrl = "https://api.open-elevation.com/api/v1/lookup?locations=" + lat + "," + lng;
        return this.http.get(apiUrl).pipe(Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["map"])(function (obj) { return obj.results[0].elevation; }));
    };
    ElevationService.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Injectable"], args: [{
                    providedIn: 'root'
                },] },
    ];
    /** @nocollapse */
    ElevationService.ctorParameters = function () { return [
        { type: _angular_common_http__WEBPACK_IMPORTED_MODULE_2__["HttpClient"] }
    ]; };
    /** @nocollapse */ ElevationService.ngInjectableDef = Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["defineInjectable"])({ factory: function ElevationService_Factory() { return new ElevationService(Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["inject"])(_angular_common_http__WEBPACK_IMPORTED_MODULE_2__["HttpClient"])); }, token: ElevationService, providedIn: "root" });
    return ElevationService;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
var MapComponent = /** @class */ (function () {
    // ----
    // CODE
    // ----
    function MapComponent(fb, geocodeService, elevationService) {
        this.fb = fb;
        this.geocodeService = geocodeService;
        this.elevationService = elevationService;
        // --------------
        // INPUT / OUTPUT
        // --------------
        this.layersToAdd = ['osm'];
        this.osmClassFilter = [];
        this.location = new _angular_core__WEBPACK_IMPORTED_MODULE_0__["EventEmitter"]();
        this.coordFormat = 'dms';
        // ---------
        // VARIABLES
        // ---------
        this._location = /** @type {?} */ ({});
        this.geolocatedPhotoLatLngData = [];
        this.geolocatedPhotoLatLngDisplayedColumnsTable = ['select', 'photoName', 'lat', 'lng', 'altitude'];
        this.isLoadingAddress = false;
        this.isLoadingLatitude = false;
        this.isLoadingLongitude = false;
        this.isLoadingElevation = false;
        // -------------
        // SUBSCRIPTIONS
        // -------------
        this.geoSearchSubscription = new rxjs__WEBPACK_IMPORTED_MODULE_3__["Subscription"];
        this.latDmsInputSubscription = new rxjs__WEBPACK_IMPORTED_MODULE_3__["Subscription"];
        this.lngDmsInputSubscription = new rxjs__WEBPACK_IMPORTED_MODULE_3__["Subscription"];
        this.mapLat = 0;
        this.mapLng = 0;
        this.osmLayer = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["tileLayer"])('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { maxZoom: 18, attribution: 'Open Street map' });
        this.googleSatelliteLayer = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["tileLayer"])('http://{s}.google.com/vt/lyrs=s&x={x}&y={y}&z={z}', { maxZoom: 20, subdomains: ['mt0', 'mt1', 'mt2', 'mt3'], attribution: 'Google maps' });
        this.googleHybridLayer = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["tileLayer"])('http://{s}.google.com/vt/lyrs=s,h&x={x}&y={y}&z={z}', { maxZoom: 20, subdomains: ['mt0', 'mt1', 'mt2', 'mt3'], attribution: 'Google maps' });
        this.brgmLayer = leaflet__WEBPACK_IMPORTED_MODULE_1__["tileLayer"].wms('http://geoservices.brgm.fr/geologie', { version: '1.3.0', layers: 'Geologie' });
        this.mapLayers = {
            'Google': this.googleHybridLayer,
            'OSM': this.osmLayer,
            'BRGM': this.brgmLayer
        };
        this.geoResultsLayer = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["geoJSON"])(null, { style: function () { return { color: '#ff7800', weight: 5, opacity: 0.65 }; } });
        this.geolocatedPhotoLatLngLayer = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["geoJSON"])();
        // map options
        this.options = {
            layers: [this.osmLayer],
            zoom: 4,
            center: Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["latLng"])({ lat: 46.55886030311719, lng: 2.9882812500000004 })
        };
        // Leaflet map configuration
        this.drawnItems = new leaflet__WEBPACK_IMPORTED_MODULE_1__["FeatureGroup"]();
        this.drawControlFull = drawControlPanel;
        this.drawControlEdit = drawControlEditPanel(this.drawnItems);
        this.circleMarkerOpt = circleMarkerStyle;
        this.geoResultsOpt = cityStyle;
    }
    /**
     * - Create the forms
     * - Set up subscriptions (geo search, geolocated photos, lat / lng inputs)
     */
    /**
     * - Create the forms
     * - Set up subscriptions (geo search, geolocated photos, lat / lng inputs)
     * @return {?}
     */
    MapComponent.prototype.ngOnInit = /**
     * - Create the forms
     * - Set up subscriptions (geo search, geolocated photos, lat / lng inputs)
     * @return {?}
     */
    function () {
        var _this = this;
        // Create forms
        this.latlngFormGroup = this.fb.group({
            latInput: this.fb.control('', [_angular_forms__WEBPACK_IMPORTED_MODULE_6__["Validators"].required, this.latLngDecValidator]),
            lngInput: this.fb.control('', [_angular_forms__WEBPACK_IMPORTED_MODULE_6__["Validators"].required, this.latLngDecValidator]),
            dmsLatInput: this.fb.control('', [_angular_forms__WEBPACK_IMPORTED_MODULE_6__["Validators"].required, this.latLngDmsValidator]),
            dmsLngInput: this.fb.control('', [_angular_forms__WEBPACK_IMPORTED_MODULE_6__["Validators"].required, this.latLngDmsValidator])
        });
        this.elevationFormGroup = this.fb.group({
            elevationInput: this.fb.control('', null)
        });
        this.geoSearchFormGroup = this.fb.group({
            placeInput: this.fb.control('', null)
        });
        // Watch placeInput changes
        this.geoSearchSubscription = this.geoSearchFormGroup.controls["placeInput"].valueChanges
            .pipe(Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["debounceTime"])(400), Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["distinctUntilChanged"])(), Object(rxjs_operators__WEBPACK_IMPORTED_MODULE_4__["switchMap"])(function (value) {
            _this.isLoadingAddress = true;
            return _this.geocodeService.geocode(value);
        })).subscribe(function (results) {
            _this.isLoadingAddress = false;
            // filter results if needed
            if (_this.osmClassFilter.length > 0) {
                _this.geocodeService.osmClassFilter(_this.osmClassFilter, results).subscribe(function (filteredResults) {
                    _this.geoSearchResults = filteredResults;
                });
            }
            else {
                _this.geoSearchResults = results;
            }
        }, function (error) {
            // @toto manage error
            // @toto manage error
            _this.isLoadingAddress = false;
        });
        // Watch geolocated photo input changes
        this.geolocatedPhotoLatLng.subscribe(function (photoLatLng) {
            // @todo clear this.geolocatedPhotoLatLngLayer
            // @todo clear this.geolocatedPhotoLatLngLayer
            _this.geolocatedPhotoLatLngData = photoLatLng;
            // For each geolocated photo, add marker and bind mouse event on thoses markers
            // For each geolocated photo, add marker and bind mouse event on thoses markers
            _this.geolocatedPhotoLatLngData.forEach(function (data) {
                /** @type {?} */
                var _latDms = data.lat.deg + '° ' + data.lat.min + '\'' + data.lat.sec + '"';
                /** @type {?} */
                var _lngDms = data.lng.deg + '° ' + data.lng.min + '\'' + data.lng.sec + '"';
                /** @type {?} */
                var g = new GeoPoint(_lngDms, _latDms);
                data.latDec = g.latDec;
                data.lngDec = g.lonDec;
                /** @type {?} */
                var latLng$$1 = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["latLng"])(data.latDec, data.lngDec);
                /** @type {?} */
                var gpsPhotoMarker = new leaflet__WEBPACK_IMPORTED_MODULE_1__["Marker"](latLng$$1, { icon: gpsPhotoMarkerIcon() });
                /** @type {?} */
                var html = "\n          <b>Fichier \"" + data.photoName + "\"</b><br>\n          Lat. : " + g.latDeg + "<br />\n          Lng. : " + g.lonDeg + "<br />\n          Alt. : " + data.altitude + " m<br /><br />\n          <b>Cliquez sur le point pour utiliser ces coordonn\u00E9es</b>";
                gpsPhotoMarker.bindPopup(html).openPopup();
                // Marker mouse events
                gpsPhotoMarker.on('click', (function (event) { _this.gpsMarkerSetValues(data.latDec, data.lngDec, data.altitude); }));
                gpsPhotoMarker.on('mouseover', function (event) { gpsPhotoMarker.openPopup(); });
                gpsPhotoMarker.on('mouseout', (function (event) { gpsPhotoMarker.closePopup(); }));
                // Add the marker to the map
                gpsPhotoMarker.addTo(_this.geolocatedPhotoLatLngLayer);
            });
            // Fit map to geolocated photos markers
            // Fit map to geolocated photos markers
            _this.flyToGeolocatedPhotoItems();
        });
        // Watch lat & lng DMS inputs changes and set up the DMS formatter
        // The DMS formatter restricts the keyboard input of the user : only number, comma, dot and '-', deg and min must be between -90 and +90
        // The formatter auto fill the ° ' and " characters to help the user input
        this.latDmsInputSubscription = this.latlngFormGroup.controls["dmsLatInput"].valueChanges.subscribe(function (value) {
            _this.latlngFormGroup.controls["dmsLatInput"].setValue(dmsFormatter(value), { emitEvent: false });
        });
        this.lngDmsInputSubscription = this.latlngFormGroup.controls["dmsLngInput"].valueChanges.subscribe(function (value) {
            _this.latlngFormGroup.controls["dmsLngInput"].setValue(dmsFormatter(value), { emitEvent: false });
        });
    };
    /**
     * Unsubscribe
     */
    /**
     * Unsubscribe
     * @return {?}
     */
    MapComponent.prototype.ngOnDestroy = /**
     * Unsubscribe
     * @return {?}
     */
    function () {
        this.geoSearchSubscription.unsubscribe();
        this.latDmsInputSubscription.unsubscribe();
        this.lngDmsInputSubscription.unsubscribe();
    };
    /**
     * Add layers and events listeners
     */
    /**
     * Add layers and events listeners
     * @param {?} map
     * @return {?}
     */
    MapComponent.prototype.onMapReady = /**
     * Add layers and events listeners
     * @param {?} map
     * @return {?}
     */
    function (map$$1) {
        var _this = this;
        this.map = map$$1;
        this.map.addControl(leaflet__WEBPACK_IMPORTED_MODULE_1__["control"].layers(null, this.mapLayers, { position: 'topright' }));
        this.map.addLayer(this.drawnItems);
        this.map.addLayer(this.geoResultsLayer);
        this.map.addLayer(this.geolocatedPhotoLatLngLayer);
        this.map.addControl(this.drawControlFull);
        this.map.on('draw:created', function (e) {
            _this.drawnItem = e['layer'];
            _this.drawType = e['layerType'];
            // If it's a marker, it must be draggable. By default, leaflet.draw module does not provide a draggable marker
            // So, we don't do a this.drawnItems.addLayer(layer);
            // We just draw a new draggableMarker instead
            if (_this.drawType === 'marker') {
                /** @type {?} */
                var latlng = _this.drawnItem._latlng;
                draggableMarker(latlng.lat, latlng.lng, function (dragEnd) { _this.callGeolocElevationApisUsingLatLngInputsValues(); }).addTo(_this.drawnItems);
            }
            else {
                _this.drawnItems.addLayer(_this.drawnItem);
            }
            // Show / hide control panels
            // if ONE item is drawn, set place and elevation inputs (call API)
            if (_this.drawnItems.getLayers().length > 0) {
                _this.setMapEditMode();
            }
            if (_this.drawnItems.getLayers().length === 1) {
                _this.callGeolocElevationApisUsingLatLngInputsValues();
            }
            _this.flyToDrawnItems();
        });
        this.map.on('draw:edited', function (e) {
            _this.drawnItem = e['layer'];
            _this.drawType = e['layerType'];
            //      this.drawnItems.addLayer(this.drawnItem);
            if (_this.drawnItems.getLayers().length === 1) {
                _this.callGeolocElevationApisUsingLatLngInputsValues();
            }
            _this.flyToDrawnItems();
        });
        this.map.on('draw:deleted', function (e) {
            _this.clearGeoResultsLayer();
            _this.clearDrawnItemsLayer();
            _this.setMapDrawMode();
            _this.clearForm();
        });
        this.redrawMap(100);
    };
    /**
     * When the map parent's div size change (eg. panel width), have to redraw the map
     * Sometimes (when opening / closing a tab), size change is detected too earlier, need to set a delay (about 10-100ms seems to be convenient)
     */
    /**
     * When the map parent's div size change (eg. panel width), have to redraw the map
     * Sometimes (when opening / closing a tab), size change is detected too earlier, need to set a delay (about 10-100ms seems to be convenient)
     * @param {?=} delay
     * @return {?}
     */
    MapComponent.prototype.redrawMap = /**
     * When the map parent's div size change (eg. panel width), have to redraw the map
     * Sometimes (when opening / closing a tab), size change is detected too earlier, need to set a delay (about 10-100ms seems to be convenient)
     * @param {?=} delay
     * @return {?}
     */
    function (delay) {
        var _this = this;
        if (delay) {
            window.setTimeout(function () { return _this.map.invalidateSize(); }, delay);
        }
        else {
            this.map.invalidateSize();
        }
    };
    /**
     * Show the "edit" toolbar inside map
     */
    /**
     * Show the "edit" toolbar inside map
     * @return {?}
     */
    MapComponent.prototype.setMapEditMode = /**
     * Show the "edit" toolbar inside map
     * @return {?}
     */
    function () {
        this.map.removeControl(this.drawControlFull);
        this.map.addControl(this.drawControlEdit);
    };
    /**
     * Show the "draw" toolbar inside map
     */
    /**
     * Show the "draw" toolbar inside map
     * @return {?}
     */
    MapComponent.prototype.setMapDrawMode = /**
     * Show the "draw" toolbar inside map
     * @return {?}
     */
    function () {
        this.map.removeControl(this.drawControlEdit);
        this.map.addControl(this.drawControlFull);
    };
    /**
     * Set map bounds to drawn items
     */
    /**
     * Set map bounds to drawn items
     * @param {?=} _maxZoom
     * @return {?}
     */
    MapComponent.prototype.flyToDrawnItems = /**
     * Set map bounds to drawn items
     * @param {?=} _maxZoom
     * @return {?}
     */
    function (_maxZoom) {
        if (_maxZoom === void 0) { _maxZoom = 14; }
        /** @type {?} */
        var b = this.drawnItems.getBounds();
        this.map.flyToBounds(b, { maxZoom: _maxZoom, animate: false });
    };
    /**
     * Set map bounds to geo reults items
     */
    /**
     * Set map bounds to geo reults items
     * @return {?}
     */
    MapComponent.prototype.flyToGeoResultsItems = /**
     * Set map bounds to geo reults items
     * @return {?}
     */
    function () {
        /** @type {?} */
        var b = this.geoResultsLayer.getBounds();
        this.map.flyToBounds(b, { maxZoom: 14, animate: false });
    };
    /**
     * Set map bounds to geolocated photos items
     */
    /**
     * Set map bounds to geolocated photos items
     * @return {?}
     */
    MapComponent.prototype.flyToGeolocatedPhotoItems = /**
     * Set map bounds to geolocated photos items
     * @return {?}
     */
    function () {
        /** @type {?} */
        var b = this.geolocatedPhotoLatLngLayer.getBounds();
        this.map.flyToBounds(b, { maxZoom: 14, animate: false });
    };
    /**
     * Draw a marker on drawItems featureGroup with DMS input values
     */
    /**
     * Draw a marker on drawItems featureGroup with DMS input values
     * @return {?}
     */
    MapComponent.prototype.addMarkerFromDmsCoord = /**
     * Draw a marker on drawItems featureGroup with DMS input values
     * @return {?}
     */
    function () {
        // clear drawn items layer
        this.clearDrawnItemsLayer();
        // update map toolbar
        this.setMapEditMode();
        /** @type {?} */
        var geopoint = new GeoPoint(this.latlngFormGroup.controls["dmsLngInput"].value, this.latlngFormGroup.controls["dmsLatInput"].value);
        draggableMarker(geopoint.getLatDec(), geopoint.getLonDec(), function (e) {
            /* dragend callback fn */ 
        }).addTo(this.drawnItems);
        // Set (decimal) latLng inputs
        this.latlngFormGroup.controls["latInput"].setValue(geopoint.getLatDec(), { emitEvent: false });
        this.latlngFormGroup.controls["lngInput"].setValue(geopoint.getLatDec(), { emitEvent: false });
        // Fly
        this.flyToDrawnItems();
    };
    /**
     * Draw a marker on drawItems featureGroup with decimal input values
     */
    /**
     * Draw a marker on drawItems featureGroup with decimal input values
     * @return {?}
     */
    MapComponent.prototype.addMarkerFromLatLngCoord = /**
     * Draw a marker on drawItems featureGroup with decimal input values
     * @return {?}
     */
    function () {
        // clear drawn items layer
        this.clearDrawnItemsLayer();
        // update map toolbar
        this.setMapEditMode();
        /** @type {?} */
        var geopoint = new GeoPoint(Number(this.latlngFormGroup.controls["lngInput"].value), Number(this.latlngFormGroup.controls["latInput"].value));
        draggableMarker(geopoint.getLatDec(), geopoint.getLonDec(), function (dragEnd) {
            /* dragend callback fn */ 
        }).addTo(this.drawnItems);
        // Set dmsLatLng inputs
        this.latlngFormGroup.controls["dmsLatInput"].setValue(geopoint.getLatDeg(), { emitEvent: false });
        this.latlngFormGroup.controls["dmsLngInput"].setValue(geopoint.getLonDeg(), { emitEvent: false });
        // Fly
        this.flyToDrawnItems();
    };
    /**
    *
    */
    /**
     *
     * @param {?} coordinates
     * @return {?}
     */
    MapComponent.prototype.addPolyline = /**
     *
     * @param {?} coordinates
     * @return {?}
     */
    function (coordinates) {
        // clear drawn items layer
        this.clearDrawnItemsLayer();
        // update map toolbar
        this.setMapEditMode();
        /** @type {?} */
        var polyline$$1 = Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["polyline"])(coordinates);
        polyline$$1.addTo(this.drawnItems);
        // fly with max zoom
        this.flyToDrawnItems(18);
    };
    /**
     * Take latitude and longitude input values and call geocoding and elevation API
     * Sometimes you may want to force the elevation value and avoid calling elevation API (eg. elevation come from gps photo metadata)
     * then, you cas use the avoidCallingElevationApi option
     *
     * What is done inside this function :
     * - create an observable that zip all required observables
     * - do a switchmap on the main observable so that if one one the sub-observable change, old data are ignored
     * - when the main observable is finished, can send new location Output
     *
     * Several if / else avoidCallingElevationApi are used because when
     * avoidCallingElevationApi === false, httpTasks returns a single value (osmPlace)
     * whereas if avoidCallingElevationApi === true, httpTasks returns an array of 2 values [elevation, osmPlace]
     */
    /**
     * Take latitude and longitude input values and call geocoding and elevation API
     * Sometimes you may want to force the elevation value and avoid calling elevation API (eg. elevation come from gps photo metadata)
     * then, you cas use the avoidCallingElevationApi option
     *
     * What is done inside this function :
     * - create an observable that zip all required observables
     * - do a switchmap on the main observable so that if one one the sub-observable change, old data are ignored
     * - when the main observable is finished, can send new location Output
     *
     * Several if / else avoidCallingElevationApi are used because when
     * avoidCallingElevationApi === false, httpTasks returns a single value (osmPlace)
     * whereas if avoidCallingElevationApi === true, httpTasks returns an array of 2 values [elevation, osmPlace]
     * @param {?=} avoidCallingElevationApi
     * @param {?=} avoidCallingGeolocApi
     * @return {?}
     */
    MapComponent.prototype.callGeolocElevationApisUsingLatLngInputsValues = /**
     * Take latitude and longitude input values and call geocoding and elevation API
     * Sometimes you may want to force the elevation value and avoid calling elevation API (eg. elevation come from gps photo metadata)
     * then, you cas use the avoidCallingElevationApi option
     *
     * What is done inside this function :
     * - create an observable that zip all required observables
     * - do a switchmap on the main observable so that if one one the sub-observable change, old data are ignored
     * - when the main observable is finished, can send new location Output
     *
     * Several if / else avoidCallingElevationApi are used because when
     * avoidCallingElevationApi === false, httpTasks returns a single value (osmPlace)
     * whereas if avoidCallingElevationApi === true, httpTasks returns an array of 2 values [elevation, osmPlace]
     * @param {?=} avoidCallingElevationApi
     * @param {?=} avoidCallingGeolocApi
     * @return {?}
     */
    function (avoidCallingElevationApi, avoidCallingGeolocApi) {
        var _this = this;
        if (avoidCallingElevationApi === void 0) { avoidCallingElevationApi = false; }
        if (avoidCallingGeolocApi === void 0) { avoidCallingGeolocApi = false; }
        this.setLatLngInputFromDrawnItems();
        this.setLatLngDmsInputFromDrawnItems();
        /** @type {?} */
        var httpTasks;
        /** @type {?} */
        var elevation;
        /** @type {?} */
        var osmPlace;
        if (avoidCallingElevationApi && !avoidCallingGeolocApi) {
            httpTasks = this.reverseGeocodingFromInputValue();
        }
        else if (avoidCallingGeolocApi && !avoidCallingElevationApi) {
            httpTasks = this.getElevationFromInputValue();
        }
        else if (!avoidCallingElevationApi && !avoidCallingGeolocApi) {
            httpTasks = Object(rxjs__WEBPACK_IMPORTED_MODULE_3__["zip"])(this.getElevationFromInputValue(), this.reverseGeocodingFromInputValue());
        }
        else if (avoidCallingElevationApi && avoidCallingGeolocApi) {
            // nothing to do ; throw or log an error ?
            return;
        }
        // spinnners on
        this.isLoadingAddress = !avoidCallingGeolocApi;
        this.isLoadingElevation = !avoidCallingElevationApi;
        httpTasks.subscribe(function (result) {
            _this.isLoadingElevation = false;
            _this.isLoadingAddress = false;
            if (avoidCallingElevationApi && !avoidCallingGeolocApi) {
                elevation = null;
                osmPlace = result;
            }
            else if (avoidCallingGeolocApi && !avoidCallingElevationApi) {
                elevation = result;
                osmPlace = null;
                elevation = result;
            }
            else if (!avoidCallingGeolocApi && !avoidCallingGeolocApi) {
                elevation = result[0];
                osmPlace = result[1];
            }
            // Set elevation input
            if (!avoidCallingElevationApi) {
                _this.elevationFormGroup.controls["elevationInput"].setValue(elevation);
            }
            // Patch place input value
            if (!avoidCallingGeolocApi) {
                _this.geoSearchFormGroup.controls["placeInput"].patchValue(_this.geocodeService.getReadbleAddress(osmPlace), { emitEvent: false });
            }
            // bind _location & emit location
            if (avoidCallingElevationApi) {
                _this.bindLocationOutput([_this.elevationFormGroup.controls["elevationInput"].value, osmPlace]);
            }
            else {
                _this.bindLocationOutput(result);
            }
        }, function (error) {
            // Manage error
            // spinnners off
            // Manage error
            // spinnners off
            _this.isLoadingAddress = false;
            _this.isLoadingElevation = false;
        });
    };
    /**
     * Should be improved for complex polygons / polylines ?
     * Could use turf.js
     */
    /**
     * Should be improved for complex polygons / polylines ?
     * Could use turf.js
     * @return {?}
     */
    MapComponent.prototype.setLatLngInputFromDrawnItems = /**
     * Should be improved for complex polygons / polylines ?
     * Could use turf.js
     * @return {?}
     */
    function () {
        /** @type {?} */
        var centroid = this.drawnItems.getBounds().getCenter();
        this.latlngFormGroup.controls["latInput"].setValue(centroid.lat);
        this.latlngFormGroup.controls["lngInput"].setValue(centroid.lng);
    };
    /**
     *
     */
    /**
     *
     * @return {?}
     */
    MapComponent.prototype.setLatLngDmsInputFromDrawnItems = /**
     *
     * @return {?}
     */
    function () {
        /** @type {?} */
        var centroid = this.drawnItems.getBounds().getCenter();
        /** @type {?} */
        var geopoint = new GeoPoint(centroid.lng, centroid.lat);
        this.latlngFormGroup.controls["dmsLatInput"].patchValue(geopoint.getLatDeg());
        this.latlngFormGroup.controls["dmsLngInput"].patchValue(geopoint.getLonDeg());
    };
    /**
     *
     */
    /**
     *
     * @return {?}
     */
    MapComponent.prototype.getElevationFromInputValue = /**
     *
     * @return {?}
     */
    function () {
        return this.elevationService.getElevation(this.latlngFormGroup.controls["latInput"].value, this.latlngFormGroup.controls["lngInput"].value);
    };
    /**
     * Reverse geocoding from lat / lng inputs values
     */
    /**
     * Reverse geocoding from lat / lng inputs values
     * @return {?}
     */
    MapComponent.prototype.reverseGeocodingFromInputValue = /**
     * Reverse geocoding from lat / lng inputs values
     * @return {?}
     */
    function () {
        return this.geocodeService.reverse(this.latlngFormGroup.controls["latInput"].value, this.latlngFormGroup.controls["lngInput"].value);
    };
    /**
     * Latitude / longitude DMS form Validator
     */
    /**
     * Latitude / longitude DMS form Validator
     * @param {?} control
     * @return {?}
     */
    MapComponent.prototype.latLngDmsValidator = /**
     * Latitude / longitude DMS form Validator
     * @param {?} control
     * @return {?}
     */
    function (control$$1) {
        /** @type {?} */
        var regexp = new RegExp('^(\\-)?[0-9]{1,2}\\° [0-9]{1,2}\\\' [0-9]{1,2}\\.[0-9]{1,12}\\"');
        return regexp.test(control$$1.value) ? null : { malformedLatLngDmsFormat: true };
    };
    /**
     * Latitude / longitude decimal form validator
     */
    /**
     * Latitude / longitude decimal form validator
     * @param {?} control
     * @return {?}
     */
    MapComponent.prototype.latLngDecValidator = /**
     * Latitude / longitude decimal form validator
     * @param {?} control
     * @return {?}
     */
    function (control$$1) {
        /** @type {?} */
        var regexp = new RegExp('^(\\-)?[0-9]{1,2}\\.[0-9]{1,20}');
        return regexp.test(control$$1.value) ? null : { malformedLatLngDecFormat: true };
    };
    /**
     * When user select an address within the autocomplete results list
     *
     * Call the geoloc API 2 times :
     *  - first call is for reverse geocoding
     *  - second call is for geoconding, so the address input (placeInput) is updated
     */
    /**
     * When user select an address within the autocomplete results list
     *
     * Call the geoloc API 2 times :
     *  - first call is for reverse geocoding
     *  - second call is for geoconding, so the address input (placeInput) is updated
     * @param {?} event
     * @return {?}
     */
    MapComponent.prototype.addressSelectedChanged = /**
     * When user select an address within the autocomplete results list
     *
     * Call the geoloc API 2 times :
     *  - first call is for reverse geocoding
     *  - second call is for geoconding, so the address input (placeInput) is updated
     * @param {?} event
     * @return {?}
     */
    function (event) {
        /** @type {?} */
        var osmPlace = event.option.value;
        /** @type {?} */
        var southWest = new leaflet__WEBPACK_IMPORTED_MODULE_1__["LatLng"](osmPlace.boundingbox[0], osmPlace.boundingbox[2]);
        /** @type {?} */
        var northEast = new leaflet__WEBPACK_IMPORTED_MODULE_1__["LatLng"](osmPlace.boundingbox[1], osmPlace.boundingbox[3]);
        this.map.fitBounds(Object(leaflet__WEBPACK_IMPORTED_MODULE_1__["latLngBounds"])(southWest, northEast));
        // Add geojson to the map (if user enter a city, draw the administrative shape on the map)
        this.clearGeoResultsLayer();
        this.geoResultsLayer.addData(osmPlace.geojson);
        // Fly
        this.flyToGeoResultsItems();
        // Patch input value
        this.geoSearchFormGroup.controls["placeInput"].patchValue(this.geocodeService.getReadbleAddress(osmPlace), { emitEvent: false });
        /** @type {?} */
        var g = new GeoPoint(Number(osmPlace.lon), Number(osmPlace.lat));
        this.latlngFormGroup.controls["latInput"].setValue(osmPlace.lat, { emitEvent: false });
        this.latlngFormGroup.controls["lngInput"].setValue(osmPlace.lon, { emitEvent: false });
        this.latlngFormGroup.controls["dmsLatInput"].setValue(g.getLatDeg(), { emitEvent: false });
        this.latlngFormGroup.controls["dmsLngInput"].setValue(g.getLonDeg(), { emitEvent: false });
        this.elevationFormGroup.controls["elevationInput"].setValue(osmPlace.elevation, { emitEvent: false });
        // Draw a polyline or place a marker at the center of a polygon
        if (osmPlace.geojson.type === 'LineString') {
            // osm geojson coordinates is like [[long, lat], [long, lat], ...]
            // but leaflet needs [[lat, long], [lat, long], ...] format !
            this.geocodeService.simplifyPolyline(osmPlace.geojson.coordinates);
            this.addPolyline(/** @type {?} */ (this.geocodeService.reverseCorrdinatesArray(this.geocodeService.simplifyPolyline(osmPlace.geojson.coordinates))));
            this.clearGeoResultsLayer();
        }
        else {
            this.addMarkerFromLatLngCoord();
        }
        // Call geoloc and elevation APIs
        this.callGeolocElevationApisUsingLatLngInputsValues(false, false);
    };
    /**
     * Clear the form when nedded : 'draw:deleted', etc.
     */
    /**
     * Clear the form when nedded : 'draw:deleted', etc.
     * @return {?}
     */
    MapComponent.prototype.clearForm = /**
     * Clear the form when nedded : 'draw:deleted', etc.
     * @return {?}
     */
    function () {
        this.latlngFormGroup.controls["latInput"].setValue('', { emitEvent: false });
        this.latlngFormGroup.controls["lngInput"].setValue('', { emitEvent: false });
        this.latlngFormGroup.controls["dmsLatInput"].setValue('', { emitEvent: false });
        this.latlngFormGroup.controls["dmsLngInput"].setValue('', { emitEvent: false });
        this.latlngFormGroup.reset();
        this.elevationFormGroup.controls["elevationInput"].setValue('', { emitEvent: false });
        this.elevationFormGroup.reset();
        this.geoSearchFormGroup.controls["placeInput"].setValue('', { emitEvent: false });
    };
    /**
     * Clear geoResults layer (eg this layer contains administrative polygons -- "commune")
     */
    /**
     * Clear geoResults layer (eg this layer contains administrative polygons -- "commune")
     * @return {?}
     */
    MapComponent.prototype.clearGeoResultsLayer = /**
     * Clear geoResults layer (eg this layer contains administrative polygons -- "commune")
     * @return {?}
     */
    function () {
        this.geoResultsLayer.clearLayers();
    };
    /**
     *
     */
    /**
     *
     * @return {?}
     */
    MapComponent.prototype.clearDrawnItemsLayer = /**
     *
     * @return {?}
     */
    function () {
        this.drawnItems.clearLayers();
    };
    /**
     *
     */
    /**
     *
     * @return {?}
     */
    MapComponent.prototype.resetLocation = /**
     *
     * @return {?}
     */
    function () {
        this.location = null;
    };
    /**
     * Bind data from elevation and OSM http results to this._location
     * Perform some verifications to ensure data integrity
     * @param data data[0] = elevation, data[1] = osm data | data = osm data
     */
    /**
     * Bind data from elevation and OSM http results to this._location
     * Perform some verifications to ensure data integrity
     * @param {?} data data[0] = elevation, data[1] = osm data | data = osm data
     * @return {?}
     */
    MapComponent.prototype.bindLocationOutput = /**
     * Bind data from elevation and OSM http results to this._location
     * Perform some verifications to ensure data integrity
     * @param {?} data data[0] = elevation, data[1] = osm data | data = osm data
     * @return {?}
     */
    function (data) {
        /** @type {?} */
        var elevation;
        /** @type {?} */
        var osmPlace;
        if (Array.isArray(data)) {
            elevation = data[0];
            osmPlace = data[1];
        }
        else {
            elevation = this.elevationFormGroup.controls["elevationInput"].value;
            osmPlace = data;
        }
        this._location.geometry = this.drawnItems.toGeoJSON();
        // geodatum
        this._location.elevation = elevation;
        this._location.localityConsistency = this._location.localityConsistency ? true : null; // perform : Cohérence entre les coordonnées et la localité
        this._location.locationAccuracy = this._location.locationAccuracy ? 0 : null; // perform : Précision (ou incertitude) de la localisation, en mètres --> voir le nombre de décimales pour decLatInput ou decLngInput si point, sinon, demi-longeur de la bounding-box
        // published_location : Précision géographique à laquelle est publiée l'obs, permet de gérer le floutage - Précise, Localité, Maille 10x10km
        this._location.osmCountry = osmPlace.address.country;
        this._location.osmCountryCode = osmPlace.address.country_code;
        this._location.osmCounty = osmPlace.address.county;
        this._location.osmPostcode = osmPlace.address.postcode;
        if (osmPlace.address.city) {
            this._location.locality = osmPlace.address.city;
        }
        if (osmPlace.address.town) {
            this._location.locality = osmPlace.address.town;
        }
        if (osmPlace.address.village) {
            this._location.locality = osmPlace.address.village;
        }
        this._location.sublocality = osmPlace.hamlet;
        this._location.osmRoad = osmPlace.address.road;
        this._location.osmState = osmPlace.address.state;
        this._location.osmSuburb = osmPlace.address.suburb;
        this._location.osmId = osmPlace.osm_id;
        this._location.osmNeighbourhood = null; // not provided by nominatim
        this._location.osmPlaceId = osmPlace.place_id;
        this._location.publishedLocation = null; // perform
        this._location.station = null; // perform
        // Verifications
        // @todo
        // Emit
        this.location.next(this._location);
    };
    /**
     * Change the form coordinates format : 'decimal' or 'dms'
     */
    /**
     * Change the form coordinates format : 'decimal' or 'dms'
     * @param {?} format
     * @return {?}
     */
    MapComponent.prototype.setLatLngInputFormat = /**
     * Change the form coordinates format : 'decimal' or 'dms'
     * @param {?} format
     * @return {?}
     */
    function (format) {
        if (format !== 'decimal' && format !== 'dms') {
            return;
        }
        this.coordFormat = format;
    };
    /**
     * Set inputs values, add a marker and call API for a geolocated photo
     */
    /**
     * Set inputs values, add a marker and call API for a geolocated photo
     * @param {?} latDec
     * @param {?} lngDec
     * @param {?} elevation
     * @return {?}
     */
    MapComponent.prototype.gpsMarkerSetValues = /**
     * Set inputs values, add a marker and call API for a geolocated photo
     * @param {?} latDec
     * @param {?} lngDec
     * @param {?} elevation
     * @return {?}
     */
    function (latDec, lngDec, elevation) {
        // set inputs values
        this.latlngFormGroup.controls["latInput"].setValue(latDec);
        this.latlngFormGroup.controls["lngInput"].setValue(lngDec);
        this.elevationFormGroup.controls["elevationInput"].setValue(elevation);
        // add marker
        this.addMarkerFromLatLngCoord();
        // call APIs
        this.callGeolocElevationApisUsingLatLngInputsValues(true, false);
        // clear geolocated photos layer
        this.geolocatedPhotoLatLngLayer.clearLayers();
    };
    /**
     * @param {?} value
     * @return {?}
     */
    MapComponent.prototype.latLngDmsAutoFormatter = /**
     * @param {?} value
     * @return {?}
     */
    function (value) {
        return '';
    };
    MapComponent.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Component"], args: [{
                    selector: 'tb-geoloc-map',
                    template: "<h1>O\u00F9 ?</h1>\n  \n<div id=\"geoloc-map\">\n  <div id=\"geoloc-map-meta\">\n    <!-- geosearch autocomplete -->\n    <mat-form-field style=\"width: 100%;\">\n      <input matInput [formControl]=\"geoSearchFormGroup.controls.placeInput\" placeholder=\"Trouver un lieu\" aria-label=\"Trouver un lieu\" [matAutocomplete]=\"auto\">\n      <mat-spinner *ngIf=\"isLoadingAddress\" diameter=\"20\" matSuffix></mat-spinner>\n      <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"addressSelectedChanged($event)\">\n        <mat-option *ngFor=\"let address of geoSearchResults\" [value]=\"address\">\n          <span>{{ address | osmPlaceReadableAddress }}</span>\n        </mat-option>\n      </mat-autocomplete>\n    </mat-form-field>\n    \n    <div class=\"geolocationInputs\">\n      <div [formGroup]=\"latlngFormGroup\">\n        <div class=\"latLngMenuInputs\">\n          <!-- latitude / longitude decimal format -->\n          <div *ngIf=\"coordFormat=='decimal'\">\n            <!-- latitude / longitude format selection -->  \n            <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n              <mat-icon>more_vert</mat-icon>\n            </button>\n\n            <mat-form-field>\n              <input matInput formControlName=\"latInput\" placeholder=\"latitude\">\n              <mat-spinner *ngIf=\"isLoadingLatitude\" diameter=\"20\" matSuffix></mat-spinner>\n              <mat-error *ngIf=\"latlngFormGroup.controls.latInput.dirty && latlngFormGroup.controls.latInput.hasError('malformedLatLngDecFormat')\">Format non valide</mat-error>\n            </mat-form-field>\n            <mat-form-field>\n              <input matInput formControlName=\"lngInput\" placeholder=\"longitude\">\n              <mat-spinner *ngIf=\"isLoadingLongitude\" diameter=\"20\" matSuffix></mat-spinner>\n              <mat-error *ngIf=\"latlngFormGroup.controls.latInput.dirty && latlngFormGroup.controls.latInput.hasError('malformedLatLngDecFormat')\">Format non valide</mat-error>\n            </mat-form-field>\n            \n            <button mat-icon-button (click)=\"addMarkerFromLatLngCoord(); callGeolocElevationApisUsingLatLngInputsValues();\" [disabled]=\"!latlngFormGroup.controls.latInput.valid || !latlngFormGroup.controls.lngInput.valid\" color=\"primary\">\n              <mat-icon matTooltip=\"Utiliser ces coordonn\u00E9es\">where_to_vote</mat-icon>\n            </button>\n          </div>\n        </div>\n\n        <!-- menu format decimal / dms-->\n        <mat-menu #menu=\"matMenu\">\n          <button mat-menu-item (click)=\"setLatLngInputFormat('dms')\">Degr\u00E9s minutes secondes</button>\n          <button mat-menu-item (click)=\"setLatLngInputFormat('decimal')\">D\u00E9cimal</button>\n        </mat-menu>\n\n        <!-- latitude / longitude DMS format -->\n        <div *ngIf=\"coordFormat=='dms'\">\n          <!-- latitude / longitude format selection -->  \n          <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n            <mat-icon>more_vert</mat-icon>\n          </button>\n\n          <mat-form-field>\n            <input matInput formControlName=\"dmsLatInput\" placeholder=\"(deg)\u00B0  (min)'  (sec)&quot;\">\n            <span matPrefix>N&nbsp;</span>\n            <mat-spinner *ngIf=\"isLoadingLatitude\" diameter=\"20\" matSuffix></mat-spinner>\n            <mat-error *ngIf=\"latlngFormGroup.controls.dmsLatInput.dirty && latlngFormGroup.controls.dmsLatInput.hasError('malformedLatLngDmsFormat')\">Format non valide</mat-error>\n          </mat-form-field>\n\n          <mat-form-field>\n            <input matInput formControlName=\"dmsLngInput\" placeholder=\"(deg)\u00B0  (min)'  (sec)&quot;\">\n            <span matPrefix>E&nbsp;</span>\n            <mat-spinner *ngIf=\"isLoadingLongitude\" diameter=\"20\" matSuffix></mat-spinner>\n            <mat-error *ngIf=\"latlngFormGroup.controls.dmsLatInput.dirty && latlngFormGroup.controls.dmsLatInput.hasError('malformedLatLngDmsFormat')\">Format non valide</mat-error>\n          </mat-form-field>\n\n          <button mat-icon-button (click)=\"addMarkerFromDmsCoord(); callGeolocElevationApisUsingLatLngInputsValues();\" [disabled]=\"!latlngFormGroup.controls.dmsLatInput.valid || !latlngFormGroup.controls.dmsLngInput.valid\" color=\"primary\">\n            <mat-icon matTooltip=\"Utiliser ces coordonn\u00E9es\">where_to_vote</mat-icon>\n          </button>\n        </div>\n      </div>\n    \n      <!-- elevation -->\n      <div [formGroup]=\"elevationFormGroup\">\n        <mat-form-field style=\"width: 100px;\">\n          <input matInput formControlName=\"elevationInput\" placeholder=\"altitude\">\n          <mat-spinner *ngIf=\"isLoadingElevation\" diameter=\"20\" matSuffix></mat-spinner>\n          <span *ngIf=\"!isLoadingElevation\" matSuffix>m</span>\n        </mat-form-field>\n      </div>\n    </div>\n  </div>\n\n  <div id=\"geoloc-map-draw\" style=\"height: 400px;\"\n      leaflet \n      [leafletOptions]=\"options\"\n      (leafletMapReady)=\"onMapReady($event)\">\n  </div>\n</div>",
                    styles: ["[hidden]{display:none!important}#geoloc-map{display:flex;flex-direction:column;min-height:200px}#geoloc-map #geoloc-map-meta{flex:1;padding:15px}#geoloc-map #geoloc-map-meta .geolocationInputs{display:flex;flex-direction:row;justify-content:space-between}#geoloc-map #geoloc-map-draw{position:relative;flex:3}#geoloc-map #httpTasksRunningSpinner{flex:1}button .mini{min-width:0;line-height:30px}.geolocatedPhotoMetadataTable{width:100%}"]
                },] },
    ];
    /** @nocollapse */
    MapComponent.ctorParameters = function () { return [
        { type: _angular_forms__WEBPACK_IMPORTED_MODULE_6__["FormBuilder"] },
        { type: GeocodingService },
        { type: ElevationService }
    ]; };
    MapComponent.propDecorators = {
        layersToAdd: [{ type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Input"] }],
        geolocatedPhotoLatLng: [{ type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Input"] }],
        osmClassFilter: [{ type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Input"] }],
        location: [{ type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Output"] }]
    };
    return MapComponent;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
/**
 * To show an address to the user, we could use the display_name attribute returned by nominatim
 * This attribute is far complicated to read (road, neighbourhood, suburb, town, city, postcode, county, country, etc.)
 * This pipe use the getReadbleAddress() function of geocode service to show minimal information about the address returned by nominatim API
 */
var OsmPlaceReadableAddressPipe = /** @class */ (function () {
    function OsmPlaceReadableAddressPipe(geocodeService) {
        this.geocodeService = geocodeService;
    }
    /**
     * @param {?} value
     * @param {?=} args
     * @return {?}
     */
    OsmPlaceReadableAddressPipe.prototype.transform = /**
     * @param {?} value
     * @param {?=} args
     * @return {?}
     */
    function (value, args) {
        return this.geocodeService.getReadbleAddress(value);
    };
    OsmPlaceReadableAddressPipe.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["Pipe"], args: [{
                    name: 'osmPlaceReadableAddress'
                },] },
    ];
    /** @nocollapse */
    OsmPlaceReadableAddressPipe.ctorParameters = function () { return [
        { type: GeocodingService }
    ]; };
    return OsmPlaceReadableAddressPipe;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */
var TbGeolocLibModule = /** @class */ (function () {
    function TbGeolocLibModule() {
    }
    TbGeolocLibModule.decorators = [
        { type: _angular_core__WEBPACK_IMPORTED_MODULE_0__["NgModule"], args: [{
                    imports: [
                        _angular_common__WEBPACK_IMPORTED_MODULE_8__["CommonModule"],
                        _angular_platform_browser_animations__WEBPACK_IMPORTED_MODULE_9__["BrowserAnimationsModule"],
                        _angular_platform_browser__WEBPACK_IMPORTED_MODULE_10__["BrowserModule"],
                        _angular_common_http__WEBPACK_IMPORTED_MODULE_2__["HttpClientModule"],
                        _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatSelectModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatInputModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatAutocompleteModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatProgressSpinnerModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatTooltipModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatChipsModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatIconModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatButtonModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatRadioModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatProgressBarModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatMenuModule"], _angular_material__WEBPACK_IMPORTED_MODULE_11__["MatTableModule"],
                        _asymmetrik_ngx_leaflet__WEBPACK_IMPORTED_MODULE_12__["LeafletModule"].forRoot(), _asymmetrik_ngx_leaflet_draw__WEBPACK_IMPORTED_MODULE_13__["LeafletDrawModule"].forRoot(),
                        _angular_forms__WEBPACK_IMPORTED_MODULE_6__["FormsModule"],
                        _angular_forms__WEBPACK_IMPORTED_MODULE_6__["ReactiveFormsModule"]
                    ],
                    declarations: [TbGeolocLibComponent, MapComponent, OsmPlaceReadableAddressPipe],
                    exports: [TbGeolocLibComponent, MapComponent]
                },] },
    ];
    return TbGeolocLibModule;
}());

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
 */



//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tb-geoloc-lib.js.map","sources":["ng://tb-geoloc-lib/lib/tb-geoloc-lib.component.ts","ng://tb-geoloc-lib/lib/_helpers/geoConvert.ts","ng://tb-geoloc-lib/lib/_helpers/leafletObjects.ts","ng://tb-geoloc-lib/lib/_helpers/dmsTools.ts","ng://tb-geoloc-lib/lib/_services/geocoding.service.ts","ng://tb-geoloc-lib/lib/_services/elevation.service.ts","ng://tb-geoloc-lib/lib/map/map.component.ts","ng://tb-geoloc-lib/lib/_pipes/osm-place-readable-address.pipe.ts","ng://tb-geoloc-lib/lib/tb-geoloc-lib.module.ts"],"sourcesContent":["import { Component, OnInit } from '@angular/core';\n\n@Component({\n  selector: 'tb-geoloc-tb-geoloc-lib',\n  template: ``,\n  styles: []\n})\nexport class TbGeolocLibComponent implements OnInit {\n\n  constructor() { }\n\n  ngOnInit() {\n  }\n\n}\n","/**\n * GeoPoint\n *\n * https://github.com/perfectline/geopoint\n *\n * Authors :\n * Tanel Suurhans (http://twitter.com/tanelsuurhans)\n * Tarmo Lehtpuu (http://twitter.com/tarmolehtpuu)\n *\n * License :\n * Copyright 2011 by PerfectLine LLC (http://www.perfectline.ee) and is released under the MIT license.\n */\n\nexport const GeoPoint = function(lon, lat) {\n\n\n  switch (typeof(lon)) {\n\n      case 'number':\n\n          this.lonDeg = this.dec2deg(lon, this.MAX_LON);\n          this.lonDec = lon;\n\n          break;\n\n      case 'string':\n\n          if (this.decode(lon)) {\n              this.lonDeg = lon;\n          }\n\n          this.lonDec = this.deg2dec(lon, this.MAX_LON);\n\n          break;\n  }\n\n  switch (typeof(lat)) {\n\n      case 'number':\n\n          this.latDeg = this.dec2deg(lat, this.MAX_LAT);\n          this.latDec = lat;\n\n          break;\n\n      case 'string':\n\n          if (this.decode(lat)) {\n              this.latDeg = lat;\n          }\n\n          this.latDec = this.deg2dec(lat, this.MAX_LAT);\n\n          break;\n\n  }\n};\n\nGeoPoint.prototype = {\n\n  CHAR_DEG : '\\u00B0',\n  CHAR_MIN : '\\u0027',\n  CHAR_SEC : '\\u0022',\n  CHAR_SEP : '\\u0020',\n\n  MAX_LON: 180,\n  MAX_LAT: 90,\n\n  // decimal\n  lonDec: NaN,\n  latDec: NaN,\n\n  // degrees\n  lonDeg: NaN,\n  latDeg: NaN,\n\n  dec2deg: function(value, max) {\n\n      const sign = value < 0 ? -1 : 1;\n\n      const abs = Math.abs(Math.round(value * 1000000));\n\n      if (abs > (max * 1000000)) {\n          return NaN;\n      }\n\n      const dec = abs % 1000000 / 1000000;\n      const deg = Math.floor(abs / 1000000) * sign;\n      const min = Math.floor(dec * 60);\n      const sec = (dec - min / 60) * 3600;\n\n      let result = '';\n\n      result += deg;\n      result += this.CHAR_DEG;\n      result += this.CHAR_SEP;\n      result += min;\n      result += this.CHAR_MIN;\n      result += this.CHAR_SEP;\n      result += sec.toFixed(2);\n      result += this.CHAR_SEC;\n\n      return result;\n\n  },\n\n  deg2dec: function(value) {\n\n      const matches = this.decode(value);\n\n      if (!matches) {\n          return NaN;\n      }\n\n      const deg = parseFloat(matches[1]);\n      const min = parseFloat(matches[2]);\n      const sec = parseFloat(matches[3]);\n\n      if (isNaN(deg) || isNaN(min) || isNaN(sec)) {\n          return NaN;\n      }\n\n      return deg + (min / 60.0) + (sec / 3600);\n  },\n\n  decode: function(value) {\n      let pattern = '';\n\n      // deg\n      pattern += '(-?\\\\d+)';\n      pattern += this.CHAR_DEG;\n      pattern += '\\\\s*';\n\n      // min\n      pattern += '(\\\\d+)';\n      pattern += this.CHAR_MIN;\n      pattern += '\\\\s*';\n\n      // sec\n      pattern += '(\\\\d+(?:\\\\.\\\\d+)?)';\n      pattern += this.CHAR_SEC;\n\n      return value.match(new RegExp(pattern));\n  },\n\n  getLonDec: function() {\n      return this.lonDec;\n  },\n\n  getLatDec: function() {\n      return this.latDec;\n  },\n\n  getLonDeg: function() {\n      return this.lonDeg;\n  },\n\n  getLatDeg: function() {\n      return this.latDeg;\n  }\n\n};\n","/**\n *\n */\n\nimport * as L from 'leaflet';\n\n/**\n *\n * @param lat\n * @param lng\n * @param dragend callback\n */\nexport const draggableMarker = function(lat: number, lng: number, dragend: Function): L.Marker {\n  const simpleIcon = simpleIconMarker();\n  const marker = L.marker([lat, lng], {icon: simpleIcon, draggable: true});\n  marker.on('dragend', function(event) { return dragend(event); });\n  return marker;\n};\n\n/**\n *\n */\nexport const simpleIconMarker = function(): L.Icon {\n  return L.icon({\n    iconUrl: './assets/img/map/marker-icon.png',\n    shadowUrl: './assets/img/map/marker-shadow.png',\n    iconAnchor: [13, 40]\n  });\n};\n\n/**\n *\n */\nexport const drawControlPanel = new L.Control.Draw({\n  position: 'topleft',\n  draw: {\n    marker: { icon: simpleIconMarker() },\n    polyline: {},\n    polygon: { showArea: true, metric: false },\n    rectangle: false,\n    circle: false,\n    circlemarker: false\n  }\n});\n\n/**\n *\n * @param editedLayer\n */\nexport function drawControlEditPanel(editedLayer) {\n  return new L.Control.Draw({\n    position: 'topleft',\n    draw: {\n      marker: false,\n      polyline: false,\n      polygon: false,\n      rectangle: false,\n      circle: false,\n      circlemarker: false\n    },\n    edit: {\n      featureGroup: editedLayer, // this panel id editing editedLayer\n      edit: {},\n      remove: {}\n    }\n  });\n}\n\n/**\n *\n */\nexport const circleMarkerStyle = {\n  radius: 6,\n  fillColor: '#ff7800',\n  color: '#000',\n  weight: 1,\n  opacity: 1,\n  fillOpacity: 0.8\n};\n\n/**\n *\n */\nexport const cityStyle = {\n  color: '#ff7800',\n    weight: 5,\n    opacity: 0.65\n};\n\n/**\n *\n */\nexport const gpsPhotoMarkerIcon = (): L.Icon => {\n  return L.icon({\n    iconUrl: './assets/img/map/photo-marker-icon.png',\n    shadowUrl: './assets/img/map/marker-shadow.png',\n\n    iconSize:     [33, 41], // size of the icon\n    // shadowSize:   [50, 64], // size of the shadow\n    iconAnchor:   [13, 40], // point of the icon which will correspond to marker's location\n    // shadowAnchor: [4, 62],  // the same for the shadow\n    popupAnchor:  [5, -41] // point from which the popup should open relative to the iconAnchor\n  });\n};\n\n/**\n *\n */\nexport const gpsPhotoMarkerIconHighlight = (): L.Icon => {\n  return L.icon({\n    iconUrl: './assets/img/map/photo-marker-icon.png',\n    shadowUrl: './assets/img/map/marker-shadow.png',\n\n    iconSize:     [43, 54], // size of the icon\n    // shadowSize:   [50, 64], // size of the shadow\n    iconAnchor:   [13, 40], // point of the icon which will correspond to marker's location\n    // shadowAnchor: [4, 62],  // the same for the shadow\n    popupAnchor:  [0, -76] // point from which the popup should open relative to the iconAnchor\n  });\n};\n","/**\n * Auto format a DMS coordinates\n * eg. user can enter 43 0 14.77\n * and the formatter returns 43Â° 0' 14.77\"\n * + avoid enter non numeric (or . ,) characters\n * + force entire numbers for degrees and minutes\n */\nexport function dmsFormatter(dmsStr: string): string {\n  try {\n    // replace multiples spaces\n    dmsStr = dmsStr.replace(/\\s\\s+/g, ' ');\n    // replace space at first position\n    if (dmsStr.charAt(0) === ' ') { dmsStr = dmsStr.slice(1, dmsStr.length - 1); }\n    // replace , by .\n    dmsStr = dmsStr.replace(',', '.');\n    // delete all non numeric characters\n    dmsStr = dmsStr.replace(/[^0-9\\-.,Â°\\'\"\\s]/g, '');\n\n    let nbSpaces: number;\n    let degChr = '';\n    let minChr = '';\n    let secChr = '';\n\n    let v = dmsStr.split(' ');\n    // remove last space od input string\n    if (dmsStr.charAt(dmsStr.length - 1) === ' ') {\n      v = v.slice(0 , v.length - 1);\n    }\n    // remove last item of v array if it's empty\n    if (v[v.length - 1] === '') {\n      v = v.slice(0 , v.length - 1);\n    }\n    if (v.length === 1) {\n      degChr = v[0];\n      // degChr must be an entire number\n      if (degChr.indexOf('.') !== -1) { degChr = degChr.slice(0, degChr.indexOf('.')); }\n      // between -90 & +90\n      if (Number(degChr) < -90) { degChr = '-90'; }\n      if (Number(degChr) > 90) { degChr = '90'; }\n    }\n    if (v.length === 2) {\n      degChr = v[0]; minChr = v[1];\n      if (degChr.indexOf('.') !== -1) { degChr = degChr.slice(0, degChr.indexOf('.')); }\n      if (minChr.indexOf('.') !== -1) { minChr = minChr.slice(0, degChr.indexOf('.')); }\n      if (Number(degChr) < -90) { degChr = '-90'; }\n      if (Number(degChr) > 90) { degChr = '90'; }\n      if (Number(minChr) < -90) { minChr = '-90'; }\n      if (Number(minChr) > 90) { minChr = '90'; }\n      }\n    if (v.length === 3) {\n      degChr = v[0]; minChr = v[1]; secChr = v[2];\n      if (degChr.indexOf('.') !== -1) { degChr = degChr.slice(0, degChr.indexOf('.')); }\n      if (minChr.indexOf('.') !== -1) { minChr = minChr.slice(0, degChr.indexOf('.')); }\n      if (Number(degChr) < -90) { degChr = '-90'; }\n      if (Number(degChr) > 90) { degChr = '90'; }\n      if (Number(minChr) < -90) { minChr = '-90'; }\n      if (Number(minChr) > 90) { minChr = '90'; }\n      }\n    if (v.length >= 4) {\n      v = v.slice(0, 2);\n      if (degChr.indexOf('.') !== -1) { degChr = degChr.slice(0, degChr.indexOf('.')); }\n      if (minChr.indexOf('.') !== -1) { minChr = minChr.slice(0, degChr.indexOf('.')); }\n      if (Number(degChr) < -90) { degChr = '-90'; }\n      if (Number(degChr) > 90) { degChr = '90'; }\n      if (Number(minChr) < -90) { minChr = '-90'; }\n      if (Number(minChr) > 90) { minChr = '90'; }\n    }\n\n    try {\n      nbSpaces = dmsStr.match(/\\s/g).length;\n    } catch (e) {\n      nbSpaces = 0;\n    }\n    if (nbSpaces === 0 && v.length === 1)Â {\n      // do nothing\n    } else if (nbSpaces === 1 && v.length >= 1) {\n      degChr = degChr.replace(' ', '');\n      if (degChr.slice(degChr.length - 1, degChr.length) !== 'Â°') { degChr += 'Â° '; } else { degChr += ' '; }\n    } else if (nbSpaces === 2 && v.length >= 2) {\n      degChr = degChr.replace(' ', '');\n      minChr = minChr.replace(' ', '');\n      if (degChr.slice(degChr.length - 1, degChr.length) !== 'Â°') { degChr += 'Â° '; } else { degChr += ' '; }\n      if (minChr.slice(minChr.length - 1, minChr.length) !== '\\'') { minChr += '\\' '; } else { minChr += ' '; }\n    } else if (nbSpaces === 3 && v.length >= 3) {\n      degChr = degChr.replace(' ', '');\n      minChr = minChr.replace(' ', '');\n      secChr = secChr.replace(' ', '');\n      if (degChr.slice(degChr.length - 1, degChr.length) !== 'Â°') { degChr += 'Â° '; } else { degChr += ' '; }\n      if (minChr.slice(minChr.length - 1, minChr.length) !== '\\'') { minChr += '\\' '; } else { minChr += ' '; }\n      if (secChr.slice(secChr.length - 1, secChr.length) !== '\"') { secChr += '\"'; }\n    } else {\n      throw { error: 'Can\\'t manage input string.' };\n    }\n\n    return degChr + minChr + secChr;\n\n  } catch (e) {\n    return dmsStr;\n  }\n}\n","import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable, empty, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { NominatimObject } from '../_models/nominatimObj.model';\nimport { OsmPlaceModel } from '../_models/osmPlace.model';\nimport { isDefined } from '@angular/compiler/src/util';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class GeocodingService {\n\n  constructor(private http: HttpClient) { }\n\n  geocode(address: string): Observable<any> {\n    if (address === null) { return empty(); } // Avoid sending request on form reset\n    const url = `https://nominatim.openstreetmap.org/?format=json&addressdetails=1&q=${address}&format=json&limit=10&polygon_geojson=1`;\n    return this.http.get(url).pipe(\n      map((obj: NominatimObject) => obj)\n    );\n  }\n\n  reverse(lat: number, lng: number): Observable<any> {\n    const url = `https://nominatim.openstreetmap.org/reverse?format=json&lat=${lat}&lon=${lng}&polygon_geojson=1`;\n    return this.http.get(url).pipe(\n      map((obj: NominatimObject) => obj)\n    );\n  }\n\n  getReadbleAddress(osmPlaceResult: OsmPlaceModel): string {\n    let locality: string = null;    // city or village or ...\n    let subLocality: string = null; // district or\n    let road: string = null;\n    let neighbourhood: string = null;\n\n    // Get \"city\" information (I mean city or something similar like village)\n    if (isDefined(osmPlaceResult.address.city)) { locality = osmPlaceResult.address.city;\n    } else if (isDefined(osmPlaceResult.address.town)) { locality = osmPlaceResult.address.town;\n    } else if (isDefined(osmPlaceResult.address.village)) { locality = osmPlaceResult.address.village;\n    } else if (isDefined(osmPlaceResult.address.hamlet)) { locality = osmPlaceResult.address.hamlet; }\n\n    // Get suburbr & if not defined : postcode\n    if (isDefined(osmPlaceResult.address.suburb) && isDefined(osmPlaceResult.address.postcode) && locality !== null) {\n      subLocality = osmPlaceResult.address.suburb + ', ' + osmPlaceResult.address.postcode;\n    } else if (!isDefined(osmPlaceResult.address.suburb) && isDefined(osmPlaceResult.address.postcode) && locality !== null) {\n      subLocality = osmPlaceResult.address.postcode;\n    }\n\n    // Get \"road\"\n    if (isDefined(osmPlaceResult.address.road)) {\n      road = osmPlaceResult.address.road;\n    } else if (isDefined(osmPlaceResult.address.pedestrian)) {\n      road = osmPlaceResult.address.pedestrian;\n    }\n\n    // Get neighbourhood\n    if (isDefined(osmPlaceResult.address.neighbourhood)) {\n      neighbourhood = osmPlaceResult.address.neighbourhood;\n    }\n\n    // Return\n    if (road && neighbourhood && subLocality && locality) {\n      return road + ' (' + neighbourhood + ') ' + subLocality + ' ' + locality;\n    } else if (road && !neighbourhood && subLocality && locality) {\n      return road + ' ' + subLocality + ' ' + locality;\n    } else if (!road && neighbourhood && subLocality && locality) {\n      return neighbourhood + ' ' + subLocality + ' ' + locality;\n    } else if (!road && !neighbourhood && subLocality && locality) {\n      return subLocality + ' ' + locality;\n    } else if (!road && !neighbourhood && !subLocality && locality) {\n      return locality;\n    } else {\n      return osmPlaceResult.display_name;\n    }\n\n  }\n\n  osmClassFilter(osmClassFilter: Array<string>, osmResults: Array<NominatimObject>) {\n    const osmFilteredResults: Array<NominatimObject> = [];\n    if (osmClassFilter.length > 0 && osmResults.length > 0) {\n      osmResults.forEach(osmItem => {\n        let filterMatchOccurence = 0;\n        let removeOccurence   = false;\n        osmClassFilter.forEach(osmFilterItem => {\n          const _class = osmFilterItem.split(':')[0];\n          const _type = osmFilterItem.split(':')[1];\n          if (_type === '*') {\n            if (osmItem.class === _class) { filterMatchOccurence++; }\n          } else {\n            // if !, remove\n            if (_type.substr(0, 1) === '!') {\n              if (osmItem.class === _class && '!' + osmItem.type === _type) { removeOccurence = true; }\n            } else {\n              if (osmItem.class === _class && osmItem.type === _type) { filterMatchOccurence++; }\n            }\n          }\n        });\n        if (filterMatchOccurence > 0 && !removeOccurence) {\n          osmFilteredResults.push(osmItem);\n        }\n      });\n      return of(osmFilteredResults);\n    } else {\n      return of(osmResults);\n    }\n  }\n\n  reverseCorrdinatesArray(coordinatesArray: Array<[number, number]>) {\n    if (coordinatesArray.length > 0) {\n      coordinatesArray.forEach(item => {\n        item.reverse();\n      });\n      return coordinatesArray;\n    }\n  }\n\n  simplifyPolyline(coordinatesArray: Array<[number, number]>): Array<[number, number]> {\n    if (coordinatesArray.length > 1) {\n      const firstCoordinate = coordinatesArray[0];\n      const lastCoordinate = coordinatesArray[coordinatesArray.length - 1];\n      return [firstCoordinate, lastCoordinate];\n    } else {\n      return coordinatesArray;\n    }\n  }\n}\n\n\n\n\n","import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElevationService {\n\n  constructor(private http: HttpClient) { }\n\n  getElevation(lat: number, lng: number): Observable<number> {\n    const apiUrl = `https://api.open-elevation.com/api/v1/lookup?locations=${lat},${lng}`;\n    return this.http.get(apiUrl).pipe(\n      map((obj: OpenElevationApiObject) => obj.results[0].elevation)\n    );\n  }\n}\n\ninterface OpenElevationApiObject {\n  results: Array<{\n    elevation: number,\n    latitude: number,\n    longitude: number\n  }>;\n}\n","/**\n * @todo limit polygon area / polyline lenght\n * @todo fix form input not updated after .setValue (except for the gpsMarkerSetValues method)\n * see : https://github.com/angular/material2/issues/7601#issuecomment-334947280,\n *       https://github.com/angular/material2/issues/2434,\n *       https://github.com/angular/material2/issues/2363,\n *       https://github.com/angular/material2/pull/2455,\n *       https://github.com/angular/material2/issues/2837#issuecomment-276538616,\n *       https://github.com/angular/material2/issues/7601,\n *       https://github.com/angular/material2/issues/2441\n */\nimport { Component, OnInit, OnDestroy, EventEmitter, Input, Output } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { MatAutocompleteSelectedEvent } from '@angular/material';\nimport { Subscription, Observable, zip } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap } from 'rxjs/operators';\nimport * as L from 'leaflet';\nimport 'leaflet-draw';\nimport { LatLngExpression } from 'leaflet';\n\nimport { GeoPoint } from '../_helpers/geoConvert';\nimport * as leafletObjects from '../_helpers/leafletObjects';\nimport { dmsFormatter } from '../_helpers/dmsTools';\n\nimport { GeocodingService } from '../_services/geocoding.service';\nimport { ElevationService } from '../_services/elevation.service';\n\nimport { LocationModel } from '../_models/location.model';\nimport { NominatimObject } from '../_models/nominatimObj.model';\nimport { LatLngDMSAltitudePhotoName } from '../_models/gpsLatLng';\n\n@Component({\n  selector: 'tb-geoloc-map',\n  template: `<h1>OÃ¹ ?</h1>\n  \n<div id=\"geoloc-map\">\n  <div id=\"geoloc-map-meta\">\n    <!-- geosearch autocomplete -->\n    <mat-form-field style=\"width: 100%;\">\n      <input matInput [formControl]=\"geoSearchFormGroup.controls.placeInput\" placeholder=\"Trouver un lieu\" aria-label=\"Trouver un lieu\" [matAutocomplete]=\"auto\">\n      <mat-spinner *ngIf=\"isLoadingAddress\" diameter=\"20\" matSuffix></mat-spinner>\n      <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"addressSelectedChanged($event)\">\n        <mat-option *ngFor=\"let address of geoSearchResults\" [value]=\"address\">\n          <span>{{ address | osmPlaceReadableAddress }}</span>\n        </mat-option>\n      </mat-autocomplete>\n    </mat-form-field>\n    \n    <div class=\"geolocationInputs\">\n      <div [formGroup]=\"latlngFormGroup\">\n        <div class=\"latLngMenuInputs\">\n          <!-- latitude / longitude decimal format -->\n          <div *ngIf=\"coordFormat=='decimal'\">\n            <!-- latitude / longitude format selection -->  \n            <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n              <mat-icon>more_vert</mat-icon>\n            </button>\n\n            <mat-form-field>\n              <input matInput formControlName=\"latInput\" placeholder=\"latitude\">\n              <mat-spinner *ngIf=\"isLoadingLatitude\" diameter=\"20\" matSuffix></mat-spinner>\n              <mat-error *ngIf=\"latlngFormGroup.controls.latInput.dirty && latlngFormGroup.controls.latInput.hasError('malformedLatLngDecFormat')\">Format non valide</mat-error>\n            </mat-form-field>\n            <mat-form-field>\n              <input matInput formControlName=\"lngInput\" placeholder=\"longitude\">\n              <mat-spinner *ngIf=\"isLoadingLongitude\" diameter=\"20\" matSuffix></mat-spinner>\n              <mat-error *ngIf=\"latlngFormGroup.controls.latInput.dirty && latlngFormGroup.controls.latInput.hasError('malformedLatLngDecFormat')\">Format non valide</mat-error>\n            </mat-form-field>\n            \n            <button mat-icon-button (click)=\"addMarkerFromLatLngCoord(); callGeolocElevationApisUsingLatLngInputsValues();\" [disabled]=\"!latlngFormGroup.controls.latInput.valid || !latlngFormGroup.controls.lngInput.valid\" color=\"primary\">\n              <mat-icon matTooltip=\"Utiliser ces coordonnÃ©es\">where_to_vote</mat-icon>\n            </button>\n          </div>\n        </div>\n\n        <!-- menu format decimal / dms-->\n        <mat-menu #menu=\"matMenu\">\n          <button mat-menu-item (click)=\"setLatLngInputFormat('dms')\">DegrÃ©s minutes secondes</button>\n          <button mat-menu-item (click)=\"setLatLngInputFormat('decimal')\">DÃ©cimal</button>\n        </mat-menu>\n\n        <!-- latitude / longitude DMS format -->\n        <div *ngIf=\"coordFormat=='dms'\">\n          <!-- latitude / longitude format selection -->  \n          <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n            <mat-icon>more_vert</mat-icon>\n          </button>\n\n          <mat-form-field>\n            <input matInput formControlName=\"dmsLatInput\" placeholder=\"(deg)Â°  (min)'  (sec)&quot;\">\n            <span matPrefix>N&nbsp;</span>\n            <mat-spinner *ngIf=\"isLoadingLatitude\" diameter=\"20\" matSuffix></mat-spinner>\n            <mat-error *ngIf=\"latlngFormGroup.controls.dmsLatInput.dirty && latlngFormGroup.controls.dmsLatInput.hasError('malformedLatLngDmsFormat')\">Format non valide</mat-error>\n          </mat-form-field>\n\n          <mat-form-field>\n            <input matInput formControlName=\"dmsLngInput\" placeholder=\"(deg)Â°  (min)'  (sec)&quot;\">\n            <span matPrefix>E&nbsp;</span>\n            <mat-spinner *ngIf=\"isLoadingLongitude\" diameter=\"20\" matSuffix></mat-spinner>\n            <mat-error *ngIf=\"latlngFormGroup.controls.dmsLatInput.dirty && latlngFormGroup.controls.dmsLatInput.hasError('malformedLatLngDmsFormat')\">Format non valide</mat-error>\n          </mat-form-field>\n\n          <button mat-icon-button (click)=\"addMarkerFromDmsCoord(); callGeolocElevationApisUsingLatLngInputsValues();\" [disabled]=\"!latlngFormGroup.controls.dmsLatInput.valid || !latlngFormGroup.controls.dmsLngInput.valid\" color=\"primary\">\n            <mat-icon matTooltip=\"Utiliser ces coordonnÃ©es\">where_to_vote</mat-icon>\n          </button>\n        </div>\n      </div>\n    \n      <!-- elevation -->\n      <div [formGroup]=\"elevationFormGroup\">\n        <mat-form-field style=\"width: 100px;\">\n          <input matInput formControlName=\"elevationInput\" placeholder=\"altitude\">\n          <mat-spinner *ngIf=\"isLoadingElevation\" diameter=\"20\" matSuffix></mat-spinner>\n          <span *ngIf=\"!isLoadingElevation\" matSuffix>m</span>\n        </mat-form-field>\n      </div>\n    </div>\n  </div>\n\n  <div id=\"geoloc-map-draw\" style=\"height: 400px;\"\n      leaflet \n      [leafletOptions]=\"options\"\n      (leafletMapReady)=\"onMapReady($event)\">\n  </div>\n</div>`,\n  styles: [`[hidden]{display:none!important}#geoloc-map{display:flex;flex-direction:column;min-height:200px}#geoloc-map #geoloc-map-meta{flex:1;padding:15px}#geoloc-map #geoloc-map-meta .geolocationInputs{display:flex;flex-direction:row;justify-content:space-between}#geoloc-map #geoloc-map-draw{position:relative;flex:3}#geoloc-map #httpTasksRunningSpinner{flex:1}button .mini{min-width:0;line-height:30px}.geolocatedPhotoMetadataTable{width:100%}`]\n})\nexport class MapComponent implements OnInit, OnDestroy {\n\n  // --------------\n  // INPUT / OUTPUT\n  // --------------\n  @Input() layersToAdd: Array<string> = ['osm'];\n  @Input() geolocatedPhotoLatLng: Observable<Array<LatLngDMSAltitudePhotoName>>;\n  @Input() osmClassFilter: Array<string> = [];\n\n  @Output() location = new EventEmitter<LocationModel>(); // object to return\n\n  // -------------------------\n  // FORMS & RELATED VARIABLES\n  // -------------------------\n  latlngFormGroup: FormGroup;\n  elevationFormGroup: FormGroup;\n  geoSearchFormGroup: FormGroup;\n  geoSearchResults: Array<NominatimObject>;\n  coordFormat = 'dms';            // 'decimal' | 'dms'\n\n  // ---------\n  // VARIABLES\n  // ---------\n  _location = <LocationModel>{};\n  geolocatedPhotoLatLngData: Array<LatLngDMSAltitudePhotoName> = [];\n  geolocatedPhotoLatLngDisplayedColumnsTable: Array<string> = ['select', 'photoName', 'lat', 'lng', 'altitude'];\n  isLoadingAddress = false;\n  isLoadingLatitude = false;\n  isLoadingLongitude = false;\n  isLoadingElevation = false;\n\n  // -------------\n  // SUBSCRIPTIONS\n  // -------------\n  geoSearchSubscription = new Subscription;\n  latDmsInputSubscription = new Subscription;\n  lngDmsInputSubscription = new Subscription;\n\n  // ----------------------------------------\n  // LEAFLET VARIABLES, LAYERS AND MAP CONFIG\n  // ----------------------------------------\n  private map: L.Map;\n  public mapLat = 0;\n  public mapLng = 0;\n  private drawType: string;\n  private drawnItem: any;\n\n  private osmLayer = L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', { maxZoom: 18, attribution: 'Open Street map' });\n  private googleSatelliteLayer = L.tileLayer('http://{s}.google.com/vt/lyrs=s&x={x}&y={y}&z={z}', { maxZoom: 20, subdomains: ['mt0', 'mt1', 'mt2', 'mt3'], attribution: 'Google maps' });\n  private googleHybridLayer = L.tileLayer('http://{s}.google.com/vt/lyrs=s,h&x={x}&y={y}&z={z}', { maxZoom: 20, subdomains: ['mt0', 'mt1', 'mt2', 'mt3'], attribution: 'Google maps' });\n  private brgmLayer = L.tileLayer.wms('http://geoservices.brgm.fr/geologie', { version: '1.3.0', layers: 'Geologie'});\n  private mapLayers = {\n    'Google': this.googleHybridLayer,\n    'OSM': this.osmLayer,\n    'BRGM': this.brgmLayer\n  };\n  private geoResultsLayer = L.geoJSON(null, {style: function() { return { color: '#ff7800', weight: 5, opacity: 0.65 }; }});\n  private geolocatedPhotoLatLngLayer = L.geoJSON();\n\n  // map options\n  options = {\n    layers: [ this.osmLayer ],\n    zoom: 4,\n    center: L.latLng({ lat: 46.55886030311719, lng: 2.9882812500000004 })\n  };\n\n  // Leaflet map configuration\n  drawnItems = new L.FeatureGroup();  // all drawn items\n  drawControlFull = leafletObjects.drawControlPanel;      // draw panel\n  drawControlEdit = leafletObjects.drawControlEditPanel(this.drawnItems);  // edit panel\n  circleMarkerOpt = leafletObjects.circleMarkerStyle;     // marker options\n  geoResultsOpt = leafletObjects.cityStyle;\n\n\n\n  // ----\n  // CODE\n  // ----\n\n  constructor(\n    private fb: FormBuilder,\n    private geocodeService: GeocodingService,\n    private elevationService: ElevationService) { }\n\n  /**\n   * - Create the forms\n   * - Set up subscriptions (geo search, geolocated photos, lat / lng inputs)\n   */\n  ngOnInit() {\n    // Create forms\n    this.latlngFormGroup = this.fb.group({\n      latInput: this.fb.control('', [Validators.required, this.latLngDecValidator]),\n      lngInput: this.fb.control('', [Validators.required, this.latLngDecValidator]),\n      dmsLatInput: this.fb.control('', [Validators.required, this.latLngDmsValidator]),\n      dmsLngInput: this.fb.control('', [Validators.required, this.latLngDmsValidator])\n    });\n\n    this.elevationFormGroup = this.fb.group({\n      elevationInput: this.fb.control('', null)\n    });\n\n    this.geoSearchFormGroup = this.fb.group({\n      placeInput: this.fb.control('', null)\n    });\n\n    // Watch placeInput changes\n    this.geoSearchSubscription = this.geoSearchFormGroup.controls.placeInput.valueChanges\n    .pipe(\n      debounceTime(400),\n      distinctUntilChanged(),\n      switchMap(value => {\n        this.isLoadingAddress = true;\n        return this.geocodeService.geocode(value);\n      })\n    ).subscribe(results => {\n      this.isLoadingAddress = false;\n      // filter results if needed\n      if (this.osmClassFilter.length > 0) {\n        this.geocodeService.osmClassFilter(this.osmClassFilter, results).subscribe(filteredResults => {\n          this.geoSearchResults = filteredResults;\n        });\n      } else {\n        this.geoSearchResults = results;\n      }\n    }, (error) => {\n      // @toto manage error\n      this.isLoadingAddress = false;\n    });\n\n    // Watch geolocated photo input changes\n    this.geolocatedPhotoLatLng.subscribe(photoLatLng => {\n      // @todo clear this.geolocatedPhotoLatLngLayer\n\n      this.geolocatedPhotoLatLngData = photoLatLng;\n\n      // For each geolocated photo, add marker and bind mouse event on thoses markers\n      this.geolocatedPhotoLatLngData.forEach(data => {\n        // Get latitude and longitude (geolocated data are in DMS format)\n        const _latDms = data.lat.deg + 'Â° ' + data.lat.min + '\\'' + data.lat.sec + '\"';\n        const _lngDms = data.lng.deg + 'Â° ' + data.lng.min + '\\'' + data.lng.sec + '\"';\n        const g = new GeoPoint(_lngDms, _latDms);\n        data.latDec = g.latDec;\n        data.lngDec = g.lonDec;\n\n        // Create the marker\n        const latLng = L.latLng(data.latDec, data.lngDec);\n        const gpsPhotoMarker = new L.Marker(latLng, { icon: leafletObjects.gpsPhotoMarkerIcon() });\n        // Marker popup\n        const html = `\n          <b>Fichier \"${data.photoName}\"</b><br>\n          Lat. : ${g.latDeg}<br />\n          Lng. : ${g.lonDeg}<br />\n          Alt. : ${data.altitude} m<br /><br />\n          <b>Cliquez sur le point pour utiliser ces coordonnÃ©es</b>`;\n        gpsPhotoMarker.bindPopup(html).openPopup();\n        // Marker mouse events\n        gpsPhotoMarker.on('click', (event => { this.gpsMarkerSetValues(data.latDec, data.lngDec, data.altitude); }));\n        gpsPhotoMarker.on('mouseover', (event) => { gpsPhotoMarker.openPopup(); });\n        gpsPhotoMarker.on('mouseout', (event => { gpsPhotoMarker.closePopup(); }));\n        // Add the marker to the map\n        gpsPhotoMarker.addTo(this.geolocatedPhotoLatLngLayer);\n      });\n\n      // Fit map to geolocated photos markers\n      this.flyToGeolocatedPhotoItems();\n    });\n\n    // Watch lat & lng DMS inputs changes and set up the DMS formatter\n    // The DMS formatter restricts the keyboard input of the user : only number, comma, dot and '-', deg and min must be between -90 and +90\n    // The formatter auto fill the Â° ' and \" characters to help the user input\n    this.latDmsInputSubscription = this.latlngFormGroup.controls.dmsLatInput.valueChanges.subscribe(value => {\n      this.latlngFormGroup.controls.dmsLatInput.setValue(dmsFormatter(value), { emitEvent: false});\n    });\n    this.lngDmsInputSubscription = this.latlngFormGroup.controls.dmsLngInput.valueChanges.subscribe(value => {\n      this.latlngFormGroup.controls.dmsLngInput.setValue(dmsFormatter(value), { emitEvent: false});\n    });\n  }\n\n  /**\n   * Unsubscribe\n   */\n  ngOnDestroy() {\n    this.geoSearchSubscription.unsubscribe();\n    this.latDmsInputSubscription.unsubscribe();\n    this.lngDmsInputSubscription.unsubscribe();\n  }\n\n  /**\n   * Add layers and events listeners\n   */\n  onMapReady(map: L.Map) {\n    this.map = map;\n    this.map.addControl(L.control.layers(null, this.mapLayers, { position: 'topright'}));\n    this.map.addLayer(this.drawnItems);\n    this.map.addLayer(this.geoResultsLayer);\n    this.map.addLayer(this.geolocatedPhotoLatLngLayer);\n    this.map.addControl(this.drawControlFull);\n    this.map.on('draw:created', (e) => {\n      this.drawnItem = e['layer'];\n      this.drawType = e['layerType'];\n      // If it's a marker, it must be draggable. By default, leaflet.draw module does not provide a draggable marker\n      // So, we don't do a this.drawnItems.addLayer(layer);\n      // We just draw a new draggableMarker instead\n      if (this.drawType === 'marker') {\n        const latlng = this.drawnItem._latlng;\n        leafletObjects.draggableMarker(latlng.lat, latlng.lng, (dragEnd) => { this.callGeolocElevationApisUsingLatLngInputsValues(); }).addTo(this.drawnItems);\n      } else {\n        this.drawnItems.addLayer(this.drawnItem);\n      }\n\n      // Show / hide control panels\n      // if ONE item is drawn, set place and elevation inputs (call API)\n      if (this.drawnItems.getLayers().length > 0) {\n        this.setMapEditMode();\n      }\n      if (this.drawnItems.getLayers().length === 1) {\n        this.callGeolocElevationApisUsingLatLngInputsValues();\n      }\n\n      this.flyToDrawnItems();\n    });\n\n    this.map.on('draw:edited', (e) => {\n      this.drawnItem = e['layer'];\n      this.drawType = e['layerType'];\n\n//      this.drawnItems.addLayer(this.drawnItem);\n\n      if (this.drawnItems.getLayers().length === 1) {\n        this.callGeolocElevationApisUsingLatLngInputsValues();\n      }\n\n      this.flyToDrawnItems();\n    });\n\n    this.map.on('draw:deleted', (e) => {\n      this.clearGeoResultsLayer();\n      this.clearDrawnItemsLayer();\n      this.setMapDrawMode();\n      this.clearForm();\n    });\n\n    this.redrawMap(100);\n  }\n\n  /**\n   * When the map parent's div size change (eg. panel width), have to redraw the map\n   * Sometimes (when opening / closing a tab), size change is detected too earlier, need to set a delay (about 10-100ms seems to be convenient)\n   */\n  redrawMap(delay?: number) {\n    if (delay) {\n      window.setTimeout(() => this.map.invalidateSize(), delay);\n    } else {\n      this.map.invalidateSize();\n    }\n  }\n\n  /**\n   * Show the \"edit\" toolbar inside map\n   */\n  setMapEditMode() {\n    this.map.removeControl(this.drawControlFull);\n    this.map.addControl(this.drawControlEdit);\n  }\n\n  /**\n   * Show the \"draw\" toolbar inside map\n   */\n  setMapDrawMode() {\n    this.map.removeControl(this.drawControlEdit);\n    this.map.addControl(this.drawControlFull);\n  }\n\n  /**\n   * Set map bounds to drawn items\n   */\n  flyToDrawnItems(_maxZoom = 14) {\n    const b = this.drawnItems.getBounds();\n    this.map.flyToBounds(b, { maxZoom: _maxZoom, animate: false });\n  }\n\n  /**\n   * Set map bounds to geo reults items\n   */\n  flyToGeoResultsItems() {\n    const b = this.geoResultsLayer.getBounds();\n    this.map.flyToBounds(b, { maxZoom: 14, animate: false });\n  }\n\n  /**\n   * Set map bounds to geolocated photos items\n   */\n  flyToGeolocatedPhotoItems() {\n    const b = this.geolocatedPhotoLatLngLayer.getBounds();\n    this.map.flyToBounds(b, { maxZoom: 14, animate: false });\n  }\n\n  /**\n   * Draw a marker on drawItems featureGroup with DMS input values\n   */\n  addMarkerFromDmsCoord() {\n    // clear drawn items layer\n    this.clearDrawnItemsLayer();\n\n    // update map toolbar\n    this.setMapEditMode();\n    // @TODO check latitude and longitude values (format + limits)\n    const geopoint = new GeoPoint(this.latlngFormGroup.controls.dmsLngInput.value, this.latlngFormGroup.controls.dmsLatInput.value);\n    leafletObjects.draggableMarker(geopoint.getLatDec(), geopoint.getLonDec(), (e) => { /* dragend callback fn */ }).addTo(this.drawnItems);\n\n    // Set (decimal) latLng inputs\n    this.latlngFormGroup.controls.latInput.setValue(geopoint.getLatDec(), { emitEvent: false });\n    this.latlngFormGroup.controls.lngInput.setValue(geopoint.getLatDec(), { emitEvent: false });\n\n    // Fly\n    this.flyToDrawnItems();\n  }\n\n  /**\n   * Draw a marker on drawItems featureGroup with decimal input values\n   */\n  addMarkerFromLatLngCoord() {\n    // clear drawn items layer\n    this.clearDrawnItemsLayer();\n\n    // update map toolbar\n    this.setMapEditMode();\n\n    // TODO check latitude and longitude values (format + limits)\n    const geopoint = new GeoPoint(Number(this.latlngFormGroup.controls.lngInput.value), Number(this.latlngFormGroup.controls.latInput.value));\n    leafletObjects.draggableMarker(geopoint.getLatDec(), geopoint.getLonDec(), (dragEnd) => { /* dragend callback fn */ }).addTo(this.drawnItems);\n\n    // Set dmsLatLng inputs\n    this.latlngFormGroup.controls.dmsLatInput.setValue(geopoint.getLatDeg(), { emitEvent: false });\n    this.latlngFormGroup.controls.dmsLngInput.setValue(geopoint.getLonDeg(), { emitEvent: false });\n\n    // Fly\n    this.flyToDrawnItems();\n  }\n\n  /**\n  *\n  */\n  addPolyline(coordinates: LatLngExpression[]) {\n    // clear drawn items layer\n    this.clearDrawnItemsLayer();\n\n    // update map toolbar\n    this.setMapEditMode();\n\n    // draw\n    const polyline = L.polyline(coordinates);\n    polyline.addTo(this.drawnItems);\n\n    // fly with max zoom\n    this.flyToDrawnItems(18);\n  }\n\n  /**\n   * Take latitude and longitude input values and call geocoding and elevation API\n   * Sometimes you may want to force the elevation value and avoid calling elevation API (eg. elevation come from gps photo metadata)\n   * then, you cas use the avoidCallingElevationApi option\n   *\n   * What is done inside this function :\n   * - create an observable that zip all required observables\n   * - do a switchmap on the main observable so that if one one the sub-observable change, old data are ignored\n   * - when the main observable is finished, can send new location Output\n   *\n   * Several if / else avoidCallingElevationApi are used because when\n   * avoidCallingElevationApi === false, httpTasks returns a single value (osmPlace)\n   * whereas if avoidCallingElevationApi === true, httpTasks returns an array of 2 values [elevation, osmPlace]\n   */\n  callGeolocElevationApisUsingLatLngInputsValues(avoidCallingElevationApi = false, avoidCallingGeolocApi = false): void {\n\n    this.setLatLngInputFromDrawnItems();\n    this.setLatLngDmsInputFromDrawnItems();\n    let httpTasks: Observable<any>;\n    let elevation: any;\n    let osmPlace: any;\n\n    if (avoidCallingElevationApi && !avoidCallingGeolocApi) {\n      httpTasks = this.reverseGeocodingFromInputValue();\n    } else if (avoidCallingGeolocApi && !avoidCallingElevationApi) {\n      httpTasks = this.getElevationFromInputValue();\n    } else if (!avoidCallingElevationApi && !avoidCallingGeolocApi) {\n      httpTasks = zip(\n        this.getElevationFromInputValue(),\n        this.reverseGeocodingFromInputValue()\n      );\n    } else if (avoidCallingElevationApi && avoidCallingGeolocApi) {\n      // nothing to do ; throw or log an error ?\n      return;\n    }\n\n    // spinnners on\n    this.isLoadingAddress = !avoidCallingGeolocApi;\n    this.isLoadingElevation = !avoidCallingElevationApi;\n\n    httpTasks.subscribe(result => {\n      this.isLoadingElevation = false;\n      this.isLoadingAddress = false;\n      if (avoidCallingElevationApi && !avoidCallingGeolocApi) {\n        elevation = null;\n        osmPlace = result;\n      } else if (avoidCallingGeolocApi && !avoidCallingElevationApi) {\n        elevation = result;\n        osmPlace = null;\n        elevation = result;\n      } else if (!avoidCallingGeolocApi && !avoidCallingGeolocApi) {\n        elevation = result[0];\n        osmPlace = result[1];\n      }\n\n      // Set elevation input\n      if (!avoidCallingElevationApi) { this.elevationFormGroup.controls.elevationInput.setValue(elevation); }\n\n      // Patch place input value\n      if (!avoidCallingGeolocApi) {\n        this.geoSearchFormGroup.controls.placeInput.patchValue(this.geocodeService.getReadbleAddress(osmPlace), {emitEvent: false});\n      }\n\n      // bind _location & emit location\n      if (avoidCallingElevationApi) {\n        this.bindLocationOutput([this.elevationFormGroup.controls.elevationInput.value, osmPlace]);\n      } else {\n        this.bindLocationOutput(result);\n      }\n\n    }, error => {\n      // Manage error\n      // spinnners off\n      this.isLoadingAddress = false;\n      this.isLoadingElevation = false;\n    });\n  }\n\n  /**\n   * Should be improved for complex polygons / polylines ?\n   * Could use turf.js\n   */\n  setLatLngInputFromDrawnItems(): void {\n    const centroid = this.drawnItems.getBounds().getCenter();\n    this.latlngFormGroup.controls.latInput.setValue(centroid.lat);\n    this.latlngFormGroup.controls.lngInput.setValue(centroid.lng);\n  }\n\n  /**\n   *\n   */\n  setLatLngDmsInputFromDrawnItems(): void {\n    const centroid = this.drawnItems.getBounds().getCenter();\n    const geopoint = new GeoPoint(centroid.lng, centroid.lat);\n    this.latlngFormGroup.controls.dmsLatInput.patchValue(geopoint.getLatDeg());\n    this.latlngFormGroup.controls.dmsLngInput.patchValue(geopoint.getLonDeg());\n  }\n\n  /**\n   *\n   */\n  getElevationFromInputValue(): Observable<number> {\n    return this.elevationService.getElevation(this.latlngFormGroup.controls.latInput.value, this.latlngFormGroup.controls.lngInput.value);\n  }\n\n  /**\n   * Reverse geocoding from lat / lng inputs values\n   */\n  reverseGeocodingFromInputValue(): Observable<any> {\n    return this.geocodeService.reverse(this.latlngFormGroup.controls.latInput.value, this.latlngFormGroup.controls.lngInput.value);\n  }\n\n  /**\n   * Latitude / longitude DMS form Validator\n   */\n  latLngDmsValidator(control: FormControl) {\n    const regexp = new RegExp('^(\\\\-)?[0-9]{1,2}\\\\Â° [0-9]{1,2}\\\\\\' [0-9]{1,2}\\\\.[0-9]{1,12}\\\\\"');\n    return regexp.test(control.value) ? null : { malformedLatLngDmsFormat: true };\n  }\n\n  /**\n   * Latitude / longitude decimal form validator\n   */\n  latLngDecValidator(control: FormControl) {\n    const regexp = new RegExp('^(\\\\-)?[0-9]{1,2}\\\\.[0-9]{1,20}');\n    return regexp.test(control.value) ? null : { malformedLatLngDecFormat: true };\n  }\n\n  /**\n   * When user select an address within the autocomplete results list\n   *\n   * Call the geoloc API 2 times :\n   *  - first call is for reverse geocoding\n   *  - second call is for geoconding, so the address input (placeInput) is updated\n   */\n  addressSelectedChanged(event: MatAutocompleteSelectedEvent) {\n    const osmPlace = event.option.value;\n    // Fit map bounds\n    const southWest = new L.LatLng(osmPlace.boundingbox[0], osmPlace.boundingbox[2]);\n    const northEast = new L.LatLng(osmPlace.boundingbox[1], osmPlace.boundingbox[3]);\n    this.map.fitBounds(L.latLngBounds(southWest, northEast));\n\n    // Add geojson to the map (if user enter a city, draw the administrative shape on the map)\n    this.clearGeoResultsLayer();\n    this.geoResultsLayer.addData(osmPlace.geojson);\n\n    // Fly\n    this.flyToGeoResultsItems();\n\n    // Patch input value\n    this.geoSearchFormGroup.controls.placeInput.patchValue(this.geocodeService.getReadbleAddress(osmPlace), {emitEvent: false});\n    // Fill latitude, longitude & altitude inputs\n    const g = new GeoPoint(Number(osmPlace.lon), Number(osmPlace.lat));\n    this.latlngFormGroup.controls.latInput.setValue(osmPlace.lat, {emitEvent: false});\n    this.latlngFormGroup.controls.lngInput.setValue(osmPlace.lon, {emitEvent: false});\n    this.latlngFormGroup.controls.dmsLatInput.setValue(g.getLatDeg() , {emitEvent: false});\n    this.latlngFormGroup.controls.dmsLngInput.setValue(g.getLonDeg(), {emitEvent: false});\n    this.elevationFormGroup.controls.elevationInput.setValue(osmPlace.elevation, {emitEvent: false});\n\n    // Draw a polyline or place a marker at the center of a polygon\n    if (osmPlace.geojson.type === 'LineString') {\n      // osm geojson coordinates is like [[long, lat], [long, lat], ...]\n      // but leaflet needs [[lat, long], [lat, long], ...] format !\n      this.geocodeService.simplifyPolyline(osmPlace.geojson.coordinates);\n      this.addPolyline(this.geocodeService.reverseCorrdinatesArray(\n        this.geocodeService.simplifyPolyline(osmPlace.geojson.coordinates)) as LatLngExpression[]\n      );\n      this.clearGeoResultsLayer();\n    } else {\n      this.addMarkerFromLatLngCoord();\n    }\n\n    // Call geoloc and elevation APIs\n    this.callGeolocElevationApisUsingLatLngInputsValues(false, false);\n\n  }\n\n  /**\n   * Clear the form when nedded : 'draw:deleted', etc.\n   */\n  clearForm(): void {\n    this.latlngFormGroup.controls.latInput.setValue('', {emitEvent: false});\n    this.latlngFormGroup.controls.lngInput.setValue('', {emitEvent: false});\n    this.latlngFormGroup.controls.dmsLatInput.setValue('', {emitEvent: false});\n    this.latlngFormGroup.controls.dmsLngInput.setValue('', {emitEvent: false});\n    this.latlngFormGroup.reset();\n\n    this.elevationFormGroup.controls.elevationInput.setValue('', {emitEvent: false});\n    this.elevationFormGroup.reset();\n\n    this.geoSearchFormGroup.controls.placeInput.setValue('', {emitEvent: false});\n  }\n\n  /**\n   * Clear geoResults layer (eg this layer contains administrative polygons -- \"commune\")\n   */\n  clearGeoResultsLayer() {\n    this.geoResultsLayer.clearLayers();\n  }\n\n  /**\n   *\n   */\n  clearDrawnItemsLayer(): void {\n    this.drawnItems.clearLayers();\n  }\n\n  /**\n   *\n   */\n  resetLocation() {\n    this.location = null;\n  }\n\n  /**\n   * Bind data from elevation and OSM http results to this._location\n   * Perform some verifications to ensure data integrity\n   * @param data data[0] = elevation, data[1] = osm data | data = osm data\n   */\n  bindLocationOutput(data: Array<any> | any): void {\n    // if elevation = 0 or null ?\n    // if osm data incomplete ?\n    let elevation: any;\n    let osmPlace: any;\n    if (Array.isArray(data)) {\n      elevation = data[0];\n      osmPlace = data[1];\n    } else {\n      elevation = this.elevationFormGroup.controls.elevationInput.value;\n      osmPlace = data;\n    }\n    this._location.geometry = this.drawnItems.toGeoJSON();\n    // geodatum\n    this._location.elevation = elevation;\n    this._location.localityConsistency = this._location.localityConsistency ? true : null;   // perform : CohÃ©rence entre les coordonnÃ©es et la localitÃ©\n    this._location.locationAccuracy = this._location.locationAccuracy ? 0 : null;         // perform : PrÃ©cision (ou incertitude) de la localisation, en mÃ¨tres --> voir le nombre de dÃ©cimales pour decLatInput ou decLngInput si point, sinon, demi-longeur de la bounding-box\n    // published_location : PrÃ©cision gÃ©ographique Ã  laquelle est publiÃ©e l'obs, permet de gÃ©rer le floutage - PrÃ©cise, LocalitÃ©, Maille 10x10km\n\n    this._location.osmCountry = osmPlace.address.country;\n    this._location.osmCountryCode = osmPlace.address.country_code;\n    this._location.osmCounty = osmPlace.address.county;\n    this._location.osmPostcode = osmPlace.address.postcode;\n    if (osmPlace.address.city) { this._location.locality = osmPlace.address.city; }\n    if (osmPlace.address.town) { this._location.locality = osmPlace.address.town; }\n    if (osmPlace.address.village) { this._location.locality = osmPlace.address.village; }\n\n    this._location.sublocality = osmPlace.hamlet;\n\n    this._location.osmRoad = osmPlace.address.road;\n    this._location.osmState = osmPlace.address.state;\n    this._location.osmSuburb = osmPlace.address.suburb;\n\n    this._location.osmId = osmPlace.osm_id;\n    this._location.osmNeighbourhood = null;      // not provided by nominatim\n    this._location.osmPlaceId = osmPlace.place_id;\n    this._location.publishedLocation = null;     // perform\n    this._location.station = null;               // perform\n\n    // Verifications\n    // @todo\n\n    // Emit\n    this.location.next(this._location);\n  }\n\n  /**\n   * Change the form coordinates format : 'decimal' or 'dms'\n   */\n  setLatLngInputFormat(format: string): void {\n    if (format !== 'decimal' && format !== 'dms') { return; }\n    this.coordFormat = format;\n  }\n\n  /**\n   * Set inputs values, add a marker and call API for a geolocated photo\n   */\n  gpsMarkerSetValues(latDec, lngDec, elevation) {\n    // set inputs values\n    this.latlngFormGroup.controls.latInput.setValue(latDec);\n    this.latlngFormGroup.controls.lngInput.setValue(lngDec);\n    this.elevationFormGroup.controls.elevationInput.setValue(elevation);\n\n    // add marker\n    this.addMarkerFromLatLngCoord();\n\n    // call APIs\n    this.callGeolocElevationApisUsingLatLngInputsValues(true, false);\n\n    // clear geolocated photos layer\n    this.geolocatedPhotoLatLngLayer.clearLayers();\n  }\n\n  latLngDmsAutoFormatter(value): string {\n    return '';\n  }\n}\n","import { Pipe, PipeTransform } from '@angular/core';\nimport { OsmPlaceModel } from '../_models/osmPlace.model';\nimport { GeocodingService } from '../_services/geocoding.service';\n\n/**\n * To show an address to the user, we could use the display_name attribute returned by nominatim\n * This attribute is far complicated to read (road, neighbourhood, suburb, town, city, postcode, county, country, etc.)\n * This pipe use the getReadbleAddress() function of geocode service to show minimal information about the address returned by nominatim API\n */\n@Pipe({\n  name: 'osmPlaceReadableAddress'\n})\nexport class OsmPlaceReadableAddressPipe implements PipeTransform {\n\n  constructor(private geocodeService: GeocodingService) { }\n\n  transform(value: OsmPlaceModel, args?: any): string {\n    return this.geocodeService.getReadbleAddress(value);\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\nimport { BrowserModule } from '@angular/platform-browser';\nimport { HttpClientModule } from '@angular/common/http';\nimport { FormsModule } from '@angular/forms';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { MatSelectModule, MatInputModule, MatAutocompleteModule, MatProgressSpinnerModule, MatTooltipModule, MatChipsModule, MatIconModule, MatButtonModule, MatRadioModule, MatProgressBarModule, MatMenuModule, MatTableModule } from '@angular/material';\nimport { LeafletModule } from '@asymmetrik/ngx-leaflet';\nimport { LeafletDrawModule } from '@asymmetrik/ngx-leaflet-draw';\n\nimport { TbGeolocLibComponent } from './tb-geoloc-lib.component';\nimport { MapComponent } from './map/map.component';\nimport { GeocodingService } from './_services/geocoding.service';\nimport { ElevationService } from './_services/elevation.service';\nimport { OsmPlaceReadableAddressPipe } from './_pipes/osm-place-readable-address.pipe';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    BrowserAnimationsModule,\n    BrowserModule,\n    HttpClientModule,\n    MatSelectModule, MatInputModule, MatAutocompleteModule, MatProgressSpinnerModule, MatTooltipModule, MatChipsModule, MatIconModule, MatButtonModule, MatRadioModule, MatProgressBarModule, MatMenuModule, MatTableModule,\n    LeafletModule.forRoot(), LeafletDrawModule.forRoot(),\n    FormsModule,\n    ReactiveFormsModule],\n  declarations: [ TbGeolocLibComponent, MapComponent, OsmPlaceReadableAddressPipe ],\n  exports: [ TbGeolocLibComponent, MapComponent ]\n})\nexport class TbGeolocLibModule {\n  providers: [\n    GeocodingService, ElevationService\n  ];\n}\n"],"names":["marker","L.marker","L.icon","L.Control","L.tileLayer","L.geoJSON","L.latLng","L.FeatureGroup","leafletObjects.drawControlPanel","leafletObjects.drawControlEditPanel","leafletObjects.circleMarkerStyle","leafletObjects.cityStyle","latLng","L.Marker","leafletObjects.gpsPhotoMarkerIcon","map","L.control","leafletObjects.draggableMarker","polyline","L.polyline","control","L.LatLng","L.latLngBounds"],"mappings":"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"}

/***/ }),

/***/ "./node_modules/@angular/compiler/src sync recursive":
/*!*************************************************!*\
  !*** ./node_modules/@angular/compiler/src sync ***!
  \*************************************************/
/*! no static exports found */
/***/ (function(module, exports) {

function webpackEmptyContext(req) {
        var e = new Error('Cannot find module "' + req + '".');
        e.code = 'MODULE_NOT_FOUND';
        throw e;
}
webpackEmptyContext.keys = function() { return []; };
webpackEmptyContext.resolve = webpackEmptyContext;
module.exports = webpackEmptyContext;
webpackEmptyContext.id = "./node_modules/@angular/compiler/src sync recursive";

/***/ }),

/***/ "./src/$$_lazy_route_resource lazy recursive":
/*!**********************************************************!*\
  !*** ./src/$$_lazy_route_resource lazy namespace object ***!
  \**********************************************************/
/*! no static exports found */
/***/ (function(module, exports) {

function webpackEmptyAsyncContext(req) {
        // Here Promise.resolve().then() is used instead of new Promise() to prevent
        // uncaught exception popping up in devtools
        return Promise.resolve().then(function() {
                var e = new Error('Cannot find module "' + req + '".');
                e.code = 'MODULE_NOT_FOUND';
                throw e;
        });
}
webpackEmptyAsyncContext.keys = function() { return []; };
webpackEmptyAsyncContext.resolve = webpackEmptyAsyncContext;
module.exports = webpackEmptyAsyncContext;
webpackEmptyAsyncContext.id = "./src/$$_lazy_route_resource lazy recursive";

/***/ }),

/***/ "./src/app/app.component.css":
/*!***********************************!*\
  !*** ./src/app/app.component.css ***!
  \***********************************/
/*! no static exports found */
/***/ (function(module, exports) {

module.exports = ""

/***/ }),

/***/ "./src/app/app.component.html":
/*!************************************!*\
  !*** ./src/app/app.component.html ***!
  \************************************/
/*! no static exports found */
/***/ (function(module, exports) {

module.exports = "<tb-geoloc-map\n  [geolocatedPhotoLatLng]=testLatLngData\n  [osmClassFilter]=osmClassFilter\n  (location)=locationChange($event)>\n</tb-geoloc-map>\n\n\n<div (click)=\"emitLatLngData()\">Simuler l'import de photos géolocalisées</div>"

/***/ }),

/***/ "./src/app/app.component.ts":
/*!**********************************!*\
  !*** ./src/app/app.component.ts ***!
  \**********************************/
/*! exports provided: AppComponent */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AppComponent", function() { return AppComponent; });
/* harmony import */ var _angular_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @angular/core */ "./node_modules/@angular/core/fesm5/core.js");
var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
    if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
    return c > 3 && r && Object.defineProperty(target, key, r), r;
};

var AppComponent = /** @class */ (function () {
    function AppComponent() {
        this.testLatLngData = new _angular_core__WEBPACK_IMPORTED_MODULE_0__["EventEmitter"]();
        this.osmClassFilter = ['highway:*'];
    }
    AppComponent.prototype.locationChange = function (data) {
        console.log(data);
    };
    AppComponent.prototype.emitLatLngData = function () {
        var data = [
            {
                lat: { deg: 44, min: 27, sec: 8.976 },
                lng: { deg: 1, min: 9, sec: 24.84 },
                altitude: 187.6,
                photoName: 'PA050156.JPG'
            },
            {
                lat: { deg: 46, min: 27, sec: 5.432 },
                lng: { deg: 3, min: 12, sec: 24.84 },
                altitude: 187.6,
                photoName: 'PA050234.JPG'
            },
            {
                lat: { deg: 48, min: 25, sec: 8.765 },
                lng: { deg: 6, min: 15, sec: 24.84 },
                altitude: 187.6,
                photoName: 'PA050789.JPG'
            }
        ];
        console.log('app emit gps data...');
        this.testLatLngData.next(data);
    };
    AppComponent = __decorate([
        Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["Component"])({
            selector: 'app-root',
            template: __webpack_require__(/*! ./app.component.html */ "./src/app/app.component.html"),
            styles: [__webpack_require__(/*! ./app.component.css */ "./src/app/app.component.css")]
        })
    ], AppComponent);
    return AppComponent;
}());



/***/ }),

/***/ "./src/app/app.module.ts":
/*!*******************************!*\
  !*** ./src/app/app.module.ts ***!
  \*******************************/
/*! exports provided: AppModule */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AppModule", function() { return AppModule; });
/* harmony import */ var _angular_platform_browser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @angular/platform-browser */ "./node_modules/@angular/platform-browser/fesm5/platform-browser.js");
/* harmony import */ var _angular_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @angular/core */ "./node_modules/@angular/core/fesm5/core.js");
/* harmony import */ var _app_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./app.component */ "./src/app/app.component.ts");
/* harmony import */ var tb_geoloc_lib__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! tb-geoloc-lib */ "./dist/tb-geoloc-lib/fesm5/tb-geoloc-lib.js");
var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
    if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
    return c > 3 && r && Object.defineProperty(target, key, r), r;
};




var AppModule = /** @class */ (function () {
    function AppModule() {
    }
    AppModule = __decorate([
        Object(_angular_core__WEBPACK_IMPORTED_MODULE_1__["NgModule"])({
            declarations: [
                _app_component__WEBPACK_IMPORTED_MODULE_2__["AppComponent"]
            ],
            imports: [
                _angular_platform_browser__WEBPACK_IMPORTED_MODULE_0__["BrowserModule"],
                tb_geoloc_lib__WEBPACK_IMPORTED_MODULE_3__["TbGeolocLibModule"]
            ],
            providers: [],
            bootstrap: [_app_component__WEBPACK_IMPORTED_MODULE_2__["AppComponent"]]
        })
    ], AppModule);
    return AppModule;
}());



/***/ }),

/***/ "./src/environments/environment.ts":
/*!*****************************************!*\
  !*** ./src/environments/environment.ts ***!
  \*****************************************/
/*! exports provided: environment */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "environment", function() { return environment; });
// This file can be replaced during build by using the `fileReplacements` array.
// `ng build ---prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.
var environment = {
    production: false
};
/*
 * In development mode, to ignore zone related error stack frames such as
 * `zone.run`, `zoneDelegate.invokeTask` for easier debugging, you can
 * import the following file, but please comment it out in production mode
 * because it will have performance impact when throw error
 */
// import 'zone.js/dist/zone-error';  // Included with Angular CLI.


/***/ }),

/***/ "./src/main.ts":
/*!*********************!*\
  !*** ./src/main.ts ***!
  \*********************/
/*! no exports provided */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _angular_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @angular/core */ "./node_modules/@angular/core/fesm5/core.js");
/* harmony import */ var _angular_platform_browser_dynamic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @angular/platform-browser-dynamic */ "./node_modules/@angular/platform-browser-dynamic/fesm5/platform-browser-dynamic.js");
/* harmony import */ var _app_app_module__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./app/app.module */ "./src/app/app.module.ts");
/* harmony import */ var _environments_environment__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./environments/environment */ "./src/environments/environment.ts");




if (_environments_environment__WEBPACK_IMPORTED_MODULE_3__["environment"].production) {
    Object(_angular_core__WEBPACK_IMPORTED_MODULE_0__["enableProdMode"])();
}
Object(_angular_platform_browser_dynamic__WEBPACK_IMPORTED_MODULE_1__["platformBrowserDynamic"])().bootstrapModule(_app_app_module__WEBPACK_IMPORTED_MODULE_2__["AppModule"])
    .catch(function (err) { return console.log(err); });


/***/ }),

/***/ 0:
/*!***************************!*\
  !*** multi ./src/main.ts ***!
  \***************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {

module.exports = __webpack_require__(/*! /home/stephane/dev/tb-geoloc-lib/src/main.ts */"./src/main.ts");


/***/ })

},[[0,"runtime","vendor"]]]);
//# sourceMappingURL=main.js.map