Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | 1x | // import Logger from "../../../Utils/LoggerByDefault"; import MR from "../../../Utils/MessagesResources"; import ErrSrv from "../../../Exceptions/ErrorService"; import GeocodeResponse from "../Response/model/GeocodeResponse"; import GeocodedLocation from "../Response/model/GeocodedLocation"; /** * Fonction retournant un objet contenant des clés de lecture (readers) * qui permettent de parser des réponses XML du service de géocodage direct du Géoportail * afin de récupérer les résultats retournés. * @module GeocodeResponseParser * @alias Gp.Services.Geocode.Formats.GeocodeResponseParser * @private */ /** * @classdesc * * Classe permettant de parser une réponse GeoJSON * * @constructor * @alias Gp.Formats.GeocodeResponseParser * * @private */ function GeocodeResponseParser () { if (!(this instanceof GeocodeResponseParser)) { throw new TypeError("GeocodeResponseParser constructor cannot be called as a function."); } } GeocodeResponseParser.prototype = { /** * @lends module:GeocodeResponseParser */ /* * Constructeur (alias) */ constructor : GeocodeResponseParser, /** * Méthode permettant de lancer la lecture d'une réponse GeoJSON, * * @param {String} json - réponse au format GeoJSON * @return {Object} geocodeResponse|exceptionReport : l'objet contenant les informations de la réponse GeoJSON, * sous la forme d'un objet GeocodeResponse, ou un objet littéral exceptionReport si le service a renvoyé une exception. */ parse : function (json) { var geocodeResponse = new GeocodeResponse(); const obj = JSON.parse(json); if (obj.type === "FeatureCollection") { for (var i = 0; i < obj.features.length; ++i) { _parseFeature(obj.features[i], geocodeResponse); } } else if (obj.type === "Feature") { _parseFeature(obj, geocodeResponse); } else if (obj.type === "SERVICE_ERROR") { return _parseError(obj); } else { var mess = MR.getMessage("SERVICE_RESPONSE_ANALYSE", obj.type); throw new ErrSrv({ message : mess, type : ErrSrv.TYPE_UNKERR, status : 200 }); } return geocodeResponse; } }; /** * Méthode permettant de parser un feature * * @private * * @param {Object} feature * @param {Object} geocodeResponse * * @memberof GeocodeResponseParser * @return {Object} objet GeocodedLocation */ function _parseFeature (feature, geocodeResponse) { var location = new GeocodedLocation(); if (feature.geometry && feature.geometry.type === "Point") { location.position = { lon : feature.geometry.coordinates[0], lat : feature.geometry.coordinates[1] }; } if (feature.properties) { for (var prop in feature.properties) { if (prop === "score") { location.accuracy = feature.properties[prop]; } else if (prop === "_type") { if (feature.properties[prop] === "address") { location.type = "StreetAddress"; } else if (feature.properties[prop] === "poi") { location.type = "PositionOfInterest"; } else if (feature.properties[prop] === "parcel" || feature.properties[prop] === "cadastral") { location.type = "CadastralParcel"; } } else { location.placeAttributes[prop] = feature.properties[prop]; } } if (feature.properties._type === "address") { location.matchType = feature.properties.number !== undefined && feature.properties.number !== null ? "street number" : "street"; } } geocodeResponse.locations.push(location); } /** * Méthode permettant de parser une erreur * * @private * * @param {Object} error * * @memberof GeocodeResponseParser * @return {Object} */ function _parseError (error) { return { exceptionReport : error }; } export default GeocodeResponseParser; |