-
Notifications
You must be signed in to change notification settings - Fork 409
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* Fix #1728. Generalized Share embedded strings. More tests (#1729) * Fix #1738. Made optional share api and showTOC (#1739) With this options you can remove via configuration the API share tool and the showTOC checkbox. * Fix #1750.Add smarter shareURLs generator and tests
- Loading branch information
1 parent
a484f44
commit 1274473
Showing
5 changed files
with
118 additions
and
17 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
/* | ||
* Copyright 2017, GeoSolutions Sas. | ||
* All rights reserved. | ||
* | ||
* This source code is licensed under the BSD-style license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
const Url = require('url'); | ||
|
||
/** | ||
* Utility functions for Share tools | ||
* @memberof utils | ||
* @type {Object} | ||
*/ | ||
var ShareUtils = { | ||
/** | ||
* get the absolute URL from the local url and the url to convert | ||
* @param {string} localUrl the context where to evaluate the URL, typically location.href | ||
* @param {string} urlToConvert the url to convert | ||
* @return {string} the absolute url of the urlToConvert | ||
*/ | ||
getAbsoluteURL: (localUrl, urlToConvert) => { | ||
// case absolute URL | ||
if (urlToConvert.indexOf("http") === 0 || urlToConvert.indexOf("//") === 0) { | ||
return urlToConvert; | ||
} | ||
return Url.resolve(localUrl, urlToConvert); | ||
}, | ||
/** | ||
* get the url for the configuration in GeoStore parsing the hash string (`#/viewer/{maptype}/1`) | ||
* @param {string} url the context where to evaluate the URL, typically location.href | ||
* @param {string} geoStoreUrl the Base URL of GeoStore | ||
* @return {string} the absolute url of the GeoStore Resource | ||
*/ | ||
getConfigUrl: (url, geoStoreUrl) => { | ||
let urlParsedObj = Url.parse(url, true); | ||
if (!urlParsedObj.hash) { | ||
return null; | ||
} | ||
const start = urlParsedObj.hash.lastIndexOf('/') + 1; | ||
const end = urlParsedObj.hash.lastIndexOf('?') >= 0 ? urlParsedObj.hash.lastIndexOf('?') : urlParsedObj.hash.length; | ||
const mapId = urlParsedObj.hash.substring(start, end); | ||
return Url.resolve(ShareUtils.getAbsoluteURL(url, geoStoreUrl), ('data/' + mapId)); | ||
}, | ||
/** | ||
* Parses the API url to get the proper base path where to retrieve the js for the api. | ||
* @param {string} url the current context | ||
* @return {string} the base path of mapstore where to retrieve the js api. | ||
*/ | ||
getApiUrl: (url) => { | ||
let urlParsedObj = Url.parse(url, false); | ||
return urlParsedObj.protocol + '//' + urlParsedObj.host + urlParsedObj.pathname; | ||
} | ||
}; | ||
|
||
module.exports = ShareUtils; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
/* | ||
* Copyright 2017, GeoSolutions Sas. | ||
* All rights reserved. | ||
* | ||
* This source code is licensed under the BSD-style license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
var expect = require('expect'); | ||
var ShareUtils = require('../ShareUtils'); | ||
|
||
|
||
const MAPSTORE_PATH = "/mapstore/"; | ||
const MAP_HASH_PATH = "#/viewer/leaflet/"; | ||
const GEOSTORE_DATA_PATH = "data/"; | ||
const QUERY_STRING = "?config=myCustomConfig"; | ||
const MS_GEOSTORE_EMBEDDED_PATH = "/mapstore/rest/geostore/"; | ||
const STANDALONE_GEOSTORE_PATH = "/geostore/rest/"; | ||
|
||
const LOCALURL = "http://localhost:8081"; | ||
const SOMEHOST = "http://somehost.it"; | ||
const DEV_URL = "http://dev.mapstore2.geo-solutions.it"; | ||
|
||
const LOCALURL_PATH = LOCALURL + MAPSTORE_PATH; | ||
const DEV_URL_PATH = DEV_URL + MAPSTORE_PATH; | ||
const DEV_URL_MAP_PATH = DEV_URL_PATH + MAP_HASH_PATH; | ||
const SOMEHOST_PATH = SOMEHOST + MAPSTORE_PATH; | ||
const SOMEHOST_PATH_QUERY_STRING = SOMEHOST_PATH + QUERY_STRING; | ||
const EXTERNAL_GEOSTORE = "http://dev.mapstore2.geo-solutions.it/geostore/rest/"; | ||
|
||
describe('ShareUtils test', () => { | ||
it('getAbsoluteURL', () => { | ||
expect(ShareUtils.getAbsoluteURL(LOCALURL, MS_GEOSTORE_EMBEDDED_PATH)).toBe( LOCALURL + MS_GEOSTORE_EMBEDDED_PATH ); | ||
expect(ShareUtils.getAbsoluteURL(DEV_URL, MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH); | ||
expect(ShareUtils.getAbsoluteURL(DEV_URL_PATH, MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH); | ||
expect(ShareUtils.getAbsoluteURL(SOMEHOST_PATH, STANDALONE_GEOSTORE_PATH)).toBe(SOMEHOST + STANDALONE_GEOSTORE_PATH); | ||
expect(ShareUtils.getAbsoluteURL(SOMEHOST_PATH_QUERY_STRING, STANDALONE_GEOSTORE_PATH)).toBe(SOMEHOST + STANDALONE_GEOSTORE_PATH); | ||
expect(ShareUtils.getAbsoluteURL(SOMEHOST_PATH_QUERY_STRING, EXTERNAL_GEOSTORE)).toBe(EXTERNAL_GEOSTORE); | ||
}); | ||
it('getConfigUrl', () => { | ||
expect(ShareUtils.getConfigUrl(DEV_URL_MAP_PATH + "1", MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH + GEOSTORE_DATA_PATH + "1"); | ||
expect(ShareUtils.getConfigUrl(DEV_URL_MAP_PATH + "11", MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH + GEOSTORE_DATA_PATH + "11"); | ||
expect(ShareUtils.getConfigUrl(DEV_URL_MAP_PATH + "111", MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH + GEOSTORE_DATA_PATH + "111"); | ||
expect(ShareUtils.getConfigUrl(DEV_URL_MAP_PATH + "111?abc=def", MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH + GEOSTORE_DATA_PATH + "111"); | ||
expect(ShareUtils.getConfigUrl(DEV_URL_MAP_PATH, MS_GEOSTORE_EMBEDDED_PATH)).toBe(DEV_URL + MS_GEOSTORE_EMBEDDED_PATH + GEOSTORE_DATA_PATH); | ||
expect(ShareUtils.getConfigUrl(SOMEHOST_PATH, MS_GEOSTORE_EMBEDDED_PATH)).toBe(null); | ||
}); | ||
it('getApiUrl', () => { | ||
expect(ShareUtils.getApiUrl(DEV_URL_MAP_PATH)).toBe(DEV_URL_PATH); | ||
expect(ShareUtils.getApiUrl(LOCALURL_PATH)).toBe(LOCALURL_PATH); | ||
expect(ShareUtils.getApiUrl(LOCALURL_PATH + MAPSTORE_PATH + QUERY_STRING)).toBe(LOCALURL_PATH + MAPSTORE_PATH); | ||
}); | ||
}); |