(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= 200 && status < 300 || status === 304; } if (cors && !('withCredentials' in x)) { // IE8-9 x = new window.XDomainRequest(); // Ensure callback is never called synchronously, i.e., before // x.send() returns (this has been observed in the wild). // See https://github.com/mapbox/mapbox.js/issues/472 var original = callback; callback = function() { if (sent) { original.apply(this, arguments); } else { var that = this, args = arguments; setTimeout(function() { original.apply(that, args); }, 0); } } } function loaded() { if ( // XDomainRequest x.status === undefined || // modern browsers isSuccessful(x.status)) callback.call(x, null, x); else callback.call(x, x, null); } // Both `onreadystatechange` and `onload` can fire. `onreadystatechange` // has [been supported for longer](http://stackoverflow.com/a/9181508/229001). if ('onload' in x) { x.onload = loaded; } else { x.onreadystatechange = function readystate() { if (x.readyState === 4) { loaded(); } }; } // Call the callback with the XMLHttpRequest object as an error and prevent // it from ever being called again by reassigning it to `noop` x.onerror = function error(evt) { // XDomainRequest provides no evt parameter callback.call(this, evt || true, null); callback = function() { }; }; // IE9 must have onprogress be set to a unique function. x.onprogress = function() { }; x.ontimeout = function(evt) { callback.call(this, evt, null); callback = function() { }; }; x.onabort = function(evt) { callback.call(this, evt, null); callback = function() { }; }; // GET is the only supported HTTP Verb by XDomainRequest and is the // only one supported here. x.open('GET', url, true); // Send the request. Sending data is not supported. x.send(null); sent = true; return x; } if (typeof module !== 'undefined') module.exports = corslite; },{}],2:[function(require,module,exports){ module.exports={ "author": "Mapbox", "name": "mapbox.js", "description": "mapbox javascript api", "version": "3.1.1", "homepage": "http://mapbox.com/", "repository": { "type": "git", "url": "git://github.com/mapbox/mapbox.js.git" }, "main": "src/index.js", "dependencies": { "corslite": "0.0.6", "isarray": "0.0.1", "leaflet": "1.0.2", "mustache": "2.2.1", "sanitize-caja": "0.1.4" }, "scripts": { "test": "eslint --no-eslintrc -c .eslintrc src && phantomjs node_modules/mocha-phantomjs-core/mocha-phantomjs-core.js test/index.html" }, "license": "BSD-3-Clause", "devDependencies": { "browserify": "^13.0.0", "clean-css": "~2.0.7", "cz-conventional-changelog": "1.2.0", "eslint": "^0.23.0", "expect.js": "0.3.1", "happen": "0.1.3", "leaflet-fullscreen": "0.0.4", "leaflet-hash": "0.2.1", "marked": "~0.3.0", "minifyify": "^6.1.0", "minimist": "0.0.5", "mocha": "2.4.5", "mocha-phantomjs-core": "2.0.1", "phantomjs-prebuilt": "2.1.12", "sinon": "1.10.2" }, "optionalDependencies": {}, "engines": { "node": "*" }, "config": { "commitizen": { "path": "./node_modules/cz-conventional-changelog" } } } },{}],3:[function(require,module,exports){ 'use strict'; module.exports = { HTTP_URL: 'http://a.tiles.mapbox.com/v4', HTTPS_URL: 'https://a.tiles.mapbox.com/v4', FORCE_HTTPS: false, REQUIRE_ACCESS_TOKEN: true }; },{}],4:[function(require,module,exports){ 'use strict'; var config = require('./config'), version = require('../package.json').version; module.exports = function(path, accessToken) { accessToken = accessToken || L.mapbox.accessToken; if (!accessToken && config.REQUIRE_ACCESS_TOKEN) { throw new Error('An API access token is required to use Mapbox.js. ' + 'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/'); } var url = (document.location.protocol === 'https:' || config.FORCE_HTTPS) ? config.HTTPS_URL : config.HTTP_URL; url = url.replace(/\/v4$/, ''); url += path; if (config.REQUIRE_ACCESS_TOKEN) { if (accessToken[0] === 's') { throw new Error('Use a public access token (pk.*) with Mapbox.js, not a secret access token (sk.*). ' + 'See https://www.mapbox.com/mapbox.js/api/v' + version + '/api-access-tokens/'); } url += url.indexOf('?') !== -1 ? '&access_token=' : '?access_token='; url += accessToken; } return url; }; module.exports.tileJSON = function(urlOrMapID, accessToken) { if (urlOrMapID.indexOf('mapbox://styles') === 0) { throw new Error('Styles created with Mapbox Studio need to be used with ' + 'L.mapbox.styleLayer, not L.mapbox.tileLayer'); } if (urlOrMapID.indexOf('/') !== -1) return urlOrMapID; var url = module.exports('/v4/' + urlOrMapID + '.json', accessToken); // TileJSON requests need a secure flag appended to their URLs so // that the server knows to send SSL-ified resource references. if (url.indexOf('https') === 0) url += '&secure'; return url; }; module.exports.style = function(styleURL, accessToken) { if (styleURL.indexOf('mapbox://styles/') === -1) throw new Error('Incorrectly formatted Mapbox style at ' + styleURL); var ownerIDStyle = styleURL.split('mapbox://styles/')[1]; var url = module.exports('/styles/v1/' + ownerIDStyle, accessToken) .replace('http://', 'https://'); return url; }; },{"../package.json":2,"./config":3}],5:[function(require,module,exports){ 'use strict'; function utfDecode(c) { if (c >= 93) c--; if (c >= 35) c--; return c - 32; } module.exports = function(data) { return function(x, y) { if (!data) return; var idx = utfDecode(data.grid[y].charCodeAt(x)), key = data.keys[idx]; return data.data[key]; }; }; },{}],6:[function(require,module,exports){ window.internals = { url: require('./format_url'), config: require('./config'), util: require('./util'), grid: require('./grid'), request: require('./request') }; },{"./config":3,"./format_url":4,"./grid":5,"./request":7,"./util":8}],7:[function(require,module,exports){ 'use strict'; var corslite = require('corslite'), strict = require('./util').strict, config = require('./config'); var protocol = /^(https?:)?(?=\/\/(.|api)\.tiles\.mapbox\.com\/)/; module.exports = function(url, callback) { strict(url, 'string'); strict(callback, 'function'); url = url.replace(protocol, function(match, protocol) { if (!('withCredentials' in new window.XMLHttpRequest())) { // XDomainRequest in use; doesn't support cross-protocol requests return document.location.protocol; } else if (protocol === 'https:' || document.location.protocol === 'https:' || config.FORCE_HTTPS) { return 'https:'; } else { return 'http:'; } }); function onload(err, resp) { if (!err && resp) { resp = JSON.parse(resp.responseText); } callback(err, resp); } return corslite(url, onload); }; },{"./config":3,"./util":8,"corslite":1}],8:[function(require,module,exports){ 'use strict'; function contains(item, list) { if (!list || !list.length) return false; for (var i = 0; i < list.length; i++) { if (list[i] === item) return true; } return false; } module.exports = { idUrl: function(_, t) { if (_.indexOf('/') === -1) t.loadID(_); else t.loadURL(_); }, log: function(_) { if (typeof console === 'object' && typeof console.error === 'function') { console.error(_); } }, strict: function(_, type) { if (typeof _ !== type) { throw new Error('Invalid argument: ' + type + ' expected'); } }, strict_instance: function(_, klass, name) { if (!(_ instanceof klass)) { throw new Error('Invalid argument: ' + name + ' expected'); } }, strict_oneof: function(_, values) { if (!contains(_, values)) { throw new Error('Invalid argument: ' + _ + ' given, valid values are ' + values.join(', ')); } }, strip_tags: function(_) { return _.replace(/<[^<]+>/g, ''); }, lbounds: function(_) { // leaflet-compatible bounds, since leaflet does not do geojson return new L.LatLngBounds([[_[1], _[0]], [_[3], _[2]]]); } }; },{}]},{},[6]) //# 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"]}