@kepler.gl/utils 3.0.0 → 3.1.0-alpha.1

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.
Files changed (73) hide show
  1. package/package.json +14 -10
  2. package/dist/aggregate-utils.d.ts +0 -3
  3. package/dist/aggregate-utils.js +0 -75
  4. package/dist/arrow-data-container.d.ts +0 -54
  5. package/dist/arrow-data-container.js +0 -360
  6. package/dist/color-utils.d.ts +0 -51
  7. package/dist/color-utils.js +0 -161
  8. package/dist/data-container-interface.d.ts +0 -133
  9. package/dist/data-container-interface.js +0 -6
  10. package/dist/data-container-utils.d.ts +0 -30
  11. package/dist/data-container-utils.js +0 -88
  12. package/dist/data-row.d.ts +0 -59
  13. package/dist/data-row.js +0 -126
  14. package/dist/data-scale-utils.d.ts +0 -23
  15. package/dist/data-scale-utils.js +0 -62
  16. package/dist/data-utils.d.ts +0 -103
  17. package/dist/data-utils.js +0 -502
  18. package/dist/dataset-utils.d.ts +0 -116
  19. package/dist/dataset-utils.js +0 -614
  20. package/dist/dom-to-image.d.ts +0 -73
  21. package/dist/dom-to-image.js +0 -489
  22. package/dist/dom-utils.d.ts +0 -23
  23. package/dist/dom-utils.js +0 -434
  24. package/dist/effect-utils.d.ts +0 -23
  25. package/dist/effect-utils.js +0 -196
  26. package/dist/export-map-html.d.ts +0 -9
  27. package/dist/export-map-html.js +0 -28
  28. package/dist/export-utils.d.ts +0 -53
  29. package/dist/export-utils.js +0 -262
  30. package/dist/filter-utils.d.ts +0 -326
  31. package/dist/filter-utils.js +0 -1333
  32. package/dist/format.d.ts +0 -1
  33. package/dist/format.js +0 -17
  34. package/dist/gl-utils.d.ts +0 -1
  35. package/dist/gl-utils.js +0 -35
  36. package/dist/h3-utils.d.ts +0 -21
  37. package/dist/h3-utils.js +0 -81
  38. package/dist/index.d.ts +0 -36
  39. package/dist/index.js +0 -772
  40. package/dist/indexed-data-container.d.ts +0 -34
  41. package/dist/indexed-data-container.js +0 -254
  42. package/dist/locale-utils.d.ts +0 -2
  43. package/dist/locale-utils.js +0 -54
  44. package/dist/map-info-utils.d.ts +0 -1
  45. package/dist/map-info-utils.js +0 -15
  46. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +0 -65
  47. package/dist/map-style-utils/mapbox-gl-style-editor.js +0 -218
  48. package/dist/map-style-utils/mapbox-utils.d.ts +0 -9
  49. package/dist/map-style-utils/mapbox-utils.js +0 -48
  50. package/dist/map-utils.d.ts +0 -9
  51. package/dist/map-utils.js +0 -65
  52. package/dist/mapbox-utils.d.ts +0 -7
  53. package/dist/mapbox-utils.js +0 -22
  54. package/dist/noop.d.ts +0 -1
  55. package/dist/noop.js +0 -11
  56. package/dist/notifications-utils.d.ts +0 -42
  57. package/dist/notifications-utils.js +0 -85
  58. package/dist/observe-dimensions.d.ts +0 -15
  59. package/dist/observe-dimensions.js +0 -151
  60. package/dist/plot.d.ts +0 -6
  61. package/dist/plot.js +0 -31
  62. package/dist/projection-utils.d.ts +0 -21
  63. package/dist/projection-utils.js +0 -100
  64. package/dist/row-data-container.d.ts +0 -31
  65. package/dist/row-data-container.js +0 -252
  66. package/dist/searcher-utils.d.ts +0 -1
  67. package/dist/searcher-utils.js +0 -28
  68. package/dist/split-map-utils.d.ts +0 -32
  69. package/dist/split-map-utils.js +0 -114
  70. package/dist/time.d.ts +0 -16
  71. package/dist/time.js +0 -89
  72. package/dist/utils.d.ts +0 -116
  73. package/dist/utils.js +0 -305
