/**
* @module modules/Edition.js
* @name Edition
* @copyright 2023 3Liz
* @author DHONT René-Luc
* @license MPL-2.0
*/
import { mainEventDispatcher } from '../modules/Globals.js';
/**
* @class
* @name Edition
*/
export default class Edition {
/**
* Create an edition instance
* @param {object} lizmap3 - The old lizmap object
*/
constructor(lizmap3) {
this._lizmap3 = lizmap3;
this.drawFeatureActivated = false;
this._layerId = undefined;
this.layerGeometry = undefined;
this.drawControl = undefined;
this._lastSegmentLength = undefined;
lizmap3.events.on({
lizmapeditiondrawfeatureactivated: (properties) => {
this.drawFeatureActivated = true;
this.layerGeometry = properties.editionConfig.geometryType;
this.drawControl = properties.drawControl;
mainEventDispatcher.dispatch('edition.drawFeatureActivated');
},
lizmapeditiondrawfeaturedeactivated: () => {
this.drawFeatureActivated = false;
this.layerGeometry = undefined;
this.drawControl = undefined;
this.lastSegmentLength = undefined;
mainEventDispatcher.dispatch('edition.drawFeatureActivated');
},
lizmapeditionformdisplayed: (evt) => {
this._layerId = (evt['layerId']);
mainEventDispatcher.dispatch('edition.formDisplayed');
},
lizmapeditionformclosed: () => {
mainEventDispatcher.dispatch('edition.formClosed');
}
});
}
get layerId() {
return this._layerId;
}
get hasEditionLayers() {
return 'editionLayers' in this._lizmap3.config;
}
get editLayer() {
const editLayer = this._lizmap3.map.getLayersByName('editLayer');
if (editLayer.length === 1) {
return editLayer[0];
} else {
return undefined;
}
}
get modifyFeatureControl(){
const modifyFeatureCtrls = this._lizmap3.map.getControlsByClass('OpenLayers.Control.ModifyFeature');
return (modifyFeatureCtrls.filter(ctrl => ctrl.layer.name === "editLayer"))[0];
}
get lastSegmentLength() {
return this._lastSegmentLength;
}
set lastSegmentLength(lastSegmentLength) {
lastSegmentLength = parseFloat(lastSegmentLength);
if (this._lastSegmentLength !== lastSegmentLength) {
this._lastSegmentLength = lastSegmentLength;
mainEventDispatcher.dispatch('edition.lastSegmentLength');
}
}
/**
* Fetch editable features for given array of layer IDs
* @param {Array} layerIds
*/
fetchEditableFeatures(layerIds){
if (Array.isArray(layerIds)){
const fetchers = [];
for (const layerId of layerIds) {
fetchers.push(fetch(globalThis['lizUrls'].edition.replace('getFeature', 'editableFeatures'),{
"method": "POST",
"body": new URLSearchParams({
repository: globalThis['lizUrls'].params.repository,
project: globalThis['lizUrls'].params.project,
layerId: layerId
})
}).then(response => {
return response.json();
}));
Promise.all(fetchers).then(responses => {
const editableFeatures = [];
for (const response of responses) {
if (response?.['success'] && response?.['status'] === 'restricted') {
for (const feature of response.features) {
editableFeatures.push(feature);
}
// Dispatch event only if there is a restriction
mainEventDispatcher.dispatch({
type: 'edition.editableFeatures',
properties: editableFeatures
});
}
}
});
}
}
}
}