From 973fe84c56fedea1658aaa328db10e432d6d0a8d Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Fri, 5 May 2017 11:57:06 -0700 Subject: [PATCH 01/10] fix update edit link, add query parameters for map feedback --- dist/mapbox-gl.css | 10 +++++++--- src/ui/control/attribution_control.js | 13 +++++++++++-- test/unit/ui/control/attribution.test.js | 10 ++++++---- 3 files changed, 24 insertions(+), 9 deletions(-) diff --git a/dist/mapbox-gl.css b/dist/mapbox-gl.css index efca2ec68cb..9067f7fdb34 100644 --- a/dist/mapbox-gl.css +++ b/dist/mapbox-gl.css @@ -161,11 +161,12 @@ a.mapboxgl-ctrl-logo { color: inherit; text-decoration: underline; } -.mapboxgl-ctrl-attrib .mapboxgl-improve-map { +/* stylelint-disable */ +.mapboxgl-ctrl-attrib .mapbox-improve-map { font-weight: bold; margin-left: 2px; } - +/*stylelint-enable*/ .mapboxgl-ctrl-scale { background-color: rgba(255,255,255,0.75); font-size: 10px; @@ -318,8 +319,11 @@ a.mapboxgl-ctrl-logo { border: 2px dotted #202020; opacity: 0.5; } + @media print { - .mapboxgl-improve-map { +/* stylelint-disable */ + .mapbox-improve-map { display:none; } +/* stylelint-enable */ } diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index f84d1c038ef..b7fc6044c66 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -66,11 +66,14 @@ class AttributionControl { } _updateEditLink() { - if (!this._editLink) this._editLink = this._container.querySelector('.mapboxgl-improve-map'); + if (!this._editLink) this._editLink = this._container.querySelector('.mapbox-improve-map'); if (this._editLink) { const center = this._map.getCenter(); this._editLink.href = `https://www.mapbox.com/map-feedback/#/${ - center.lng}/${center.lat}/${Math.round(this._map.getZoom() + 1)}`; + Math.round(center.lng * 1000) / 1000}/${Math.round(center.lat * 1000) / 1000}/${Math.round(this._map.getZoom())}`; + if (this.styleOwner && this.styleId) { + this._editLink.href += `?owner=${this.styleOwner}&id=${this.styleId}`; + } } } @@ -85,6 +88,12 @@ class AttributionControl { if (!this._map.style) return; let attributions = []; + if (this._map.style.stylesheet) { + const stylesheet = this._map.style.stylesheet; + this.styleOwner = stylesheet.owner; + this.styleId = stylesheet.id; + } + const sourceCaches = this._map.style.sourceCaches; for (const id in sourceCaches) { const source = sourceCaches[id].getSource(); diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index 41be18e9300..baa1f882003 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -13,7 +13,9 @@ function createMap() { style: { version: 8, sources: {}, - layers: [] + layers: [], + owner: 'mapbox', + id: 'streets-v10' } }); } @@ -105,12 +107,12 @@ test('AttributionControl has the correct edit map link', (t) => { map.addControl(attribution); map.on('load', () => { - map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); + map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/1', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/0?owner=mapbox&id=streets-v10', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/3', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/2?owner=mapbox&id=streets-v10', 'edit link updates on mapmove'); t.end(); } }); From d18d40822830efb45d8680e31bf8639ba656c9d0 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Tue, 9 May 2017 11:12:22 -0700 Subject: [PATCH 02/10] update url structure --- src/ui/control/attribution_control.js | 6 ++---- test/unit/ui/control/attribution.test.js | 4 ++-- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index b7fc6044c66..2ea5693685b 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -69,11 +69,9 @@ class AttributionControl { if (!this._editLink) this._editLink = this._container.querySelector('.mapbox-improve-map'); if (this._editLink) { const center = this._map.getCenter(); - this._editLink.href = `https://www.mapbox.com/map-feedback/#/${ + const styleParams = (this.styleOwner && this.styleId) ? `?owner=${this.styleOwner}&id=${this.styleId}` : ''; + this._editLink.href = `https://www.mapbox.com/feedback/${styleParams}#/${ Math.round(center.lng * 1000) / 1000}/${Math.round(center.lat * 1000) / 1000}/${Math.round(this._map.getZoom())}`; - if (this.styleOwner && this.styleId) { - this._editLink.href += `?owner=${this.styleOwner}&id=${this.styleId}`; - } } } diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index baa1f882003..ff23fefd46b 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -110,9 +110,9 @@ test('AttributionControl has the correct edit map link', (t) => { map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/0?owner=mapbox&id=streets-v10', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10#/0/0/0', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/map-feedback/#/0/0/2?owner=mapbox&id=streets-v10', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10#/0/0/2', 'edit link updates on mapmove'); t.end(); } }); From ef0eb1f10666b6cb1826be0a2341029f8a536114 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Fri, 12 May 2017 11:03:21 -0700 Subject: [PATCH 03/10] correct url in test --- test/unit/ui/control/attribution.test.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index ff23fefd46b..8ec576a34da 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -107,7 +107,7 @@ test('AttributionControl has the correct edit map link', (t) => { map.addControl(attribution); map.on('load', () => { - map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); + map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10#/0/0/0', 'edit link contains map location data'); From ad82f4f5db01d768c459670280245a98fb2fec90 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Tue, 23 May 2017 09:46:21 +0200 Subject: [PATCH 04/10] add access_token param --- src/ui/control/attribution_control.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index 2ea5693685b..ff6295ebc1d 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -2,6 +2,7 @@ const DOM = require('../../util/dom'); const util = require('../../util/util'); +const config = require('../../util/config'); /** * An `AttributionControl` control presents the map's [attribution information](https://www.mapbox.com/help/attribution/). @@ -69,7 +70,7 @@ class AttributionControl { if (!this._editLink) this._editLink = this._container.querySelector('.mapbox-improve-map'); if (this._editLink) { const center = this._map.getCenter(); - const styleParams = (this.styleOwner && this.styleId) ? `?owner=${this.styleOwner}&id=${this.styleId}` : ''; + const styleParams = (this.styleOwner && this.styleId) ? config.ACCESS_TOKEN ? `?owner=${this.styleOwner}&id=${this.styleId}&access_token=${config.ACCESS_TOKEN}` : `?owner=${this.styleOwner}&id=${this.styleId}` : ''; this._editLink.href = `https://www.mapbox.com/feedback/${styleParams}#/${ Math.round(center.lng * 1000) / 1000}/${Math.round(center.lat * 1000) / 1000}/${Math.round(this._map.getZoom())}`; } From cbfe7b7fbbfcb624578e68bb1ef633e9ae658ce1 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Tue, 23 May 2017 10:59:45 +0200 Subject: [PATCH 05/10] update tests w access_token param --- test/unit/ui/control/attribution.test.js | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index 8ec576a34da..59750fa522d 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -3,10 +3,12 @@ const test = require('mapbox-gl-js-test').test; const window = require('../../../../src/util/window'); const Map = require('../../../../src/ui/map'); +const config = require('../../../../src/util/config'); const AttributionControl = require('../../../../src/ui/control/attribution_control'); function createMap() { const container = window.document.createElement('div'); + config.ACCESS_TOKEN = 'pk.123'; return new Map({ container: container, attributionControl: false, @@ -15,9 +17,10 @@ function createMap() { sources: {}, layers: [], owner: 'mapbox', - id: 'streets-v10' + id: 'streets-v10', } }); + } test('AttributionControl appears in bottom-right by default', (t) => { @@ -105,14 +108,13 @@ test('AttributionControl has the correct edit map link', (t) => { const map = createMap(); const attribution = new AttributionControl(); map.addControl(attribution); - map.on('load', () => { map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10#/0/0/0', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/0', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10#/0/0/2', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/2', 'edit link updates on mapmove'); t.end(); } }); From dc8664fc5d8f62a17637cfc0b6fe5baeebe63950 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Wed, 24 May 2017 00:38:33 +0200 Subject: [PATCH 06/10] add pitch and bearing --- src/ui/control/attribution_control.js | 13 +++++++++++-- test/unit/ui/control/attribution.test.js | 4 ++-- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index ff6295ebc1d..78a299c08b2 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -68,14 +68,23 @@ class AttributionControl { _updateEditLink() { if (!this._editLink) this._editLink = this._container.querySelector('.mapbox-improve-map'); + const params = [ + {key: "pitch", value: this._map.getPitch()}, + {key: "bearing", value: this._map.getBearing()}, + {key: "owner", value: this.styleOwner}, + {key: "id", value: this.styleId}, + {key: "access_token", value: config.ACCESS_TOKEN} + ]; + if (this._editLink) { const center = this._map.getCenter(); - const styleParams = (this.styleOwner && this.styleId) ? config.ACCESS_TOKEN ? `?owner=${this.styleOwner}&id=${this.styleId}&access_token=${config.ACCESS_TOKEN}` : `?owner=${this.styleOwner}&id=${this.styleId}` : ''; - this._editLink.href = `https://www.mapbox.com/feedback/${styleParams}#/${ + const paramString = params.reduce((acc, next, i) => acc += next.value !== undefined ? `${next.key}=${next.value}${i < params.length - 1 ? '&' : ''}` : '', `?`); + this._editLink.href = `https://www.mapbox.com/feedback/${paramString}#/${ Math.round(center.lng * 1000) / 1000}/${Math.round(center.lat * 1000) / 1000}/${Math.round(this._map.getZoom())}`; } } + _updateData(e) { if (e && e.sourceDataType === 'metadata') { this._updateAttributions(); diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index 59750fa522d..f30591f4907 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -112,9 +112,9 @@ test('AttributionControl has the correct edit map link', (t) => { map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/0', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?pitch=0&bearing=0&owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/0', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/2', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?pitch=0&bearing=0&owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/2', 'edit link updates on mapmove'); t.end(); } }); From e2d0a3f3e4b50d535c0d27893d7432dc90c9f3a3 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Wed, 24 May 2017 01:03:58 +0200 Subject: [PATCH 07/10] fix hash, make consistent w existing hash option --- src/ui/control/attribution_control.js | 14 ++++++----- src/ui/hash.js | 31 ++++++++++++++---------- src/ui/map.js | 6 ++--- test/unit/ui/control/attribution.test.js | 7 +++--- 4 files changed, 33 insertions(+), 25 deletions(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index 78a299c08b2..dfceca415db 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -69,18 +69,20 @@ class AttributionControl { _updateEditLink() { if (!this._editLink) this._editLink = this._container.querySelector('.mapbox-improve-map'); const params = [ - {key: "pitch", value: this._map.getPitch()}, - {key: "bearing", value: this._map.getBearing()}, {key: "owner", value: this.styleOwner}, {key: "id", value: this.styleId}, {key: "access_token", value: config.ACCESS_TOKEN} ]; if (this._editLink) { - const center = this._map.getCenter(); - const paramString = params.reduce((acc, next, i) => acc += next.value !== undefined ? `${next.key}=${next.value}${i < params.length - 1 ? '&' : ''}` : '', `?`); - this._editLink.href = `https://www.mapbox.com/feedback/${paramString}#/${ - Math.round(center.lng * 1000) / 1000}/${Math.round(center.lat * 1000) / 1000}/${Math.round(this._map.getZoom())}`; + const paramString = params.reduce((acc, next, i) => { + if (next.value !== undefined) { + acc += `${next.key}=${next.value}${i < params.length - 1 ? '&' : ''}`; + } + return acc; + }, `?`); + this._editLink.href = `https://www.mapbox.com/feedback/${paramString}${this._map.hash ? this._map.hash.getHashString() : ''}`; + } } diff --git a/src/ui/hash.js b/src/ui/hash.js index 9068c055d7b..9ed7bc77f0f 100644 --- a/src/ui/hash.js +++ b/src/ui/hash.js @@ -42,6 +42,22 @@ class Hash { return this; } + getHashString() { + const center = this._map.getCenter(), + zoom = this._map.getZoom(), + bearing = this._map.getBearing(), + pitch = this._map.getPitch(), + precision = Math.max(0, Math.ceil(Math.log(zoom) / Math.LN2)); + + let hash = `#${Math.round(zoom * 100) / 100 + }/${Math.round(center.lat * Math.pow(10, precision)) / Math.pow(10, precision) + }/${Math.round(center.lng * Math.pow(10, precision)) / Math.pow(10, precision)}`; + + if (bearing || pitch) hash += (`/${Math.round(bearing * 10) / 10}`); + if (pitch) hash += (`/${Math.round(pitch)}`); + return hash; + } + _onHashChange() { const loc = window.location.hash.replace('#', '').split('/'); if (loc.length >= 3) { @@ -57,21 +73,10 @@ class Hash { } _updateHash() { - const center = this._map.getCenter(), - zoom = this._map.getZoom(), - bearing = this._map.getBearing(), - pitch = this._map.getPitch(), - precision = Math.max(0, Math.ceil(Math.log(zoom) / Math.LN2)); - - let hash = `#${Math.round(zoom * 100) / 100 - }/${center.lat.toFixed(precision) - }/${center.lng.toFixed(precision)}`; - - if (bearing || pitch) hash += (`/${Math.round(bearing * 10) / 10}`); - if (pitch) hash += (`/${Math.round(pitch)}`); - + const hash = this.getHashString(this._map); window.history.replaceState('', '', hash); } + } module.exports = Hash; diff --git a/src/ui/map.js b/src/ui/map.js index 315edd95540..1dc42956e09 100755 --- a/src/ui/map.js +++ b/src/ui/map.js @@ -192,9 +192,9 @@ class Map extends Camera { bindHandlers(this, options); - this._hash = options.hash && (new Hash()).addTo(this); + this.hash = options.hash && (new Hash()).addTo(this); // don't set position from options if set through hash - if (!this._hash || !this._hash._onHashChange()) { + if (!this.hash || !this.hash._onHashChange()) { this.jumpTo({ center: options.center, zoom: options.zoom, @@ -1458,7 +1458,7 @@ class Map extends Camera { * methods on the map. */ remove() { - if (this._hash) this._hash.remove(); + if (this.hash) this.hash.remove(); browser.cancelFrame(this._frameId); this.setStyle(null); if (typeof window !== 'undefined') { diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index f30591f4907..a4e42cf219f 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -18,7 +18,8 @@ function createMap() { layers: [], owner: 'mapbox', id: 'streets-v10', - } + }, + hash: true }); } @@ -112,9 +113,9 @@ test('AttributionControl has the correct edit map link', (t) => { map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?pitch=0&bearing=0&owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/0', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#0/0/0', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?pitch=0&bearing=0&owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/2', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#2/0/0', 'edit link updates on mapmove'); t.end(); } }); From 860185444ea78240deda3b30749630112664300d Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Wed, 24 May 2017 11:08:22 +0200 Subject: [PATCH 08/10] use rounding instead of toFixed to get rid of .00s, update tests --- test/unit/ui/hash.test.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/test/unit/ui/hash.test.js b/test/unit/ui/hash.test.js index f568701977d..b4a521c271f 100644 --- a/test/unit/ui/hash.test.js +++ b/test/unit/ui/hash.test.js @@ -121,8 +121,8 @@ test('hash', (t) => { t.equal(newHash.length, 3); t.equal(newHash[0], '#3'); - t.equal(newHash[1], '1.00'); - t.equal(newHash[2], '2.00'); + t.equal(newHash[1], '1'); + t.equal(newHash[2], '2'); map.setPitch(60); @@ -130,8 +130,8 @@ test('hash', (t) => { t.equal(newHash.length, 5); t.equal(newHash[0], '#3'); - t.equal(newHash[1], '1.00'); - t.equal(newHash[2], '2.00'); + t.equal(newHash[1], '1'); + t.equal(newHash[2], '2'); t.equal(newHash[3], '0'); t.equal(newHash[4], '60'); @@ -141,8 +141,8 @@ test('hash', (t) => { t.equal(newHash.length, 5); t.equal(newHash[0], '#3'); - t.equal(newHash[1], '1.00'); - t.equal(newHash[2], '2.00'); + t.equal(newHash[1], '1'); + t.equal(newHash[2], '2'); t.equal(newHash[3], '135'); t.equal(newHash[4], '60'); From fc2afc157d78df3633be8b54eff4760d60eed8f4 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Wed, 24 May 2017 18:53:37 +0200 Subject: [PATCH 09/10] make hash conform to feedback expectations --- src/ui/control/attribution_control.js | 2 +- src/ui/hash.js | 24 +++++++++++++++--------- test/unit/ui/control/attribution.test.js | 4 ++-- 3 files changed, 18 insertions(+), 12 deletions(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index dfceca415db..d68443371e1 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -81,7 +81,7 @@ class AttributionControl { } return acc; }, `?`); - this._editLink.href = `https://www.mapbox.com/feedback/${paramString}${this._map.hash ? this._map.hash.getHashString() : ''}`; + this._editLink.href = `https://www.mapbox.com/feedback/${paramString}${this._map.hash ? this._map.hash.getHashString(true) : ''}`; } } diff --git a/src/ui/hash.js b/src/ui/hash.js index 9ed7bc77f0f..82efb9e0503 100644 --- a/src/ui/hash.js +++ b/src/ui/hash.js @@ -42,16 +42,22 @@ class Hash { return this; } - getHashString() { + getHashString(mapFeedback) { const center = this._map.getCenter(), - zoom = this._map.getZoom(), + zoom = Math.round(this._map.getZoom() * 100) / 100, + precision = Math.max(0, Math.ceil(Math.log(zoom) / Math.LN2)), + lng = Math.round(center.lng * Math.pow(10, precision)) / Math.pow(10, precision), + lat = Math.round(center.lat * Math.pow(10, precision)) / Math.pow(10, precision), bearing = this._map.getBearing(), - pitch = this._map.getPitch(), - precision = Math.max(0, Math.ceil(Math.log(zoom) / Math.LN2)); - - let hash = `#${Math.round(zoom * 100) / 100 - }/${Math.round(center.lat * Math.pow(10, precision)) / Math.pow(10, precision) - }/${Math.round(center.lng * Math.pow(10, precision)) / Math.pow(10, precision)}`; + pitch = this._map.getPitch(); + let hash = ''; + if (mapFeedback) { + // new map feedback site has some constraints that don't allow + // us to use the same hash format as we do for the Map hash option. + hash += `#/${lng}/${lat}/${zoom}`; + } else { + hash += `#${zoom}/${lat}/${lng}`; + } if (bearing || pitch) hash += (`/${Math.round(bearing * 10) / 10}`); if (pitch) hash += (`/${Math.round(pitch)}`); @@ -73,7 +79,7 @@ class Hash { } _updateHash() { - const hash = this.getHashString(this._map); + const hash = this.getHashString(); window.history.replaceState('', '', hash); } diff --git a/test/unit/ui/control/attribution.test.js b/test/unit/ui/control/attribution.test.js index a4e42cf219f..4dcb8940339 100644 --- a/test/unit/ui/control/attribution.test.js +++ b/test/unit/ui/control/attribution.test.js @@ -113,9 +113,9 @@ test('AttributionControl has the correct edit map link', (t) => { map.addSource('1', {type: 'vector', attribution: 'Improve this map'}); map.on('data', (e) => { if (e.dataType === 'source' && e.sourceDataType === 'metadata') { - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#0/0/0', 'edit link contains map location data'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/0', 'edit link contains map location data'); map.setZoom(2); - t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#2/0/0', 'edit link updates on mapmove'); + t.equal(attribution._editLink.href, 'https://www.mapbox.com/feedback/?owner=mapbox&id=streets-v10&access_token=pk.123#/0/0/2', 'edit link updates on mapmove'); t.end(); } }); From 192dfd48ba46cbac80faba0e3efe325389c3fbf5 Mon Sep 17 00:00:00 2001 From: Molly Lloyd Date: Fri, 26 May 2017 13:17:43 +0200 Subject: [PATCH 10/10] change hash back to private property --- src/ui/control/attribution_control.js | 2 +- src/ui/map.js | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/ui/control/attribution_control.js b/src/ui/control/attribution_control.js index d68443371e1..0ce99e81884 100644 --- a/src/ui/control/attribution_control.js +++ b/src/ui/control/attribution_control.js @@ -81,7 +81,7 @@ class AttributionControl { } return acc; }, `?`); - this._editLink.href = `https://www.mapbox.com/feedback/${paramString}${this._map.hash ? this._map.hash.getHashString(true) : ''}`; + this._editLink.href = `https://www.mapbox.com/feedback/${paramString}${this._map._hash ? this._map._hash.getHashString(true) : ''}`; } } diff --git a/src/ui/map.js b/src/ui/map.js index 1dc42956e09..315edd95540 100755 --- a/src/ui/map.js +++ b/src/ui/map.js @@ -192,9 +192,9 @@ class Map extends Camera { bindHandlers(this, options); - this.hash = options.hash && (new Hash()).addTo(this); + this._hash = options.hash && (new Hash()).addTo(this); // don't set position from options if set through hash - if (!this.hash || !this.hash._onHashChange()) { + if (!this._hash || !this._hash._onHashChange()) { this.jumpTo({ center: options.center, zoom: options.zoom, @@ -1458,7 +1458,7 @@ class Map extends Camera { * methods on the map. */ remove() { - if (this.hash) this.hash.remove(); + if (this._hash) this._hash.remove(); browser.cancelFrame(this._frameId); this.setStyle(null); if (typeof window !== 'undefined') {