Skip to content

Commit

Permalink
support in geometries : rewrite as suggested by a reviewer
Browse files Browse the repository at this point in the history
  • Loading branch information
ltkum committed Nov 4, 2024
1 parent c817c7e commit 37d6736
Showing 1 changed file with 22 additions and 25 deletions.
47 changes: 22 additions & 25 deletions src/VectorEncoder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -187,34 +187,31 @@ export default class VectorEncoder {
// handling more cases than we actually do
let geometry: any = style.getGeometry();
let geojsonFeature;
// In some cases, the geometries are objects, in other cases they're features.
// We need to make sure that either the geometry is an object, or that the feature it contains returns
// a non-null / non-undefined value.
if (geometry && ((typeof geometry === 'object' && geometry instanceof Object) || (typeof geometry === 'function' && geometry(feature))) {
const styledFeature = feature.clone();
if (geometry instanceof Object && typeof geometry === 'object') {
styledFeature.setGeometry(geometry);
}
else {
styledFeature.setGeometry(geometry(feature));
}
geojsonFeature = this.geojsonFormat.writeFeatureObject(styledFeature);
geojsonFeatures.push(geojsonFeature);
} else {
geojsonFeature = origGeojsonFeature;
geometry = feature.getGeometry();
// no need to encode features with no geometry
if (!geometry) {
return;
}
if (!this.customizer_.geometryFilter(geometry)) {
return;
// In some cases, the geometries are objects, in other cases they're functions.
// we need to ensure we're handling functions, wether they return an object or not.
if (typeof geometry === 'function') {
geometry = geometry(feature);
}
if (!isOriginalFeatureAdded) {
if (typeof geometry === 'object') {
const styledFeature = feature.clone();
styledFeature.setGeometry(geometry);
geojsonFeature = this.geojsonFormat.writeFeatureObject(styledFeature);
geojsonFeatures.push(geojsonFeature);
isOriginalFeatureAdded = true;
} else {
geojsonFeature = origGeojsonFeature;
geometry = feature.getGeometry();
// no need to encode features with no geometry
if (!geometry) {
return;
}
if (!this.customizer_.geometryFilter(geometry)) {
return;
}
if (!isOriginalFeatureAdded) {
geojsonFeatures.push(geojsonFeature);
isOriginalFeatureAdded = true;
}
}
}

this.addVectorStyle(mapfishStyleObject, geojsonFeature, style);
});
Expand Down

0 comments on commit 37d6736

Please sign in to comment.