@@ -1,73 +0,0 @@
1
- declare const domtoimage: {
2
- toSvg: typeof toSvg;
3
- toPng: typeof toPng;
4
- toJpeg: typeof toJpeg;
5
- toBlob: typeof toBlob;
6
- toPixelData: typeof toPixelData;
7
- impl: {
8
- fontFaces: {
9
- resolveAll: () => Promise<string>;
10
- impl: {
11
- readAll: () => Promise<any>;
12
- };
13
- };
14
- images: {
15
- inlineAll: (node: any) => any;
16
- impl: {
17
- newImage: (element: any) => {
18
- inline: (get: any) => Promise<unknown>;
19
- };
20
- };
21
- };
22
- inliner: {
23
- inlineAll: (string: any, baseUrl: any, get: any) => Promise<any>;
24
- shouldProcess: (string: any) => boolean;
25
- impl: {
26
- readUrls: (string: any) => string[];
27
- inline: (string: any, url: any, baseUrl: any, get: any) => Promise<any>;
28
- };
29
- };
30
- options: any;
31
- };
32
- };
33
- /**
34
- * @param {Node} node - The DOM Node object to render
35
- * @param {Object} options - Rendering options
36
- * @param {Function} [options.filter] - Should return true if passed node should be included in the output
37
- * (excluding node means excluding it's children as well). Not called on the root node.
38
- * @param {String} [options.bgcolor] - color for the background, any valid CSS color value.
39
- * @param {Number} [options.width] - width to be applied to node before rendering.
40
- * @param {Number} [options.height] - height to be applied to node before rendering.
41
- * @param {Object} [options.style] - an object whose properties to be copied to node's style before rendering.
42
- * @param {Number} [options.quality] - a Number between 0 and 1 indicating image quality (applicable to JPEG only), defaults to 1.0.
43
- * @param {boolean} [options.escapeXhtmlForWebpack] - whether to apply fix for uglify error in dom-to-image (should be true for webpack builds), defaults to true.
44
- * @param {String} [options.imagePlaceholder] - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch
45
- * @param {Boolean} [options.cacheBust] - set to true to cache bust by appending the time to the request url
46
- * @return {Promise} - A promise that is fulfilled with a SVG image data URL
47
- * */
48
- declare function toSvg(node: any, options: any): Promise<string>;
49
- /**
50
- * @param {Node} node - The DOM Node object to render
51
- * @param {Object} options - Rendering options
52
- * @return {Promise} - A promise that is fulfilled with a Uint8Array containing RGBA pixel data.
53
- * */
54
- declare function toPixelData(node: any, options: any): Promise<any>;
55
- /**
56
- * @param {Node} node - The DOM Node object to render
57
- * @param {Object} options - Rendering options
58
- * @return {Promise} - A promise that is fulfilled with a PNG image data URL
59
- * */
60
- declare function toPng(node: any, options: any): Promise<any>;
61
- /**
62
- * @param {Node} node - The DOM Node object to render
63
- * @param {Object} options - Rendering options
64
- * @return {Promise} - A promise that is fulfilled with a JPEG image data URL
65
- * */
66
- declare function toJpeg(node: any, options: any): Promise<any>;
67
- /**
68
- * @param {Node} node - The DOM Node object to render
69
- * @param {Object} options - Rendering options
70
- * @return {Promise} - A promise that is fulfilled with a PNG image blob
71
- * */
72
- declare function toBlob(node: any, options: any): Promise<unknown>;
73
- export default domtoimage;
@@ -1,489 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
-
10
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
11
-
12
- var _window = _interopRequireDefault(require("global/window"));
13
-
14
- var _document = _interopRequireDefault(require("global/document"));
15
-
16
- var _console = _interopRequireDefault(require("global/console"));
17
-
18
- var _miniSvgDataUri = _interopRequireDefault(require("mini-svg-data-uri"));
19
-
20
- var _constants = require("@kepler.gl/constants");
21
-
22
- var _domUtils = require("./dom-utils");
23
-
24
- // SPDX-License-Identifier: MIT
25
- // Copyright contributors to the kepler.gl project
26
-
27
- /**
28
- * This file is copied from https://github.com/tsayen/dom-to-image
29
- * Modified by heshan0131 to allow loading external stylesheets and inline webfonts
30
- */
31
- var inliner = newInliner();
32
- var fontFaces = newFontFaces();
33
- var images = newImages(); // Default impl options
34
-
35
- var defaultOptions = {
36
- // Default is to fail on error, no placeholder
37
- imagePlaceholder: undefined,
38
- // Default cache bust is false, it will use the cache
39
- cacheBust: false
40
- };
41
- var domtoimage = {
42
- toSvg: toSvg,
43
- toPng: toPng,
44
- toJpeg: toJpeg,
45
- toBlob: toBlob,
46
- toPixelData: toPixelData,
47
- impl: {
48
- fontFaces: fontFaces,
49
- images: images,
50
- inliner: inliner,
51
- options: {}
52
- }
53
- };
54
- /**
55
- * @param {Node} node - The DOM Node object to render
56
- * @param {Object} options - Rendering options
57
- * @param {Function} [options.filter] - Should return true if passed node should be included in the output
58
- * (excluding node means excluding it's children as well). Not called on the root node.
59
- * @param {String} [options.bgcolor] - color for the background, any valid CSS color value.
60
- * @param {Number} [options.width] - width to be applied to node before rendering.
61
- * @param {Number} [options.height] - height to be applied to node before rendering.
62
- * @param {Object} [options.style] - an object whose properties to be copied to node's style before rendering.
63
- * @param {Number} [options.quality] - a Number between 0 and 1 indicating image quality (applicable to JPEG only), defaults to 1.0.
64
- * @param {boolean} [options.escapeXhtmlForWebpack] - whether to apply fix for uglify error in dom-to-image (should be true for webpack builds), defaults to true.
65
- * @param {String} [options.imagePlaceholder] - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch
66
- * @param {Boolean} [options.cacheBust] - set to true to cache bust by appending the time to the request url
67
- * @return {Promise} - A promise that is fulfilled with a SVG image data URL
68
- * */
69
-
70
- function toSvg(node, options) {
71
- options = options || {};
72
- copyOptions(options);
73
- return Promise.resolve(node).then(function (nd) {
74
- return cloneNode(nd, options.filter, true);
75
- }).then(embedFonts).then(inlineImages).then(applyOptions).then(function (clone) {
76
- return makeSvgDataUri(clone, options.width || (0, _domUtils.getWidth)(node), options.height || (0, _domUtils.getHeight)(node), options.escapeXhtmlForWebpack);
77
- });
78
-
79
- function applyOptions(clone) {
80
- if (options.bgcolor) clone.style.backgroundColor = options.bgcolor;
81
- if (options.width) clone.style.width = "".concat(options.width, "px");
82
- if (options.height) clone.style.height = "".concat(options.height, "px");
83
- if (options.style) Object.keys(options.style).forEach(function (property) {
84
- clone.style[property] = options.style[property];
85
- });
86
- return clone;
87
- }
88
- }
89
- /**
90
- * @param {Node} node - The DOM Node object to render
91
- * @param {Object} options - Rendering options
92
- * @return {Promise} - A promise that is fulfilled with a Uint8Array containing RGBA pixel data.
93
- * */
94
-
95
-
96
- function toPixelData(node, options) {
97
- return draw(node, options || {}).then(function (canvas) {
98
- return canvas.getContext('2d').getImageData(0, 0, (0, _domUtils.getWidth)(node), (0, _domUtils.getHeight)(node)).data;
99
- });
100
- }
101
- /**
102
- * @param {Node} node - The DOM Node object to render
103
- * @param {Object} options - Rendering options
104
- * @return {Promise} - A promise that is fulfilled with a PNG image data URL
105
- * */
106
-
107
-
108
- function toPng(node, options) {
109
- return draw(node, options || {}).then(function (canvas) {
110
- return canvas.toDataURL();
111
- });
112
- }
113
- /**
114
- * @param {Node} node - The DOM Node object to render
115
- * @param {Object} options - Rendering options
116
- * @return {Promise} - A promise that is fulfilled with a JPEG image data URL
117
- * */
118
-
119
-
120
- function toJpeg(node, options) {
121
- options = options || {};
122
- return draw(node, options).then(function (canvas) {
123
- return canvas.toDataURL('image/jpeg', options.quality || 1.0);
124
- });
125
- }
126
- /**
127
- * @param {Node} node - The DOM Node object to render
128
- * @param {Object} options - Rendering options
129
- * @return {Promise} - A promise that is fulfilled with a PNG image blob
130
- * */
131
-
132
-
133
- function toBlob(node, options) {
134
- return draw(node, options || {}).then(_domUtils.canvasToBlob);
135
- }
136
-
137
- function copyOptions(options) {
138
- // Copy options to impl options for use in impl
139
- if (typeof options.imagePlaceholder === 'undefined') {
140
- domtoimage.impl.options.imagePlaceholder = defaultOptions.imagePlaceholder;
141
- } else {
142
- domtoimage.impl.options.imagePlaceholder = options.imagePlaceholder;
143
- }
144
-
145
- if (typeof options.cacheBust === 'undefined') {
146
- domtoimage.impl.options.cacheBust = defaultOptions.cacheBust;
147
- } else {
148
- domtoimage.impl.options.cacheBust = options.cacheBust;
149
- }
150
- }
151
-
152
- function draw(domNode, options) {
153
- return toSvg(domNode, options).then(_domUtils.makeImage).then((0, _domUtils.delay)(100)).then(function (image) {
154
- var canvas = newCanvas(domNode);
155
- canvas.getContext('2d').drawImage(image, 0, 0);
156
- return canvas;
157
- });
158
-
159
- function newCanvas(dNode) {
160
- var canvas = _document["default"].createElement('canvas');
161
-
162
- canvas.width = options.width || (0, _domUtils.getWidth)(dNode);
163
- canvas.height = options.height || (0, _domUtils.getHeight)(dNode);
164
-
165
- if (options.bgcolor) {
166
- var ctx = canvas.getContext('2d');
167
- ctx.fillStyle = options.bgcolor;
168
- ctx.fillRect(0, 0, canvas.width, canvas.height);
169
- }
170
-
171
- return canvas;
172
- }
173
- }
174
-
175
- function cloneNode(node, filter, root) {
176
- if (!root && filter && !filter(node)) {
177
- return Promise.resolve();
178
- }
179
-
180
- return Promise.resolve(node).then(makeNodeCopy).then(function (clone) {
181
- return cloneChildren(node, clone, filter);
182
- }).then(function (clone) {
183
- return (0, _domUtils.processClone)(node, clone);
184
- });
185
-
186
- function makeNodeCopy(nd) {
187
- if (nd instanceof _window["default"].HTMLCanvasElement) {
188
- return (0, _domUtils.makeImage)(nd.toDataURL());
189
- }
190
-
191
- return nd.cloneNode(false);
192
- }
193
-
194
- function cloneChildrenInOrder(parent, arrChildren, flt) {
195
- var done = Promise.resolve();
196
- arrChildren.forEach(function (child) {
197
- done = done.then(function () {
198
- return cloneNode(child, flt, null);
199
- }).then(function (childClone) {
200
- if (childClone) {
201
- parent.appendChild(childClone);
202
- }
203
- });
204
- });
205
- return done;
206
- }
207
-
208
- function cloneChildren(original, clone, flt) {
209
- var children = original.childNodes;
210
-
211
- if (children.length === 0) {
212
- return Promise.resolve(clone);
213
- }
214
-
215
- return cloneChildrenInOrder(clone, (0, _domUtils.asArray)(children), flt).then(function () {
216
- return clone;
217
- });
218
- }
219
- }
220
-
221
- function embedFonts(node) {
222
- return fontFaces.resolveAll().then(function (cssText) {
223
- var styleNode = _document["default"].createElement('style');
224
-
225
- node.appendChild(styleNode);
226
- styleNode.appendChild(_document["default"].createTextNode(cssText));
227
- return node;
228
- });
229
- }
230
-
231
- function inlineImages(node) {
232
- return images.inlineAll(node).then(function () {
233
- return node;
234
- });
235
- }
236
-
237
- function makeSvgDataUri(node, width, height) {
238
- var escapeXhtmlForWebpack = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
239
- return Promise.resolve(node).then(function (nd) {
240
- nd.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
241
- var serializedString = new _window["default"].XMLSerializer().serializeToString(nd);
242
- var xhtml = escapeXhtmlForWebpack ? (0, _domUtils.escapeXhtml)(serializedString) : serializedString;
243
- var foreignObject = "<foreignObject x=\"0\" y=\"0\" width=\"100%\" height=\"100%\">".concat(xhtml, "</foreignObject>");
244
- var svgStr = "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"".concat(width, "\" height=\"").concat(height, "\">").concat(foreignObject, "</svg>"); // Optimizing SVGs in data URIs
245
- // see https://codepen.io/tigt/post/optimizing-svgs-in-data-uris
246
- // the best way of encoding SVG in a data: URI is data:image/svg+xml,[actual data].
247
- // We don’t need the ;charset=utf-8 parameter because the given SVG is ASCII.
248
-
249
- return (0, _miniSvgDataUri["default"])(svgStr);
250
- });
251
- }
252
-
253
- function newInliner() {
254
- var URL_REGEX = /url\(['"]?([^'"]+?)['"]?\)/g;
255
- return {
256
- inlineAll: inlineAll,
257
- shouldProcess: shouldProcess,
258
- impl: {
259
- readUrls: readUrls,
260
- inline: inline
261
- }
262
- };
263
-
264
- function shouldProcess(string) {
265
- return string.search(URL_REGEX) !== -1;
266
- }
267
-
268
- function readUrls(string) {
269
- var result = [];
270
- var match;
271
-
272
- while ((match = URL_REGEX.exec(string)) !== null) {
273
- result.push(match[1]);
274
- }
275
-
276
- return result.filter(function (url) {
277
- return !(0, _domUtils.isDataUrl)(url);
278
- });
279
- }
280
-
281
- function urlAsRegex(url0) {
282
- return new RegExp("(url\\(['\"]?)(".concat((0, _domUtils.escape)(url0), ")(['\"]?\\))"), 'g');
283
- }
284
-
285
- function inline(string, url, baseUrl, get) {
286
- return Promise.resolve(url).then(function (ul) {
287
- return baseUrl ? (0, _domUtils.resolveUrl)(ul, baseUrl) : ul;
288
- }).then(function (ul) {
289
- return typeof get === 'function' ? get(ul) : (0, _domUtils.getAndEncode)(ul, domtoimage.impl.options);
290
- }).then(function (data) {
291
- return (0, _domUtils.dataAsUrl)(data, (0, _domUtils.mimeType)(url));
292
- }).then(function (dataUrl) {
293
- return string.replace(urlAsRegex(url), "$1".concat(dataUrl, "$3"));
294
- });
295
- }
296
-
297
- function inlineAll(string, baseUrl, get) {
298
- if (!shouldProcess(string) || (0, _domUtils.isSrcAsDataUrl)(string)) {
299
- return Promise.resolve(string);
300
- }
301
-
302
- return Promise.resolve(string).then(readUrls).then(function (urls) {
303
- var done = Promise.resolve(string);
304
- urls.forEach(function (url) {
305
- done = done.then(function (str) {
306
- return inline(str, url, baseUrl, get);
307
- });
308
- });
309
- return done;
310
- });
311
- }
312
- }
313
-
314
- function newFontFaces() {
315
- return {
316
- resolveAll: resolveAll,
317
- impl: {
318
- readAll: readAll
319
- }
320
- };
321
-
322
- function resolveAll() {
323
- return readAll().then(function (webFonts) {
324
- return Promise.all(webFonts.map(function (webFont) {
325
- return webFont.resolve();
326
- }));
327
- }).then(function (cssStrings) {
328
- return cssStrings.join('\n');
329
- });
330
- }
331
-
332
- function readAll() {
333
- return Promise.resolve((0, _domUtils.asArray)(_document["default"].styleSheets)).then(loadExternalStyleSheets).then(getCssRules).then(selectWebFontRules).then(function (rules) {
334
- return rules.map(newWebFont);
335
- });
336
-
337
- function selectWebFontRules(cssRules) {
338
- return cssRules.filter(function (rule) {
339
- return rule.type === _window["default"].CSSRule.FONT_FACE_RULE;
340
- }).filter(function (rule) {
341
- return inliner.shouldProcess(rule.style.getPropertyValue('src'));
342
- });
343
- }
344
-
345
- function loadExternalStyleSheets(styleSheets) {
346
- return Promise.all(styleSheets.map(function (sheet) {
347
- if (sheet.href) {
348
- // cloudfont doesn't have allow origin header properly set
349
- // error response will remain in cache
350
- var cache = sheet.href.includes('uber-fonts') ? 'no-cache' : 'default';
351
- return _window["default"].fetch(sheet.href, {
352
- credentials: 'omit',
353
- cache: cache
354
- }).then(function (response) {
355
- return response.text();
356
- }).then(function (text) {
357
- var result = (0, _domUtils.setStyleSheetBaseHref)(text, sheet.href);
358
- return (0, _domUtils.toStyleSheet)(result);
359
- })["catch"](function (err) {
360
- // Handle any error that occurred in any of the previous
361
- // promises in the chain. stylesheet failed to load should not stop
362
- // the process, hence result in only a warning, instead of reject
363
- _console["default"].warn(_constants.IMAGE_EXPORT_ERRORS.styleSheet, sheet.href);
364
-
365
- _console["default"].log(err);
366
-
367
- return;
368
- });
369
- }
370
-
371
- return Promise.resolve(sheet);
372
- }));
373
- }
374
-
375
- function getCssRules(styleSheets) {
376
- var cssRules = [];
377
- styleSheets.forEach(function (sheet) {
378
- // try...catch because browser may not able to enumerate rules for cross-domain sheets
379
- if (!sheet) {
380
- return;
381
- }
382
-
383
- var rules;
384
-
385
- try {
386
- rules = sheet.rules || sheet.cssRules;
387
- } catch (e) {
388
- _console["default"].log("'Can't read the css rules of: ".concat(sheet.href), e);
389
-
390
- return;
391
- }
392
-
393
- if (rules && (0, _typeof2["default"])(rules) === 'object') {
394
- try {
395
- (0, _domUtils.asArray)(rules || []).forEach(cssRules.push.bind(cssRules));
396
- } catch (e) {
397
- _console["default"].log("Error while reading CSS rules from ".concat(sheet.href), e);
398
-
399
- return;
400
- }
401
- } else {
402
- _console["default"].log('getCssRules can not find cssRules');
403
-
404
- return;
405
- }
406
- });
407
- return cssRules;
408
- }
409
-
410
- function newWebFont(webFontRule) {
411
- return {
412
- resolve: function resolve() {
413
- var baseUrl = (webFontRule.parentStyleSheet || {}).href;
414
- return inliner.inlineAll(webFontRule.cssText, baseUrl, null);
415
- },
416
- src: function src() {
417
- return webFontRule.style.getPropertyValue('src');
418
- }
419
- };
420
- }
421
- }
422
- }
423
-
424
- function newImages() {
425
- return {
426
- inlineAll: inlineAll,
427
- impl: {
428
- newImage: newImage
429
- }
430
- };
431
-
432
- function newImage(element) {
433
- function inline(get) {
434
- if ((0, _domUtils.isDataUrl)(element.src)) {
435
- return Promise.resolve();
436
- }
437
-
438
- return Promise.resolve(element.src).then(function (ul) {
439
- return typeof get === 'function' ? get(ul) : (0, _domUtils.getAndEncode)(ul, domtoimage.impl.options);
440
- }).then(function (data) {
441
- return (0, _domUtils.dataAsUrl)(data, (0, _domUtils.mimeType)(element.src));
442
- }).then(function (dataUrl) {
443
- return new Promise(function (resolve, reject) {
444
- element.onload = resolve;
445
- element.onerror = reject;
446
- element.src = dataUrl;
447
- });
448
- });
449
- }
450
-
451
- return {
452
- inline: inline
453
- };
454
- }
455
-
456
- function inlineAll(node) {
457
- if (!(node instanceof Element)) {
458
- return Promise.resolve(node);
459
- }
460
-
461
- return inlineBackground(node).then(function () {
462
- if (node instanceof HTMLImageElement) {
463
- return newImage(node).inline(null);
464
- }
465
-
466
- return Promise.all((0, _domUtils.asArray)(node.childNodes).map(function (child) {
467
- return inlineAll(child);
468
- }));
469
- });
470
-
471
- function inlineBackground(nd) {
472
- var background = nd.style.getPropertyValue('background');
473
-
474
- if (!background) {
475
- return Promise.resolve(nd);
476
- }
477
-
478
- return inliner.inlineAll(background, null, null).then(function (inlined) {
479
- nd.style.setProperty('background', inlined, nd.style.getPropertyPriority('background'));
480
- }).then(function () {
481
- return nd;
482
- });
483
- }
484
- }
485
- }
486
-
487
- var _default = domtoimage;
488
- exports["default"] = _default;
489
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/dom-to-image.ts"],"names":["inliner","newInliner","fontFaces","newFontFaces","images","newImages","defaultOptions","imagePlaceholder","undefined","cacheBust","domtoimage","toSvg","toPng","toJpeg","toBlob","toPixelData","impl","options","node","copyOptions","Promise","resolve","then","nd","cloneNode","filter","embedFonts","inlineImages","applyOptions","clone","makeSvgDataUri","width","height","escapeXhtmlForWebpack","bgcolor","style","backgroundColor","Object","keys","forEach","property","draw","canvas","getContext","getImageData","data","toDataURL","quality","canvasToBlob","domNode","makeImage","image","newCanvas","drawImage","dNode","document","createElement","ctx","fillStyle","fillRect","root","makeNodeCopy","cloneChildren","window","HTMLCanvasElement","cloneChildrenInOrder","parent","arrChildren","flt","done","child","childClone","appendChild","original","children","childNodes","length","resolveAll","cssText","styleNode","createTextNode","inlineAll","setAttribute","serializedString","XMLSerializer","serializeToString","xhtml","foreignObject","svgStr","URL_REGEX","shouldProcess","readUrls","inline","string","search","result","match","exec","push","url","urlAsRegex","url0","RegExp","baseUrl","get","ul","dataUrl","replace","urls","str","readAll","webFonts","all","map","webFont","cssStrings","join","styleSheets","loadExternalStyleSheets","getCssRules","selectWebFontRules","rules","newWebFont","cssRules","rule","type","CSSRule","FONT_FACE_RULE","getPropertyValue","sheet","href","cache","includes","fetch","credentials","response","text","err","Console","warn","IMAGE_EXPORT_ERRORS","styleSheet","log","e","bind","webFontRule","parentStyleSheet","src","newImage","element","reject","onload","onerror","Element","inlineBackground","HTMLImageElement","background","inlined","setProperty","getPropertyPriority"],"mappings":"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","sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n/**\n * This file is copied from https://github.com/tsayen/dom-to-image\n * Modified by heshan0131 to allow loading external stylesheets and inline webfonts\n */\n\nimport window from 'global/window';\nimport document from 'global/document';\nimport Console from 'global/console';\nimport svgToMiniDataURI from 'mini-svg-data-uri';\nimport {IMAGE_EXPORT_ERRORS} from '@kepler.gl/constants';\n\nimport {\n  canvasToBlob,\n  escape,\n  escapeXhtml,\n  delay,\n  processClone,\n  asArray,\n  makeImage,\n  mimeType,\n  dataAsUrl,\n  isDataUrl,\n  isSrcAsDataUrl,\n  resolveUrl,\n  getWidth,\n  getHeight,\n  getAndEncode,\n  setStyleSheetBaseHref,\n  toStyleSheet\n} from './dom-utils';\n\nconst inliner = newInliner();\nconst fontFaces = newFontFaces();\nconst images = newImages();\n// Default impl options\nconst defaultOptions = {\n  // Default is to fail on error, no placeholder\n  imagePlaceholder: undefined,\n  // Default cache bust is false, it will use the cache\n  cacheBust: false\n};\n\nconst domtoimage = {\n  toSvg,\n  toPng,\n  toJpeg,\n  toBlob,\n  toPixelData,\n  impl: {\n    fontFaces,\n    images,\n    inliner,\n    options: {} as any\n  }\n};\n\n/**\n * @param {Node} node - The DOM Node object to render\n * @param {Object} options - Rendering options\n * @param {Function} [options.filter] - Should return true if passed node should be included in the output\n *          (excluding node means excluding it's children as well). Not called on the root node.\n * @param {String} [options.bgcolor] - color for the background, any valid CSS color value.\n * @param {Number} [options.width] - width to be applied to node before rendering.\n * @param {Number} [options.height] - height to be applied to node before rendering.\n * @param {Object} [options.style] - an object whose properties to be copied to node's style before rendering.\n * @param {Number} [options.quality] - a Number between 0 and 1 indicating image quality (applicable to JPEG only), defaults to 1.0.\n * @param {boolean} [options.escapeXhtmlForWebpack] - whether to apply fix for uglify error in dom-to-image (should be true for webpack builds), defaults to true.\n * @param {String} [options.imagePlaceholder] - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch\n * @param {Boolean} [options.cacheBust] - set to true to cache bust by appending the time to the request url\n * @return {Promise} - A promise that is fulfilled with a SVG image data URL\n * */\nfunction toSvg(node, options) {\n  options = options || {};\n  copyOptions(options);\n  return Promise.resolve(node)\n    .then(nd => cloneNode(nd, options.filter, true))\n    .then(embedFonts)\n    .then(inlineImages)\n    .then(applyOptions)\n    .then(clone =>\n      makeSvgDataUri(\n        clone,\n        options.width || getWidth(node),\n        options.height || getHeight(node),\n        options.escapeXhtmlForWebpack\n      )\n    );\n\n  function applyOptions(clone) {\n    if (options.bgcolor) clone.style.backgroundColor = options.bgcolor;\n\n    if (options.width) clone.style.width = `${options.width}px`;\n    if (options.height) clone.style.height = `${options.height}px`;\n\n    if (options.style)\n      Object.keys(options.style).forEach(property => {\n        clone.style[property] = options.style[property];\n      });\n\n    return clone;\n  }\n}\n\n/**\n * @param {Node} node - The DOM Node object to render\n * @param {Object} options - Rendering options\n * @return {Promise} - A promise that is fulfilled with a Uint8Array containing RGBA pixel data.\n * */\nfunction toPixelData(node, options) {\n  return draw(node, options || {}).then(\n    canvas => canvas.getContext('2d').getImageData(0, 0, getWidth(node), getHeight(node)).data\n  );\n}\n\n/**\n * @param {Node} node - The DOM Node object to render\n * @param {Object} options - Rendering options\n * @return {Promise} - A promise that is fulfilled with a PNG image data URL\n * */\nfunction toPng(node, options) {\n  return draw(node, options || {}).then(canvas => canvas.toDataURL());\n}\n\n/**\n * @param {Node} node - The DOM Node object to render\n * @param {Object} options - Rendering options\n * @return {Promise} - A promise that is fulfilled with a JPEG image data URL\n * */\nfunction toJpeg(node, options) {\n  options = options || {};\n  return draw(node, options).then(canvas => canvas.toDataURL('image/jpeg', options.quality || 1.0));\n}\n\n/**\n * @param {Node} node - The DOM Node object to render\n * @param {Object} options - Rendering options\n * @return {Promise} - A promise that is fulfilled with a PNG image blob\n * */\nfunction toBlob(node, options) {\n  return draw(node, options || {}).then(canvasToBlob);\n}\n\nfunction copyOptions(options) {\n  // Copy options to impl options for use in impl\n  if (typeof options.imagePlaceholder === 'undefined') {\n    domtoimage.impl.options.imagePlaceholder = defaultOptions.imagePlaceholder;\n  } else {\n    domtoimage.impl.options.imagePlaceholder = options.imagePlaceholder;\n  }\n\n  if (typeof options.cacheBust === 'undefined') {\n    domtoimage.impl.options.cacheBust = defaultOptions.cacheBust;\n  } else {\n    domtoimage.impl.options.cacheBust = options.cacheBust;\n  }\n}\n\nfunction draw(domNode, options) {\n  return toSvg(domNode, options)\n    .then(makeImage)\n    .then(delay(100))\n    .then(image => {\n      const canvas = newCanvas(domNode);\n      canvas.getContext('2d').drawImage(image, 0, 0);\n      return canvas;\n    });\n\n  function newCanvas(dNode) {\n    const canvas = document.createElement('canvas');\n    canvas.width = options.width || getWidth(dNode);\n    canvas.height = options.height || getHeight(dNode);\n\n    if (options.bgcolor) {\n      const ctx = canvas.getContext('2d');\n      ctx.fillStyle = options.bgcolor;\n      ctx.fillRect(0, 0, canvas.width, canvas.height);\n    }\n\n    return canvas;\n  }\n}\n\nfunction cloneNode(node, filter, root) {\n  if (!root && filter && !filter(node)) {\n    return Promise.resolve();\n  }\n\n  return Promise.resolve(node)\n    .then(makeNodeCopy)\n    .then(clone => cloneChildren(node, clone, filter))\n    .then(clone => processClone(node, clone));\n\n  function makeNodeCopy(nd) {\n    if (nd instanceof window.HTMLCanvasElement) {\n      return makeImage(nd.toDataURL());\n    }\n    return nd.cloneNode(false);\n  }\n\n  function cloneChildrenInOrder(parent, arrChildren, flt) {\n    let done = Promise.resolve();\n    arrChildren.forEach(child => {\n      done = done\n        .then(() => cloneNode(child, flt, null))\n        .then(childClone => {\n          if (childClone) {\n            parent.appendChild(childClone);\n          }\n        });\n    });\n    return done;\n  }\n\n  function cloneChildren(original, clone, flt) {\n    const children = original.childNodes;\n    if (children.length === 0) {\n      return Promise.resolve(clone);\n    }\n\n    return cloneChildrenInOrder(clone, asArray(children), flt).then(() => clone);\n  }\n}\n\nfunction embedFonts(node) {\n  return fontFaces.resolveAll().then(cssText => {\n    const styleNode = document.createElement('style');\n    node.appendChild(styleNode);\n    styleNode.appendChild(document.createTextNode(cssText));\n    return node;\n  });\n}\n\nfunction inlineImages(node) {\n  return images.inlineAll(node).then(() => node);\n}\n\nfunction makeSvgDataUri(node, width, height, escapeXhtmlForWebpack = true) {\n  return Promise.resolve(node).then(nd => {\n    nd.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml');\n    const serializedString = new window.XMLSerializer().serializeToString(nd);\n\n    const xhtml = escapeXhtmlForWebpack ? escapeXhtml(serializedString) : serializedString;\n    const foreignObject = `<foreignObject x=\"0\" y=\"0\" width=\"100%\" height=\"100%\">${xhtml}</foreignObject>`;\n    const svgStr = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"${width}\" height=\"${height}\">${foreignObject}</svg>`;\n\n    // Optimizing SVGs in data URIs\n    // see https://codepen.io/tigt/post/optimizing-svgs-in-data-uris\n    // the best way of encoding SVG in a data: URI is data:image/svg+xml,[actual data].\n    // We don’t need the ;charset=utf-8 parameter because the given SVG is ASCII.\n    return svgToMiniDataURI(svgStr);\n  });\n}\n\nfunction newInliner() {\n  const URL_REGEX = /url\\(['\"]?([^'\"]+?)['\"]?\\)/g;\n\n  return {\n    inlineAll,\n    shouldProcess,\n    impl: {\n      readUrls,\n      inline\n    }\n  };\n\n  function shouldProcess(string) {\n    return string.search(URL_REGEX) !== -1;\n  }\n\n  function readUrls(string) {\n    const result: string[] = [];\n    let match: null | RegExpExecArray;\n    while ((match = URL_REGEX.exec(string)) !== null) {\n      result.push(match[1]);\n    }\n    return result.filter(url => {\n      return !isDataUrl(url);\n    });\n  }\n\n  function urlAsRegex(url0) {\n    return new RegExp(`(url\\\\([\\'\"]?)(${escape(url0)})([\\'\"]?\\\\))`, 'g');\n  }\n\n  function inline(string, url, baseUrl, get) {\n    return Promise.resolve(url)\n      .then(ul => (baseUrl ? resolveUrl(ul, baseUrl) : ul))\n      .then(ul => (typeof get === 'function' ? get(ul) : getAndEncode(ul, domtoimage.impl.options)))\n      .then(data => dataAsUrl(data, mimeType(url)))\n      .then(dataUrl => string.replace(urlAsRegex(url), `$1${dataUrl}$3`));\n  }\n\n  function inlineAll(string, baseUrl, get) {\n    if (!shouldProcess(string) || isSrcAsDataUrl(string)) {\n      return Promise.resolve(string);\n    }\n    return Promise.resolve(string)\n      .then(readUrls)\n      .then(urls => {\n        let done = Promise.resolve(string);\n        urls.forEach(url => {\n          done = done.then(str => inline(str, url, baseUrl, get));\n        });\n        return done;\n      });\n  }\n}\n\nfunction newFontFaces() {\n  return {\n    resolveAll,\n    impl: {readAll}\n  };\n\n  function resolveAll() {\n    return readAll()\n      .then(webFonts => {\n        return Promise.all(webFonts.map(webFont => webFont.resolve()));\n      })\n      .then(cssStrings => cssStrings.join('\\n'));\n  }\n\n  function readAll() {\n    return Promise.resolve(asArray(document.styleSheets))\n      .then(loadExternalStyleSheets)\n      .then(getCssRules)\n      .then(selectWebFontRules)\n      .then(rules => rules.map(newWebFont));\n\n    function selectWebFontRules(cssRules) {\n      return cssRules\n        .filter(rule => rule.type === window.CSSRule.FONT_FACE_RULE)\n        .filter(rule => inliner.shouldProcess(rule.style.getPropertyValue('src')));\n    }\n\n    function loadExternalStyleSheets(styleSheets) {\n      return Promise.all(\n        styleSheets.map(sheet => {\n          if (sheet.href) {\n            // cloudfont doesn't have allow origin header properly set\n            // error response will remain in cache\n            const cache = sheet.href.includes('uber-fonts') ? 'no-cache' : 'default';\n            return window\n              .fetch(sheet.href, {credentials: 'omit', cache})\n              .then(response => response.text())\n              .then(text => {\n                const result = setStyleSheetBaseHref(text, sheet.href);\n                return toStyleSheet(result);\n              })\n              .catch(err => {\n                // Handle any error that occurred in any of the previous\n                // promises in the chain. stylesheet failed to load should not stop\n                // the process, hence result in only a warning, instead of reject\n                Console.warn(IMAGE_EXPORT_ERRORS.styleSheet, sheet.href);\n                Console.log(err);\n                return;\n              });\n          }\n          return Promise.resolve(sheet);\n        })\n      );\n    }\n\n    function getCssRules(styleSheets) {\n      const cssRules: any[] = [];\n      styleSheets.forEach(sheet => {\n        // try...catch because browser may not able to enumerate rules for cross-domain sheets\n        if (!sheet) {\n          return;\n        }\n        let rules;\n        try {\n          rules = sheet.rules || sheet.cssRules;\n        } catch (e) {\n          Console.log(`'Can't read the css rules of: ${sheet.href}`, e);\n          return;\n        }\n\n        if (rules && typeof rules === 'object') {\n          try {\n            asArray(rules || []).forEach(cssRules.push.bind(cssRules));\n          } catch (e) {\n            Console.log(`Error while reading CSS rules from ${sheet.href}`, e);\n            return;\n          }\n        } else {\n          Console.log('getCssRules can not find cssRules');\n          return;\n        }\n      });\n\n      return cssRules;\n    }\n\n    function newWebFont(webFontRule) {\n      return {\n        resolve: () => {\n          const baseUrl = (webFontRule.parentStyleSheet || {}).href;\n          return inliner.inlineAll(webFontRule.cssText, baseUrl, null);\n        },\n        src: () => webFontRule.style.getPropertyValue('src')\n      };\n    }\n  }\n}\n\nfunction newImages() {\n  return {\n    inlineAll,\n    impl: {\n      newImage\n    }\n  };\n\n  function newImage(element) {\n    function inline(get) {\n      if (isDataUrl(element.src)) {\n        return Promise.resolve();\n      }\n      return Promise.resolve(element.src)\n        .then(ul =>\n          typeof get === 'function' ? get(ul) : getAndEncode(ul, domtoimage.impl.options)\n        )\n        .then(data => dataAsUrl(data, mimeType(element.src)))\n        .then(\n          dataUrl =>\n            new Promise((resolve, reject) => {\n              element.onload = resolve;\n              element.onerror = reject;\n              element.src = dataUrl;\n            })\n        );\n    }\n\n    return {\n      inline\n    };\n  }\n\n  function inlineAll(node) {\n    if (!(node instanceof Element)) {\n      return Promise.resolve(node);\n    }\n\n    return inlineBackground(node).then(() => {\n      if (node instanceof HTMLImageElement) {\n        return newImage(node).inline(null);\n      }\n      return Promise.all(asArray(node.childNodes).map(child => inlineAll(child)));\n    });\n\n    function inlineBackground(nd) {\n      const background = nd.style.getPropertyValue('background');\n\n      if (!background) {\n        return Promise.resolve(nd);\n      }\n\n      return inliner\n        .inlineAll(background, null, null)\n        .then(inlined => {\n          nd.style.setProperty('background', inlined, nd.style.getPropertyPriority('background'));\n        })\n        .then(() => nd);\n    }\n  }\n}\n\nexport default domtoimage;\n"]}
@@ -1,23 +0,0 @@
1
- export declare function processClone(original: any, clone: any): any;
2
- /****
3
- * UTILS
4
- ****/
5
- export declare function asArray(arrayLike: any): any[];
6
- export declare function fourRandomChars(): string;
7
- export declare function uid(): string;
8
- export declare function makeImage(uri: any): Promise<unknown>;
9
- export declare function isDataUrl(url: any): boolean;
10
- export declare function mimeType(url: any): any;
11
- export declare function dataAsUrl(content: any, type: any): string;
12
- export declare function escape(string: any): any;
13
- export declare function delay(ms: any): (arg: any) => Promise<unknown>;
14
- export declare function isSrcAsDataUrl(text: any): boolean;
15
- export declare function canvasToBlob(canvas: any): Promise<unknown>;
16
- export declare function escapeXhtml(string: any): any;
17
- export declare function getWidth(node: any): any;
18
- export declare function getHeight(node: any): any;
19
- export declare function resolveUrl(url: any, baseUrl: any): any;
20
- export declare function getAndEncode(url: any, options: any): Promise<unknown>;
21
- export declare function concatAndResolveUrl(base: any, url: any): string;
22
- export declare function setStyleSheetBaseHref(text: any, base: any): any;
23
- export declare function toStyleSheet(text: any): any;