From 49d0b715fb81678be390910cc1bf1ec4f61e24e4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexis=20M=C3=A9taireau?= Date: Fri, 31 May 2024 19:31:10 +0200 Subject: [PATCH] refactor(sync): Sync layers creation with `map.createDataLayer` utility. Rather than having it done inside the datalayer itself. This gives us more control. --- umap/static/umap/js/modules/sync/updaters.js | 2 +- umap/static/umap/js/umap.forms.js | 5 +++-- umap/static/umap/js/umap.js | 7 ++++++- umap/static/umap/js/umap.layer.js | 7 +------ 4 files changed, 11 insertions(+), 10 deletions(-) diff --git a/umap/static/umap/js/modules/sync/updaters.js b/umap/static/umap/js/modules/sync/updaters.js index 307dffc65..9d83e0016 100644 --- a/umap/static/umap/js/modules/sync/updaters.js +++ b/umap/static/umap/js/modules/sync/updaters.js @@ -51,7 +51,7 @@ export class DataLayerUpdater extends BaseUpdater { upsert({ value }) { // Inserts does not happen (we use multiple updates instead). this.map.createDataLayer(value, false) - this.map.render() + this.map.render([]) } update({ key, metadata, value }) { diff --git a/umap/static/umap/js/umap.forms.js b/umap/static/umap/js/umap.forms.js index 92c1cdfa1..0f4422574 100644 --- a/umap/static/umap/js/umap.forms.js +++ b/umap/static/umap/js/umap.forms.js @@ -943,8 +943,9 @@ L.FormBuilder.MultiChoice = L.FormBuilder.Element.extend({ } const choices = this.getChoices().map(([value, label]) => value) if (choices.includes(value)) { - this.container.querySelector(`input[type="radio"][value="${value}"]`).checked = - true + this.container.querySelector( + `input[type="radio"][value="${value}"]` + ).checked = true } }, diff --git a/umap/static/umap/js/umap.js b/umap/static/umap/js/umap.js index cb717d052..c95236a42 100644 --- a/umap/static/umap/js/umap.js +++ b/umap/static/umap/js/umap.js @@ -808,7 +808,12 @@ U.Map = L.Map.extend({ datalayer = datalayer || { name: `${L._('Layer')} ${this.datalayers_index.length + 1}`, } - return new U.DataLayer(this, datalayer, sync) + const dl = new U.DataLayer(this, datalayer, sync) + + if (sync !== false) { + dl.sync.upsert(dl.options) + } + return dl }, newDataLayer: function () { diff --git a/umap/static/umap/js/umap.layer.js b/umap/static/umap/js/umap.layer.js index 93b801b1e..f6b702cf8 100644 --- a/umap/static/umap/js/umap.layer.js +++ b/umap/static/umap/js/umap.layer.js @@ -606,18 +606,13 @@ U.DataLayer = L.Evented.extend({ // be in the "forced visibility" mode if (this.autoLoaded()) this.map.on('zoomend', this.onZoomEnd, this) this.on('datachanged', this.map.onDataLayersChanged, this.map) - - if (sync !== false) { - const { engine, subject, metadata } = this.getSyncMetadata() - engine.upsert(subject, metadata, this.options) - } }, getSyncMetadata: function () { return { subject: 'datalayer', metadata: { - id: this.umap_id, + id: this.umap_id || null, }, } },