diff --git a/packages/landing/src/__tests__/map.config.test.ts b/packages/landing/src/__tests__/map.config.test.ts index a4de5f406..cf91ec0d7 100644 --- a/packages/landing/src/__tests__/map.config.test.ts +++ b/packages/landing/src/__tests__/map.config.test.ts @@ -174,4 +174,50 @@ describe('WindowUrl', () => { mc.updateFromUrl('i=01EDA2YFXH2JN264VG1HKBT625'); assert.equal(mc.layerId, '01EDA2YFXH2JN264VG1HKBT625'); }); + + it('should enable labels by default', () => { + // aerial layer & debug disabled + mc.updateFromUrl(''); + assert.equal(mc.layerId, 'aerial'); + assert.equal(mc.isDebug, false); + assert.equal(mc.labels, true); + + // aerial layer, labels enabled & debug disabled + mc.updateFromUrl('?labels=true'); + assert.equal(mc.layerId, 'aerial'); + assert.equal(mc.isDebug, false); + assert.equal(mc.labels, true); + }); + + it('should not enable labels by default', () => { + // aerial layer, but labels disabled + mc.updateFromUrl('?labels=false'); + assert.equal(mc.layerId, 'aerial'); + assert.equal(mc.isDebug, false); + assert.equal(mc.labels, false); + + // aerial layer, but debug enabled + mc.updateFromUrl('?debug'); + assert.equal(mc.layerId, 'aerial'); + assert.equal(mc.isDebug, true); + assert.equal(mc.labels, false); + + // aerial layer, labels disabled & debug enabled + mc.updateFromUrl('?labels=false&debug'); + assert.equal(mc.layerId, 'aerial'); + assert.equal(mc.isDebug, true); + assert.equal(mc.labels, false); + + // debug disabled, but individual layer + mc.updateFromUrl('i=abc123'); + assert.equal(mc.layerId, 'abc123'); + assert.equal(mc.isDebug, false); + assert.equal(mc.labels, false); + + // individual layer & debug enabled + mc.updateFromUrl('i=abc123&debug'); + assert.equal(mc.layerId, 'abc123'); + assert.equal(mc.isDebug, true); + assert.equal(mc.labels, false); + }); }); diff --git a/packages/landing/src/config.map.ts b/packages/landing/src/config.map.ts index 09c528a85..5f925833b 100644 --- a/packages/landing/src/config.map.ts +++ b/packages/landing/src/config.map.ts @@ -128,7 +128,7 @@ export class MapConfig extends Emitter { const config = urlParams.get('c') ?? urlParams.get('config'); const layerId = urlParams.get('i') ?? style ?? 'aerial'; const terrain = urlParams.get('t') ?? urlParams.get('terrain'); - const labels = Boolean(urlParams.get('labels')); + const labels = urlParams.get('labels'); const projectionParam = (urlParams.get('p') ?? urlParams.get('tileMatrix') ?? GoogleTms.identifier).toLowerCase(); let tileMatrix = TileMatrixSets.All.find((f) => f.identifier.toLowerCase() === projectionParam); @@ -145,7 +145,11 @@ export class MapConfig extends Emitter { this.style = style ?? null; this.layerId = layerId.startsWith('im_') ? layerId.slice(3) : layerId; this.tileMatrix = tileMatrix; - this.labels = labels; + if (labels == null) { + this.labels = layerId === 'aerial' && !this.debug.debug; + } else { + this.labels = labels === 'true'; + } if (this.layerId === 'topographic' && this.style == null) this.style = 'topographic'; this.emit('tileMatrix', this.tileMatrix);