mapbox.internals.js 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
  2. function corslite(url, callback, cors) {
  3. var sent = false;
  4. if (typeof window.XMLHttpRequest === 'undefined') {
  5. return callback(Error('Browser not supported'));
  6. }
  7. if (typeof cors === 'undefined') {
  8. var m = url.match(/^\s*https?:\/\/[^\/]*/);
  9. cors = m && (m[0] !== location.protocol + '//' + location.domain +
  10. (location.port ? ':' + location.port : ''));
  11. }
  12. var x = new window.XMLHttpRequest();
  13. function isSuccessful(status) {
  14. return status >= 200 && status < 300 || status === 304;
  15. }
  16. if (cors && !('withCredentials' in x)) {
  17. // IE8-9
  18. x = new window.XDomainRequest();
  19. // Ensure callback is never called synchronously, i.e., before
  20. // x.send() returns (this has been observed in the wild).
  21. // See https://github.com/mapbox/mapbox.js/issues/472
  22. var original = callback;
  23. callback = function() {
  24. if (sent) {
  25. original.apply(this, arguments);
  26. } else {
  27. var that = this, args = arguments;
  28. setTimeout(function() {
  29. original.apply(that, args);
  30. }, 0);
  31. }
  32. }
  33. }
  34. function loaded() {
  35. if (
  36. // XDomainRequest
  37. x.status === undefined ||
  38. // modern browsers
  39. isSuccessful(x.status)) callback.call(x, null, x);
  40. else callback.call(x, x, null);
  41. }
  42. // Both `onreadystatechange` and `onload` can fire. `onreadystatechange`
  43. // has [been supported for longer](http://stackoverflow.com/a/9181508/229001).
  44. if ('onload' in x) {
  45. x.onload = loaded;
  46. } else {
  47. x.onreadystatechange = function readystate() {
  48. if (x.readyState === 4) {
  49. loaded();
  50. }
  51. };
  52. }
  53. // Call the callback with the XMLHttpRequest object as an error and prevent
  54. // it from ever being called again by reassigning it to `noop`
  55. x.onerror = function error(evt) {
  56. // XDomainRequest provides no evt parameter
  57. callback.call(this, evt || true, null);
  58. callback = function() { };
  59. };
  60. // IE9 must have onprogress be set to a unique function.
  61. x.onprogress = function() { };
  62. x.ontimeout = function(evt) {
  63. callback.call(this, evt, null);
  64. callback = function() { };
  65. };
  66. x.onabort = function(evt) {
  67. callback.call(this, evt, null);
  68. callback = function() { };
  69. };
  70. // GET is the only supported HTTP Verb by XDomainRequest and is the
  71. // only one supported here.
  72. x.open('GET', url, true);
  73. // Send the request. Sending data is not supported.
  74. x.send(null);
  75. sent = true;
  76. return x;
  77. }
  78. if (typeof module !== 'undefined') module.exports = corslite;
  79. },{}],2:[function(require,module,exports){
  80. module.exports={
  81. "author": "Mapbox",
  82. "name": "mapbox.js",
  83. "description": "mapbox javascript api",
  84. "version": "3.1.1",
  85. "homepage": "http://mapbox.com/",
  86. "repository": {
  87. "type": "git",
  88. "url": "git://github.com/mapbox/mapbox.js.git"
  89. },
  90. "main": "src/index.js",
  91. "dependencies": {
  92. "corslite": "0.0.6",
  93. "isarray": "0.0.1",
  94. "leaflet": "1.0.2",
  95. "mustache": "2.2.1",
  96. "sanitize-caja": "0.1.4"
  97. },
  98. "scripts": {
  99. "test": "eslint --no-eslintrc -c .eslintrc src && phantomjs node_modules/mocha-phantomjs-core/mocha-phantomjs-core.js test/index.html"
  100. },
  101. "license": "BSD-3-Clause",
  102. "devDependencies": {
  103. "browserify": "^13.0.0",
  104. "clean-css": "~2.0.7",
  105. "cz-conventional-changelog": "1.2.0",
  106. "eslint": "^0.23.0",
  107. "expect.js": "0.3.1",
  108. "happen": "0.1.3",
  109. "leaflet-fullscreen": "0.0.4",
  110. "leaflet-hash": "0.2.1",
  111. "marked": "~0.3.0",
  112. "minifyify": "^6.1.0",
  113. "minimist": "0.0.5",
  114. "mocha": "2.4.5",
  115. "mocha-phantomjs-core": "2.0.1",
  116. "phantomjs-prebuilt": "2.1.12",
  117. "sinon": "1.10.2"
  118. },
  119. "optionalDependencies": {},
  120. "engines": {
  121. "node": "*"
  122. },
  123. "config": {
  124. "commitizen": {
  125. "path": "./node_modules/cz-conventional-changelog"
  126. }
  127. }
  128. }
  129. },{}],3:[function(require,module,exports){
  130. 'use strict';
  131. module.exports = {
  132. HTTP_URL: 'http://a.tiles.mapbox.com/v4',
  133. HTTPS_URL: 'https://a.tiles.mapbox.com/v4',
  134. FORCE_HTTPS: false,
  135. REQUIRE_ACCESS_TOKEN: true
  136. };
  137. },{}],4:[function(require,module,exports){
  138. 'use strict';
  139. var config = require('./config'),
  140. version = require('../package.json').version;
  141. module.exports = function(path, accessToken) {
  142. accessToken = accessToken || L.mapbox.accessToken;
  143. if (!accessToken && config.REQUIRE_ACCESS_TOKEN) {
  144. throw new Error('An API access token is required to use Mapbox.js. ' +
  145. 'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/');
  146. }
  147. var url = (document.location.protocol === 'https:' || config.FORCE_HTTPS) ? config.HTTPS_URL : config.HTTP_URL;
  148. url = url.replace(/\/v4$/, '');
  149. url += path;
  150. if (config.REQUIRE_ACCESS_TOKEN) {
  151. if (accessToken[0] === 's') {
  152. throw new Error('Use a public access token (pk.*) with Mapbox.js, not a secret access token (sk.*). ' +
  153. 'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/');
  154. }
  155. url += url.indexOf('?') !== -1 ? '&access_token=' : '?access_token=';
  156. url += accessToken;
  157. }
  158. return url;
  159. };
  160. module.exports.tileJSON = function(urlOrMapID, accessToken) {
  161. if (urlOrMapID.indexOf('mapbox://styles') === 0) {
  162. throw new Error('Styles created with Mapbox Studio need to be used with ' +
  163. 'L.mapbox.styleLayer, not L.mapbox.tileLayer');
  164. }
  165. if (urlOrMapID.indexOf('/') !== -1)
  166. return urlOrMapID;
  167. var url = module.exports('/v4/' + urlOrMapID + '.json', accessToken);
  168. // TileJSON requests need a secure flag appended to their URLs so
  169. // that the server knows to send SSL-ified resource references.
  170. if (url.indexOf('https') === 0)
  171. url += '&secure';
  172. return url;
  173. };
  174. module.exports.style = function(styleURL, accessToken) {
  175. if (styleURL.indexOf('mapbox://styles/') === -1) throw new Error('Incorrectly formatted Mapbox style at ' + styleURL);
  176. var ownerIDStyle = styleURL.split('mapbox://styles/')[1];
  177. var url = module.exports('/styles/v1/' + ownerIDStyle, accessToken)
  178. .replace('http://', 'https://');
  179. return url;
  180. };
  181. },{"../package.json":2,"./config":3}],5:[function(require,module,exports){
  182. 'use strict';
  183. function utfDecode(c) {
  184. if (c >= 93) c--;
  185. if (c >= 35) c--;
  186. return c - 32;
  187. }
  188. module.exports = function(data) {
  189. return function(x, y) {
  190. if (!data) return;
  191. var idx = utfDecode(data.grid[y].charCodeAt(x)),
  192. key = data.keys[idx];
  193. return data.data[key];
  194. };
  195. };
  196. },{}],6:[function(require,module,exports){
  197. window.internals = {
  198. url: require('./format_url'),
  199. config: require('./config'),
  200. util: require('./util'),
  201. grid: require('./grid'),
  202. request: require('./request')
  203. };
  204. },{"./config":3,"./format_url":4,"./grid":5,"./request":7,"./util":8}],7:[function(require,module,exports){
  205. 'use strict';
  206. var corslite = require('corslite'),
  207. strict = require('./util').strict,
  208. config = require('./config');
  209. var protocol = /^(https?:)?(?=\/\/(.|api)\.tiles\.mapbox\.com\/)/;
  210. module.exports = function(url, callback) {
  211. strict(url, 'string');
  212. strict(callback, 'function');
  213. url = url.replace(protocol, function(match, protocol) {
  214. if (!('withCredentials' in new window.XMLHttpRequest())) {
  215. // XDomainRequest in use; doesn't support cross-protocol requests
  216. return document.location.protocol;
  217. } else if (protocol === 'https:' || document.location.protocol === 'https:' || config.FORCE_HTTPS) {
  218. return 'https:';
  219. } else {
  220. return 'http:';
  221. }
  222. });
  223. function onload(err, resp) {
  224. if (!err && resp) {
  225. resp = JSON.parse(resp.responseText);
  226. }
  227. callback(err, resp);
  228. }
  229. return corslite(url, onload);
  230. };
  231. },{"./config":3,"./util":8,"corslite":1}],8:[function(require,module,exports){
  232. 'use strict';
  233. function contains(item, list) {
  234. if (!list || !list.length) return false;
  235. for (var i = 0; i < list.length; i++) {
  236. if (list[i] === item) return true;
  237. }
  238. return false;
  239. }
  240. module.exports = {
  241. idUrl: function(_, t) {
  242. if (_.indexOf('/') === -1) t.loadID(_);
  243. else t.loadURL(_);
  244. },
  245. log: function(_) {
  246. if (typeof console === 'object' &&
  247. typeof console.error === 'function') {
  248. console.error(_);
  249. }
  250. },
  251. strict: function(_, type) {
  252. if (typeof _ !== type) {
  253. throw new Error('Invalid argument: ' + type + ' expected');
  254. }
  255. },
  256. strict_instance: function(_, klass, name) {
  257. if (!(_ instanceof klass)) {
  258. throw new Error('Invalid argument: ' + name + ' expected');
  259. }
  260. },
  261. strict_oneof: function(_, values) {
  262. if (!contains(_, values)) {
  263. throw new Error('Invalid argument: ' + _ + ' given, valid values are ' +
  264. values.join(', '));
  265. }
  266. },
  267. strip_tags: function(_) {
  268. return _.replace(/<[^<]+>/g, '');
  269. },
  270. lbounds: function(_) {
  271. // leaflet-compatible bounds, since leaflet does not do geojson
  272. return new L.LatLngBounds([[_[1], _[0]], [_[3], _[2]]]);
  273. }
  274. };
  275. },{}]},{},[6])
  276. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/corslite/corslite.js","package.json","src/config.js","src/format_url.js","src/grid.js","src/internals.js","src/request.js","src/util.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","function corslite(url, callback, cors) {\n    var sent = false;\n\n    if (typeof window.XMLHttpRequest === 'undefined') {\n        return callback(Error('Browser not supported'));\n    }\n\n    if (typeof cors === 'undefined') {\n        var m = url.match(/^\\s*https?:\\/\\/[^\\/]*/);\n        cors = m && (m[0] !== location.protocol + '//' + location.domain +\n                (location.port ? ':' + location.port : ''));\n    }\n\n    var x = new window.XMLHttpRequest();\n\n    function isSuccessful(status) {\n        return status >= 200 && status < 300 || status === 304;\n    }\n\n    if (cors && !('withCredentials' in x)) {\n        // IE8-9\n        x = new window.XDomainRequest();\n\n        // Ensure callback is never called synchronously, i.e., before\n        // x.send() returns (this has been observed in the wild).\n        // See https://github.com/mapbox/mapbox.js/issues/472\n        var original = callback;\n        callback = function() {\n            if (sent) {\n                original.apply(this, arguments);\n            } else {\n                var that = this, args = arguments;\n                setTimeout(function() {\n                    original.apply(that, args);\n                }, 0);\n            }\n        }\n    }\n\n    function loaded() {\n        if (\n            // XDomainRequest\n            x.status === undefined ||\n            // modern browsers\n            isSuccessful(x.status)) callback.call(x, null, x);\n        else callback.call(x, x, null);\n    }\n\n    // Both `onreadystatechange` and `onload` can fire. `onreadystatechange`\n    // has [been supported for longer](http://stackoverflow.com/a/9181508/229001).\n    if ('onload' in x) {\n        x.onload = loaded;\n    } else {\n        x.onreadystatechange = function readystate() {\n            if (x.readyState === 4) {\n                loaded();\n            }\n        };\n    }\n\n    // Call the callback with the XMLHttpRequest object as an error and prevent\n    // it from ever being called again by reassigning it to `noop`\n    x.onerror = function error(evt) {\n        // XDomainRequest provides no evt parameter\n        callback.call(this, evt || true, null);\n        callback = function() { };\n    };\n\n    // IE9 must have onprogress be set to a unique function.\n    x.onprogress = function() { };\n\n    x.ontimeout = function(evt) {\n        callback.call(this, evt, null);\n        callback = function() { };\n    };\n\n    x.onabort = function(evt) {\n        callback.call(this, evt, null);\n        callback = function() { };\n    };\n\n    // GET is the only supported HTTP Verb by XDomainRequest and is the\n    // only one supported here.\n    x.open('GET', url, true);\n\n    // Send the request. Sending data is not supported.\n    x.send(null);\n    sent = true;\n\n    return x;\n}\n\nif (typeof module !== 'undefined') module.exports = corslite;\n","module.exports={\n  \"author\": \"Mapbox\",\n  \"name\": \"mapbox.js\",\n  \"description\": \"mapbox javascript api\",\n  \"version\": \"3.1.1\",\n  \"homepage\": \"http://mapbox.com/\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/mapbox/mapbox.js.git\"\n  },\n  \"main\": \"src/index.js\",\n  \"dependencies\": {\n    \"corslite\": \"0.0.6\",\n    \"isarray\": \"0.0.1\",\n    \"leaflet\": \"1.0.2\",\n    \"mustache\": \"2.2.1\",\n    \"sanitize-caja\": \"0.1.4\"\n  },\n  \"scripts\": {\n    \"test\": \"eslint --no-eslintrc -c .eslintrc src && phantomjs node_modules/mocha-phantomjs-core/mocha-phantomjs-core.js test/index.html\"\n  },\n  \"license\": \"BSD-3-Clause\",\n  \"devDependencies\": {\n    \"browserify\": \"^13.0.0\",\n    \"clean-css\": \"~2.0.7\",\n    \"cz-conventional-changelog\": \"1.2.0\",\n    \"eslint\": \"^0.23.0\",\n    \"expect.js\": \"0.3.1\",\n    \"happen\": \"0.1.3\",\n    \"leaflet-fullscreen\": \"0.0.4\",\n    \"leaflet-hash\": \"0.2.1\",\n    \"marked\": \"~0.3.0\",\n    \"minifyify\": \"^6.1.0\",\n    \"minimist\": \"0.0.5\",\n    \"mocha\": \"2.4.5\",\n    \"mocha-phantomjs-core\": \"2.0.1\",\n    \"phantomjs-prebuilt\": \"2.1.12\",\n    \"sinon\": \"1.10.2\"\n  },\n  \"optionalDependencies\": {},\n  \"engines\": {\n    \"node\": \"*\"\n  },\n  \"config\": {\n    \"commitizen\": {\n      \"path\": \"./node_modules/cz-conventional-changelog\"\n    }\n  }\n}\n","'use strict';\n\nmodule.exports = {\n    HTTP_URL: 'http://a.tiles.mapbox.com/v4',\n    HTTPS_URL: 'https://a.tiles.mapbox.com/v4',\n    FORCE_HTTPS: false,\n    REQUIRE_ACCESS_TOKEN: true\n};\n","'use strict';\n\nvar config = require('./config'),\n    version = require('../package.json').version;\n\nmodule.exports = function(path, accessToken) {\n    accessToken = accessToken || L.mapbox.accessToken;\n\n    if (!accessToken && config.REQUIRE_ACCESS_TOKEN) {\n        throw new Error('An API access token is required to use Mapbox.js. ' +\n            'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/');\n    }\n\n    var url = (document.location.protocol === 'https:' || config.FORCE_HTTPS) ? config.HTTPS_URL : config.HTTP_URL;\n    url = url.replace(/\\/v4$/, '');\n    url += path;\n\n    if (config.REQUIRE_ACCESS_TOKEN) {\n        if (accessToken[0] === 's') {\n            throw new Error('Use a public access token (pk.*) with Mapbox.js, not a secret access token (sk.*). ' +\n                'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/');\n        }\n\n        url += url.indexOf('?') !== -1 ? '&access_token=' : '?access_token=';\n        url += accessToken;\n    }\n\n    return url;\n};\n\nmodule.exports.tileJSON = function(urlOrMapID, accessToken) {\n\n    if (urlOrMapID.indexOf('mapbox://styles') === 0) {\n        throw new Error('Styles created with Mapbox Studio need to be used with ' +\n            'L.mapbox.styleLayer, not L.mapbox.tileLayer');\n    }\n\n    if (urlOrMapID.indexOf('/') !== -1)\n        return urlOrMapID;\n\n    var url = module.exports('/v4/' + urlOrMapID + '.json', accessToken);\n\n    // TileJSON requests need a secure flag appended to their URLs so\n    // that the server knows to send SSL-ified resource references.\n    if (url.indexOf('https') === 0)\n        url += '&secure';\n\n    return url;\n};\n\n\nmodule.exports.style = function(styleURL, accessToken) {\n    if (styleURL.indexOf('mapbox://styles/') === -1) throw new Error('Incorrectly formatted Mapbox style at ' + styleURL);\n\n    var ownerIDStyle = styleURL.split('mapbox://styles/')[1];\n    var url = module.exports('/styles/v1/' + ownerIDStyle, accessToken)\n        .replace('http://', 'https://');\n\n    return url;\n};\n","'use strict';\n\nfunction utfDecode(c) {\n    if (c >= 93) c--;\n    if (c >= 35) c--;\n    return c - 32;\n}\n\nmodule.exports = function(data) {\n    return function(x, y) {\n        if (!data) return;\n        var idx = utfDecode(data.grid[y].charCodeAt(x)),\n            key = data.keys[idx];\n        return data.data[key];\n    };\n};\n","window.internals = {\n    url: require('./format_url'),\n    config: require('./config'),\n    util: require('./util'),\n    grid: require('./grid'),\n    request: require('./request')\n};\n","'use strict';\n\nvar corslite = require('corslite'),\n    strict = require('./util').strict,\n    config = require('./config');\n\nvar protocol = /^(https?:)?(?=\\/\\/(.|api)\\.tiles\\.mapbox\\.com\\/)/;\n\nmodule.exports = function(url, callback) {\n    strict(url, 'string');\n    strict(callback, 'function');\n\n    url = url.replace(protocol, function(match, protocol) {\n        if (!('withCredentials' in new window.XMLHttpRequest())) {\n            // XDomainRequest in use; doesn't support cross-protocol requests\n            return document.location.protocol;\n        } else if (protocol === 'https:' || document.location.protocol === 'https:' || config.FORCE_HTTPS) {\n            return 'https:';\n        } else {\n            return 'http:';\n        }\n    });\n\n    function onload(err, resp) {\n        if (!err && resp) {\n            resp = JSON.parse(resp.responseText);\n        }\n        callback(err, resp);\n    }\n\n    return corslite(url, onload);\n};\n","'use strict';\n\nfunction contains(item, list) {\n    if (!list || !list.length) return false;\n    for (var i = 0; i < list.length; i++) {\n        if (list[i] === item) return true;\n    }\n    return false;\n}\n\nmodule.exports = {\n    idUrl: function(_, t) {\n        if (_.indexOf('/') === -1) t.loadID(_);\n        else t.loadURL(_);\n    },\n    log: function(_) {\n        if (typeof console === 'object' &&\n            typeof console.error === 'function') {\n            console.error(_);\n        }\n    },\n    strict: function(_, type) {\n        if (typeof _ !== type) {\n            throw new Error('Invalid argument: ' + type + ' expected');\n        }\n    },\n    strict_instance: function(_, klass, name) {\n        if (!(_ instanceof klass)) {\n            throw new Error('Invalid argument: ' + name + ' expected');\n        }\n    },\n    strict_oneof: function(_, values) {\n        if (!contains(_, values)) {\n            throw new Error('Invalid argument: ' + _ + ' given, valid values are ' +\n                values.join(', '));\n        }\n    },\n    strip_tags: function(_) {\n        return _.replace(/<[^<]+>/g, '');\n    },\n    lbounds: function(_) {\n        // leaflet-compatible bounds, since leaflet does not do geojson\n        return new L.LatLngBounds([[_[1], _[0]], [_[3], _[2]]]);\n    }\n};\n"]}