chore: refactore datalayers loading
This commit is contained in:
parent
3f1070c90d
commit
d07d9f61d2
6 changed files with 37 additions and 65 deletions
|
@ -186,7 +186,7 @@ L.U.Map.include({
|
||||||
// Needs locate control and hash to exist
|
// Needs locate control and hash to exist
|
||||||
this.initCenter()
|
this.initCenter()
|
||||||
this.handleLimitBounds()
|
this.handleLimitBounds()
|
||||||
this.initDatalayers()
|
this.initDataLayers()
|
||||||
|
|
||||||
if (this.options.displayCaptionOnLoad) {
|
if (this.options.displayCaptionOnLoad) {
|
||||||
// Retrocompat
|
// Retrocompat
|
||||||
|
@ -239,8 +239,6 @@ L.U.Map.include({
|
||||||
this._default_extent = true
|
this._default_extent = true
|
||||||
this.options.name = L._('Untitled map')
|
this.options.name = L._('Untitled map')
|
||||||
this.options.editMode = 'advanced'
|
this.options.editMode = 'advanced'
|
||||||
const datalayer = this.createDataLayer()
|
|
||||||
datalayer.connectToMap()
|
|
||||||
this.enableEdit()
|
this.enableEdit()
|
||||||
let dataUrl = L.Util.queryString('dataUrl', null)
|
let dataUrl = L.Util.queryString('dataUrl', null)
|
||||||
const dataFormat = L.Util.queryString('dataFormat', 'geojson')
|
const dataFormat = L.Util.queryString('dataFormat', 'geojson')
|
||||||
|
@ -276,8 +274,6 @@ L.U.Map.include({
|
||||||
this.options.onLoadPanel === 'datafilters'
|
this.options.onLoadPanel === 'datafilters'
|
||||||
)
|
)
|
||||||
this.openFacet()
|
this.openFacet()
|
||||||
})
|
|
||||||
this.onceDataLoaded(function () {
|
|
||||||
const slug = L.Util.queryString('feature')
|
const slug = L.Util.queryString('feature')
|
||||||
if (slug && this.features_index[slug]) this.features_index[slug].view()
|
if (slug && this.features_index[slug]) this.features_index[slug].view()
|
||||||
if (L.Util.queryString('edit')) {
|
if (L.Util.queryString('edit')) {
|
||||||
|
@ -422,56 +418,22 @@ L.U.Map.include({
|
||||||
if (this.options.scaleControl) this._controls.scale.addTo(this)
|
if (this.options.scaleControl) this._controls.scale.addTo(this)
|
||||||
},
|
},
|
||||||
|
|
||||||
initDatalayers: function () {
|
initDataLayers: async function (datalayers) {
|
||||||
for (let j = 0; j < this.options.datalayers.length; j++) {
|
datalayers = datalayers || this.options.datalayers
|
||||||
this.createDataLayer(this.options.datalayers[j])
|
for (const options of datalayers) {
|
||||||
|
this.createDataLayer(options)
|
||||||
}
|
}
|
||||||
this.loadDatalayers()
|
await this.loadDataLayers()
|
||||||
},
|
},
|
||||||
|
|
||||||
loadDatalayers: function (force) {
|
loadDataLayers: async function () {
|
||||||
const total = this.datalayers_index.length
|
this.datalayersLoaded = true
|
||||||
// toload => datalayer metadata remaining to load (synchronous)
|
this.fire('datalayersloaded')
|
||||||
// dataToload => datalayer data remaining to load (asynchronous)
|
for (const datalayer of Object.values(this.datalayers)) {
|
||||||
let toload = total,
|
if (datalayer.showAtLoad()) await datalayer.show()
|
||||||
dataToload = total
|
|
||||||
let datalayer
|
|
||||||
const loaded = () => {
|
|
||||||
this.datalayersLoaded = true
|
|
||||||
this.fire('datalayersloaded')
|
|
||||||
}
|
|
||||||
const decrementToLoad = () => {
|
|
||||||
toload--
|
|
||||||
if (toload === 0) loaded()
|
|
||||||
}
|
|
||||||
const dataLoaded = () => {
|
|
||||||
this.dataLoaded = true
|
|
||||||
this.fire('dataloaded')
|
|
||||||
}
|
|
||||||
const decrementDataToLoad = () => {
|
|
||||||
dataToload--
|
|
||||||
if (dataToload === 0) dataLoaded()
|
|
||||||
}
|
|
||||||
this.eachDataLayer(function (datalayer) {
|
|
||||||
if (force && !datalayer.hasDataLoaded()) {
|
|
||||||
datalayer.show()
|
|
||||||
}
|
|
||||||
if (datalayer.showAtLoad() || force) {
|
|
||||||
datalayer.onceLoaded(decrementToLoad)
|
|
||||||
} else {
|
|
||||||
decrementToLoad()
|
|
||||||
}
|
|
||||||
if (datalayer.showAtLoad() || force) {
|
|
||||||
datalayer.onceDataLoaded(decrementDataToLoad)
|
|
||||||
} else {
|
|
||||||
decrementDataToLoad({ sourceTarget: datalayer })
|
|
||||||
}
|
|
||||||
})
|
|
||||||
if (total === 0) {
|
|
||||||
// no datalayer
|
|
||||||
loaded()
|
|
||||||
dataLoaded()
|
|
||||||
}
|
}
|
||||||
|
this.dataloaded = true
|
||||||
|
this.fire('dataloaded')
|
||||||
},
|
},
|
||||||
|
|
||||||
indexDatalayers: function () {
|
indexDatalayers: function () {
|
||||||
|
@ -504,7 +466,7 @@ L.U.Map.include({
|
||||||
|
|
||||||
onceDataLoaded: function (callback, context) {
|
onceDataLoaded: function (callback, context) {
|
||||||
// Once datalayers **data** have been loaded
|
// Once datalayers **data** have been loaded
|
||||||
if (this.dataLoaded) {
|
if (this.dataloaded) {
|
||||||
callback.call(context || this, this)
|
callback.call(context || this, this)
|
||||||
} else {
|
} else {
|
||||||
this.once('dataloaded', callback, context)
|
this.once('dataloaded', callback, context)
|
||||||
|
|
|
@ -581,8 +581,10 @@ L.U.DataLayer = L.Evented.extend({
|
||||||
this.backupOptions()
|
this.backupOptions()
|
||||||
this.connectToMap()
|
this.connectToMap()
|
||||||
this.permissions = new L.U.DataLayerPermissions(this)
|
this.permissions = new L.U.DataLayerPermissions(this)
|
||||||
if (this.showAtLoad()) this.show()
|
if (!this.umap_id) {
|
||||||
if (!this.umap_id) this.isDirty = true
|
if (this.showAtLoad()) this.show()
|
||||||
|
this.isDirty = true
|
||||||
|
}
|
||||||
|
|
||||||
this.onceLoaded(function () {
|
this.onceLoaded(function () {
|
||||||
this.map.on('moveend', this.onMoveEnd, this)
|
this.map.on('moveend', this.onMoveEnd, this)
|
||||||
|
@ -1431,9 +1433,9 @@ L.U.DataLayer = L.Evented.extend({
|
||||||
return features
|
return features
|
||||||
},
|
},
|
||||||
|
|
||||||
show: function () {
|
show: async function () {
|
||||||
if (!this.isLoaded()) this.fetchData()
|
|
||||||
this.map.addLayer(this.layer)
|
this.map.addLayer(this.layer)
|
||||||
|
if (!this.isLoaded()) await this.fetchData()
|
||||||
this.fire('show')
|
this.fire('show')
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import re
|
import re
|
||||||
from time import sleep
|
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from django.core.signing import get_cookie_signer
|
from django.core.signing import get_cookie_signer
|
||||||
|
@ -126,10 +125,14 @@ def test_anonymous_can_add_marker_on_editable_layer(
|
||||||
|
|
||||||
def test_can_change_perms_after_create(tilelayer, live_server, page):
|
def test_can_change_perms_after_create(tilelayer, live_server, page):
|
||||||
page.goto(f"{live_server.url}/en/map/new")
|
page.goto(f"{live_server.url}/en/map/new")
|
||||||
|
# Create a layer
|
||||||
|
page.get_by_title("Manage layers").click()
|
||||||
|
page.get_by_role("button", name="Add a layer").click()
|
||||||
|
page.locator("input[name=name]").fill("Layer 1")
|
||||||
save = page.get_by_role("button", name="Save")
|
save = page.get_by_role("button", name="Save")
|
||||||
expect(save).to_be_visible()
|
expect(save).to_be_visible()
|
||||||
save.click()
|
with page.expect_response(re.compile(r".*/datalayer/create/.*")):
|
||||||
sleep(1) # Let save ajax go back
|
save.click()
|
||||||
edit_permissions = page.get_by_title("Update permissions and editors")
|
edit_permissions = page.get_by_title("Update permissions and editors")
|
||||||
expect(edit_permissions).to_be_visible()
|
expect(edit_permissions).to_be_visible()
|
||||||
edit_permissions.click()
|
edit_permissions.click()
|
||||||
|
|
|
@ -9,9 +9,10 @@ def test_should_have_fieldset_for_layer_type_properties(page, live_server, tilel
|
||||||
expect(button).to_be_visible()
|
expect(button).to_be_visible()
|
||||||
button.click()
|
button.click()
|
||||||
|
|
||||||
edit = page.locator("#umap-ui-container").get_by_title("Edit", exact=True)
|
# Create a layer
|
||||||
expect(edit).to_be_visible()
|
page.get_by_title("Manage layers").click()
|
||||||
edit.click()
|
page.get_by_role("button", name="Add a layer").click()
|
||||||
|
page.locator("input[name=name]").fill("Layer 1")
|
||||||
|
|
||||||
select = page.locator("#umap-ui-container .umap-field-type select")
|
select = page.locator("#umap-ui-container .umap-field-type select")
|
||||||
expect(select).to_be_visible()
|
expect(select).to_be_visible()
|
||||||
|
|
|
@ -21,7 +21,7 @@ def test_umap_import_from_file(live_server, datalayer, page):
|
||||||
expect(button).to_be_visible()
|
expect(button).to_be_visible()
|
||||||
button.click()
|
button.click()
|
||||||
layers = page.locator(".umap-browse-datalayers li")
|
layers = page.locator(".umap-browse-datalayers li")
|
||||||
expect(layers).to_have_count(3)
|
expect(layers).to_have_count(2)
|
||||||
nonloaded = page.locator(".umap-browse-datalayers li.off")
|
nonloaded = page.locator(".umap-browse-datalayers li.off")
|
||||||
expect(nonloaded).to_have_count(1)
|
expect(nonloaded).to_have_count(1)
|
||||||
assert file_input.input_value()
|
assert file_input.input_value()
|
||||||
|
@ -37,7 +37,7 @@ def test_umap_import_geojson_from_textarea(live_server, datalayer, page):
|
||||||
paths = page.locator("path")
|
paths = page.locator("path")
|
||||||
expect(markers).to_have_count(0)
|
expect(markers).to_have_count(0)
|
||||||
expect(paths).to_have_count(0)
|
expect(paths).to_have_count(0)
|
||||||
expect(layers).to_have_count(1)
|
expect(layers).to_have_count(0)
|
||||||
button = page.get_by_title("Import data")
|
button = page.get_by_title("Import data")
|
||||||
expect(button).to_be_visible()
|
expect(button).to_be_visible()
|
||||||
button.click()
|
button.click()
|
||||||
|
@ -48,7 +48,7 @@ def test_umap_import_geojson_from_textarea(live_server, datalayer, page):
|
||||||
button = page.get_by_role("button", name="Import", exact=True)
|
button = page.get_by_role("button", name="Import", exact=True)
|
||||||
expect(button).to_be_visible()
|
expect(button).to_be_visible()
|
||||||
button.click()
|
button.click()
|
||||||
# No layer has been created
|
# A layer has been created
|
||||||
expect(layers).to_have_count(1)
|
expect(layers).to_have_count(1)
|
||||||
expect(markers).to_have_count(2)
|
expect(markers).to_have_count(2)
|
||||||
expect(paths).to_have_count(3)
|
expect(paths).to_have_count(3)
|
||||||
|
|
|
@ -191,6 +191,10 @@ def test_create(tilelayer, live_server, login, user):
|
||||||
def test_can_change_perms_after_create(tilelayer, live_server, login, user):
|
def test_can_change_perms_after_create(tilelayer, live_server, login, user):
|
||||||
page = login(user)
|
page = login(user)
|
||||||
page.goto(f"{live_server.url}/en/map/new")
|
page.goto(f"{live_server.url}/en/map/new")
|
||||||
|
# Create a layer
|
||||||
|
page.get_by_title("Manage layers").click()
|
||||||
|
page.get_by_role("button", name="Add a layer").click()
|
||||||
|
page.locator("input[name=name]").fill("Layer 1")
|
||||||
save = page.get_by_role("button", name="Save")
|
save = page.get_by_role("button", name="Save")
|
||||||
expect(save).to_be_visible()
|
expect(save).to_be_visible()
|
||||||
save.click()
|
save.click()
|
||||||
|
|
Loading…
Reference in a new issue