@loaders.gl/images 3.4.14 → 3.4.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/es5/bundle.js +1 -1
- package/dist/es5/bundle.js.map +1 -1
- package/dist/es5/image-loader.js +6 -8
- package/dist/es5/image-loader.js.map +1 -1
- package/dist/es5/image-writer.js +1 -1
- package/dist/es5/image-writer.js.map +1 -1
- package/dist/es5/index.js +12 -12
- package/dist/es5/lib/category-api/binary-image-api.js +24 -23
- package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
- package/dist/es5/lib/category-api/image-format.js +35 -142
- package/dist/es5/lib/category-api/image-format.js.map +1 -1
- package/dist/es5/lib/category-api/image-type.js +7 -5
- package/dist/es5/lib/category-api/image-type.js.map +1 -1
- package/dist/es5/lib/category-api/parse-isobmff-binary.js +6 -10
- package/dist/es5/lib/category-api/parse-isobmff-binary.js.map +1 -1
- package/dist/es5/lib/category-api/parsed-image-api.js +4 -6
- package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
- package/dist/es5/lib/encoders/encode-image.js +45 -78
- package/dist/es5/lib/encoders/encode-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-image.js +26 -52
- package/dist/es5/lib/parsers/parse-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js +27 -81
- package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-image.js +26 -75
- package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
- package/dist/es5/lib/parsers/parse-to-node-image.js +7 -26
- package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
- package/dist/es5/lib/parsers/svg-utils.js +5 -5
- package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
- package/dist/es5/lib/texture-api/async-deep-map.js +32 -147
- package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
- package/dist/es5/lib/texture-api/deep-load.js +6 -52
- package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
- package/dist/es5/lib/texture-api/generate-url.js +8 -7
- package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
- package/dist/es5/lib/texture-api/load-image.js +39 -112
- package/dist/es5/lib/texture-api/load-image.js.map +1 -1
- package/dist/es5/lib/utils/version.js +1 -1
- package/dist/es5/lib/utils/version.js.map +1 -1
- package/dist/esm/lib/utils/version.js +1 -1
- package/package.json +3 -3
|
@@ -1,86 +1,37 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.loadToImage = loadToImage;
|
|
8
7
|
exports.parseToImage = parseToImage;
|
|
9
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
11
8
|
var _svgUtils = require("./svg-utils");
|
|
12
|
-
function parseToImage(
|
|
13
|
-
|
|
9
|
+
async function parseToImage(arrayBuffer, options, url) {
|
|
10
|
+
const blobOrDataUrl = (0, _svgUtils.getBlobOrSVGDataUrl)(arrayBuffer, url);
|
|
11
|
+
const URL = self.URL || self.webkitURL;
|
|
12
|
+
const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);
|
|
13
|
+
try {
|
|
14
|
+
return await loadToImage(objectUrl || blobOrDataUrl, options);
|
|
15
|
+
} finally {
|
|
16
|
+
if (objectUrl) {
|
|
17
|
+
URL.revokeObjectURL(objectUrl);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
14
20
|
}
|
|
15
|
-
function
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
_context.prev = 7;
|
|
31
|
-
if (objectUrl) {
|
|
32
|
-
URL.revokeObjectURL(objectUrl);
|
|
33
|
-
}
|
|
34
|
-
return _context.finish(7);
|
|
35
|
-
case 10:
|
|
36
|
-
case "end":
|
|
37
|
-
return _context.stop();
|
|
38
|
-
}
|
|
39
|
-
}, _callee, null, [[3,, 7, 10]]);
|
|
40
|
-
}));
|
|
41
|
-
return _parseToImage.apply(this, arguments);
|
|
42
|
-
}
|
|
43
|
-
function loadToImage(_x4, _x5) {
|
|
44
|
-
return _loadToImage.apply(this, arguments);
|
|
45
|
-
}
|
|
46
|
-
function _loadToImage() {
|
|
47
|
-
_loadToImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(url, options) {
|
|
48
|
-
var image;
|
|
49
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
50
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
51
|
-
case 0:
|
|
52
|
-
image = new Image();
|
|
53
|
-
image.src = url;
|
|
54
|
-
if (!(options.image && options.image.decode && image.decode)) {
|
|
55
|
-
_context2.next = 6;
|
|
56
|
-
break;
|
|
57
|
-
}
|
|
58
|
-
_context2.next = 5;
|
|
59
|
-
return image.decode();
|
|
60
|
-
case 5:
|
|
61
|
-
return _context2.abrupt("return", image);
|
|
62
|
-
case 6:
|
|
63
|
-
_context2.next = 8;
|
|
64
|
-
return new Promise(function (resolve, reject) {
|
|
65
|
-
try {
|
|
66
|
-
image.onload = function () {
|
|
67
|
-
return resolve(image);
|
|
68
|
-
};
|
|
69
|
-
image.onerror = function (err) {
|
|
70
|
-
return reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
|
|
71
|
-
};
|
|
72
|
-
} catch (error) {
|
|
73
|
-
reject(error);
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
case 8:
|
|
77
|
-
return _context2.abrupt("return", _context2.sent);
|
|
78
|
-
case 9:
|
|
79
|
-
case "end":
|
|
80
|
-
return _context2.stop();
|
|
81
|
-
}
|
|
82
|
-
}, _callee2);
|
|
83
|
-
}));
|
|
84
|
-
return _loadToImage.apply(this, arguments);
|
|
21
|
+
async function loadToImage(url, options) {
|
|
22
|
+
const image = new Image();
|
|
23
|
+
image.src = url;
|
|
24
|
+
if (options.image && options.image.decode && image.decode) {
|
|
25
|
+
await image.decode();
|
|
26
|
+
return image;
|
|
27
|
+
}
|
|
28
|
+
return await new Promise((resolve, reject) => {
|
|
29
|
+
try {
|
|
30
|
+
image.onload = () => resolve(image);
|
|
31
|
+
image.onerror = err => reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
|
|
32
|
+
} catch (error) {
|
|
33
|
+
reject(error);
|
|
34
|
+
}
|
|
35
|
+
});
|
|
85
36
|
}
|
|
86
37
|
//# sourceMappingURL=parse-to-image.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-to-image.js","names":["_svgUtils","require","parseToImage","
|
|
1
|
+
{"version":3,"file":"parse-to-image.js","names":["_svgUtils","require","parseToImage","arrayBuffer","options","url","blobOrDataUrl","getBlobOrSVGDataUrl","URL","self","webkitURL","objectUrl","createObjectURL","loadToImage","revokeObjectURL","image","Image","src","decode","Promise","resolve","reject","onload","onerror","err","Error","concat","error"],"sources":["../../../../src/lib/parsers/parse-to-image.ts"],"sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport async function parseToImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<HTMLImageElement> {\n // Note: image parsing requires conversion to Blob (for createObjectURL).\n // Potentially inefficient for not using `response.blob()` (and for File / Blob inputs)...\n // But presumably not worth adding 'blob' flag to loader objects?\n\n const blobOrDataUrl = getBlobOrSVGDataUrl(arrayBuffer, url);\n const URL = self.URL || self.webkitURL;\n const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);\n try {\n return await loadToImage(objectUrl || blobOrDataUrl, options);\n } finally {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n }\n}\n\nexport async function loadToImage(url, options): Promise<HTMLImageElement> {\n const image = new Image();\n image.src = url;\n\n // The `image.onload()` callback does not guarantee that the image has been decoded\n // so a main thread \"freeze\" can be incurred when using the image for the first time.\n // `Image.decode()` returns a promise that completes when image is decoded.\n\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/decode\n // Note: When calling `img.decode()`, we do not need to wait for `img.onload()`\n // Note: `HTMLImageElement.decode()` is not available in Edge and IE11\n if (options.image && options.image.decode && image.decode) {\n await image.decode();\n return image;\n }\n\n // Create a promise that tracks onload/onerror callbacks\n return await new Promise((resolve, reject) => {\n try {\n image.onload = () => resolve(image);\n image.onerror = (err) => reject(new Error(`Could not load image ${url}: ${err}`));\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"mappings":";;;;;;;AACA,IAAAA,SAAA,GAAAC,OAAA;AAGO,eAAeC,YAAYA,CAChCC,WAAwB,EACxBC,OAA2B,EAC3BC,GAAY,EACe;EAK3B,MAAMC,aAAa,GAAG,IAAAC,6BAAmB,EAACJ,WAAW,EAAEE,GAAG,CAAC;EAC3D,MAAMG,GAAG,GAAGC,IAAI,CAACD,GAAG,IAAIC,IAAI,CAACC,SAAS;EACtC,MAAMC,SAAS,GAAG,OAAOL,aAAa,KAAK,QAAQ,IAAIE,GAAG,CAACI,eAAe,CAACN,aAAa,CAAC;EACzF,IAAI;IACF,OAAO,MAAMO,WAAW,CAACF,SAAS,IAAIL,aAAa,EAAEF,OAAO,CAAC;EAC/D,CAAC,SAAS;IACR,IAAIO,SAAS,EAAE;MACbH,GAAG,CAACM,eAAe,CAACH,SAAS,CAAC;IAChC;EACF;AACF;AAEO,eAAeE,WAAWA,CAACR,GAAG,EAAED,OAAO,EAA6B;EACzE,MAAMW,KAAK,GAAG,IAAIC,KAAK,CAAC,CAAC;EACzBD,KAAK,CAACE,GAAG,GAAGZ,GAAG;EASf,IAAID,OAAO,CAACW,KAAK,IAAIX,OAAO,CAACW,KAAK,CAACG,MAAM,IAAIH,KAAK,CAACG,MAAM,EAAE;IACzD,MAAMH,KAAK,CAACG,MAAM,CAAC,CAAC;IACpB,OAAOH,KAAK;EACd;EAGA,OAAO,MAAM,IAAII,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;IAC5C,IAAI;MACFN,KAAK,CAACO,MAAM,GAAG,MAAMF,OAAO,CAACL,KAAK,CAAC;MACnCA,KAAK,CAACQ,OAAO,GAAIC,GAAG,IAAKH,MAAM,CAAC,IAAII,KAAK,yBAAAC,MAAA,CAAyBrB,GAAG,QAAAqB,MAAA,CAAKF,GAAG,CAAE,CAAC,CAAC;IACnF,CAAC,CAAC,OAAOG,KAAK,EAAE;MACdN,MAAM,CAACM,KAAK,CAAC;IACf;EACF,CAAC,CAAC;AACJ"}
|
|
@@ -1,36 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.parseToNodeImage = parseToNodeImage;
|
|
8
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
7
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
11
8
|
var _binaryImageApi = require("../category-api/binary-image-api");
|
|
12
|
-
function parseToNodeImage(
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
while (1) switch (_context.prev = _context.next) {
|
|
20
|
-
case 0:
|
|
21
|
-
_ref = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {}, mimeType = _ref.mimeType;
|
|
22
|
-
_parseImageNode = globalThis._parseImageNode;
|
|
23
|
-
(0, _loaderUtils.assert)(_parseImageNode);
|
|
24
|
-
_context.next = 5;
|
|
25
|
-
return _parseImageNode(arrayBuffer, mimeType);
|
|
26
|
-
case 5:
|
|
27
|
-
return _context.abrupt("return", _context.sent);
|
|
28
|
-
case 6:
|
|
29
|
-
case "end":
|
|
30
|
-
return _context.stop();
|
|
31
|
-
}
|
|
32
|
-
}, _callee);
|
|
33
|
-
}));
|
|
34
|
-
return _parseToNodeImage.apply(this, arguments);
|
|
9
|
+
async function parseToNodeImage(arrayBuffer, options) {
|
|
10
|
+
const {
|
|
11
|
+
mimeType
|
|
12
|
+
} = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {};
|
|
13
|
+
const _parseImageNode = globalThis._parseImageNode;
|
|
14
|
+
(0, _loaderUtils.assert)(_parseImageNode);
|
|
15
|
+
return await _parseImageNode(arrayBuffer, mimeType);
|
|
35
16
|
}
|
|
36
17
|
//# sourceMappingURL=parse-to-node-image.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-to-node-image.js","names":["_loaderUtils","require","_binaryImageApi","parseToNodeImage","
|
|
1
|
+
{"version":3,"file":"parse-to-node-image.js","names":["_loaderUtils","require","_binaryImageApi","parseToNodeImage","arrayBuffer","options","mimeType","getBinaryImageMetadata","_parseImageNode","globalThis","assert"],"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport type {ImageDataType} from '../../types';\nimport {assert} from '@loaders.gl/loader-utils';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Note: These types should be consistent with loaders.gl/polyfills\n\ntype NDArray = {\n shape: number[];\n data: Uint8Array;\n width: number;\n height: number;\n components: number;\n layers: number[];\n};\n\ntype ParseImageNode = (arrayBuffer: ArrayBuffer, mimeType: string) => Promise<NDArray>;\n\n// Use polyfills if installed to parsed image using get-pixels\nexport async function parseToNodeImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions\n): Promise<ImageDataType> {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const _parseImageNode: ParseImageNode = globalThis._parseImageNode;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n // @ts-expect-error TODO should we throw error in this case?\n return await _parseImageNode(arrayBuffer, mimeType);\n}\n"],"mappings":";;;;;;AAEA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,eAAA,GAAAD,OAAA;AAgBO,eAAeE,gBAAgBA,CACpCC,WAAwB,EACxBC,OAA2B,EACH;EACxB,MAAM;IAACC;EAAQ,CAAC,GAAG,IAAAC,sCAAsB,EAACH,WAAW,CAAC,IAAI,CAAC,CAAC;EAG5D,MAAMI,eAA+B,GAAGC,UAAU,CAACD,eAAe;EAClE,IAAAE,mBAAM,EAACF,eAAe,CAAC;EAGvB,OAAO,MAAMA,eAAe,CAACJ,WAAW,EAAEE,QAAQ,CAAC;AACrD"}
|
|
@@ -6,15 +6,15 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.getBlob = getBlob;
|
|
7
7
|
exports.getBlobOrSVGDataUrl = getBlobOrSVGDataUrl;
|
|
8
8
|
exports.isSVG = isSVG;
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
const SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
|
|
10
|
+
const SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
|
|
11
11
|
function isSVG(url) {
|
|
12
12
|
return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));
|
|
13
13
|
}
|
|
14
14
|
function getBlobOrSVGDataUrl(arrayBuffer, url) {
|
|
15
15
|
if (isSVG(url)) {
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
const textDecoder = new TextDecoder();
|
|
17
|
+
let xmlText = textDecoder.decode(arrayBuffer);
|
|
18
18
|
try {
|
|
19
19
|
if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {
|
|
20
20
|
xmlText = unescape(encodeURIComponent(xmlText));
|
|
@@ -22,7 +22,7 @@ function getBlobOrSVGDataUrl(arrayBuffer, url) {
|
|
|
22
22
|
} catch (error) {
|
|
23
23
|
throw new Error(error.message);
|
|
24
24
|
}
|
|
25
|
-
|
|
25
|
+
const src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
|
|
26
26
|
return src;
|
|
27
27
|
}
|
|
28
28
|
return getBlob(arrayBuffer, url);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"svg-utils.js","names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","concat","btoa","getBlob","Blob","Uint8Array"],"sources":["../../../../src/lib/parsers/svg-utils.ts"],"sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer: ArrayBuffer, url?: string): Blob | string {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer: ArrayBuffer, url?: string): Blob {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"mappings":";;;;;;;;AAGA,
|
|
1
|
+
{"version":3,"file":"svg-utils.js","names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","concat","btoa","getBlob","Blob","Uint8Array"],"sources":["../../../../src/lib/parsers/svg-utils.ts"],"sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer: ArrayBuffer, url?: string): Blob | string {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer: ArrayBuffer, url?: string): Blob {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"mappings":";;;;;;;;AAGA,MAAMA,oBAAoB,GAAG,uBAAuB;AACpD,MAAMC,eAAe,GAAG,mBAAmB;AAEpC,SAASC,KAAKA,CAACC,GAAG,EAAE;EACzB,OAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAAI,CAACD,GAAG,CAAC,IAAIF,eAAe,CAACG,IAAI,CAACD,GAAG,CAAC,CAAC;AAC7E;AAEO,SAASE,mBAAmBA,CAACC,WAAwB,EAAEH,GAAY,EAAiB;EACzF,IAAID,KAAK,CAACC,GAAG,CAAC,EAAE;IAEd,MAAMI,WAAW,GAAG,IAAIC,WAAW,CAAC,CAAC;IACrC,IAAIC,OAAO,GAAGF,WAAW,CAACG,MAAM,CAACJ,WAAW,CAAC;IAE7C,IAAI;MACF,IAAI,OAAOK,QAAQ,KAAK,UAAU,IAAI,OAAOC,kBAAkB,KAAK,UAAU,EAAE;QAC9EH,OAAO,GAAGE,QAAQ,CAACC,kBAAkB,CAACH,OAAO,CAAC,CAAC;MACjD;IACF,CAAC,CAAC,OAAOI,KAAK,EAAE;MACd,MAAM,IAAIC,KAAK,CAAED,KAAK,CAAWE,OAAO,CAAC;IAC3C;IAEA,MAAMC,GAAG,gCAAAC,MAAA,CAAgCC,IAAI,CAACT,OAAO,CAAC,CAAE;IACxD,OAAOO,GAAG;EACZ;EACA,OAAOG,OAAO,CAACb,WAAW,EAAEH,GAAG,CAAC;AAClC;AAEO,SAASgB,OAAOA,CAACb,WAAwB,EAAEH,GAAY,EAAQ;EACpE,IAAID,KAAK,CAACC,GAAG,CAAC,EAAE;IAGd,MAAM,IAAIW,KAAK,CAAC,8CAA8C,CAAC;EACjE;EAEA,OAAO,IAAIM,IAAI,CAAC,CAAC,IAAIC,UAAU,CAACf,WAAW,CAAC,CAAC,CAAC;AAChD"}
|
|
@@ -1,156 +1,41 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.asyncDeepMap = asyncDeepMap;
|
|
8
7
|
exports.mapSubtree = mapSubtree;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
function _mapSubtree() {
|
|
42
|
-
_mapSubtree = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(object, func, options) {
|
|
43
|
-
var url;
|
|
44
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
45
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
46
|
-
case 0:
|
|
47
|
-
if (!Array.isArray(object)) {
|
|
48
|
-
_context2.next = 4;
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
_context2.next = 3;
|
|
52
|
-
return mapArray(object, func, options);
|
|
53
|
-
case 3:
|
|
54
|
-
return _context2.abrupt("return", _context2.sent);
|
|
55
|
-
case 4:
|
|
56
|
-
if (!isObject(object)) {
|
|
57
|
-
_context2.next = 8;
|
|
58
|
-
break;
|
|
59
|
-
}
|
|
60
|
-
_context2.next = 7;
|
|
61
|
-
return mapObject(object, func, options);
|
|
62
|
-
case 7:
|
|
63
|
-
return _context2.abrupt("return", _context2.sent);
|
|
64
|
-
case 8:
|
|
65
|
-
url = object;
|
|
66
|
-
_context2.next = 11;
|
|
67
|
-
return func(url, options);
|
|
68
|
-
case 11:
|
|
69
|
-
return _context2.abrupt("return", _context2.sent);
|
|
70
|
-
case 12:
|
|
71
|
-
case "end":
|
|
72
|
-
return _context2.stop();
|
|
73
|
-
}
|
|
74
|
-
}, _callee2);
|
|
75
|
-
}));
|
|
76
|
-
return _mapSubtree.apply(this, arguments);
|
|
77
|
-
}
|
|
78
|
-
function mapObject(_x6, _x7, _x8) {
|
|
79
|
-
return _mapObject.apply(this, arguments);
|
|
80
|
-
}
|
|
81
|
-
function _mapObject() {
|
|
82
|
-
_mapObject = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(object, func, options) {
|
|
83
|
-
var promises, values, _loop, key;
|
|
84
|
-
return _regenerator.default.wrap(function _callee3$(_context4) {
|
|
85
|
-
while (1) switch (_context4.prev = _context4.next) {
|
|
86
|
-
case 0:
|
|
87
|
-
promises = [];
|
|
88
|
-
values = {};
|
|
89
|
-
_loop = _regenerator.default.mark(function _loop(key) {
|
|
90
|
-
var url, promise;
|
|
91
|
-
return _regenerator.default.wrap(function _loop$(_context3) {
|
|
92
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
93
|
-
case 0:
|
|
94
|
-
url = object[key];
|
|
95
|
-
promise = mapSubtree(url, func, options).then(function (value) {
|
|
96
|
-
values[key] = value;
|
|
97
|
-
});
|
|
98
|
-
promises.push(promise);
|
|
99
|
-
case 3:
|
|
100
|
-
case "end":
|
|
101
|
-
return _context3.stop();
|
|
102
|
-
}
|
|
103
|
-
}, _loop);
|
|
104
|
-
});
|
|
105
|
-
_context4.t0 = _regenerator.default.keys(object);
|
|
106
|
-
case 4:
|
|
107
|
-
if ((_context4.t1 = _context4.t0()).done) {
|
|
108
|
-
_context4.next = 9;
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
key = _context4.t1.value;
|
|
112
|
-
return _context4.delegateYield(_loop(key), "t2", 7);
|
|
113
|
-
case 7:
|
|
114
|
-
_context4.next = 4;
|
|
115
|
-
break;
|
|
116
|
-
case 9:
|
|
117
|
-
_context4.next = 11;
|
|
118
|
-
return Promise.all(promises);
|
|
119
|
-
case 11:
|
|
120
|
-
return _context4.abrupt("return", values);
|
|
121
|
-
case 12:
|
|
122
|
-
case "end":
|
|
123
|
-
return _context4.stop();
|
|
124
|
-
}
|
|
125
|
-
}, _callee3);
|
|
126
|
-
}));
|
|
127
|
-
return _mapObject.apply(this, arguments);
|
|
128
|
-
}
|
|
129
|
-
function mapArray(_x9, _x10) {
|
|
130
|
-
return _mapArray.apply(this, arguments);
|
|
131
|
-
}
|
|
132
|
-
function _mapArray() {
|
|
133
|
-
_mapArray = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(urlArray, func) {
|
|
134
|
-
var options,
|
|
135
|
-
promises,
|
|
136
|
-
_args5 = arguments;
|
|
137
|
-
return _regenerator.default.wrap(function _callee4$(_context5) {
|
|
138
|
-
while (1) switch (_context5.prev = _context5.next) {
|
|
139
|
-
case 0:
|
|
140
|
-
options = _args5.length > 2 && _args5[2] !== undefined ? _args5[2] : {};
|
|
141
|
-
promises = urlArray.map(function (url) {
|
|
142
|
-
return mapSubtree(url, func, options);
|
|
143
|
-
});
|
|
144
|
-
_context5.next = 4;
|
|
145
|
-
return Promise.all(promises);
|
|
146
|
-
case 4:
|
|
147
|
-
return _context5.abrupt("return", _context5.sent);
|
|
148
|
-
case 5:
|
|
149
|
-
case "end":
|
|
150
|
-
return _context5.stop();
|
|
151
|
-
}
|
|
152
|
-
}, _callee4);
|
|
153
|
-
}));
|
|
154
|
-
return _mapArray.apply(this, arguments);
|
|
8
|
+
const isObject = value => value && typeof value === 'object';
|
|
9
|
+
async function asyncDeepMap(tree, func) {
|
|
10
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
11
|
+
return await mapSubtree(tree, func, options);
|
|
12
|
+
}
|
|
13
|
+
async function mapSubtree(object, func, options) {
|
|
14
|
+
if (Array.isArray(object)) {
|
|
15
|
+
return await mapArray(object, func, options);
|
|
16
|
+
}
|
|
17
|
+
if (isObject(object)) {
|
|
18
|
+
return await mapObject(object, func, options);
|
|
19
|
+
}
|
|
20
|
+
const url = object;
|
|
21
|
+
return await func(url, options);
|
|
22
|
+
}
|
|
23
|
+
async function mapObject(object, func, options) {
|
|
24
|
+
const promises = [];
|
|
25
|
+
const values = {};
|
|
26
|
+
for (const key in object) {
|
|
27
|
+
const url = object[key];
|
|
28
|
+
const promise = mapSubtree(url, func, options).then(value => {
|
|
29
|
+
values[key] = value;
|
|
30
|
+
});
|
|
31
|
+
promises.push(promise);
|
|
32
|
+
}
|
|
33
|
+
await Promise.all(promises);
|
|
34
|
+
return values;
|
|
35
|
+
}
|
|
36
|
+
async function mapArray(urlArray, func) {
|
|
37
|
+
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
38
|
+
const promises = urlArray.map(url => mapSubtree(url, func, options));
|
|
39
|
+
return await Promise.all(promises);
|
|
155
40
|
}
|
|
156
41
|
//# sourceMappingURL=async-deep-map.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"async-deep-map.js","names":["isObject","value","
|
|
1
|
+
{"version":3,"file":"async-deep-map.js","names":["isObject","value","asyncDeepMap","tree","func","options","arguments","length","undefined","mapSubtree","object","Array","isArray","mapArray","mapObject","url","promises","values","key","promise","then","push","Promise","all","urlArray","map"],"sources":["../../../../src/lib/texture-api/async-deep-map.ts"],"sourcesContent":["/*\nAsynchronously maps a deep structure of values (e.g. objects and arrays of urls).\n\nE.g. a mipmapped cubemap\n{\n [CUBE_FACE_FRONT]: [\n \"image-front-0.jpg\",\n \"image-front-1.jpg\",\n \"image-front-2.jpg\",\n ],\n [CUBE_MAP_BACK]: [\n ...\n ]\n}\n*/\n\nconst isObject = (value) => value && typeof value === 'object';\n\n// Loads a deep structure of urls (objects and arrays of urls)\n// Returns an object with six key-value pairs containing the images (or image mip arrays)\n// for each cube face\nexport async function asyncDeepMap(tree, func, options = {}) {\n return await mapSubtree(tree, func, options);\n}\n\nexport async function mapSubtree(object, func, options) {\n if (Array.isArray(object)) {\n return await mapArray(object, func, options);\n }\n\n if (isObject(object)) {\n return await mapObject(object, func, options);\n }\n\n // TODO - ignore non-urls, non-arraybuffers?\n const url = object;\n return await func(url, options);\n}\n\n// HELPERS\n\nasync function mapObject(object, func, options) {\n const promises: Promise<any>[] = [];\n const values = {};\n\n for (const key in object) {\n const url = object[key];\n const promise = mapSubtree(url, func, options).then((value) => {\n values[key] = value;\n });\n promises.push(promise);\n }\n\n await Promise.all(promises);\n\n return values;\n}\n\nasync function mapArray(urlArray, func, options = {}) {\n const promises = urlArray.map((url) => mapSubtree(url, func, options));\n return await Promise.all(promises);\n}\n"],"mappings":";;;;;;;AAgBA,MAAMA,QAAQ,GAAIC,KAAK,IAAKA,KAAK,IAAI,OAAOA,KAAK,KAAK,QAAQ;AAKvD,eAAeC,YAAYA,CAACC,IAAI,EAAEC,IAAI,EAAgB;EAAA,IAAdC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EACzD,OAAO,MAAMG,UAAU,CAACN,IAAI,EAAEC,IAAI,EAAEC,OAAO,CAAC;AAC9C;AAEO,eAAeI,UAAUA,CAACC,MAAM,EAAEN,IAAI,EAAEC,OAAO,EAAE;EACtD,IAAIM,KAAK,CAACC,OAAO,CAACF,MAAM,CAAC,EAAE;IACzB,OAAO,MAAMG,QAAQ,CAACH,MAAM,EAAEN,IAAI,EAAEC,OAAO,CAAC;EAC9C;EAEA,IAAIL,QAAQ,CAACU,MAAM,CAAC,EAAE;IACpB,OAAO,MAAMI,SAAS,CAACJ,MAAM,EAAEN,IAAI,EAAEC,OAAO,CAAC;EAC/C;EAGA,MAAMU,GAAG,GAAGL,MAAM;EAClB,OAAO,MAAMN,IAAI,CAACW,GAAG,EAAEV,OAAO,CAAC;AACjC;AAIA,eAAeS,SAASA,CAACJ,MAAM,EAAEN,IAAI,EAAEC,OAAO,EAAE;EAC9C,MAAMW,QAAwB,GAAG,EAAE;EACnC,MAAMC,MAAM,GAAG,CAAC,CAAC;EAEjB,KAAK,MAAMC,GAAG,IAAIR,MAAM,EAAE;IACxB,MAAMK,GAAG,GAAGL,MAAM,CAACQ,GAAG,CAAC;IACvB,MAAMC,OAAO,GAAGV,UAAU,CAACM,GAAG,EAAEX,IAAI,EAAEC,OAAO,CAAC,CAACe,IAAI,CAAEnB,KAAK,IAAK;MAC7DgB,MAAM,CAACC,GAAG,CAAC,GAAGjB,KAAK;IACrB,CAAC,CAAC;IACFe,QAAQ,CAACK,IAAI,CAACF,OAAO,CAAC;EACxB;EAEA,MAAMG,OAAO,CAACC,GAAG,CAACP,QAAQ,CAAC;EAE3B,OAAOC,MAAM;AACf;AAEA,eAAeJ,QAAQA,CAACW,QAAQ,EAAEpB,IAAI,EAAgB;EAAA,IAAdC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;EAClD,MAAMU,QAAQ,GAAGQ,QAAQ,CAACC,GAAG,CAAEV,GAAG,IAAKN,UAAU,CAACM,GAAG,EAAEX,IAAI,EAAEC,OAAO,CAAC,CAAC;EACtE,OAAO,MAAMiB,OAAO,CAACC,GAAG,CAACP,QAAQ,CAAC;AACpC"}
|
|
@@ -1,63 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.deepLoad = deepLoad;
|
|
8
7
|
exports.shallowLoad = shallowLoad;
|
|
9
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
11
8
|
var _asyncDeepMap = require("./async-deep-map");
|
|
12
|
-
function deepLoad(
|
|
13
|
-
return
|
|
9
|
+
async function deepLoad(urlTree, load, options) {
|
|
10
|
+
return await (0, _asyncDeepMap.asyncDeepMap)(urlTree, url => shallowLoad(url, load, options));
|
|
14
11
|
}
|
|
15
|
-
function
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
case 0:
|
|
20
|
-
_context.next = 2;
|
|
21
|
-
return (0, _asyncDeepMap.asyncDeepMap)(urlTree, function (url) {
|
|
22
|
-
return shallowLoad(url, load, options);
|
|
23
|
-
});
|
|
24
|
-
case 2:
|
|
25
|
-
return _context.abrupt("return", _context.sent);
|
|
26
|
-
case 3:
|
|
27
|
-
case "end":
|
|
28
|
-
return _context.stop();
|
|
29
|
-
}
|
|
30
|
-
}, _callee);
|
|
31
|
-
}));
|
|
32
|
-
return _deepLoad.apply(this, arguments);
|
|
33
|
-
}
|
|
34
|
-
function shallowLoad(_x4, _x5, _x6) {
|
|
35
|
-
return _shallowLoad.apply(this, arguments);
|
|
36
|
-
}
|
|
37
|
-
function _shallowLoad() {
|
|
38
|
-
_shallowLoad = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(url, load, options) {
|
|
39
|
-
var response, arrayBuffer;
|
|
40
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
41
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
42
|
-
case 0:
|
|
43
|
-
_context2.next = 2;
|
|
44
|
-
return fetch(url, options.fetch);
|
|
45
|
-
case 2:
|
|
46
|
-
response = _context2.sent;
|
|
47
|
-
_context2.next = 5;
|
|
48
|
-
return response.arrayBuffer();
|
|
49
|
-
case 5:
|
|
50
|
-
arrayBuffer = _context2.sent;
|
|
51
|
-
_context2.next = 8;
|
|
52
|
-
return load(arrayBuffer, options);
|
|
53
|
-
case 8:
|
|
54
|
-
return _context2.abrupt("return", _context2.sent);
|
|
55
|
-
case 9:
|
|
56
|
-
case "end":
|
|
57
|
-
return _context2.stop();
|
|
58
|
-
}
|
|
59
|
-
}, _callee2);
|
|
60
|
-
}));
|
|
61
|
-
return _shallowLoad.apply(this, arguments);
|
|
12
|
+
async function shallowLoad(url, load, options) {
|
|
13
|
+
const response = await fetch(url, options.fetch);
|
|
14
|
+
const arrayBuffer = await response.arrayBuffer();
|
|
15
|
+
return await load(arrayBuffer, options);
|
|
62
16
|
}
|
|
63
17
|
//# sourceMappingURL=deep-load.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deep-load.js","names":["_asyncDeepMap","require","deepLoad","
|
|
1
|
+
{"version":3,"file":"deep-load.js","names":["_asyncDeepMap","require","deepLoad","urlTree","load","options","asyncDeepMap","url","shallowLoad","response","fetch","arrayBuffer"],"sources":["../../../../src/lib/texture-api/deep-load.ts"],"sourcesContent":["import {asyncDeepMap} from './async-deep-map';\n\nexport async function deepLoad(urlTree, load, options) {\n return await asyncDeepMap(urlTree, (url) => shallowLoad(url, load, options));\n}\n\nexport async function shallowLoad(url, load, options) {\n // console.error('loading', url);\n const response = await fetch(url, options.fetch);\n const arrayBuffer = await response.arrayBuffer();\n return await load(arrayBuffer, options);\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,aAAA,GAAAC,OAAA;AAEO,eAAeC,QAAQA,CAACC,OAAO,EAAEC,IAAI,EAAEC,OAAO,EAAE;EACrD,OAAO,MAAM,IAAAC,0BAAY,EAACH,OAAO,EAAGI,GAAG,IAAKC,WAAW,CAACD,GAAG,EAAEH,IAAI,EAAEC,OAAO,CAAC,CAAC;AAC9E;AAEO,eAAeG,WAAWA,CAACD,GAAG,EAAEH,IAAI,EAAEC,OAAO,EAAE;EAEpD,MAAMI,QAAQ,GAAG,MAAMC,KAAK,CAACH,GAAG,EAAEF,OAAO,CAACK,KAAK,CAAC;EAChD,MAAMC,WAAW,GAAG,MAAMF,QAAQ,CAACE,WAAW,CAAC,CAAC;EAChD,OAAO,MAAMP,IAAI,CAACO,WAAW,EAAEN,OAAO,CAAC;AACzC"}
|
|
@@ -1,21 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
6
|
exports.generateUrl = generateUrl;
|
|
8
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
7
|
var _loaderUtils = require("@loaders.gl/loader-utils");
|
|
10
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
11
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
12
8
|
function generateUrl(getUrl, options, urlOptions) {
|
|
13
|
-
|
|
9
|
+
let url = getUrl;
|
|
14
10
|
if (typeof getUrl === 'function') {
|
|
15
|
-
url = getUrl(
|
|
11
|
+
url = getUrl({
|
|
12
|
+
...options,
|
|
13
|
+
...urlOptions
|
|
14
|
+
});
|
|
16
15
|
}
|
|
17
16
|
(0, _loaderUtils.assert)(typeof url === 'string');
|
|
18
|
-
|
|
17
|
+
const {
|
|
18
|
+
baseUrl
|
|
19
|
+
} = options;
|
|
19
20
|
if (baseUrl) {
|
|
20
21
|
url = baseUrl[baseUrl.length - 1] === '/' ? "".concat(baseUrl).concat(url) : "".concat(baseUrl, "/").concat(url);
|
|
21
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generate-url.js","names":["_loaderUtils","require","
|
|
1
|
+
{"version":3,"file":"generate-url.js","names":["_loaderUtils","require","generateUrl","getUrl","options","urlOptions","url","assert","baseUrl","length","concat","resolvePath"],"sources":["../../../../src/lib/texture-api/generate-url.ts"],"sourcesContent":["import {resolvePath, assert} from '@loaders.gl/loader-utils';\n\n// Generate a url by calling getUrl with mix of options, applying options.baseUrl\nexport function generateUrl(getUrl, options, urlOptions) {\n // Get url\n let url = getUrl;\n if (typeof getUrl === 'function') {\n url = getUrl({...options, ...urlOptions});\n }\n assert(typeof url === 'string');\n\n // Apply options.baseUrl\n const {baseUrl} = options;\n if (baseUrl) {\n url = baseUrl[baseUrl.length - 1] === '/' ? `${baseUrl}${url}` : `${baseUrl}/${url}`;\n }\n\n return resolvePath(url);\n}\n"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAGO,SAASC,WAAWA,CAACC,MAAM,EAAEC,OAAO,EAAEC,UAAU,EAAE;EAEvD,IAAIC,GAAG,GAAGH,MAAM;EAChB,IAAI,OAAOA,MAAM,KAAK,UAAU,EAAE;IAChCG,GAAG,GAAGH,MAAM,CAAC;MAAC,GAAGC,OAAO;MAAE,GAAGC;IAAU,CAAC,CAAC;EAC3C;EACA,IAAAE,mBAAM,EAAC,OAAOD,GAAG,KAAK,QAAQ,CAAC;EAG/B,MAAM;IAACE;EAAO,CAAC,GAAGJ,OAAO;EACzB,IAAII,OAAO,EAAE;IACXF,GAAG,GAAGE,OAAO,CAACA,OAAO,CAACC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,MAAAC,MAAA,CAAMF,OAAO,EAAAE,MAAA,CAAGJ,GAAG,OAAAI,MAAA,CAAQF,OAAO,OAAAE,MAAA,CAAIJ,GAAG,CAAE;EACtF;EAEA,OAAO,IAAAK,wBAAW,EAACL,GAAG,CAAC;AACzB"}
|