@kepler.gl/utils 3.2.4 → 3.2.6
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.
|
@@ -49,6 +49,8 @@ export declare type KeplerApplicationConfig = {
|
|
|
49
49
|
/** Whether to show the server input field in the raster tile layer setup form */
|
|
50
50
|
rasterServerShowServerInput?: boolean;
|
|
51
51
|
enableWMSLayer?: boolean;
|
|
52
|
+
/** Whether to apply fix for uglify error in dom-to-image (should be true for webpack builds, false for Vite) */
|
|
53
|
+
escapeXhtmlForWebpack?: boolean;
|
|
52
54
|
};
|
|
53
55
|
export declare const getApplicationConfig: () => Required<KeplerApplicationConfig>;
|
|
54
56
|
export declare function initApplicationConfig(appConfig?: KeplerApplicationConfig): void;
|
|
@@ -11,6 +11,14 @@ var _constants = require("@kepler.gl/constants");
|
|
|
11
11
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
12
12
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != (0, _typeof2["default"])(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } // SPDX-License-Identifier: MIT
|
|
13
13
|
// Copyright contributors to the kepler.gl project
|
|
14
|
+
/**
|
|
15
|
+
* Detect if running with webpack build tool
|
|
16
|
+
*/
|
|
17
|
+
function isWebpackBuild() {
|
|
18
|
+
// @ts-ignore - __webpack_require__ is injected by webpack at runtime
|
|
19
|
+
return typeof __webpack_require__ !== 'undefined';
|
|
20
|
+
}
|
|
21
|
+
|
|
14
22
|
/**
|
|
15
23
|
* A mechanism to override default Kepler values/settings so that we
|
|
16
24
|
* without having to make application-specific changes to the kepler repo.
|
|
@@ -69,7 +77,10 @@ var DEFAULT_APPLICATION_CONFIG = {
|
|
|
69
77
|
rasterServerServerErrorsToRetry: [503],
|
|
70
78
|
rasterServerMaxPerServerRequests: 0,
|
|
71
79
|
// WMS layer config
|
|
72
|
-
enableWMSLayer: true
|
|
80
|
+
enableWMSLayer: true,
|
|
81
|
+
// Image export config
|
|
82
|
+
// Default to true for webpack builds, false for other build tools (e.g., Vite)
|
|
83
|
+
escapeXhtmlForWebpack: isWebpackBuild()
|
|
73
84
|
};
|
|
74
85
|
var applicationConfig = DEFAULT_APPLICATION_CONFIG;
|
|
75
86
|
var getApplicationConfig = exports.getApplicationConfig = function getApplicationConfig() {
|
|
@@ -79,4 +90,4 @@ function initApplicationConfig() {
|
|
|
79
90
|
var appConfig = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
80
91
|
Object.assign(applicationConfig, appConfig);
|
|
81
92
|
}
|
|
82
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_getRequireWildcardCache","e","WeakMap","r","t","_interopRequireWildcard","__esModule","_typeof2","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DEFAULT_APPLICATION_CONFIG","defaultHtmlName","defaultImageName","defaultJsonName","defaultDataName","defaultExportJsonSettings","hasData","baseMapLibraryConfig","maplibre","getMapLib","Promise","resolve","then","mapLibCssClass","mapLibAttributionCssClass","mapLibName","mapLibUrl","mapbox","cdnUrl","KEPLER_UNFOLDED_BUCKET","plugins","table","database","useArrowProgressiveLoading","showReleaseBanner","useOnFilteredItemsChange","enableRasterTileLayer","rasterServerUseLatestTitiler","rasterServerShowServerInput","rasterServerUrls","rasterServerSupportsElevation","rasterServerMaxRetries","rasterServerRetryDelay","rasterServerServerErrorsToRetry","rasterServerMaxPerServerRequests","enableWMSLayer","applicationConfig","getApplicationConfig","exports","initApplicationConfig","appConfig","arguments","length","undefined","assign"],"sources":["../src/application-config.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {MapLib, MapRef} from 'react-map-gl';\n\nimport {KEPLER_UNFOLDED_BUCKET} from '@kepler.gl/constants';\nimport type {BaseMapLibraryType} from '@kepler.gl/constants';\n\nimport type {DatabaseAdapter} from './application-config-types';\n\nexport type MapLibInstance = MapLib<any>;\nexport type GetMapRef = ReturnType<MapRef['getMap']>;\n\nexport type BaseMapLibraryConfig = {\n  getMapLib: () => Promise<MapLibInstance>;\n  mapLibAttributionCssClass: string;\n  mapLibCssClass: string;\n  mapLibName: string;\n  mapLibUrl: string;\n};\n\n/**\n * A mechanism to override default Kepler values/settings so that we\n * without having to make application-specific changes to the kepler repo.\n */\nexport type KeplerApplicationConfig = {\n  /** Default name of export HTML file, can be overridden by user */\n  defaultHtmlName?: string;\n  defaultImageName?: string;\n  defaultJsonName?: string;\n  defaultDataName?: string;\n  defaultExportJsonSettings?: {\n    hasData?: boolean;\n  };\n  baseMapLibraryConfig?: Record<BaseMapLibraryType, BaseMapLibraryConfig>;\n  plugins?: any[];\n  // KeplerTable alternative\n  // TODO improve typing by exporting KeplerTable interface to @kepler.gl/types\n  table?: any;\n  database?: DatabaseAdapter | null;\n\n  // Disable progressive loading for arrow files\n  useArrowProgressiveLoading?: boolean;\n  // Show built-in banner associated with the current version of Kepler.gl\n  showReleaseBanner?: boolean;\n  // Use the onFilteredItemsChange callback for DataFilterExtension.\n  // Enabling this option may cause performance issues when dealing with a large number of layers or sublayers,\n  // especially if large Arrow files are split into relatively small batches (should be fixed in the future).\n  useOnFilteredItemsChange?: boolean;\n\n  // A URL to the CDN where the kepler.gl assets are hosted.\n  cdnUrl?: string;\n\n  // Raster Tile layer config\n  // Raster Tile layer is under development and not ready for production use. Disabled by default.\n  enableRasterTileLayer?: boolean;\n  /** Whether to use Titiler v0.21 API endpoints instead of v0.11 */\n  rasterServerUseLatestTitiler?: boolean;\n  /** An array of URLs to shards of the raster tile server to be used by the raster tile layer. */\n  rasterServerUrls?: string[];\n  /** If true then try to fetch quantized elevation meshes from raster servers */\n  rasterServerSupportsElevation?: boolean;\n  /** How many times to retry a request if case of rasterServerServerErrorsToRetry errors */\n  rasterServerMaxRetries?: number;\n  /** How long between retries */\n  rasterServerRetryDelay?: number;\n  /** An array of HTTP status codes that should be retried when encountered. */\n  rasterServerServerErrorsToRetry?: number[];\n  /** Maximum number of simultaneous requests per raster server. 0 - no limit */\n  rasterServerMaxPerServerRequests?: number;\n  /** Whether to show the server input field in the raster tile layer setup form */\n  rasterServerShowServerInput?: boolean;\n\n  // WMS layer config -- Experimental\n  // WMS layer is under development and not ready for production use. Disabled by default.\n  enableWMSLayer?: boolean;\n};\n\nconst DEFAULT_APPLICATION_CONFIG: Required<KeplerApplicationConfig> = {\n  defaultHtmlName: 'kepler.gl.html',\n  defaultImageName: 'kepler.gl.png',\n  defaultJsonName: 'kepler.gl.json',\n  defaultDataName: 'kepler.gl',\n  defaultExportJsonSettings: {\n    hasData: true\n  },\n\n  baseMapLibraryConfig: {\n    maplibre: {\n      getMapLib: () => import('maplibre-gl'),\n      mapLibCssClass: 'maplibregl',\n      mapLibAttributionCssClass: 'maplibre-attribution-container',\n      mapLibName: 'MapLibre',\n      mapLibUrl: 'https://www.maplibre.org/'\n    },\n    mapbox: {\n      getMapLib: () => import('mapbox-gl'),\n      mapLibCssClass: 'mapboxgl',\n      mapLibAttributionCssClass: 'mapbox-attribution-container',\n      mapLibName: 'Mapbox',\n      mapLibUrl: 'https://www.mapbox.com/'\n    }\n  },\n\n  cdnUrl: KEPLER_UNFOLDED_BUCKET,\n\n  plugins: [],\n  // The default table class is KeplerTable.\n  // TODO include KeplerTable here when the circular dependency with @kepler.gl/table and @kepler.gl/utils are resolved.\n  table: null,\n  database: null,\n\n  useArrowProgressiveLoading: true,\n  showReleaseBanner: true,\n  useOnFilteredItemsChange: false,\n\n  // Raster Tile layer config\n  enableRasterTileLayer: true,\n  rasterServerUseLatestTitiler: true,\n  rasterServerShowServerInput: true,\n  rasterServerUrls: [], // TODO: provide a default free server or leave blank\n  rasterServerSupportsElevation: true,\n  rasterServerMaxRetries: 1,\n  rasterServerRetryDelay: 10000,\n  rasterServerServerErrorsToRetry: [503],\n  rasterServerMaxPerServerRequests: 0,\n\n  // WMS layer config\n  enableWMSLayer: true\n};\n\nconst applicationConfig: Required<KeplerApplicationConfig> = DEFAULT_APPLICATION_CONFIG;\n\nexport const getApplicationConfig = (): Required<KeplerApplicationConfig> => applicationConfig;\n\nexport function initApplicationConfig(appConfig: KeplerApplicationConfig = {}) {\n  Object.assign(applicationConfig, appConfig);\n}\n"],"mappings":"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","ignoreList":[]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_getRequireWildcardCache","e","WeakMap","r","t","_interopRequireWildcard","__esModule","_typeof2","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","isWebpackBuild","__webpack_require__","DEFAULT_APPLICATION_CONFIG","defaultHtmlName","defaultImageName","defaultJsonName","defaultDataName","defaultExportJsonSettings","hasData","baseMapLibraryConfig","maplibre","getMapLib","Promise","resolve","then","mapLibCssClass","mapLibAttributionCssClass","mapLibName","mapLibUrl","mapbox","cdnUrl","KEPLER_UNFOLDED_BUCKET","plugins","table","database","useArrowProgressiveLoading","showReleaseBanner","useOnFilteredItemsChange","enableRasterTileLayer","rasterServerUseLatestTitiler","rasterServerShowServerInput","rasterServerUrls","rasterServerSupportsElevation","rasterServerMaxRetries","rasterServerRetryDelay","rasterServerServerErrorsToRetry","rasterServerMaxPerServerRequests","enableWMSLayer","escapeXhtmlForWebpack","applicationConfig","getApplicationConfig","exports","initApplicationConfig","appConfig","arguments","length","undefined","assign"],"sources":["../src/application-config.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {MapLib, MapRef} from 'react-map-gl';\n\nimport {KEPLER_UNFOLDED_BUCKET} from '@kepler.gl/constants';\nimport type {BaseMapLibraryType} from '@kepler.gl/constants';\n\nimport type {DatabaseAdapter} from './application-config-types';\n\n/**\n * Detect if running with webpack build tool\n */\nfunction isWebpackBuild(): boolean {\n  // @ts-ignore - __webpack_require__ is injected by webpack at runtime\n  return typeof __webpack_require__ !== 'undefined';\n}\n\nexport type MapLibInstance = MapLib<any>;\nexport type GetMapRef = ReturnType<MapRef['getMap']>;\n\nexport type BaseMapLibraryConfig = {\n  getMapLib: () => Promise<MapLibInstance>;\n  mapLibAttributionCssClass: string;\n  mapLibCssClass: string;\n  mapLibName: string;\n  mapLibUrl: string;\n};\n\n/**\n * A mechanism to override default Kepler values/settings so that we\n * without having to make application-specific changes to the kepler repo.\n */\nexport type KeplerApplicationConfig = {\n  /** Default name of export HTML file, can be overridden by user */\n  defaultHtmlName?: string;\n  defaultImageName?: string;\n  defaultJsonName?: string;\n  defaultDataName?: string;\n  defaultExportJsonSettings?: {\n    hasData?: boolean;\n  };\n  baseMapLibraryConfig?: Record<BaseMapLibraryType, BaseMapLibraryConfig>;\n  plugins?: any[];\n  // KeplerTable alternative\n  // TODO improve typing by exporting KeplerTable interface to @kepler.gl/types\n  table?: any;\n  database?: DatabaseAdapter | null;\n\n  // Disable progressive loading for arrow files\n  useArrowProgressiveLoading?: boolean;\n  // Show built-in banner associated with the current version of Kepler.gl\n  showReleaseBanner?: boolean;\n  // Use the onFilteredItemsChange callback for DataFilterExtension.\n  // Enabling this option may cause performance issues when dealing with a large number of layers or sublayers,\n  // especially if large Arrow files are split into relatively small batches (should be fixed in the future).\n  useOnFilteredItemsChange?: boolean;\n\n  // A URL to the CDN where the kepler.gl assets are hosted.\n  cdnUrl?: string;\n\n  // Raster Tile layer config\n  // Raster Tile layer is under development and not ready for production use. Disabled by default.\n  enableRasterTileLayer?: boolean;\n  /** Whether to use Titiler v0.21 API endpoints instead of v0.11 */\n  rasterServerUseLatestTitiler?: boolean;\n  /** An array of URLs to shards of the raster tile server to be used by the raster tile layer. */\n  rasterServerUrls?: string[];\n  /** If true then try to fetch quantized elevation meshes from raster servers */\n  rasterServerSupportsElevation?: boolean;\n  /** How many times to retry a request if case of rasterServerServerErrorsToRetry errors */\n  rasterServerMaxRetries?: number;\n  /** How long between retries */\n  rasterServerRetryDelay?: number;\n  /** An array of HTTP status codes that should be retried when encountered. */\n  rasterServerServerErrorsToRetry?: number[];\n  /** Maximum number of simultaneous requests per raster server. 0 - no limit */\n  rasterServerMaxPerServerRequests?: number;\n  /** Whether to show the server input field in the raster tile layer setup form */\n  rasterServerShowServerInput?: boolean;\n\n  // WMS layer config -- Experimental\n  // WMS layer is under development and not ready for production use. Disabled by default.\n  enableWMSLayer?: boolean;\n\n  // Image export config\n  /** Whether to apply fix for uglify error in dom-to-image (should be true for webpack builds, false for Vite) */\n  escapeXhtmlForWebpack?: boolean;\n};\n\nconst DEFAULT_APPLICATION_CONFIG: Required<KeplerApplicationConfig> = {\n  defaultHtmlName: 'kepler.gl.html',\n  defaultImageName: 'kepler.gl.png',\n  defaultJsonName: 'kepler.gl.json',\n  defaultDataName: 'kepler.gl',\n  defaultExportJsonSettings: {\n    hasData: true\n  },\n\n  baseMapLibraryConfig: {\n    maplibre: {\n      getMapLib: () => import('maplibre-gl'),\n      mapLibCssClass: 'maplibregl',\n      mapLibAttributionCssClass: 'maplibre-attribution-container',\n      mapLibName: 'MapLibre',\n      mapLibUrl: 'https://www.maplibre.org/'\n    },\n    mapbox: {\n      getMapLib: () => import('mapbox-gl'),\n      mapLibCssClass: 'mapboxgl',\n      mapLibAttributionCssClass: 'mapbox-attribution-container',\n      mapLibName: 'Mapbox',\n      mapLibUrl: 'https://www.mapbox.com/'\n    }\n  },\n\n  cdnUrl: KEPLER_UNFOLDED_BUCKET,\n\n  plugins: [],\n  // The default table class is KeplerTable.\n  // TODO include KeplerTable here when the circular dependency with @kepler.gl/table and @kepler.gl/utils are resolved.\n  table: null,\n  database: null,\n\n  useArrowProgressiveLoading: true,\n  showReleaseBanner: true,\n  useOnFilteredItemsChange: false,\n\n  // Raster Tile layer config\n  enableRasterTileLayer: true,\n  rasterServerUseLatestTitiler: true,\n  rasterServerShowServerInput: true,\n  rasterServerUrls: [], // TODO: provide a default free server or leave blank\n  rasterServerSupportsElevation: true,\n  rasterServerMaxRetries: 1,\n  rasterServerRetryDelay: 10000,\n  rasterServerServerErrorsToRetry: [503],\n  rasterServerMaxPerServerRequests: 0,\n\n  // WMS layer config\n  enableWMSLayer: true,\n\n  // Image export config\n  // Default to true for webpack builds, false for other build tools (e.g., Vite)\n  escapeXhtmlForWebpack: isWebpackBuild()\n};\n\nconst applicationConfig: Required<KeplerApplicationConfig> = DEFAULT_APPLICATION_CONFIG;\n\nexport const getApplicationConfig = (): Required<KeplerApplicationConfig> => applicationConfig;\n\nexport function initApplicationConfig(appConfig: KeplerApplicationConfig = {}) {\n  Object.assign(applicationConfig, appConfig);\n}\n"],"mappings":"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","ignoreList":[]}
|
package/dist/dom-to-image.js
CHANGED
|
@@ -9,7 +9,6 @@ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
|
9
9
|
var _window = _interopRequireDefault(require("global/window"));
|
|
10
10
|
var _document = _interopRequireDefault(require("global/document"));
|
|
11
11
|
var _console = _interopRequireDefault(require("global/console"));
|
|
12
|
-
var _miniSvgDataUri = _interopRequireDefault(require("mini-svg-data-uri"));
|
|
13
12
|
var _constants = require("@kepler.gl/constants");
|
|
14
13
|
var _domUtils = require("./dom-utils");
|
|
15
14
|
// SPDX-License-Identifier: MIT
|
|
@@ -211,11 +210,24 @@ function makeSvgDataUri(node, width, height) {
|
|
|
211
210
|
var foreignObject = "<foreignObject x=\"0\" y=\"0\" width=\"100%\" height=\"100%\">".concat(xhtml, "</foreignObject>");
|
|
212
211
|
var svgStr = "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"".concat(width, "\" height=\"").concat(height, "\">").concat(foreignObject, "</svg>");
|
|
213
212
|
|
|
214
|
-
//
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
213
|
+
// Use base64 encoding
|
|
214
|
+
var base64Svg;
|
|
215
|
+
if (typeof Buffer !== 'undefined' && Buffer.from) {
|
|
216
|
+
base64Svg = Buffer.from(svgStr, 'utf8').toString('base64');
|
|
217
|
+
} else if (typeof TextEncoder !== 'undefined') {
|
|
218
|
+
// Modern browsers: TextEncoder handles Unicode → UTF-8 bytes
|
|
219
|
+
// Must chunk to avoid call stack limits with large arrays
|
|
220
|
+
var bytes = new TextEncoder().encode(svgStr);
|
|
221
|
+
var CHUNK_SIZE = 8192;
|
|
222
|
+
var binary = '';
|
|
223
|
+
for (var i = 0; i < bytes.length; i += CHUNK_SIZE) {
|
|
224
|
+
binary += String.fromCharCode.apply(null, Array.from(bytes.slice(i, i + CHUNK_SIZE)));
|
|
225
|
+
}
|
|
226
|
+
base64Svg = _window["default"].btoa(binary);
|
|
227
|
+
} else {
|
|
228
|
+
throw new Error('No base64 encoder found');
|
|
229
|
+
}
|
|
230
|
+
return "data:image/svg+xml;base64,".concat(base64Svg);
|
|
219
231
|
});
|
|
220
232
|
}
|
|
221
233
|
function newInliner() {
|
|
@@ -418,4 +430,4 @@ function newImages() {
|
|
|
418
430
|
}
|
|
419
431
|
}
|
|
420
432
|
var _default = exports["default"] = domtoimage;
|
|
421
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","_interopRequireDefault","require","_document","_console","_miniSvgDataUri","_constants","_domUtils","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","getWidth","height","getHeight","escapeXhtmlForWebpack","bgcolor","style","backgroundColor","concat","Object","keys","forEach","property","draw","canvas","getContext","getImageData","data","toDataURL","quality","canvasToBlob","domNode","makeImage","delay","image","newCanvas","drawImage","dNode","document","createElement","ctx","fillStyle","fillRect","root","makeNodeCopy","cloneChildren","processClone","Window","HTMLCanvasElement","cloneChildrenInOrder","parent","arrChildren","flt","done","child","childClone","appendChild","original","children","childNodes","length","asArray","resolveAll","cssText","styleNode","createTextNode","inlineAll","arguments","setAttribute","serializedString","XMLSerializer","serializeToString","xhtml","escapeXhtml","foreignObject","svgStr","svgToMiniDataURI","URL_REGEX","shouldProcess","readUrls","inline","string","search","result","match","exec","push","url","isDataUrl","urlAsRegex","url0","RegExp","escape","baseUrl","get","ul","resolveUrl","getAndEncode","dataAsUrl","mimeType","dataUrl","replace","isSrcAsDataUrl","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","setStyleSheetBaseHref","toStyleSheet","err","Console","warn","IMAGE_EXPORT_ERRORS","styleSheet","log","e","_typeof2","bind","webFontRule","parentStyleSheet","src","newImage","element","reject","onload","onerror","Element","inlineBackground","HTMLImageElement","background","inlined","setProperty","getPropertyPriority","_default","exports"],"sources":["../src/dom-to-image.ts"],"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.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"],"mappings":";;;;;;;;AAQA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,SAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,QAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,eAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,UAAA,GAAAJ,OAAA;AAEA,IAAAK,SAAA,GAAAL,OAAA;AAdA;AACA;;AAEA;AACA;AACA;AACA;;AA4BA,IAAMM,OAAO,GAAGC,UAAU,CAAC,CAAC;AAC5B,IAAMC,SAAS,GAAGC,YAAY,CAAC,CAAC;AAChC,IAAMC,MAAM,GAAGC,SAAS,CAAC,CAAC;AAC1B;AACA,IAAMC,cAAc,GAAG;EACrB;EACAC,gBAAgB,EAAEC,SAAS;EAC3B;EACAC,SAAS,EAAE;AACb,CAAC;AAED,IAAMC,UAAU,GAAG;EACjBC,KAAK,EAALA,KAAK;EACLC,KAAK,EAALA,KAAK;EACLC,MAAM,EAANA,MAAM;EACNC,MAAM,EAANA,MAAM;EACNC,WAAW,EAAXA,WAAW;EACXC,IAAI,EAAE;IACJd,SAAS,EAATA,SAAS;IACTE,MAAM,EAANA,MAAM;IACNJ,OAAO,EAAPA,OAAO;IACPiB,OAAO,EAAE,CAAC;EACZ;AACF,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASN,KAAKA,CAACO,IAAI,EAAED,OAAO,EAAE;EAC5BA,OAAO,GAAGA,OAAO,IAAI,CAAC,CAAC;EACvBE,WAAW,CAACF,OAAO,CAAC;EACpB,OAAOG,OAAO,CAACC,OAAO,CAACH,IAAI,CAAC,CACzBI,IAAI,CAAC,UAAAC,EAAE;IAAA,OAAIC,SAAS,CAACD,EAAE,EAAEN,OAAO,CAACQ,MAAM,EAAE,IAAI,CAAC;EAAA,EAAC,CAC/CH,IAAI,CAACI,UAAU,CAAC,CAChBJ,IAAI,CAACK,YAAY,CAAC,CAClBL,IAAI,CAACM,YAAY,CAAC,CAClBN,IAAI,CAAC,UAAAO,KAAK;IAAA,OACTC,cAAc,CACZD,KAAK,EACLZ,OAAO,CAACc,KAAK,IAAI,IAAAC,kBAAQ,EAACd,IAAI,CAAC,EAC/BD,OAAO,CAACgB,MAAM,IAAI,IAAAC,mBAAS,EAAChB,IAAI,CAAC,EACjCD,OAAO,CAACkB,qBACV,CAAC;EAAA,CACH,CAAC;EAEH,SAASP,YAAYA,CAACC,KAAK,EAAE;IAC3B,IAAIZ,OAAO,CAACmB,OAAO,EAAEP,KAAK,CAACQ,KAAK,CAACC,eAAe,GAAGrB,OAAO,CAACmB,OAAO;IAElE,IAAInB,OAAO,CAACc,KAAK,EAAEF,KAAK,CAACQ,KAAK,CAACN,KAAK,MAAAQ,MAAA,CAAMtB,OAAO,CAACc,KAAK,OAAI;IAC3D,IAAId,OAAO,CAACgB,MAAM,EAAEJ,KAAK,CAACQ,KAAK,CAACJ,MAAM,MAAAM,MAAA,CAAMtB,OAAO,CAACgB,MAAM,OAAI;IAE9D,IAAIhB,OAAO,CAACoB,KAAK,EACfG,MAAM,CAACC,IAAI,CAACxB,OAAO,CAACoB,KAAK,CAAC,CAACK,OAAO,CAAC,UAAAC,QAAQ,EAAI;MAC7Cd,KAAK,CAACQ,KAAK,CAACM,QAAQ,CAAC,GAAG1B,OAAO,CAACoB,KAAK,CAACM,QAAQ,CAAC;IACjD,CAAC,CAAC;IAEJ,OAAOd,KAAK;EACd;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA,SAASd,WAAWA,CAACG,IAAI,EAAED,OAAO,EAAE;EAClC,OAAO2B,IAAI,CAAC1B,IAAI,EAAED,OAAO,IAAI,CAAC,CAAC,CAAC,CAACK,IAAI,CACnC,UAAAuB,MAAM;IAAA,OAAIA,MAAM,CAACC,UAAU,CAAC,IAAI,CAAC,CAACC,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,IAAAf,kBAAQ,EAACd,IAAI,CAAC,EAAE,IAAAgB,mBAAS,EAAChB,IAAI,CAAC,CAAC,CAAC8B,IAAI;EAAA,CAC5F,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,SAASpC,KAAKA,CAACM,IAAI,EAAED,OAAO,EAAE;EAC5B,OAAO2B,IAAI,CAAC1B,IAAI,EAAED,OAAO,IAAI,CAAC,CAAC,CAAC,CAACK,IAAI,CAAC,UAAAuB,MAAM;IAAA,OAAIA,MAAM,CAACI,SAAS,CAAC,CAAC;EAAA,EAAC;AACrE;;AAEA;AACA;AACA;AACA;AACA;AACA,SAASpC,MAAMA,CAACK,IAAI,EAAED,OAAO,EAAE;EAC7BA,OAAO,GAAGA,OAAO,IAAI,CAAC,CAAC;EACvB,OAAO2B,IAAI,CAAC1B,IAAI,EAAED,OAAO,CAAC,CAACK,IAAI,CAAC,UAAAuB,MAAM;IAAA,OAAIA,MAAM,CAACI,SAAS,CAAC,YAAY,EAAEhC,OAAO,CAACiC,OAAO,IAAI,GAAG,CAAC;EAAA,EAAC;AACnG;;AAEA;AACA;AACA;AACA;AACA;AACA,SAASpC,MAAMA,CAACI,IAAI,EAAED,OAAO,EAAE;EAC7B,OAAO2B,IAAI,CAAC1B,IAAI,EAAED,OAAO,IAAI,CAAC,CAAC,CAAC,CAACK,IAAI,CAAC6B,sBAAY,CAAC;AACrD;AAEA,SAAShC,WAAWA,CAACF,OAAO,EAAE;EAC5B;EACA,IAAI,OAAOA,OAAO,CAACV,gBAAgB,KAAK,WAAW,EAAE;IACnDG,UAAU,CAACM,IAAI,CAACC,OAAO,CAACV,gBAAgB,GAAGD,cAAc,CAACC,gBAAgB;EAC5E,CAAC,MAAM;IACLG,UAAU,CAACM,IAAI,CAACC,OAAO,CAACV,gBAAgB,GAAGU,OAAO,CAACV,gBAAgB;EACrE;EAEA,IAAI,OAAOU,OAAO,CAACR,SAAS,KAAK,WAAW,EAAE;IAC5CC,UAAU,CAACM,IAAI,CAACC,OAAO,CAACR,SAAS,GAAGH,cAAc,CAACG,SAAS;EAC9D,CAAC,MAAM;IACLC,UAAU,CAACM,IAAI,CAACC,OAAO,CAACR,SAAS,GAAGQ,OAAO,CAACR,SAAS;EACvD;AACF;AAEA,SAASmC,IAAIA,CAACQ,OAAO,EAAEnC,OAAO,EAAE;EAC9B,OAAON,KAAK,CAACyC,OAAO,EAAEnC,OAAO,CAAC,CAC3BK,IAAI,CAAC+B,mBAAS,CAAC,CACf/B,IAAI,CAAC,IAAAgC,eAAK,EAAC,GAAG,CAAC,CAAC,CAChBhC,IAAI,CAAC,UAAAiC,KAAK,EAAI;IACb,IAAMV,MAAM,GAAGW,SAAS,CAACJ,OAAO,CAAC;IACjCP,MAAM,CAACC,UAAU,CAAC,IAAI,CAAC,CAACW,SAAS,CAACF,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IAC9C,OAAOV,MAAM;EACf,CAAC,CAAC;EAEJ,SAASW,SAASA,CAACE,KAAK,EAAE;IACxB,IAAMb,MAAM,GAAGc,oBAAQ,CAACC,aAAa,CAAC,QAAQ,CAAC;IAC/Cf,MAAM,CAACd,KAAK,GAAGd,OAAO,CAACc,KAAK,IAAI,IAAAC,kBAAQ,EAAC0B,KAAK,CAAC;IAC/Cb,MAAM,CAACZ,MAAM,GAAGhB,OAAO,CAACgB,MAAM,IAAI,IAAAC,mBAAS,EAACwB,KAAK,CAAC;IAElD,IAAIzC,OAAO,CAACmB,OAAO,EAAE;MACnB,IAAMyB,GAAG,GAAGhB,MAAM,CAACC,UAAU,CAAC,IAAI,CAAC;MACnCe,GAAG,CAACC,SAAS,GAAG7C,OAAO,CAACmB,OAAO;MAC/ByB,GAAG,CAACE,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAElB,MAAM,CAACd,KAAK,EAAEc,MAAM,CAACZ,MAAM,CAAC;IACjD;IAEA,OAAOY,MAAM;EACf;AACF;AAEA,SAASrB,SAASA,CAACN,IAAI,EAAEO,MAAM,EAAEuC,IAAI,EAAE;EACrC,IAAI,CAACA,IAAI,IAAIvC,MAAM,IAAI,CAACA,MAAM,CAACP,IAAI,CAAC,EAAE;IACpC,OAAOE,OAAO,CAACC,OAAO,CAAC,CAAC;EAC1B;EAEA,OAAOD,OAAO,CAACC,OAAO,CAACH,IAAI,CAAC,CACzBI,IAAI,CAAC2C,YAAY,CAAC,CAClB3C,IAAI,CAAC,UAAAO,KAAK;IAAA,OAAIqC,aAAa,CAAChD,IAAI,EAAEW,KAAK,EAAEJ,MAAM,CAAC;EAAA,EAAC,CACjDH,IAAI,CAAC,UAAAO,KAAK;IAAA,OAAI,IAAAsC,sBAAY,EAACjD,IAAI,EAAEW,KAAK,CAAC;EAAA,EAAC;EAE3C,SAASoC,YAAYA,CAAC1C,EAAE,EAAE;IACxB,IAAIA,EAAE,YAAY6C,kBAAM,CAACC,iBAAiB,EAAE;MAC1C,OAAO,IAAAhB,mBAAS,EAAC9B,EAAE,CAAC0B,SAAS,CAAC,CAAC,CAAC;IAClC;IACA,OAAO1B,EAAE,CAACC,SAAS,CAAC,KAAK,CAAC;EAC5B;EAEA,SAAS8C,oBAAoBA,CAACC,MAAM,EAAEC,WAAW,EAAEC,GAAG,EAAE;IACtD,IAAIC,IAAI,GAAGtD,OAAO,CAACC,OAAO,CAAC,CAAC;IAC5BmD,WAAW,CAAC9B,OAAO,CAAC,UAAAiC,KAAK,EAAI;MAC3BD,IAAI,GAAGA,IAAI,CACRpD,IAAI,CAAC;QAAA,OAAME,SAAS,CAACmD,KAAK,EAAEF,GAAG,EAAE,IAAI,CAAC;MAAA,EAAC,CACvCnD,IAAI,CAAC,UAAAsD,UAAU,EAAI;QAClB,IAAIA,UAAU,EAAE;UACdL,MAAM,CAACM,WAAW,CAACD,UAAU,CAAC;QAChC;MACF,CAAC,CAAC;IACN,CAAC,CAAC;IACF,OAAOF,IAAI;EACb;EAEA,SAASR,aAAaA,CAACY,QAAQ,EAAEjD,KAAK,EAAE4C,GAAG,EAAE;IAC3C,IAAMM,QAAQ,GAAGD,QAAQ,CAACE,UAAU;IACpC,IAAID,QAAQ,CAACE,MAAM,KAAK,CAAC,EAAE;MACzB,OAAO7D,OAAO,CAACC,OAAO,CAACQ,KAAK,CAAC;IAC/B;IAEA,OAAOyC,oBAAoB,CAACzC,KAAK,EAAE,IAAAqD,iBAAO,EAACH,QAAQ,CAAC,EAAEN,GAAG,CAAC,CAACnD,IAAI,CAAC;MAAA,OAAMO,KAAK;IAAA,EAAC;EAC9E;AACF;AAEA,SAASH,UAAUA,CAACR,IAAI,EAAE;EACxB,OAAOhB,SAAS,CAACiF,UAAU,CAAC,CAAC,CAAC7D,IAAI,CAAC,UAAA8D,OAAO,EAAI;IAC5C,IAAMC,SAAS,GAAG1B,oBAAQ,CAACC,aAAa,CAAC,OAAO,CAAC;IACjD1C,IAAI,CAAC2D,WAAW,CAACQ,SAAS,CAAC;IAC3BA,SAAS,CAACR,WAAW,CAAClB,oBAAQ,CAAC2B,cAAc,CAACF,OAAO,CAAC,CAAC;IACvD,OAAOlE,IAAI;EACb,CAAC,CAAC;AACJ;AAEA,SAASS,YAAYA,CAACT,IAAI,EAAE;EAC1B,OAAOd,MAAM,CAACmF,SAAS,CAACrE,IAAI,CAAC,CAACI,IAAI,CAAC;IAAA,OAAMJ,IAAI;EAAA,EAAC;AAChD;AAEA,SAASY,cAAcA,CAACZ,IAAI,EAAEa,KAAK,EAAEE,MAAM,EAAgC;EAAA,IAA9BE,qBAAqB,GAAAqD,SAAA,CAAAP,MAAA,QAAAO,SAAA,QAAAhF,SAAA,GAAAgF,SAAA,MAAG,IAAI;EACvE,OAAOpE,OAAO,CAACC,OAAO,CAACH,IAAI,CAAC,CAACI,IAAI,CAAC,UAAAC,EAAE,EAAI;IACtCA,EAAE,CAACkE,YAAY,CAAC,OAAO,EAAE,8BAA8B,CAAC;IACxD,IAAMC,gBAAgB,GAAG,IAAItB,kBAAM,CAACuB,aAAa,CAAC,CAAC,CAACC,iBAAiB,CAACrE,EAAE,CAAC;IAEzE,IAAMsE,KAAK,GAAG1D,qBAAqB,GAAG,IAAA2D,qBAAW,EAACJ,gBAAgB,CAAC,GAAGA,gBAAgB;IACtF,IAAMK,aAAa,oEAAAxD,MAAA,CAA4DsD,KAAK,qBAAkB;IACtG,IAAMG,MAAM,wDAAAzD,MAAA,CAAqDR,KAAK,kBAAAQ,MAAA,CAAaN,MAAM,SAAAM,MAAA,CAAKwD,aAAa,WAAQ;;IAEnH;IACA;IACA;IACA;IACA,OAAO,IAAAE,0BAAgB,EAACD,MAAM,CAAC;EACjC,CAAC,CAAC;AACJ;AAEA,SAAS/F,UAAUA,CAAA,EAAG;EACpB,IAAMiG,SAAS,GAAG,6BAA6B;EAE/C,OAAO;IACLX,SAAS,EAATA,SAAS;IACTY,aAAa,EAAbA,aAAa;IACbnF,IAAI,EAAE;MACJoF,QAAQ,EAARA,QAAQ;MACRC,MAAM,EAANA;IACF;EACF,CAAC;EAED,SAASF,aAAaA,CAACG,MAAM,EAAE;IAC7B,OAAOA,MAAM,CAACC,MAAM,CAACL,SAAS,CAAC,KAAK,CAAC,CAAC;EACxC;EAEA,SAASE,QAAQA,CAACE,MAAM,EAAE;IACxB,IAAME,MAAgB,GAAG,EAAE;IAC3B,IAAIC,KAA6B;IACjC,OAAO,CAACA,KAAK,GAAGP,SAAS,CAACQ,IAAI,CAACJ,MAAM,CAAC,MAAM,IAAI,EAAE;MAChDE,MAAM,CAACG,IAAI,CAACF,KAAK,CAAC,CAAC,CAAC,CAAC;IACvB;IACA,OAAOD,MAAM,CAAC/E,MAAM,CAAC,UAAAmF,GAAG,EAAI;MAC1B,OAAO,CAAC,IAAAC,mBAAS,EAACD,GAAG,CAAC;IACxB,CAAC,CAAC;EACJ;EAEA,SAASE,UAAUA,CAACC,IAAI,EAAE;IACxB,OAAO,IAAIC,MAAM,mBAAAzE,MAAA,CAAkB,IAAA0E,gBAAM,EAACF,IAAI,CAAC,mBAAe,GAAG,CAAC;EACpE;EAEA,SAASV,MAAMA,CAACC,MAAM,EAAEM,GAAG,EAAEM,OAAO,EAAEC,GAAG,EAAE;IACzC,OAAO/F,OAAO,CAACC,OAAO,CAACuF,GAAG,CAAC,CACxBtF,IAAI,CAAC,UAAA8F,EAAE;MAAA,OAAKF,OAAO,GAAG,IAAAG,oBAAU,EAACD,EAAE,EAAEF,OAAO,CAAC,GAAGE,EAAE;IAAA,CAAC,CAAC,CACpD9F,IAAI,CAAC,UAAA8F,EAAE;MAAA,OAAK,OAAOD,GAAG,KAAK,UAAU,GAAGA,GAAG,CAACC,EAAE,CAAC,GAAG,IAAAE,sBAAY,EAACF,EAAE,EAAE1G,UAAU,CAACM,IAAI,CAACC,OAAO,CAAC;IAAA,CAAC,CAAC,CAC7FK,IAAI,CAAC,UAAA0B,IAAI;MAAA,OAAI,IAAAuE,mBAAS,EAACvE,IAAI,EAAE,IAAAwE,kBAAQ,EAACZ,GAAG,CAAC,CAAC;IAAA,EAAC,CAC5CtF,IAAI,CAAC,UAAAmG,OAAO;MAAA,OAAInB,MAAM,CAACoB,OAAO,CAACZ,UAAU,CAACF,GAAG,CAAC,OAAArE,MAAA,CAAOkF,OAAO,OAAI,CAAC;IAAA,EAAC;EACvE;EAEA,SAASlC,SAASA,CAACe,MAAM,EAAEY,OAAO,EAAEC,GAAG,EAAE;IACvC,IAAI,CAAChB,aAAa,CAACG,MAAM,CAAC,IAAI,IAAAqB,wBAAc,EAACrB,MAAM,CAAC,EAAE;MACpD,OAAOlF,OAAO,CAACC,OAAO,CAACiF,MAAM,CAAC;IAChC;IACA,OAAOlF,OAAO,CAACC,OAAO,CAACiF,MAAM,CAAC,CAC3BhF,IAAI,CAAC8E,QAAQ,CAAC,CACd9E,IAAI,CAAC,UAAAsG,IAAI,EAAI;MACZ,IAAIlD,IAAI,GAAGtD,OAAO,CAACC,OAAO,CAACiF,MAAM,CAAC;MAClCsB,IAAI,CAAClF,OAAO,CAAC,UAAAkE,GAAG,EAAI;QAClBlC,IAAI,GAAGA,IAAI,CAACpD,IAAI,CAAC,UAAAuG,GAAG;UAAA,OAAIxB,MAAM,CAACwB,GAAG,EAAEjB,GAAG,EAAEM,OAAO,EAAEC,GAAG,CAAC;QAAA,EAAC;MACzD,CAAC,CAAC;MACF,OAAOzC,IAAI;IACb,CAAC,CAAC;EACN;AACF;AAEA,SAASvE,YAAYA,CAAA,EAAG;EACtB,OAAO;IACLgF,UAAU,EAAVA,UAAU;IACVnE,IAAI,EAAE;MAAC8G,OAAO,EAAPA;IAAO;EAChB,CAAC;EAED,SAAS3C,UAAUA,CAAA,EAAG;IACpB,OAAO2C,OAAO,CAAC,CAAC,CACbxG,IAAI,CAAC,UAAAyG,QAAQ,EAAI;MAChB,OAAO3G,OAAO,CAAC4G,GAAG,CAACD,QAAQ,CAACE,GAAG,CAAC,UAAAC,OAAO;QAAA,OAAIA,OAAO,CAAC7G,OAAO,CAAC,CAAC;MAAA,EAAC,CAAC;IAChE,CAAC,CAAC,CACDC,IAAI,CAAC,UAAA6G,UAAU;MAAA,OAAIA,UAAU,CAACC,IAAI,CAAC,IAAI,CAAC;IAAA,EAAC;EAC9C;EAEA,SAASN,OAAOA,CAAA,EAAG;IACjB,OAAO1G,OAAO,CAACC,OAAO,CAAC,IAAA6D,iBAAO,EAACvB,oBAAQ,CAAC0E,WAAW,CAAC,CAAC,CAClD/G,IAAI,CAACgH,uBAAuB,CAAC,CAC7BhH,IAAI,CAACiH,WAAW,CAAC,CACjBjH,IAAI,CAACkH,kBAAkB,CAAC,CACxBlH,IAAI,CAAC,UAAAmH,KAAK;MAAA,OAAIA,KAAK,CAACR,GAAG,CAACS,UAAU,CAAC;IAAA,EAAC;IAEvC,SAASF,kBAAkBA,CAACG,QAAQ,EAAE;MACpC,OAAOA,QAAQ,CACZlH,MAAM,CAAC,UAAAmH,IAAI;QAAA,OAAIA,IAAI,CAACC,IAAI,KAAKzE,kBAAM,CAAC0E,OAAO,CAACC,cAAc;MAAA,EAAC,CAC3DtH,MAAM,CAAC,UAAAmH,IAAI;QAAA,OAAI5I,OAAO,CAACmG,aAAa,CAACyC,IAAI,CAACvG,KAAK,CAAC2G,gBAAgB,CAAC,KAAK,CAAC,CAAC;MAAA,EAAC;IAC9E;IAEA,SAASV,uBAAuBA,CAACD,WAAW,EAAE;MAC5C,OAAOjH,OAAO,CAAC4G,GAAG,CAChBK,WAAW,CAACJ,GAAG,CAAC,UAAAgB,KAAK,EAAI;QACvB,IAAIA,KAAK,CAACC,IAAI,EAAE;UACd;UACA;UACA,IAAMC,KAAK,GAAGF,KAAK,CAACC,IAAI,CAACE,QAAQ,CAAC,YAAY,CAAC,GAAG,UAAU,GAAG,SAAS;UACxE,OAAOhF,kBAAM,CAACiF,KAAK,CAACJ,KAAK,CAACC,IAAI,EAAE;YAACI,WAAW,EAAE,MAAM;YAAEH,KAAK,EAALA;UAAK,CAAC,CAAC,CAC1D7H,IAAI,CAAC,UAAAiI,QAAQ;YAAA,OAAIA,QAAQ,CAACC,IAAI,CAAC,CAAC;UAAA,EAAC,CACjClI,IAAI,CAAC,UAAAkI,IAAI,EAAI;YACZ,IAAMhD,MAAM,GAAG,IAAAiD,+BAAqB,EAACD,IAAI,EAAEP,KAAK,CAACC,IAAI,CAAC;YACtD,OAAO,IAAAQ,sBAAY,EAAClD,MAAM,CAAC;UAC7B,CAAC,CAAC,SACI,CAAC,UAAAmD,GAAG,EAAI;YACZ;YACA;YACA;YACAC,mBAAO,CAACC,IAAI,CAACC,8BAAmB,CAACC,UAAU,EAAEd,KAAK,CAACC,IAAI,CAAC;YACxDU,mBAAO,CAACI,GAAG,CAACL,GAAG,CAAC;YAChB;UACF,CAAC,CAAC;QACN;QACA,OAAOvI,OAAO,CAACC,OAAO,CAAC4H,KAAK,CAAC;MAC/B,CAAC,CACH,CAAC;IACH;IAEA,SAASV,WAAWA,CAACF,WAAW,EAAE;MAChC,IAAMM,QAAe,GAAG,EAAE;MAC1BN,WAAW,CAAC3F,OAAO,CAAC,UAAAuG,KAAK,EAAI;QAC3B;QACA,IAAI,CAACA,KAAK,EAAE;UACV;QACF;QACA,IAAIR,KAAK;QACT,IAAI;UACFA,KAAK,GAAGQ,KAAK,CAACR,KAAK,IAAIQ,KAAK,CAACN,QAAQ;QACvC,CAAC,CAAC,OAAOsB,CAAC,EAAE;UACVL,mBAAO,CAACI,GAAG,kCAAAzH,MAAA,CAAkC0G,KAAK,CAACC,IAAI,GAAIe,CAAC,CAAC;UAC7D;QACF;QAEA,IAAIxB,KAAK,IAAI,IAAAyB,QAAA,aAAOzB,KAAK,MAAK,QAAQ,EAAE;UACtC,IAAI;YACF,IAAAvD,iBAAO,EAACuD,KAAK,IAAI,EAAE,CAAC,CAAC/F,OAAO,CAACiG,QAAQ,CAAChC,IAAI,CAACwD,IAAI,CAACxB,QAAQ,CAAC,CAAC;UAC5D,CAAC,CAAC,OAAOsB,CAAC,EAAE;YACVL,mBAAO,CAACI,GAAG,uCAAAzH,MAAA,CAAuC0G,KAAK,CAACC,IAAI,GAAIe,CAAC,CAAC;YAClE;UACF;QACF,CAAC,MAAM;UACLL,mBAAO,CAACI,GAAG,CAAC,mCAAmC,CAAC;UAChD;QACF;MACF,CAAC,CAAC;MAEF,OAAOrB,QAAQ;IACjB;IAEA,SAASD,UAAUA,CAAC0B,WAAW,EAAE;MAC/B,OAAO;QACL/I,OAAO,EAAE,SAATA,OAAOA,CAAA,EAAQ;UACb,IAAM6F,OAAO,GAAG,CAACkD,WAAW,CAACC,gBAAgB,IAAI,CAAC,CAAC,EAAEnB,IAAI;UACzD,OAAOlJ,OAAO,CAACuF,SAAS,CAAC6E,WAAW,CAAChF,OAAO,EAAE8B,OAAO,EAAE,IAAI,CAAC;QAC9D,CAAC;QACDoD,GAAG,EAAE,SAALA,GAAGA,CAAA;UAAA,OAAQF,WAAW,CAAC/H,KAAK,CAAC2G,gBAAgB,CAAC,KAAK,CAAC;QAAA;MACtD,CAAC;IACH;EACF;AACF;AAEA,SAAS3I,SAASA,CAAA,EAAG;EACnB,OAAO;IACLkF,SAAS,EAATA,SAAS;IACTvE,IAAI,EAAE;MACJuJ,QAAQ,EAARA;IACF;EACF,CAAC;EAED,SAASA,QAAQA,CAACC,OAAO,EAAE;IACzB,SAASnE,MAAMA,CAACc,GAAG,EAAE;MACnB,IAAI,IAAAN,mBAAS,EAAC2D,OAAO,CAACF,GAAG,CAAC,EAAE;QAC1B,OAAOlJ,OAAO,CAACC,OAAO,CAAC,CAAC;MAC1B;MACA,OAAOD,OAAO,CAACC,OAAO,CAACmJ,OAAO,CAACF,GAAG,CAAC,CAChChJ,IAAI,CAAC,UAAA8F,EAAE;QAAA,OACN,OAAOD,GAAG,KAAK,UAAU,GAAGA,GAAG,CAACC,EAAE,CAAC,GAAG,IAAAE,sBAAY,EAACF,EAAE,EAAE1G,UAAU,CAACM,IAAI,CAACC,OAAO,CAAC;MAAA,CACjF,CAAC,CACAK,IAAI,CAAC,UAAA0B,IAAI;QAAA,OAAI,IAAAuE,mBAAS,EAACvE,IAAI,EAAE,IAAAwE,kBAAQ,EAACgD,OAAO,CAACF,GAAG,CAAC,CAAC;MAAA,EAAC,CACpDhJ,IAAI,CACH,UAAAmG,OAAO;QAAA,OACL,IAAIrG,OAAO,CAAC,UAACC,OAAO,EAAEoJ,MAAM,EAAK;UAC/BD,OAAO,CAACE,MAAM,GAAGrJ,OAAO;UACxBmJ,OAAO,CAACG,OAAO,GAAGF,MAAM;UACxBD,OAAO,CAACF,GAAG,GAAG7C,OAAO;QACvB,CAAC,CAAC;MAAA,CACN,CAAC;IACL;IAEA,OAAO;MACLpB,MAAM,EAANA;IACF,CAAC;EACH;EAEA,SAASd,SAASA,CAACrE,IAAI,EAAE;IACvB,IAAI,EAAEA,IAAI,YAAY0J,OAAO,CAAC,EAAE;MAC9B,OAAOxJ,OAAO,CAACC,OAAO,CAACH,IAAI,CAAC;IAC9B;IAEA,OAAO2J,gBAAgB,CAAC3J,IAAI,CAAC,CAACI,IAAI,CAAC,YAAM;MACvC,IAAIJ,IAAI,YAAY4J,gBAAgB,EAAE;QACpC,OAAOP,QAAQ,CAACrJ,IAAI,CAAC,CAACmF,MAAM,CAAC,IAAI,CAAC;MACpC;MACA,OAAOjF,OAAO,CAAC4G,GAAG,CAAC,IAAA9C,iBAAO,EAAChE,IAAI,CAAC8D,UAAU,CAAC,CAACiD,GAAG,CAAC,UAAAtD,KAAK;QAAA,OAAIY,SAAS,CAACZ,KAAK,CAAC;MAAA,EAAC,CAAC;IAC7E,CAAC,CAAC;IAEF,SAASkG,gBAAgBA,CAACtJ,EAAE,EAAE;MAC5B,IAAMwJ,UAAU,GAAGxJ,EAAE,CAACc,KAAK,CAAC2G,gBAAgB,CAAC,YAAY,CAAC;MAE1D,IAAI,CAAC+B,UAAU,EAAE;QACf,OAAO3J,OAAO,CAACC,OAAO,CAACE,EAAE,CAAC;MAC5B;MAEA,OAAOvB,OAAO,CACXuF,SAAS,CAACwF,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CACjCzJ,IAAI,CAAC,UAAA0J,OAAO,EAAI;QACfzJ,EAAE,CAACc,KAAK,CAAC4I,WAAW,CAAC,YAAY,EAAED,OAAO,EAAEzJ,EAAE,CAACc,KAAK,CAAC6I,mBAAmB,CAAC,YAAY,CAAC,CAAC;MACzF,CAAC,CAAC,CACD5J,IAAI,CAAC;QAAA,OAAMC,EAAE;MAAA,EAAC;IACnB;EACF;AACF;AAAC,IAAA4J,QAAA,GAAAC,OAAA,cAEc1K,UAAU","ignoreList":[]}
|
|
433
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","_interopRequireDefault","require","_document","_console","_constants","_domUtils","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","getWidth","height","getHeight","escapeXhtmlForWebpack","bgcolor","style","backgroundColor","concat","Object","keys","forEach","property","draw","canvas","getContext","getImageData","data","toDataURL","quality","canvasToBlob","domNode","makeImage","delay","image","newCanvas","drawImage","dNode","document","createElement","ctx","fillStyle","fillRect","root","makeNodeCopy","cloneChildren","processClone","Window","HTMLCanvasElement","cloneChildrenInOrder","parent","arrChildren","flt","done","child","childClone","appendChild","original","children","childNodes","length","asArray","resolveAll","cssText","styleNode","createTextNode","inlineAll","arguments","setAttribute","serializedString","XMLSerializer","serializeToString","xhtml","escapeXhtml","foreignObject","svgStr","base64Svg","Buffer","from","toString","TextEncoder","bytes","encode","CHUNK_SIZE","binary","i","String","fromCharCode","apply","Array","slice","btoa","Error","URL_REGEX","shouldProcess","readUrls","inline","string","search","result","match","exec","push","url","isDataUrl","urlAsRegex","url0","RegExp","escape","baseUrl","get","ul","resolveUrl","getAndEncode","dataAsUrl","mimeType","dataUrl","replace","isSrcAsDataUrl","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","setStyleSheetBaseHref","toStyleSheet","err","Console","warn","IMAGE_EXPORT_ERRORS","styleSheet","log","e","_typeof2","bind","webFontRule","parentStyleSheet","src","newImage","element","reject","onload","onerror","Element","inlineBackground","HTMLImageElement","background","inlined","setProperty","getPropertyPriority","_default","exports"],"sources":["../src/dom-to-image.ts"],"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 {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    // Use base64 encoding\n    let base64Svg: string;\n    if (typeof Buffer !== 'undefined' && Buffer.from) {\n      base64Svg = Buffer.from(svgStr, 'utf8').toString('base64');\n    } else if (typeof TextEncoder !== 'undefined') {\n      // Modern browsers: TextEncoder handles Unicode → UTF-8 bytes\n      // Must chunk to avoid call stack limits with large arrays\n      const bytes = new TextEncoder().encode(svgStr);\n      const CHUNK_SIZE = 8192;\n      let binary = '';\n      for (let i = 0; i < bytes.length; i += CHUNK_SIZE) {\n        binary += String.fromCharCode.apply(null, Array.from(bytes.slice(i, i + CHUNK_SIZE)));\n      }\n      base64Svg = Window.btoa(binary);\n    } else {\n      throw new Error('No base64 encoder found');\n    }\n    return `data:image/svg+xml;base64,${base64Svg}`;\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.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"],"mappings":"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","ignoreList":[]}
|
package/dist/export-map-html.js
CHANGED
|
@@ -20,6 +20,6 @@ var _constants = require("@kepler.gl/constants");
|
|
|
20
20
|
*/
|
|
21
21
|
var exportMapToHTML = exports.exportMapToHTML = function exportMapToHTML(options) {
|
|
22
22
|
var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _constants.KEPLER_GL_VERSION;
|
|
23
|
-
return "\n <!DOCTYPE html>\n <html>\n <head>\n <meta charset=\"UTF-8\"/>\n <title>Kepler.gl embedded map</title>\n\n <!--Uber Font-->\n <link rel=\"stylesheet\" href=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/uber-fonts/4.0.0/superfine.css\">\n\n <!--Kepler css-->\n <link href=\"https://unpkg.com/kepler.gl@".concat(version, "/umd/keplergl.min.css\" rel=\"stylesheet\">\n\n <!--MapBox css-->\n <link href=\"https://api.tiles.mapbox.com/mapbox-gl-js/v1.1.1/mapbox-gl.css\" rel=\"stylesheet\">\n <link href=\"https://unpkg.com/maplibre-gl@^3/dist/maplibre-gl.css\" rel=\"stylesheet\">\n\n <!-\u2014 facebook open graph tags -->\n <meta property=\"og:url\" content=\"http://kepler.gl/\" />\n <meta property=\"og:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\" />\n <meta property=\"og:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\" />\n <meta property=\"og:site_name\" content=\"kepler.gl\" />\n <meta property=\"og:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n <meta property=\"og:image:type\" content=\"image/png\" />\n <meta property=\"og:image:width\" content=\"800\" />\n <meta property=\"og:image:height\" content=\"800\" />\n\n <!-\u2014 twitter card tags -->\n <meta name=\"twitter:card\" content=\"summary_large_image\">\n <meta name=\"twitter:site\" content=\"@openjsf\">\n <meta name=\"twitter:creator\" content=\"@openjsf\">\n <meta name=\"twitter:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\">\n <meta name=\"twitter:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\">\n <meta name=\"twitter:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n\n <!-- Load React/Redux -->\n <script src=\"https://unpkg.com/react@18.3.1/umd/react.production.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/react-dom@18.3.1/umd/react-dom.production.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/redux@4.2.1/dist/redux.js\" crossorigin></script>\n <script src=\"https://unpkg.com/react-redux@8.1.2/dist/react-redux.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/styled-components@6.1.8/dist/styled-components.min.js\" crossorigin></script>\n\n <!-- Load Kepler.gl -->\n <script src=\"https://unpkg.com/kepler.gl@").concat(version, "/umd/keplergl.min.js\" crossorigin></script>\n\n <style type=\"text/css\">\n body {margin: 0; padding: 0; overflow: hidden;}\n </style>\n\n <!--MapBox token-->\n <script>\n /**\n * Provide your MapBox Token\n **/\n const MAPBOX_TOKEN = '").concat(options.mapboxApiAccessToken || 'PROVIDE_MAPBOX_TOKEN', "';\n const WARNING_MESSAGE = 'Please Provide a Mapbox Token in order to use Kepler.gl. Edit this file and fill out MAPBOX_TOKEN with your access key';\n </script>\n\n <!-- GA: Delete this as you wish, However to pat ourselves on the back, we only track anonymous pageview to understand how many people are using kepler.gl. -->\n <script>\n (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){\n (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),\n m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)\n })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');\n ga('create', 'UA-64694404-19', {\n 'storage': 'none',\n 'clientId': localStorage.getItem('ga:clientId')\n });\n ga(function(tracker) {\n localStorage.setItem('ga:clientId', tracker.get('clientId'));\n });\n ga('set', 'checkProtocolTask', null); // Disable file protocol checking.\n ga('set', 'checkStorageTask', null); // Disable cookie storage checking.\n ga('set', 'historyImportTask', null); // Disable history checking (requires reading from cookies).\n ga('set', 'page', 'keplergl-html');\n ga('send', 'pageview');\n </script>\n </head>\n <body>\n <!-- We will put our React component inside this div. -->\n <div id=\"app\">\n <!-- Kepler.gl map will be placed here-->\n </div>\n\n <!-- Load our React component. -->\n <script>\n /* Validate Mapbox Token */\n if ((MAPBOX_TOKEN || '') === '' || MAPBOX_TOKEN === 'PROVIDE_MAPBOX_TOKEN') {\n alert(WARNING_MESSAGE);\n }\n\n /** STORE **/\n const reducers = (function createReducers(redux, keplerGl) {\n return redux.combineReducers({\n // mount keplerGl reducer\n keplerGl: keplerGl.keplerGlReducer.initialState({\n uiState: {\n readOnly: ").concat(options.mode === _constants.EXPORT_HTML_MAP_MODES.READ, ",\n currentModal: null\n }\n })\n });\n }(Redux, KeplerGl));\n\n const middleWares = (function createMiddlewares(keplerGl) {\n return keplerGl.enhanceReduxMiddleware([\n // Add other middlewares here\n ]);\n }(KeplerGl));\n\n const enhancers = (function craeteEnhancers(redux, middles) {\n return redux.applyMiddleware(...middles);\n }(Redux, middleWares));\n\n const store = (function createStore(redux, enhancers) {\n const initialState = {};\n\n return redux.createStore(\n reducers,\n initialState,\n redux.compose(enhancers)\n );\n }(Redux, enhancers));\n /** END STORE **/\n\n /** COMPONENTS **/\n var KeplerElement = (function makeKeplerElement(react, keplerGl, mapboxToken) {\n var LogoSvg = function LogoSvg() {\n return react.createElement(\n \"div\",\n { className: \"logo-container\", style: {position: 'fixed', zIndex: 10000, padding: '4px'} },\n react.createElement(\n \"svg\",\n {\n className: \"kepler_gl__logo\",\n width: \"107px\",\n height: \"21px\",\n viewBox: \"0 0 124 24\"\n },\n react.createElement(\n \"g\",\n { transform: \"translate(13.500000, 13.500000) rotate(45.000000) translate(-13.500000, -13.500000) translate(4.000000, 4.000000)\" },\n react.createElement(\"rect\", { x: \"0\", y: \"6\", transform: \"matrix(2.535181e-06 1 -1 2.535181e-06 18.1107 6.0369)\", fill: \"#535C6C\", width: \"12.1\", height: \"12.1\" }),\n react.createElement(\"rect\", { x: \"6\", y: \"0\", transform: \"matrix(2.535182e-06 1 -1 2.535182e-06 18.1107 -6.0369)\", fill:\"#1FBAD6\", width: \"12.1\", height: \"12.1\" })\n ),\n react.createElement(\n \"g\",\n {},\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M39,8.7h2.2l-2.8,4.2l2.9,5.1H39l-2.4-4.2h-1.3V18h-2V5l2-0.1v7.3h1.3L39,8.7z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M42.4,13.3c0-1.5,0.4-2.7,1.1-3.5s1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C42.8,16.1,42.4,14.9,42.4,13.3z M46.6,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S47.2,10.1,46.6,10.1z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M57.1,18.2c-1,0-1.8-0.3-2.3-0.9l0,0l0,1.3v2.5h-2V8.7h1.5l0.3,0.9h0c0.3-0.3,0.7-0.6,1.2-0.7 c0.4-0.2,0.9-0.3,1.4-0.3c1.2,0,2.1,0.4,2.7,1.1c0.6,0.7,0.9,2,0.9,3.7c0,1.6-0.3,2.8-1,3.7C59.2,17.8,58.3,18.2,57.1,18.2z M56.7,10.3c-0.4,0-0.8,0.1-1.1,0.2c-0.3,0.2-0.6,0.4-0.8,0.7v4.3c0.2,0.3,0.4,0.5,0.7,0.7c0.3,0.2,0.7,0.3,1.1,0.3 c0.7,0,1.2-0.2,1.6-0.7c0.4-0.5,0.5-1.3,0.5-2.5c0-0.8-0.1-1.4-0.2-1.8s-0.4-0.7-0.7-0.9C57.6,10.4,57.2,10.3,56.7,10.3z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M63.2,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S63.2,16.8,63.2,16z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M68.2,13.3c0-1.5,0.4-2.7,1.1-3.5c0.7-0.8,1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C68.6,16.1,68.2,14.9,68.2,13.3z M72.4,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S73,10.1,72.4,10.1z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M80.2,8.7l0.1,1.7h0c0.3-0.6,0.7-1.1,1.1-1.4c0.4-0.3,1-0.5,1.6-0.5c0.4,0,0.7,0,1,0.1l-0.1,2 c-0.3-0.1-0.7-0.2-1-0.2c-0.7,0-1.3,0.3-1.7,0.8c-0.4,0.5-0.7,1.2-0.7,2.1V18h-2V8.7H80.2z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M83.8,17c0-0.8,0.4-1.2,1.2-1.2c0.8,0,1.2,0.4,1.2,1.2c0,0.8-0.4,1.1-1.2,1.1C84.2,18.2,83.8,17.8,83.8,17z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M88.5,18.7c0-0.8,0.4-1.4,1.2-1.8c-0.6-0.3-0.9-0.8-0.9-1.5c0-0.7,0.4-1.2,1.1-1.6c-0.3-0.3-0.6-0.6-0.7-0.9 c-0.2-0.4-0.2-0.8-0.2-1.3c0-1,0.3-1.8,0.9-2.3c0.6-0.5,1.6-0.8,2.8-0.8c0.5,0,1,0,1.4,0.1c0.4,0.1,0.8,0.2,1.1,0.4l2.4-0.2v1.5 h-1.5c0.2,0.4,0.2,0.8,0.2,1.3c0,1-0.3,1.7-0.9,2.2s-1.5,0.8-2.7,0.8c-0.7,0-1.2-0.1-1.6-0.2c-0.1,0.1-0.2,0.2-0.3,0.3 c-0.1,0.1-0.1,0.2-0.1,0.4c0,0.2,0.1,0.3,0.2,0.4c0.1,0.1,0.3,0.2,0.6,0.2l2.7,0.2c1,0.1,1.7,0.3,2.2,0.6c0.5,0.3,0.8,0.9,0.8,1.7 c0,0.6-0.2,1.1-0.5,1.5c-0.4,0.4-0.9,0.8-1.5,1c-0.7,0.2-1.5,0.4-2.4,0.4c-1.3,0-2.3-0.2-3-0.6C88.8,20.1,88.5,19.5,88.5,18.7z M95.1,18.4c0-0.3-0.1-0.5-0.3-0.7s-0.6-0.2-1.1-0.3l-2.7-0.3c-0.2,0.1-0.4,0.3-0.5,0.5c-0.1,0.2-0.2,0.4-0.2,0.6 c0,0.4,0.2,0.8,0.5,1c0.4,0.2,1,0.3,1.8,0.3C94.2,19.5,95.1,19.2,95.1,18.4z M94.3,11.5c0-0.6-0.1-1-0.4-1.2 c-0.3-0.2-0.7-0.3-1.3-0.3c-0.7,0-1.1,0.1-1.4,0.3c-0.3,0.2-0.4,0.6-0.4,1.2s0.1,1,0.4,1.2c0.3,0.2,0.7,0.3,1.4,0.3 c0.6,0,1.1-0.1,1.3-0.4S94.3,12,94.3,11.5z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M99.4,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S99.4,16.8,99.4,16z\" })\n )\n )\n );\n };\n\n return function App() {\n var rootElm = react.useRef(null);\n var _useState = react.useState({\n width: window.innerWidth,\n height: window.innerHeight\n });\n var windowDimension = _useState[0];\n var setDimension = _useState[1];\n react.useEffect(function sideEffect(){\n function handleResize() {\n setDimension({width: window.innerWidth, height: window.innerHeight});\n };\n window.addEventListener('resize', handleResize);\n return function() {window.removeEventListener('resize', handleResize);};\n }, []);\n return react.createElement(\n 'div',\n {style: {position: 'absolute', left: 0, width: '100vw', height: '100vh'}},\n ").concat(options.mode === _constants.EXPORT_HTML_MAP_MODES.READ ? 'LogoSvg(),' : '', "\n react.createElement(keplerGl.KeplerGl, {\n mapboxApiAccessToken: mapboxToken,\n id: \"map\",\n width: windowDimension.width,\n height: windowDimension.height\n })\n )\n }\n }(React, KeplerGl, MAPBOX_TOKEN));\n\n const app = (function createReactReduxProvider(react, reactRedux, KeplerElement) {\n return react.createElement(\n reactRedux.Provider,\n {store},\n react.createElement(KeplerElement, null)\n )\n }(React, ReactRedux, KeplerElement));\n /** END COMPONENTS **/\n\n /** Render **/\n (function render(react, reactDOM, app) {\n const container = document.getElementById('app');\n const root = reactDOM.createRoot(container);\n root.render(app);\n }(React, ReactDOM, app));\n </script>\n <!-- The next script will show how to interact directly with Kepler map store -->\n <script>\n /**\n * Customize map.\n * In the following section you can use the store object to dispatch Kepler.gl actions\n * to add new data and customize behavior\n */\n (function customize(keplerGl, store) {\n const datasets = ").concat(JSON.stringify(options.datasets), ";\n const config = ").concat(JSON.stringify(options.config), ";\n\n const loadedData = keplerGl.KeplerGlSchema.load(\n datasets,\n config\n );\n\n // For some reason Kepler overwrites the config without extra wait time\n window.setTimeout(() => {\n store.dispatch(\n keplerGl.addDataToMap({\n datasets: loadedData.datasets,\n config: loadedData.config,\n options: {\n centerMap: false,\n },\n })\n );\n }, 500);\n }(KeplerGl, store))\n </script>\n </body>\n </html>\n ");
|
|
23
|
+
return "\n <!DOCTYPE html>\n <html>\n <head>\n <meta charset=\"UTF-8\"/>\n <title>Kepler.gl embedded map</title>\n\n <!--Uber Font-->\n <link rel=\"stylesheet\" href=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/uber-fonts/4.0.0/superfine.css\">\n\n <!--Kepler css-->\n <link href=\"https://unpkg.com/kepler.gl@".concat(version, "/umd/keplergl.min.css\" rel=\"stylesheet\">\n\n <!--MapBox css-->\n <link href=\"https://api.tiles.mapbox.com/mapbox-gl-js/v1.1.1/mapbox-gl.css\" rel=\"stylesheet\">\n <link href=\"https://unpkg.com/maplibre-gl@^3/dist/maplibre-gl.css\" rel=\"stylesheet\">\n\n <!-\u2014 facebook open graph tags -->\n <meta property=\"og:url\" content=\"http://kepler.gl/\" />\n <meta property=\"og:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\" />\n <meta property=\"og:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\" />\n <meta property=\"og:site_name\" content=\"kepler.gl\" />\n <meta property=\"og:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n <meta property=\"og:image:type\" content=\"image/png\" />\n <meta property=\"og:image:width\" content=\"800\" />\n <meta property=\"og:image:height\" content=\"800\" />\n\n <!-\u2014 twitter card tags -->\n <meta name=\"twitter:card\" content=\"summary_large_image\">\n <meta name=\"twitter:site\" content=\"@openjsf\">\n <meta name=\"twitter:creator\" content=\"@openjsf\">\n <meta name=\"twitter:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\">\n <meta name=\"twitter:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\">\n <meta name=\"twitter:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n\n <!-- Load React/Redux -->\n <script src=\"https://unpkg.com/react@18.3.1/umd/react.production.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/react-dom@18.3.1/umd/react-dom.production.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/redux@4.2.1/dist/redux.js\" crossorigin></script>\n <script src=\"https://unpkg.com/react-redux@8.1.2/dist/react-redux.min.js\" crossorigin></script>\n <script src=\"https://unpkg.com/styled-components@6.1.8/dist/styled-components.min.js\" crossorigin></script>\n\n <!-- Load Kepler.gl -->\n <script src=\"https://unpkg.com/kepler.gl@").concat(version, "/umd/keplergl.min.js\" crossorigin></script>\n\n <style type=\"text/css\">\n body {margin: 0; padding: 0; overflow: hidden;}\n </style>\n\n <!--MapBox token-->\n <!--\n SECURITY NOTE: Your Mapbox access token is embedded below in plain text.\n Anyone with access to this HTML file can see and use this token.\n Consider using a scoped token with URL restrictions to limit misuse.\n See: https://docs.mapbox.com/accounts/guides/tokens/#url-restrictions\n -->\n <script>\n /**\n * Provide your MapBox Token\n **/\n const MAPBOX_TOKEN = '").concat(options.mapboxApiAccessToken || 'PROVIDE_MAPBOX_TOKEN', "';\n const WARNING_MESSAGE = 'Please Provide a Mapbox Token in order to use Kepler.gl. Edit this file and fill out MAPBOX_TOKEN with your access key';\n </script>\n\n <!-- GA: Delete this as you wish, However to pat ourselves on the back, we only track anonymous pageview to understand how many people are using kepler.gl. -->\n <script>\n (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){\n (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),\n m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)\n })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');\n ga('create', 'UA-64694404-19', {\n 'storage': 'none',\n 'clientId': localStorage.getItem('ga:clientId')\n });\n ga(function(tracker) {\n localStorage.setItem('ga:clientId', tracker.get('clientId'));\n });\n ga('set', 'checkProtocolTask', null); // Disable file protocol checking.\n ga('set', 'checkStorageTask', null); // Disable cookie storage checking.\n ga('set', 'historyImportTask', null); // Disable history checking (requires reading from cookies).\n ga('set', 'page', 'keplergl-html');\n ga('send', 'pageview');\n </script>\n </head>\n <body>\n <!-- We will put our React component inside this div. -->\n <div id=\"app\">\n <!-- Kepler.gl map will be placed here-->\n </div>\n\n <!-- Load our React component. -->\n <script>\n /* Validate Mapbox Token */\n if ((MAPBOX_TOKEN || '') === '' || MAPBOX_TOKEN === 'PROVIDE_MAPBOX_TOKEN') {\n alert(WARNING_MESSAGE);\n }\n\n /** STORE **/\n const reducers = (function createReducers(redux, keplerGl) {\n return redux.combineReducers({\n // mount keplerGl reducer\n keplerGl: keplerGl.keplerGlReducer.initialState({\n uiState: {\n readOnly: ").concat(options.mode === _constants.EXPORT_HTML_MAP_MODES.READ, ",\n currentModal: null\n }\n })\n });\n }(Redux, KeplerGl));\n\n const middleWares = (function createMiddlewares(keplerGl) {\n return keplerGl.enhanceReduxMiddleware([\n // Add other middlewares here\n ]);\n }(KeplerGl));\n\n const enhancers = (function craeteEnhancers(redux, middles) {\n return redux.applyMiddleware(...middles);\n }(Redux, middleWares));\n\n const store = (function createStore(redux, enhancers) {\n const initialState = {};\n\n return redux.createStore(\n reducers,\n initialState,\n redux.compose(enhancers)\n );\n }(Redux, enhancers));\n /** END STORE **/\n\n /** COMPONENTS **/\n var KeplerElement = (function makeKeplerElement(react, keplerGl, mapboxToken) {\n var LogoSvg = function LogoSvg() {\n return react.createElement(\n \"div\",\n { className: \"logo-container\", style: {position: 'fixed', zIndex: 10000, padding: '4px'} },\n react.createElement(\n \"svg\",\n {\n className: \"kepler_gl__logo\",\n width: \"107px\",\n height: \"21px\",\n viewBox: \"0 0 124 24\"\n },\n react.createElement(\n \"g\",\n { transform: \"translate(13.500000, 13.500000) rotate(45.000000) translate(-13.500000, -13.500000) translate(4.000000, 4.000000)\" },\n react.createElement(\"rect\", { x: \"0\", y: \"6\", transform: \"matrix(2.535181e-06 1 -1 2.535181e-06 18.1107 6.0369)\", fill: \"#535C6C\", width: \"12.1\", height: \"12.1\" }),\n react.createElement(\"rect\", { x: \"6\", y: \"0\", transform: \"matrix(2.535182e-06 1 -1 2.535182e-06 18.1107 -6.0369)\", fill:\"#1FBAD6\", width: \"12.1\", height: \"12.1\" })\n ),\n react.createElement(\n \"g\",\n {},\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M39,8.7h2.2l-2.8,4.2l2.9,5.1H39l-2.4-4.2h-1.3V18h-2V5l2-0.1v7.3h1.3L39,8.7z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M42.4,13.3c0-1.5,0.4-2.7,1.1-3.5s1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C42.8,16.1,42.4,14.9,42.4,13.3z M46.6,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S47.2,10.1,46.6,10.1z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M57.1,18.2c-1,0-1.8-0.3-2.3-0.9l0,0l0,1.3v2.5h-2V8.7h1.5l0.3,0.9h0c0.3-0.3,0.7-0.6,1.2-0.7 c0.4-0.2,0.9-0.3,1.4-0.3c1.2,0,2.1,0.4,2.7,1.1c0.6,0.7,0.9,2,0.9,3.7c0,1.6-0.3,2.8-1,3.7C59.2,17.8,58.3,18.2,57.1,18.2z M56.7,10.3c-0.4,0-0.8,0.1-1.1,0.2c-0.3,0.2-0.6,0.4-0.8,0.7v4.3c0.2,0.3,0.4,0.5,0.7,0.7c0.3,0.2,0.7,0.3,1.1,0.3 c0.7,0,1.2-0.2,1.6-0.7c0.4-0.5,0.5-1.3,0.5-2.5c0-0.8-0.1-1.4-0.2-1.8s-0.4-0.7-0.7-0.9C57.6,10.4,57.2,10.3,56.7,10.3z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M63.2,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S63.2,16.8,63.2,16z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M68.2,13.3c0-1.5,0.4-2.7,1.1-3.5c0.7-0.8,1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C68.6,16.1,68.2,14.9,68.2,13.3z M72.4,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S73,10.1,72.4,10.1z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M80.2,8.7l0.1,1.7h0c0.3-0.6,0.7-1.1,1.1-1.4c0.4-0.3,1-0.5,1.6-0.5c0.4,0,0.7,0,1,0.1l-0.1,2 c-0.3-0.1-0.7-0.2-1-0.2c-0.7,0-1.3,0.3-1.7,0.8c-0.4,0.5-0.7,1.2-0.7,2.1V18h-2V8.7H80.2z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M83.8,17c0-0.8,0.4-1.2,1.2-1.2c0.8,0,1.2,0.4,1.2,1.2c0,0.8-0.4,1.1-1.2,1.1C84.2,18.2,83.8,17.8,83.8,17z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M88.5,18.7c0-0.8,0.4-1.4,1.2-1.8c-0.6-0.3-0.9-0.8-0.9-1.5c0-0.7,0.4-1.2,1.1-1.6c-0.3-0.3-0.6-0.6-0.7-0.9 c-0.2-0.4-0.2-0.8-0.2-1.3c0-1,0.3-1.8,0.9-2.3c0.6-0.5,1.6-0.8,2.8-0.8c0.5,0,1,0,1.4,0.1c0.4,0.1,0.8,0.2,1.1,0.4l2.4-0.2v1.5 h-1.5c0.2,0.4,0.2,0.8,0.2,1.3c0,1-0.3,1.7-0.9,2.2s-1.5,0.8-2.7,0.8c-0.7,0-1.2-0.1-1.6-0.2c-0.1,0.1-0.2,0.2-0.3,0.3 c-0.1,0.1-0.1,0.2-0.1,0.4c0,0.2,0.1,0.3,0.2,0.4c0.1,0.1,0.3,0.2,0.6,0.2l2.7,0.2c1,0.1,1.7,0.3,2.2,0.6c0.5,0.3,0.8,0.9,0.8,1.7 c0,0.6-0.2,1.1-0.5,1.5c-0.4,0.4-0.9,0.8-1.5,1c-0.7,0.2-1.5,0.4-2.4,0.4c-1.3,0-2.3-0.2-3-0.6C88.8,20.1,88.5,19.5,88.5,18.7z M95.1,18.4c0-0.3-0.1-0.5-0.3-0.7s-0.6-0.2-1.1-0.3l-2.7-0.3c-0.2,0.1-0.4,0.3-0.5,0.5c-0.1,0.2-0.2,0.4-0.2,0.6 c0,0.4,0.2,0.8,0.5,1c0.4,0.2,1,0.3,1.8,0.3C94.2,19.5,95.1,19.2,95.1,18.4z M94.3,11.5c0-0.6-0.1-1-0.4-1.2 c-0.3-0.2-0.7-0.3-1.3-0.3c-0.7,0-1.1,0.1-1.4,0.3c-0.3,0.2-0.4,0.6-0.4,1.2s0.1,1,0.4,1.2c0.3,0.2,0.7,0.3,1.4,0.3 c0.6,0,1.1-0.1,1.3-0.4S94.3,12,94.3,11.5z\" }),\n react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M99.4,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S99.4,16.8,99.4,16z\" })\n )\n )\n );\n };\n\n return function App() {\n var rootElm = react.useRef(null);\n var _useState = react.useState({\n width: window.innerWidth,\n height: window.innerHeight\n });\n var windowDimension = _useState[0];\n var setDimension = _useState[1];\n react.useEffect(function sideEffect(){\n function handleResize() {\n setDimension({width: window.innerWidth, height: window.innerHeight});\n };\n window.addEventListener('resize', handleResize);\n return function() {window.removeEventListener('resize', handleResize);};\n }, []);\n return react.createElement(\n 'div',\n {style: {position: 'absolute', left: 0, width: '100vw', height: '100vh'}},\n ").concat(options.mode === _constants.EXPORT_HTML_MAP_MODES.READ ? 'LogoSvg(),' : '', "\n react.createElement(keplerGl.KeplerGl, {\n mapboxApiAccessToken: mapboxToken,\n id: \"map\",\n width: windowDimension.width,\n height: windowDimension.height\n })\n )\n }\n }(React, KeplerGl, MAPBOX_TOKEN));\n\n const app = (function createReactReduxProvider(react, reactRedux, KeplerElement) {\n return react.createElement(\n reactRedux.Provider,\n {store},\n react.createElement(KeplerElement, null)\n )\n }(React, ReactRedux, KeplerElement));\n /** END COMPONENTS **/\n\n /** Render **/\n (function render(react, reactDOM, app) {\n const container = document.getElementById('app');\n const root = reactDOM.createRoot(container);\n root.render(app);\n }(React, ReactDOM, app));\n </script>\n <!-- The next script will show how to interact directly with Kepler map store -->\n <script>\n /**\n * Customize map.\n * In the following section you can use the store object to dispatch Kepler.gl actions\n * to add new data and customize behavior\n */\n (function customize(keplerGl, store) {\n const datasets = ").concat(JSON.stringify(options.datasets), ";\n const config = ").concat(JSON.stringify(options.config), ";\n\n const loadedData = keplerGl.KeplerGlSchema.load(\n datasets,\n config\n );\n\n // For some reason Kepler overwrites the config without extra wait time\n window.setTimeout(() => {\n store.dispatch(\n keplerGl.addDataToMap({\n datasets: loadedData.datasets,\n config: loadedData.config,\n options: {\n centerMap: false,\n },\n })\n );\n }, 500);\n }(KeplerGl, store))\n </script>\n </body>\n </html>\n ");
|
|
24
24
|
};
|
|
25
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","exportMapToHTML","exports","options","version","arguments","length","undefined","KEPLER_GL_VERSION","concat","mapboxApiAccessToken","mode","EXPORT_HTML_MAP_MODES","READ","JSON","stringify","datasets","config"],"sources":["../src/export-map-html.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// @ts-nocheck\nimport {EXPORT_HTML_MAP_MODES, KEPLER_GL_VERSION} from '@kepler.gl/constants';\n\n/**\n * This method is used to create an html file which will inlcude kepler and map data\n * @param {Object} options Object that collects all necessary data to  create the html file\n * @param {string} options.mapboxApiAccessToken Mapbox token used to fetch mapbox tiles\n * @param {Array<Object>} options.datasets Data to include in the map\n * @param {Object} options.config this object will contain the full kepler.gl instance configuration {mapState, mapStyle, visState}\n * @param {string} version which version of Kepler.gl to load.\n */\nexport const exportMapToHTML = (options, version = KEPLER_GL_VERSION) => {\n  return `\n    <!DOCTYPE html>\n    <html>\n      <head>\n        <meta charset=\"UTF-8\"/>\n        <title>Kepler.gl embedded map</title>\n\n        <!--Uber Font-->\n        <link rel=\"stylesheet\" href=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/uber-fonts/4.0.0/superfine.css\">\n\n        <!--Kepler css-->\n        <link href=\"https://unpkg.com/kepler.gl@${version}/umd/keplergl.min.css\" rel=\"stylesheet\">\n\n        <!--MapBox css-->\n        <link href=\"https://api.tiles.mapbox.com/mapbox-gl-js/v1.1.1/mapbox-gl.css\" rel=\"stylesheet\">\n        <link href=\"https://unpkg.com/maplibre-gl@^3/dist/maplibre-gl.css\" rel=\"stylesheet\">\n\n        <!-— facebook open graph tags -->\n        <meta property=\"og:url\" content=\"http://kepler.gl/\" />\n        <meta property=\"og:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\" />\n        <meta property=\"og:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\" />\n        <meta property=\"og:site_name\" content=\"kepler.gl\" />\n        <meta property=\"og:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n        <meta property=\"og:image:type\" content=\"image/png\" />\n        <meta property=\"og:image:width\" content=\"800\" />\n        <meta property=\"og:image:height\" content=\"800\" />\n\n        <!-— twitter card tags -->\n        <meta name=\"twitter:card\" content=\"summary_large_image\">\n        <meta name=\"twitter:site\" content=\"@openjsf\">\n        <meta name=\"twitter:creator\" content=\"@openjsf\">\n        <meta name=\"twitter:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\">\n        <meta name=\"twitter:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\">\n        <meta name=\"twitter:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n\n        <!-- Load React/Redux -->\n        <script src=\"https://unpkg.com/react@18.3.1/umd/react.production.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/react-dom@18.3.1/umd/react-dom.production.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/redux@4.2.1/dist/redux.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/react-redux@8.1.2/dist/react-redux.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/styled-components@6.1.8/dist/styled-components.min.js\" crossorigin></script>\n\n        <!-- Load Kepler.gl -->\n        <script src=\"https://unpkg.com/kepler.gl@${version}/umd/keplergl.min.js\" crossorigin></script>\n\n        <style type=\"text/css\">\n          body {margin: 0; padding: 0; overflow: hidden;}\n        </style>\n\n        <!--MapBox token-->\n        <script>\n          /**\n           * Provide your MapBox Token\n           **/\n          const MAPBOX_TOKEN = '${options.mapboxApiAccessToken || 'PROVIDE_MAPBOX_TOKEN'}';\n          const WARNING_MESSAGE = 'Please Provide a Mapbox Token in order to use Kepler.gl. Edit this file and fill out MAPBOX_TOKEN with your access key';\n        </script>\n\n        <!-- GA: Delete this as you wish, However to pat ourselves on the back, we only track anonymous pageview to understand how many people are using kepler.gl. -->\n        <script>\n          (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){\n          (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),\n          m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)\n          })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');\n          ga('create', 'UA-64694404-19', {\n            'storage': 'none',\n            'clientId': localStorage.getItem('ga:clientId')\n          });\n          ga(function(tracker) {\n              localStorage.setItem('ga:clientId', tracker.get('clientId'));\n          });\n          ga('set', 'checkProtocolTask', null); // Disable file protocol checking.\n          ga('set', 'checkStorageTask', null); // Disable cookie storage checking.\n          ga('set', 'historyImportTask', null); // Disable history checking (requires reading from cookies).\n          ga('set', 'page', 'keplergl-html');\n          ga('send', 'pageview');\n        </script>\n      </head>\n      <body>\n        <!-- We will put our React component inside this div. -->\n        <div id=\"app\">\n          <!-- Kepler.gl map will be placed here-->\n        </div>\n\n        <!-- Load our React component. -->\n        <script>\n          /* Validate Mapbox Token */\n          if ((MAPBOX_TOKEN || '') === '' || MAPBOX_TOKEN === 'PROVIDE_MAPBOX_TOKEN') {\n            alert(WARNING_MESSAGE);\n          }\n\n          /** STORE **/\n          const reducers = (function createReducers(redux, keplerGl) {\n            return redux.combineReducers({\n              // mount keplerGl reducer\n              keplerGl: keplerGl.keplerGlReducer.initialState({\n                uiState: {\n                  readOnly: ${options.mode === EXPORT_HTML_MAP_MODES.READ},\n                  currentModal: null\n                }\n              })\n            });\n          }(Redux, KeplerGl));\n\n          const middleWares = (function createMiddlewares(keplerGl) {\n            return keplerGl.enhanceReduxMiddleware([\n              // Add other middlewares here\n            ]);\n          }(KeplerGl));\n\n          const enhancers = (function craeteEnhancers(redux, middles) {\n            return redux.applyMiddleware(...middles);\n          }(Redux, middleWares));\n\n          const store = (function createStore(redux, enhancers) {\n            const initialState = {};\n\n            return redux.createStore(\n              reducers,\n              initialState,\n              redux.compose(enhancers)\n            );\n          }(Redux, enhancers));\n          /** END STORE **/\n\n          /** COMPONENTS **/\n          var KeplerElement = (function makeKeplerElement(react, keplerGl, mapboxToken) {\n            var LogoSvg = function LogoSvg() {\n              return react.createElement(\n                \"div\",\n                { className: \"logo-container\", style: {position: 'fixed', zIndex: 10000, padding: '4px'} },\n                  react.createElement(\n                    \"svg\",\n                    {\n                      className: \"kepler_gl__logo\",\n                      width: \"107px\",\n                      height: \"21px\",\n                      viewBox: \"0 0 124 24\"\n                    },\n                    react.createElement(\n                      \"g\",\n                      { transform: \"translate(13.500000, 13.500000) rotate(45.000000) translate(-13.500000, -13.500000) translate(4.000000, 4.000000)\" },\n                      react.createElement(\"rect\", { x: \"0\", y: \"6\", transform: \"matrix(2.535181e-06 1 -1 2.535181e-06 18.1107 6.0369)\", fill: \"#535C6C\", width: \"12.1\", height: \"12.1\" }),\n                      react.createElement(\"rect\", { x: \"6\", y: \"0\", transform: \"matrix(2.535182e-06 1 -1 2.535182e-06 18.1107 -6.0369)\", fill:\"#1FBAD6\", width: \"12.1\", height: \"12.1\" })\n                    ),\n                    react.createElement(\n                      \"g\",\n                      {},\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M39,8.7h2.2l-2.8,4.2l2.9,5.1H39l-2.4-4.2h-1.3V18h-2V5l2-0.1v7.3h1.3L39,8.7z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M42.4,13.3c0-1.5,0.4-2.7,1.1-3.5s1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C42.8,16.1,42.4,14.9,42.4,13.3z M46.6,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S47.2,10.1,46.6,10.1z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M57.1,18.2c-1,0-1.8-0.3-2.3-0.9l0,0l0,1.3v2.5h-2V8.7h1.5l0.3,0.9h0c0.3-0.3,0.7-0.6,1.2-0.7 c0.4-0.2,0.9-0.3,1.4-0.3c1.2,0,2.1,0.4,2.7,1.1c0.6,0.7,0.9,2,0.9,3.7c0,1.6-0.3,2.8-1,3.7C59.2,17.8,58.3,18.2,57.1,18.2z M56.7,10.3c-0.4,0-0.8,0.1-1.1,0.2c-0.3,0.2-0.6,0.4-0.8,0.7v4.3c0.2,0.3,0.4,0.5,0.7,0.7c0.3,0.2,0.7,0.3,1.1,0.3 c0.7,0,1.2-0.2,1.6-0.7c0.4-0.5,0.5-1.3,0.5-2.5c0-0.8-0.1-1.4-0.2-1.8s-0.4-0.7-0.7-0.9C57.6,10.4,57.2,10.3,56.7,10.3z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M63.2,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S63.2,16.8,63.2,16z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M68.2,13.3c0-1.5,0.4-2.7,1.1-3.5c0.7-0.8,1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C68.6,16.1,68.2,14.9,68.2,13.3z M72.4,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S73,10.1,72.4,10.1z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M80.2,8.7l0.1,1.7h0c0.3-0.6,0.7-1.1,1.1-1.4c0.4-0.3,1-0.5,1.6-0.5c0.4,0,0.7,0,1,0.1l-0.1,2 c-0.3-0.1-0.7-0.2-1-0.2c-0.7,0-1.3,0.3-1.7,0.8c-0.4,0.5-0.7,1.2-0.7,2.1V18h-2V8.7H80.2z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M83.8,17c0-0.8,0.4-1.2,1.2-1.2c0.8,0,1.2,0.4,1.2,1.2c0,0.8-0.4,1.1-1.2,1.1C84.2,18.2,83.8,17.8,83.8,17z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M88.5,18.7c0-0.8,0.4-1.4,1.2-1.8c-0.6-0.3-0.9-0.8-0.9-1.5c0-0.7,0.4-1.2,1.1-1.6c-0.3-0.3-0.6-0.6-0.7-0.9 c-0.2-0.4-0.2-0.8-0.2-1.3c0-1,0.3-1.8,0.9-2.3c0.6-0.5,1.6-0.8,2.8-0.8c0.5,0,1,0,1.4,0.1c0.4,0.1,0.8,0.2,1.1,0.4l2.4-0.2v1.5 h-1.5c0.2,0.4,0.2,0.8,0.2,1.3c0,1-0.3,1.7-0.9,2.2s-1.5,0.8-2.7,0.8c-0.7,0-1.2-0.1-1.6-0.2c-0.1,0.1-0.2,0.2-0.3,0.3 c-0.1,0.1-0.1,0.2-0.1,0.4c0,0.2,0.1,0.3,0.2,0.4c0.1,0.1,0.3,0.2,0.6,0.2l2.7,0.2c1,0.1,1.7,0.3,2.2,0.6c0.5,0.3,0.8,0.9,0.8,1.7 c0,0.6-0.2,1.1-0.5,1.5c-0.4,0.4-0.9,0.8-1.5,1c-0.7,0.2-1.5,0.4-2.4,0.4c-1.3,0-2.3-0.2-3-0.6C88.8,20.1,88.5,19.5,88.5,18.7z M95.1,18.4c0-0.3-0.1-0.5-0.3-0.7s-0.6-0.2-1.1-0.3l-2.7-0.3c-0.2,0.1-0.4,0.3-0.5,0.5c-0.1,0.2-0.2,0.4-0.2,0.6 c0,0.4,0.2,0.8,0.5,1c0.4,0.2,1,0.3,1.8,0.3C94.2,19.5,95.1,19.2,95.1,18.4z M94.3,11.5c0-0.6-0.1-1-0.4-1.2 c-0.3-0.2-0.7-0.3-1.3-0.3c-0.7,0-1.1,0.1-1.4,0.3c-0.3,0.2-0.4,0.6-0.4,1.2s0.1,1,0.4,1.2c0.3,0.2,0.7,0.3,1.4,0.3 c0.6,0,1.1-0.1,1.3-0.4S94.3,12,94.3,11.5z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M99.4,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S99.4,16.8,99.4,16z\" })\n                    )\n                  )\n                );\n              };\n\n            return function App() {\n              var rootElm = react.useRef(null);\n              var _useState = react.useState({\n                width: window.innerWidth,\n                height: window.innerHeight\n              });\n              var windowDimension = _useState[0];\n              var setDimension = _useState[1];\n              react.useEffect(function sideEffect(){\n                function handleResize() {\n                  setDimension({width: window.innerWidth, height: window.innerHeight});\n                };\n                window.addEventListener('resize', handleResize);\n                return function() {window.removeEventListener('resize', handleResize);};\n              }, []);\n              return react.createElement(\n                'div',\n                {style: {position: 'absolute', left: 0, width: '100vw', height: '100vh'}},\n                ${options.mode === EXPORT_HTML_MAP_MODES.READ ? 'LogoSvg(),' : ''}\n                react.createElement(keplerGl.KeplerGl, {\n                  mapboxApiAccessToken: mapboxToken,\n                  id: \"map\",\n                  width: windowDimension.width,\n                  height: windowDimension.height\n                })\n              )\n            }\n          }(React, KeplerGl, MAPBOX_TOKEN));\n\n          const app = (function createReactReduxProvider(react, reactRedux, KeplerElement) {\n            return react.createElement(\n              reactRedux.Provider,\n              {store},\n              react.createElement(KeplerElement, null)\n            )\n          }(React, ReactRedux, KeplerElement));\n          /** END COMPONENTS **/\n\n          /** Render **/\n          (function render(react, reactDOM, app) {\n            const container = document.getElementById('app');\n            const root = reactDOM.createRoot(container);\n            root.render(app);\n          }(React, ReactDOM, app));\n        </script>\n        <!-- The next script will show how to interact directly with Kepler map store -->\n        <script>\n          /**\n           * Customize map.\n           * In the following section you can use the store object to dispatch Kepler.gl actions\n           * to add new data and customize behavior\n           */\n          (function customize(keplerGl, store) {\n            const datasets = ${JSON.stringify(options.datasets)};\n            const config = ${JSON.stringify(options.config)};\n\n            const loadedData = keplerGl.KeplerGlSchema.load(\n              datasets,\n              config\n            );\n\n            // For some reason Kepler overwrites the config without extra wait time\n            window.setTimeout(() => {\n              store.dispatch(\n                keplerGl.addDataToMap({\n                  datasets: loadedData.datasets,\n                  config: loadedData.config,\n                  options: {\n                    centerMap: false,\n                  },\n                })\n              );\n            }, 500);\n          }(KeplerGl, store))\n        </script>\n      </body>\n    </html>\n  `;\n};\n"],"mappings":";;;;;;AAIA,IAAAA,UAAA,GAAAC,OAAA;AAJA;AACA;;AAEA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,IAAMC,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,SAAlBA,eAAeA,CAAIE,OAAO,EAAkC;EAAA,IAAhCC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAGG,4BAAiB;EAClE,kXAAAC,MAAA,CAWgDL,OAAO,y4EAAAK,MAAA,CAgCNL,OAAO,8TAAAK,MAAA,CAWxBN,OAAO,CAACO,oBAAoB,IAAI,sBAAsB,qlEAAAD,MAAA,CA2C1DN,OAAO,CAACQ,IAAI,KAAKC,gCAAqB,CAACC,IAAI,0oNAAAJ,MAAA,CAmFvDN,OAAO,CAACQ,IAAI,KAAKC,gCAAqB,CAACC,IAAI,GAAG,YAAY,GAAG,EAAE,02CAAAJ,MAAA,CAmClDK,IAAI,CAACC,SAAS,CAACZ,OAAO,CAACa,QAAQ,CAAC,oCAAAP,MAAA,CAClCK,IAAI,CAACC,SAAS,CAACZ,OAAO,CAACc,MAAM,CAAC;AAwB3D,CAAC","ignoreList":[]}
|
|
25
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","exportMapToHTML","exports","options","version","arguments","length","undefined","KEPLER_GL_VERSION","concat","mapboxApiAccessToken","mode","EXPORT_HTML_MAP_MODES","READ","JSON","stringify","datasets","config"],"sources":["../src/export-map-html.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// @ts-nocheck\nimport {EXPORT_HTML_MAP_MODES, KEPLER_GL_VERSION} from '@kepler.gl/constants';\n\n/**\n * This method is used to create an html file which will inlcude kepler and map data\n * @param {Object} options Object that collects all necessary data to  create the html file\n * @param {string} options.mapboxApiAccessToken Mapbox token used to fetch mapbox tiles\n * @param {Array<Object>} options.datasets Data to include in the map\n * @param {Object} options.config this object will contain the full kepler.gl instance configuration {mapState, mapStyle, visState}\n * @param {string} version which version of Kepler.gl to load.\n */\nexport const exportMapToHTML = (options, version = KEPLER_GL_VERSION) => {\n  return `\n    <!DOCTYPE html>\n    <html>\n      <head>\n        <meta charset=\"UTF-8\"/>\n        <title>Kepler.gl embedded map</title>\n\n        <!--Uber Font-->\n        <link rel=\"stylesheet\" href=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/uber-fonts/4.0.0/superfine.css\">\n\n        <!--Kepler css-->\n        <link href=\"https://unpkg.com/kepler.gl@${version}/umd/keplergl.min.css\" rel=\"stylesheet\">\n\n        <!--MapBox css-->\n        <link href=\"https://api.tiles.mapbox.com/mapbox-gl-js/v1.1.1/mapbox-gl.css\" rel=\"stylesheet\">\n        <link href=\"https://unpkg.com/maplibre-gl@^3/dist/maplibre-gl.css\" rel=\"stylesheet\">\n\n        <!-— facebook open graph tags -->\n        <meta property=\"og:url\" content=\"http://kepler.gl/\" />\n        <meta property=\"og:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\" />\n        <meta property=\"og:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\" />\n        <meta property=\"og:site_name\" content=\"kepler.gl\" />\n        <meta property=\"og:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n        <meta property=\"og:image:type\" content=\"image/png\" />\n        <meta property=\"og:image:width\" content=\"800\" />\n        <meta property=\"og:image:height\" content=\"800\" />\n\n        <!-— twitter card tags -->\n        <meta name=\"twitter:card\" content=\"summary_large_image\">\n        <meta name=\"twitter:site\" content=\"@openjsf\">\n        <meta name=\"twitter:creator\" content=\"@openjsf\">\n        <meta name=\"twitter:title\" content=\"Large-scale WebGL-powered Geospatial Data Visualization Tool\">\n        <meta name=\"twitter:description\" content=\"Kepler.gl is a powerful web-based geospatial data analysis tool. Built on a high performance rendering engine and designed for large-scale data sets.\">\n        <meta name=\"twitter:image\" content=\"https://d1a3f4spazzrp4.cloudfront.net/kepler.gl/kepler.gl-meta-tag.png\" />\n\n        <!-- Load React/Redux -->\n        <script src=\"https://unpkg.com/react@18.3.1/umd/react.production.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/react-dom@18.3.1/umd/react-dom.production.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/redux@4.2.1/dist/redux.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/react-redux@8.1.2/dist/react-redux.min.js\" crossorigin></script>\n        <script src=\"https://unpkg.com/styled-components@6.1.8/dist/styled-components.min.js\" crossorigin></script>\n\n        <!-- Load Kepler.gl -->\n        <script src=\"https://unpkg.com/kepler.gl@${version}/umd/keplergl.min.js\" crossorigin></script>\n\n        <style type=\"text/css\">\n          body {margin: 0; padding: 0; overflow: hidden;}\n        </style>\n\n        <!--MapBox token-->\n        <!--\n          SECURITY NOTE: Your Mapbox access token is embedded below in plain text.\n          Anyone with access to this HTML file can see and use this token.\n          Consider using a scoped token with URL restrictions to limit misuse.\n          See: https://docs.mapbox.com/accounts/guides/tokens/#url-restrictions\n        -->\n        <script>\n          /**\n           * Provide your MapBox Token\n           **/\n          const MAPBOX_TOKEN = '${options.mapboxApiAccessToken || 'PROVIDE_MAPBOX_TOKEN'}';\n          const WARNING_MESSAGE = 'Please Provide a Mapbox Token in order to use Kepler.gl. Edit this file and fill out MAPBOX_TOKEN with your access key';\n        </script>\n\n        <!-- GA: Delete this as you wish, However to pat ourselves on the back, we only track anonymous pageview to understand how many people are using kepler.gl. -->\n        <script>\n          (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){\n          (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),\n          m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)\n          })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');\n          ga('create', 'UA-64694404-19', {\n            'storage': 'none',\n            'clientId': localStorage.getItem('ga:clientId')\n          });\n          ga(function(tracker) {\n              localStorage.setItem('ga:clientId', tracker.get('clientId'));\n          });\n          ga('set', 'checkProtocolTask', null); // Disable file protocol checking.\n          ga('set', 'checkStorageTask', null); // Disable cookie storage checking.\n          ga('set', 'historyImportTask', null); // Disable history checking (requires reading from cookies).\n          ga('set', 'page', 'keplergl-html');\n          ga('send', 'pageview');\n        </script>\n      </head>\n      <body>\n        <!-- We will put our React component inside this div. -->\n        <div id=\"app\">\n          <!-- Kepler.gl map will be placed here-->\n        </div>\n\n        <!-- Load our React component. -->\n        <script>\n          /* Validate Mapbox Token */\n          if ((MAPBOX_TOKEN || '') === '' || MAPBOX_TOKEN === 'PROVIDE_MAPBOX_TOKEN') {\n            alert(WARNING_MESSAGE);\n          }\n\n          /** STORE **/\n          const reducers = (function createReducers(redux, keplerGl) {\n            return redux.combineReducers({\n              // mount keplerGl reducer\n              keplerGl: keplerGl.keplerGlReducer.initialState({\n                uiState: {\n                  readOnly: ${options.mode === EXPORT_HTML_MAP_MODES.READ},\n                  currentModal: null\n                }\n              })\n            });\n          }(Redux, KeplerGl));\n\n          const middleWares = (function createMiddlewares(keplerGl) {\n            return keplerGl.enhanceReduxMiddleware([\n              // Add other middlewares here\n            ]);\n          }(KeplerGl));\n\n          const enhancers = (function craeteEnhancers(redux, middles) {\n            return redux.applyMiddleware(...middles);\n          }(Redux, middleWares));\n\n          const store = (function createStore(redux, enhancers) {\n            const initialState = {};\n\n            return redux.createStore(\n              reducers,\n              initialState,\n              redux.compose(enhancers)\n            );\n          }(Redux, enhancers));\n          /** END STORE **/\n\n          /** COMPONENTS **/\n          var KeplerElement = (function makeKeplerElement(react, keplerGl, mapboxToken) {\n            var LogoSvg = function LogoSvg() {\n              return react.createElement(\n                \"div\",\n                { className: \"logo-container\", style: {position: 'fixed', zIndex: 10000, padding: '4px'} },\n                  react.createElement(\n                    \"svg\",\n                    {\n                      className: \"kepler_gl__logo\",\n                      width: \"107px\",\n                      height: \"21px\",\n                      viewBox: \"0 0 124 24\"\n                    },\n                    react.createElement(\n                      \"g\",\n                      { transform: \"translate(13.500000, 13.500000) rotate(45.000000) translate(-13.500000, -13.500000) translate(4.000000, 4.000000)\" },\n                      react.createElement(\"rect\", { x: \"0\", y: \"6\", transform: \"matrix(2.535181e-06 1 -1 2.535181e-06 18.1107 6.0369)\", fill: \"#535C6C\", width: \"12.1\", height: \"12.1\" }),\n                      react.createElement(\"rect\", { x: \"6\", y: \"0\", transform: \"matrix(2.535182e-06 1 -1 2.535182e-06 18.1107 -6.0369)\", fill:\"#1FBAD6\", width: \"12.1\", height: \"12.1\" })\n                    ),\n                    react.createElement(\n                      \"g\",\n                      {},\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M39,8.7h2.2l-2.8,4.2l2.9,5.1H39l-2.4-4.2h-1.3V18h-2V5l2-0.1v7.3h1.3L39,8.7z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M42.4,13.3c0-1.5,0.4-2.7,1.1-3.5s1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C42.8,16.1,42.4,14.9,42.4,13.3z M46.6,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S47.2,10.1,46.6,10.1z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M57.1,18.2c-1,0-1.8-0.3-2.3-0.9l0,0l0,1.3v2.5h-2V8.7h1.5l0.3,0.9h0c0.3-0.3,0.7-0.6,1.2-0.7 c0.4-0.2,0.9-0.3,1.4-0.3c1.2,0,2.1,0.4,2.7,1.1c0.6,0.7,0.9,2,0.9,3.7c0,1.6-0.3,2.8-1,3.7C59.2,17.8,58.3,18.2,57.1,18.2z M56.7,10.3c-0.4,0-0.8,0.1-1.1,0.2c-0.3,0.2-0.6,0.4-0.8,0.7v4.3c0.2,0.3,0.4,0.5,0.7,0.7c0.3,0.2,0.7,0.3,1.1,0.3 c0.7,0,1.2-0.2,1.6-0.7c0.4-0.5,0.5-1.3,0.5-2.5c0-0.8-0.1-1.4-0.2-1.8s-0.4-0.7-0.7-0.9C57.6,10.4,57.2,10.3,56.7,10.3z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M63.2,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S63.2,16.8,63.2,16z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M68.2,13.3c0-1.5,0.4-2.7,1.1-3.5c0.7-0.8,1.8-1.2,3.1-1.2c1.3,0,2.2,0.4,2.8,1.1c0.6,0.7,0.9,1.8,0.9,3.3 c0,0.4,0,0.8,0,1.1h-5.8c0,1.6,0.8,2.4,2.4,2.4c1,0,2-0.2,2.9-0.6l0.2,1.7c-0.4,0.2-0.9,0.4-1.4,0.5s-1.1,0.2-1.7,0.2 c-1.5,0-2.6-0.4-3.3-1.2C68.6,16.1,68.2,14.9,68.2,13.3z M72.4,10.1c-0.7,0-1.2,0.2-1.5,0.5c-0.4,0.4-0.6,0.9-0.6,1.7h4 c0-0.8-0.2-1.4-0.5-1.7S73,10.1,72.4,10.1z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M80.2,8.7l0.1,1.7h0c0.3-0.6,0.7-1.1,1.1-1.4c0.4-0.3,1-0.5,1.6-0.5c0.4,0,0.7,0,1,0.1l-0.1,2 c-0.3-0.1-0.7-0.2-1-0.2c-0.7,0-1.3,0.3-1.7,0.8c-0.4,0.5-0.7,1.2-0.7,2.1V18h-2V8.7H80.2z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M83.8,17c0-0.8,0.4-1.2,1.2-1.2c0.8,0,1.2,0.4,1.2,1.2c0,0.8-0.4,1.1-1.2,1.1C84.2,18.2,83.8,17.8,83.8,17z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M88.5,18.7c0-0.8,0.4-1.4,1.2-1.8c-0.6-0.3-0.9-0.8-0.9-1.5c0-0.7,0.4-1.2,1.1-1.6c-0.3-0.3-0.6-0.6-0.7-0.9 c-0.2-0.4-0.2-0.8-0.2-1.3c0-1,0.3-1.8,0.9-2.3c0.6-0.5,1.6-0.8,2.8-0.8c0.5,0,1,0,1.4,0.1c0.4,0.1,0.8,0.2,1.1,0.4l2.4-0.2v1.5 h-1.5c0.2,0.4,0.2,0.8,0.2,1.3c0,1-0.3,1.7-0.9,2.2s-1.5,0.8-2.7,0.8c-0.7,0-1.2-0.1-1.6-0.2c-0.1,0.1-0.2,0.2-0.3,0.3 c-0.1,0.1-0.1,0.2-0.1,0.4c0,0.2,0.1,0.3,0.2,0.4c0.1,0.1,0.3,0.2,0.6,0.2l2.7,0.2c1,0.1,1.7,0.3,2.2,0.6c0.5,0.3,0.8,0.9,0.8,1.7 c0,0.6-0.2,1.1-0.5,1.5c-0.4,0.4-0.9,0.8-1.5,1c-0.7,0.2-1.5,0.4-2.4,0.4c-1.3,0-2.3-0.2-3-0.6C88.8,20.1,88.5,19.5,88.5,18.7z M95.1,18.4c0-0.3-0.1-0.5-0.3-0.7s-0.6-0.2-1.1-0.3l-2.7-0.3c-0.2,0.1-0.4,0.3-0.5,0.5c-0.1,0.2-0.2,0.4-0.2,0.6 c0,0.4,0.2,0.8,0.5,1c0.4,0.2,1,0.3,1.8,0.3C94.2,19.5,95.1,19.2,95.1,18.4z M94.3,11.5c0-0.6-0.1-1-0.4-1.2 c-0.3-0.2-0.7-0.3-1.3-0.3c-0.7,0-1.1,0.1-1.4,0.3c-0.3,0.2-0.4,0.6-0.4,1.2s0.1,1,0.4,1.2c0.3,0.2,0.7,0.3,1.4,0.3 c0.6,0,1.1-0.1,1.3-0.4S94.3,12,94.3,11.5z\" }),\n                      react.createElement(\"path\", { fill:\"#1FBAD6\", d: \"M99.4,16V5l2-0.1v10.8c0,0.3,0.1,0.5,0.2,0.6c0.1,0.1,0.3,0.2,0.6,0.2c0.3,0,0.6,0,0.9-0.1V18 c-0.4,0.1-1,0.2-1.6,0.2c-0.8,0-1.3-0.2-1.7-0.5S99.4,16.8,99.4,16z\" })\n                    )\n                  )\n                );\n              };\n\n            return function App() {\n              var rootElm = react.useRef(null);\n              var _useState = react.useState({\n                width: window.innerWidth,\n                height: window.innerHeight\n              });\n              var windowDimension = _useState[0];\n              var setDimension = _useState[1];\n              react.useEffect(function sideEffect(){\n                function handleResize() {\n                  setDimension({width: window.innerWidth, height: window.innerHeight});\n                };\n                window.addEventListener('resize', handleResize);\n                return function() {window.removeEventListener('resize', handleResize);};\n              }, []);\n              return react.createElement(\n                'div',\n                {style: {position: 'absolute', left: 0, width: '100vw', height: '100vh'}},\n                ${options.mode === EXPORT_HTML_MAP_MODES.READ ? 'LogoSvg(),' : ''}\n                react.createElement(keplerGl.KeplerGl, {\n                  mapboxApiAccessToken: mapboxToken,\n                  id: \"map\",\n                  width: windowDimension.width,\n                  height: windowDimension.height\n                })\n              )\n            }\n          }(React, KeplerGl, MAPBOX_TOKEN));\n\n          const app = (function createReactReduxProvider(react, reactRedux, KeplerElement) {\n            return react.createElement(\n              reactRedux.Provider,\n              {store},\n              react.createElement(KeplerElement, null)\n            )\n          }(React, ReactRedux, KeplerElement));\n          /** END COMPONENTS **/\n\n          /** Render **/\n          (function render(react, reactDOM, app) {\n            const container = document.getElementById('app');\n            const root = reactDOM.createRoot(container);\n            root.render(app);\n          }(React, ReactDOM, app));\n        </script>\n        <!-- The next script will show how to interact directly with Kepler map store -->\n        <script>\n          /**\n           * Customize map.\n           * In the following section you can use the store object to dispatch Kepler.gl actions\n           * to add new data and customize behavior\n           */\n          (function customize(keplerGl, store) {\n            const datasets = ${JSON.stringify(options.datasets)};\n            const config = ${JSON.stringify(options.config)};\n\n            const loadedData = keplerGl.KeplerGlSchema.load(\n              datasets,\n              config\n            );\n\n            // For some reason Kepler overwrites the config without extra wait time\n            window.setTimeout(() => {\n              store.dispatch(\n                keplerGl.addDataToMap({\n                  datasets: loadedData.datasets,\n                  config: loadedData.config,\n                  options: {\n                    centerMap: false,\n                  },\n                })\n              );\n            }, 500);\n          }(KeplerGl, store))\n        </script>\n      </body>\n    </html>\n  `;\n};\n"],"mappings":";;;;;;AAIA,IAAAA,UAAA,GAAAC,OAAA;AAJA;AACA;;AAEA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,IAAMC,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,SAAlBA,eAAeA,CAAIE,OAAO,EAAkC;EAAA,IAAhCC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAGG,4BAAiB;EAClE,kXAAAC,MAAA,CAWgDL,OAAO,y4EAAAK,MAAA,CAgCNL,OAAO,0pBAAAK,MAAA,CAiBxBN,OAAO,CAACO,oBAAoB,IAAI,sBAAsB,qlEAAAD,MAAA,CA2C1DN,OAAO,CAACQ,IAAI,KAAKC,gCAAqB,CAACC,IAAI,0oNAAAJ,MAAA,CAmFvDN,OAAO,CAACQ,IAAI,KAAKC,gCAAqB,CAACC,IAAI,GAAG,YAAY,GAAG,EAAE,02CAAAJ,MAAA,CAmClDK,IAAI,CAACC,SAAS,CAACZ,OAAO,CAACa,QAAQ,CAAC,oCAAAP,MAAA,CAClCK,IAAI,CAACC,SAAS,CAACZ,OAAO,CAACc,MAAM,CAAC;AAwB3D,CAAC","ignoreList":[]}
|
package/dist/export-utils.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Blob } from 'global/window';
|
|
2
|
-
import {
|
|
2
|
+
import { EXPORT_IMG_RATIOS, type ExportResolutionOption } from '@kepler.gl/constants';
|
|
3
3
|
import { ExportImage } from '@kepler.gl/types';
|
|
4
4
|
export declare function isMSEdge(window: Window): boolean;
|
|
5
5
|
export declare function getScaleFromImageSize(imageW?: number, imageH?: number, mapW?: number, mapH?: number): number;
|
|
@@ -7,7 +7,7 @@ export declare function calculateExportImageSize({ mapW, mapH, ratio, resolution
|
|
|
7
7
|
mapW: number;
|
|
8
8
|
mapH: number;
|
|
9
9
|
ratio: keyof typeof EXPORT_IMG_RATIOS;
|
|
10
|
-
resolution:
|
|
10
|
+
resolution: ExportResolutionOption;
|
|
11
11
|
}): {
|
|
12
12
|
scale: number | undefined;
|
|
13
13
|
imageW: number;
|
package/dist/export-utils.js
CHANGED
|
@@ -198,4 +198,4 @@ var exporters = {
|
|
|
198
198
|
exportHtml: exportHtml
|
|
199
199
|
};
|
|
200
200
|
var _default = exports["default"] = exporters;
|
|
201
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","require","_get","_interopRequireDefault","_constants","_commonUtils","_domToImage","_utils","_exportMapHtml","_applicationConfig","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","defaultResolution","OneXResolutionOption","defaultRatio","FourByThreeRatioOption","isMSEdge","window","Boolean","navigator","msSaveOrOpenBlob","getScaleFromImageSize","imageW","undefined","imageH","mapW","mapH","some","d","base","mapBase","calculateExportImageSize","_ref","ratio","resolution","ratioItem","EXPORT_IMG_RATIO_OPTIONS","find","op","id","resolutionItem","EXPORT_IMG_RESOLUTION_OPTIONS","_resolutionItem$getSi","getSize","scaledWidth","width","scaledHeight","height","_ratioItem$getSize","_ref2","EXPORT_IMG_RATIOS","CUSTOM","scale","convertToPng","sourceElem","options","domtoimage","toPng","dataURItoBlob","dataURI","binary","atob","split","mimeString","ab","ArrayBuffer","ia","Uint8Array","i","charCodeAt","Blob","type","downloadFile","fileBlob","fileName","url","URL","createObjectURL","link","document","createElement","setAttribute","body","appendChild","evt","MouseEvent","view","bubbles","cancelable","dispatchEvent","removeChild","revokeObjectURL","exportImage","uiStateExportImage","filename","getApplicationConfig","defaultImageName","imageDataUri","file","exportToJsonString","data","JSON","stringify","TypeError","message","description","getMapJSON","state","defaultExportJsonSettings","hasData","schema","visState","getConfigToSave","mapToSave","save","title","get","set","concat","generateHashId","exportJson","map","info","source","appName","defaultJsonName","exportHtml","userMapboxToken","exportMapboxAccessToken","mode","mapboxApiAccessToken","exportMapToHTML","defaultHtmlName","exportMap","uiState","thumbnail","exporters","_default","exports"],"sources":["../src/export-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Blob, URL, atob, Uint8Array, ArrayBuffer, document} from 'global/window';\nimport get from 'lodash/get';\n\nimport {\n  EXPORT_IMG_RESOLUTION_OPTIONS,\n  EXPORT_IMG_RATIO_OPTIONS,\n  RESOLUTIONS,\n  EXPORT_IMG_RATIOS,\n  FourByThreeRatioOption,\n  OneXResolutionOption\n} from '@kepler.gl/constants';\nimport {ExportImage} from '@kepler.gl/types';\nimport {generateHashId} from '@kepler.gl/common-utils';\nimport domtoimage from './dom-to-image';\nimport {set} from './utils';\nimport {exportMapToHTML} from './export-map-html';\nimport {getApplicationConfig} from './application-config';\n\nconst defaultResolution = OneXResolutionOption;\n\nconst defaultRatio = FourByThreeRatioOption;\n\nexport function isMSEdge(window: Window): boolean {\n  // @ts-ignore msSaveOrOpenBlob was a proprietary addition to the Navigator object, added by Microsoft for Internet Explorer.\n  return Boolean(window.navigator && window.navigator.msSaveOrOpenBlob);\n}\n\nexport function getScaleFromImageSize(imageW = 0, imageH = 0, mapW = 0, mapH = 0) {\n  if ([imageW, imageH, mapW, mapH].some(d => d <= 0)) {\n    return 1;\n  }\n\n  const base = imageW / imageH > 1 ? imageW : imageH;\n  const mapBase = imageW / imageH > 1 ? mapW : mapH;\n  return base / mapBase;\n}\n\nexport function calculateExportImageSize({\n  mapW,\n  mapH,\n  ratio,\n  resolution\n}: {\n  mapW: number;\n  mapH: number;\n  ratio: keyof typeof EXPORT_IMG_RATIOS;\n  resolution: keyof typeof RESOLUTIONS;\n}) {\n  if (mapW <= 0 || mapH <= 0) {\n    return null;\n  }\n\n  const ratioItem = EXPORT_IMG_RATIO_OPTIONS.find(op => op.id === ratio) || defaultRatio;\n\n  const resolutionItem =\n    EXPORT_IMG_RESOLUTION_OPTIONS.find(op => op.id === resolution) || defaultResolution;\n\n  const {width: scaledWidth, height: scaledHeight} = resolutionItem.getSize(mapW, mapH);\n\n  const {width: imageW, height: imageH} = ratioItem.getSize(scaledWidth, scaledHeight);\n\n  const {scale} = ratioItem.id === EXPORT_IMG_RATIOS.CUSTOM ? {scale: undefined} : resolutionItem;\n\n  return {\n    scale,\n    imageW,\n    imageH\n  };\n}\n\nexport function convertToPng(sourceElem: HTMLElement, options) {\n  return domtoimage.toPng(sourceElem, options);\n}\n\nexport function dataURItoBlob(dataURI: string): Blob {\n  const binary = atob(dataURI.split(',')[1]);\n\n  // separate out the mime component\n  const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];\n\n  // write the bytes of the string to an ArrayBuffer\n  const ab = new ArrayBuffer(binary.length);\n\n  // create a view into the buffer\n  const ia = new Uint8Array(ab);\n\n  for (let i = 0; i < binary.length; i++) {\n    ia[i] = binary.charCodeAt(i);\n  }\n\n  return new Blob([ab], {type: mimeString});\n}\n\nexport function downloadFile(fileBlob: Blob, fileName: string) {\n  if (isMSEdge(window)) {\n    (window.navigator as any).msSaveOrOpenBlob(fileBlob, fileName);\n  } else {\n    const url = URL.createObjectURL(fileBlob);\n\n    const link = document.createElement('a');\n    link.setAttribute('href', url);\n    link.setAttribute('download', fileName);\n\n    document.body.appendChild(link);\n    // in some cases where maps are embedded, e.g. need to\n    // create and dispatch an event so that the browser downloads\n    // the file instead of navigating to the url\n    const evt = new MouseEvent('click', {\n      view: window,\n      bubbles: false,\n      cancelable: true\n    });\n    link.dispatchEvent(evt);\n    document.body.removeChild(link);\n    URL.revokeObjectURL(url);\n  }\n}\n\n/**\n * Whether color is rgb\n * @returns\n */\nexport function exportImage(\n  uiStateExportImage: ExportImage,\n  filename = getApplicationConfig().defaultImageName\n) {\n  const {imageDataUri} = uiStateExportImage;\n  if (imageDataUri) {\n    const file = dataURItoBlob(imageDataUri);\n    downloadFile(file, filename);\n  }\n}\n\nexport function exportToJsonString(data) {\n  try {\n    return JSON.stringify(data);\n  } catch (e) {\n    if (e instanceof TypeError) return e.message;\n    // Non-Standard Error Object Property\n    return (e as any).description;\n  }\n}\n\nexport function getMapJSON(state, options = getApplicationConfig().defaultExportJsonSettings) {\n  const {hasData} = options;\n  const schema = state.visState.schema;\n\n  if (!hasData) {\n    return schema.getConfigToSave(state);\n  }\n\n  let mapToSave = schema.save(state);\n  // add file name if title is not provided\n  const title = get(mapToSave, ['info', 'title']);\n  if (!title || !title.length) {\n    mapToSave = set(['info', 'title'], `keplergl_${generateHashId(6)}`, mapToSave);\n  }\n  return mapToSave;\n}\n\nexport function exportJson(state, options: any = {}) {\n  const map = getMapJSON(state, options);\n  map.info.source = 'kepler.gl';\n  const fileBlob = new Blob([exportToJsonString(map)], {type: 'application/json'});\n  const fileName = state.appName ? `${state.appName}.json` : getApplicationConfig().defaultJsonName;\n  downloadFile(fileBlob, fileName);\n}\n\nexport function exportHtml(state, options) {\n  const {userMapboxToken, exportMapboxAccessToken, mode} = options;\n\n  const data = {\n    ...getMapJSON(state),\n    mapboxApiAccessToken:\n      (userMapboxToken || '') !== '' ? userMapboxToken : exportMapboxAccessToken,\n    mode\n  };\n\n  const fileBlob = new Blob([exportMapToHTML(data)], {type: 'text/html'});\n  downloadFile(\n    fileBlob,\n    state.appName ? `${state.appName}.html` : getApplicationConfig().defaultHtmlName\n  );\n}\n\nexport function exportMap(state, options = getApplicationConfig().defaultExportJsonSettings) {\n  const {imageDataUri} = state.uiState.exportImage;\n  const thumbnail: Blob | null = imageDataUri ? dataURItoBlob(imageDataUri) : null;\n  const mapToSave = getMapJSON(state, options);\n\n  return {\n    map: mapToSave,\n    thumbnail\n  };\n}\n\nconst exporters = {\n  exportImage,\n  exportJson,\n  exportHtml\n};\n\nexport default exporters;\n"],"mappings":"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","ignoreList":[]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","require","_get","_interopRequireDefault","_constants","_commonUtils","_domToImage","_utils","_exportMapHtml","_applicationConfig","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","defaultResolution","OneXResolutionOption","defaultRatio","FourByThreeRatioOption","isMSEdge","window","Boolean","navigator","msSaveOrOpenBlob","getScaleFromImageSize","imageW","undefined","imageH","mapW","mapH","some","d","base","mapBase","calculateExportImageSize","_ref","ratio","resolution","ratioItem","EXPORT_IMG_RATIO_OPTIONS","find","op","id","resolutionItem","EXPORT_IMG_RESOLUTION_OPTIONS","_resolutionItem$getSi","getSize","scaledWidth","width","scaledHeight","height","_ratioItem$getSize","_ref2","EXPORT_IMG_RATIOS","CUSTOM","scale","convertToPng","sourceElem","options","domtoimage","toPng","dataURItoBlob","dataURI","binary","atob","split","mimeString","ab","ArrayBuffer","ia","Uint8Array","i","charCodeAt","Blob","type","downloadFile","fileBlob","fileName","url","URL","createObjectURL","link","document","createElement","setAttribute","body","appendChild","evt","MouseEvent","view","bubbles","cancelable","dispatchEvent","removeChild","revokeObjectURL","exportImage","uiStateExportImage","filename","getApplicationConfig","defaultImageName","imageDataUri","file","exportToJsonString","data","JSON","stringify","TypeError","message","description","getMapJSON","state","defaultExportJsonSettings","hasData","schema","visState","getConfigToSave","mapToSave","save","title","get","set","concat","generateHashId","exportJson","map","info","source","appName","defaultJsonName","exportHtml","userMapboxToken","exportMapboxAccessToken","mode","mapboxApiAccessToken","exportMapToHTML","defaultHtmlName","exportMap","uiState","thumbnail","exporters","_default","exports"],"sources":["../src/export-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Blob, URL, atob, Uint8Array, ArrayBuffer, document} from 'global/window';\nimport get from 'lodash/get';\n\nimport {\n  EXPORT_IMG_RESOLUTION_OPTIONS,\n  EXPORT_IMG_RATIO_OPTIONS,\n  EXPORT_IMG_RATIOS,\n  FourByThreeRatioOption,\n  OneXResolutionOption,\n  type ExportResolutionOption\n} from '@kepler.gl/constants';\nimport {ExportImage} from '@kepler.gl/types';\nimport {generateHashId} from '@kepler.gl/common-utils';\nimport domtoimage from './dom-to-image';\nimport {set} from './utils';\nimport {exportMapToHTML} from './export-map-html';\nimport {getApplicationConfig} from './application-config';\n\nconst defaultResolution = OneXResolutionOption;\n\nconst defaultRatio = FourByThreeRatioOption;\n\nexport function isMSEdge(window: Window): boolean {\n  // @ts-ignore msSaveOrOpenBlob was a proprietary addition to the Navigator object, added by Microsoft for Internet Explorer.\n  return Boolean(window.navigator && window.navigator.msSaveOrOpenBlob);\n}\n\nexport function getScaleFromImageSize(imageW = 0, imageH = 0, mapW = 0, mapH = 0) {\n  if ([imageW, imageH, mapW, mapH].some(d => d <= 0)) {\n    return 1;\n  }\n\n  const base = imageW / imageH > 1 ? imageW : imageH;\n  const mapBase = imageW / imageH > 1 ? mapW : mapH;\n  return base / mapBase;\n}\n\nexport function calculateExportImageSize({\n  mapW,\n  mapH,\n  ratio,\n  resolution\n}: {\n  mapW: number;\n  mapH: number;\n  ratio: keyof typeof EXPORT_IMG_RATIOS;\n  resolution: ExportResolutionOption;\n}) {\n  if (mapW <= 0 || mapH <= 0) {\n    return null;\n  }\n\n  const ratioItem = EXPORT_IMG_RATIO_OPTIONS.find(op => op.id === ratio) || defaultRatio;\n\n  const resolutionItem =\n    EXPORT_IMG_RESOLUTION_OPTIONS.find(op => op.id === resolution) || defaultResolution;\n\n  const {width: scaledWidth, height: scaledHeight} = resolutionItem.getSize(mapW, mapH);\n\n  const {width: imageW, height: imageH} = ratioItem.getSize(scaledWidth, scaledHeight);\n\n  const {scale} = ratioItem.id === EXPORT_IMG_RATIOS.CUSTOM ? {scale: undefined} : resolutionItem;\n\n  return {\n    scale,\n    imageW,\n    imageH\n  };\n}\n\nexport function convertToPng(sourceElem: HTMLElement, options) {\n  return domtoimage.toPng(sourceElem, options);\n}\n\nexport function dataURItoBlob(dataURI: string): Blob {\n  const binary = atob(dataURI.split(',')[1]);\n\n  // separate out the mime component\n  const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];\n\n  // write the bytes of the string to an ArrayBuffer\n  const ab = new ArrayBuffer(binary.length);\n\n  // create a view into the buffer\n  const ia = new Uint8Array(ab);\n\n  for (let i = 0; i < binary.length; i++) {\n    ia[i] = binary.charCodeAt(i);\n  }\n\n  return new Blob([ab], {type: mimeString});\n}\n\nexport function downloadFile(fileBlob: Blob, fileName: string) {\n  if (isMSEdge(window)) {\n    (window.navigator as any).msSaveOrOpenBlob(fileBlob, fileName);\n  } else {\n    const url = URL.createObjectURL(fileBlob);\n\n    const link = document.createElement('a');\n    link.setAttribute('href', url);\n    link.setAttribute('download', fileName);\n\n    document.body.appendChild(link);\n    // in some cases where maps are embedded, e.g. need to\n    // create and dispatch an event so that the browser downloads\n    // the file instead of navigating to the url\n    const evt = new MouseEvent('click', {\n      view: window,\n      bubbles: false,\n      cancelable: true\n    });\n    link.dispatchEvent(evt);\n    document.body.removeChild(link);\n    URL.revokeObjectURL(url);\n  }\n}\n\n/**\n * Whether color is rgb\n * @returns\n */\nexport function exportImage(\n  uiStateExportImage: ExportImage,\n  filename = getApplicationConfig().defaultImageName\n) {\n  const {imageDataUri} = uiStateExportImage;\n  if (imageDataUri) {\n    const file = dataURItoBlob(imageDataUri);\n    downloadFile(file, filename);\n  }\n}\n\nexport function exportToJsonString(data) {\n  try {\n    return JSON.stringify(data);\n  } catch (e) {\n    if (e instanceof TypeError) return e.message;\n    // Non-Standard Error Object Property\n    return (e as any).description;\n  }\n}\n\nexport function getMapJSON(state, options = getApplicationConfig().defaultExportJsonSettings) {\n  const {hasData} = options;\n  const schema = state.visState.schema;\n\n  if (!hasData) {\n    return schema.getConfigToSave(state);\n  }\n\n  let mapToSave = schema.save(state);\n  // add file name if title is not provided\n  const title = get(mapToSave, ['info', 'title']);\n  if (!title || !title.length) {\n    mapToSave = set(['info', 'title'], `keplergl_${generateHashId(6)}`, mapToSave);\n  }\n  return mapToSave;\n}\n\nexport function exportJson(state, options: any = {}) {\n  const map = getMapJSON(state, options);\n  map.info.source = 'kepler.gl';\n  const fileBlob = new Blob([exportToJsonString(map)], {type: 'application/json'});\n  const fileName = state.appName ? `${state.appName}.json` : getApplicationConfig().defaultJsonName;\n  downloadFile(fileBlob, fileName);\n}\n\nexport function exportHtml(state, options) {\n  const {userMapboxToken, exportMapboxAccessToken, mode} = options;\n\n  const data = {\n    ...getMapJSON(state),\n    mapboxApiAccessToken:\n      (userMapboxToken || '') !== '' ? userMapboxToken : exportMapboxAccessToken,\n    mode\n  };\n\n  const fileBlob = new Blob([exportMapToHTML(data)], {type: 'text/html'});\n  downloadFile(\n    fileBlob,\n    state.appName ? `${state.appName}.html` : getApplicationConfig().defaultHtmlName\n  );\n}\n\nexport function exportMap(state, options = getApplicationConfig().defaultExportJsonSettings) {\n  const {imageDataUri} = state.uiState.exportImage;\n  const thumbnail: Blob | null = imageDataUri ? dataURItoBlob(imageDataUri) : null;\n  const mapToSave = getMapJSON(state, options);\n\n  return {\n    map: mapToSave,\n    thumbnail\n  };\n}\n\nconst exporters = {\n  exportImage,\n  exportJson,\n  exportHtml\n};\n\nexport default exporters;"],"mappings":";;;;;;;;;;;;;;;;;;;;AAGA,IAAAA,OAAA,GAAAC,OAAA;AACA,IAAAC,IAAA,GAAAC,sBAAA,CAAAF,OAAA;AAEA,IAAAG,UAAA,GAAAH,OAAA;AASA,IAAAI,YAAA,GAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,MAAA,GAAAN,OAAA;AACA,IAAAO,cAAA,GAAAP,OAAA;AACA,IAAAQ,kBAAA,GAAAR,OAAA;AAA0D,SAAAS,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA,IAnB1D;AACA;AAoBA,IAAMoB,iBAAiB,GAAGC,+BAAoB;AAE9C,IAAMC,YAAY,GAAGC,iCAAsB;AAEpC,SAASC,QAAQA,CAACC,MAAc,EAAW;EAChD;EACA,OAAOC,OAAO,CAACD,MAAM,CAACE,SAAS,IAAIF,MAAM,CAACE,SAAS,CAACC,gBAAgB,CAAC;AACvE;AAEO,SAASC,qBAAqBA,CAAA,EAA6C;EAAA,IAA5CC,MAAM,GAAAjB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,CAAC;EAAA,IAAEmB,MAAM,GAAAnB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,CAAC;EAAA,IAAEoB,IAAI,GAAApB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,CAAC;EAAA,IAAEqB,IAAI,GAAArB,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,CAAC;EAC9E,IAAI,CAACiB,MAAM,EAAEE,MAAM,EAAEC,IAAI,EAAEC,IAAI,CAAC,CAACC,IAAI,CAAC,UAAAC,CAAC;IAAA,OAAIA,CAAC,IAAI,CAAC;EAAA,EAAC,EAAE;IAClD,OAAO,CAAC;EACV;EAEA,IAAMC,IAAI,GAAGP,MAAM,GAAGE,MAAM,GAAG,CAAC,GAAGF,MAAM,GAAGE,MAAM;EAClD,IAAMM,OAAO,GAAGR,MAAM,GAAGE,MAAM,GAAG,CAAC,GAAGC,IAAI,GAAGC,IAAI;EACjD,OAAOG,IAAI,GAAGC,OAAO;AACvB;AAEO,SAASC,wBAAwBA,CAAAC,IAAA,EAUrC;EAAA,IATDP,IAAI,GAAAO,IAAA,CAAJP,IAAI;IACJC,IAAI,GAAAM,IAAA,CAAJN,IAAI;IACJO,KAAK,GAAAD,IAAA,CAALC,KAAK;IACLC,UAAU,GAAAF,IAAA,CAAVE,UAAU;EAOV,IAAIT,IAAI,IAAI,CAAC,IAAIC,IAAI,IAAI,CAAC,EAAE;IAC1B,OAAO,IAAI;EACb;EAEA,IAAMS,SAAS,GAAGC,mCAAwB,CAACC,IAAI,CAAC,UAAAC,EAAE;IAAA,OAAIA,EAAE,CAACC,EAAE,KAAKN,KAAK;EAAA,EAAC,IAAInB,YAAY;EAEtF,IAAM0B,cAAc,GAClBC,wCAA6B,CAACJ,IAAI,CAAC,UAAAC,EAAE;IAAA,OAAIA,EAAE,CAACC,EAAE,KAAKL,UAAU;EAAA,EAAC,IAAItB,iBAAiB;EAErF,IAAA8B,qBAAA,GAAmDF,cAAc,CAACG,OAAO,CAAClB,IAAI,EAAEC,IAAI,CAAC;IAAvEkB,WAAW,GAAAF,qBAAA,CAAlBG,KAAK;IAAuBC,YAAY,GAAAJ,qBAAA,CAApBK,MAAM;EAEjC,IAAAC,kBAAA,GAAwCb,SAAS,CAACQ,OAAO,CAACC,WAAW,EAAEE,YAAY,CAAC;IAAtExB,MAAM,GAAA0B,kBAAA,CAAbH,KAAK;IAAkBrB,MAAM,GAAAwB,kBAAA,CAAdD,MAAM;EAE5B,IAAAE,KAAA,GAAgBd,SAAS,CAACI,EAAE,KAAKW,4BAAiB,CAACC,MAAM,GAAG;MAACC,KAAK,EAAE7B;IAAS,CAAC,GAAGiB,cAAc;IAAxFY,KAAK,GAAAH,KAAA,CAALG,KAAK;EAEZ,OAAO;IACLA,KAAK,EAALA,KAAK;IACL9B,MAAM,EAANA,MAAM;IACNE,MAAM,EAANA;EACF,CAAC;AACH;AAEO,SAAS6B,YAAYA,CAACC,UAAuB,EAAEC,OAAO,EAAE;EAC7D,OAAOC,sBAAU,CAACC,KAAK,CAACH,UAAU,EAAEC,OAAO,CAAC;AAC9C;AAEO,SAASG,aAAaA,CAACC,OAAe,EAAQ;EACnD,IAAMC,MAAM,GAAG,IAAAC,YAAI,EAACF,OAAO,CAACG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;;EAE1C;EACA,IAAMC,UAAU,GAAGJ,OAAO,CAACG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAACA,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAACA,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;;EAEpE;EACA,IAAME,EAAE,GAAG,IAAIC,mBAAW,CAACL,MAAM,CAACtD,MAAM,CAAC;;EAEzC;EACA,IAAM4D,EAAE,GAAG,IAAIC,kBAAU,CAACH,EAAE,CAAC;EAE7B,KAAK,IAAII,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGR,MAAM,CAACtD,MAAM,EAAE8D,CAAC,EAAE,EAAE;IACtCF,EAAE,CAACE,CAAC,CAAC,GAAGR,MAAM,CAACS,UAAU,CAACD,CAAC,CAAC;EAC9B;EAEA,OAAO,IAAIE,YAAI,CAAC,CAACN,EAAE,CAAC,EAAE;IAACO,IAAI,EAAER;EAAU,CAAC,CAAC;AAC3C;AAEO,SAASS,YAAYA,CAACC,QAAc,EAAEC,QAAgB,EAAE;EAC7D,IAAI1D,QAAQ,CAACC,MAAM,CAAC,EAAE;IACnBA,MAAM,CAACE,SAAS,CAASC,gBAAgB,CAACqD,QAAQ,EAAEC,QAAQ,CAAC;EAChE,CAAC,MAAM;IACL,IAAMC,GAAG,GAAGC,WAAG,CAACC,eAAe,CAACJ,QAAQ,CAAC;IAEzC,IAAMK,IAAI,GAAGC,gBAAQ,CAACC,aAAa,CAAC,GAAG,CAAC;IACxCF,IAAI,CAACG,YAAY,CAAC,MAAM,EAAEN,GAAG,CAAC;IAC9BG,IAAI,CAACG,YAAY,CAAC,UAAU,EAAEP,QAAQ,CAAC;IAEvCK,gBAAQ,CAACG,IAAI,CAACC,WAAW,CAACL,IAAI,CAAC;IAC/B;IACA;IACA;IACA,IAAMM,GAAG,GAAG,IAAIC,UAAU,CAAC,OAAO,EAAE;MAClCC,IAAI,EAAErE,MAAM;MACZsE,OAAO,EAAE,KAAK;MACdC,UAAU,EAAE;IACd,CAAC,CAAC;IACFV,IAAI,CAACW,aAAa,CAACL,GAAG,CAAC;IACvBL,gBAAQ,CAACG,IAAI,CAACQ,WAAW,CAACZ,IAAI,CAAC;IAC/BF,WAAG,CAACe,eAAe,CAAChB,GAAG,CAAC;EAC1B;AACF;;AAEA;AACA;AACA;AACA;AACO,SAASiB,WAAWA,CACzBC,kBAA+B,EAE/B;EAAA,IADAC,QAAQ,GAAAzF,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,IAAA0F,uCAAoB,EAAC,CAAC,CAACC,gBAAgB;EAElD,IAAOC,YAAY,GAAIJ,kBAAkB,CAAlCI,YAAY;EACnB,IAAIA,YAAY,EAAE;IAChB,IAAMC,IAAI,GAAGxC,aAAa,CAACuC,YAAY,CAAC;IACxCzB,YAAY,CAAC0B,IAAI,EAAEJ,QAAQ,CAAC;EAC9B;AACF;AAEO,SAASK,kBAAkBA,CAACC,IAAI,EAAE;EACvC,IAAI;IACF,OAAOC,IAAI,CAACC,SAAS,CAACF,IAAI,CAAC;EAC7B,CAAC,CAAC,OAAO5G,CAAC,EAAE;IACV,IAAIA,CAAC,YAAY+G,SAAS,EAAE,OAAO/G,CAAC,CAACgH,OAAO;IAC5C;IACA,OAAQhH,CAAC,CAASiH,WAAW;EAC/B;AACF;AAEO,SAASC,UAAUA,CAACC,KAAK,EAA8D;EAAA,IAA5DpD,OAAO,GAAAlD,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,IAAA0F,uCAAoB,EAAC,CAAC,CAACa,yBAAyB;EAC1F,IAAOC,OAAO,GAAItD,OAAO,CAAlBsD,OAAO;EACd,IAAMC,MAAM,GAAGH,KAAK,CAACI,QAAQ,CAACD,MAAM;EAEpC,IAAI,CAACD,OAAO,EAAE;IACZ,OAAOC,MAAM,CAACE,eAAe,CAACL,KAAK,CAAC;EACtC;EAEA,IAAIM,SAAS,GAAGH,MAAM,CAACI,IAAI,CAACP,KAAK,CAAC;EAClC;EACA,IAAMQ,KAAK,GAAG,IAAAC,eAAG,EAACH,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;EAC/C,IAAI,CAACE,KAAK,IAAI,CAACA,KAAK,CAAC7G,MAAM,EAAE;IAC3B2G,SAAS,GAAG,IAAAI,UAAG,EAAC,CAAC,MAAM,EAAE,OAAO,CAAC,cAAAC,MAAA,CAAc,IAAAC,2BAAc,EAAC,CAAC,CAAC,GAAIN,SAAS,CAAC;EAChF;EACA,OAAOA,SAAS;AAClB;AAEO,SAASO,UAAUA,CAACb,KAAK,EAAqB;EAAA,IAAnBpD,OAAY,GAAAlD,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,CAAC,CAAC;EACjD,IAAMoH,GAAG,GAAGf,UAAU,CAACC,KAAK,EAAEpD,OAAO,CAAC;EACtCkE,GAAG,CAACC,IAAI,CAACC,MAAM,GAAG,WAAW;EAC7B,IAAMlD,QAAQ,GAAG,IAAIH,YAAI,CAAC,CAAC6B,kBAAkB,CAACsB,GAAG,CAAC,CAAC,EAAE;IAAClD,IAAI,EAAE;EAAkB,CAAC,CAAC;EAChF,IAAMG,QAAQ,GAAGiC,KAAK,CAACiB,OAAO,MAAAN,MAAA,CAAMX,KAAK,CAACiB,OAAO,aAAU,IAAA7B,uCAAoB,EAAC,CAAC,CAAC8B,eAAe;EACjGrD,YAAY,CAACC,QAAQ,EAAEC,QAAQ,CAAC;AAClC;AAEO,SAASoD,UAAUA,CAACnB,KAAK,EAAEpD,OAAO,EAAE;EACzC,IAAOwE,eAAe,GAAmCxE,OAAO,CAAzDwE,eAAe;IAAEC,uBAAuB,GAAUzE,OAAO,CAAxCyE,uBAAuB;IAAEC,IAAI,GAAI1E,OAAO,CAAf0E,IAAI;EAErD,IAAM7B,IAAI,GAAAhG,aAAA,CAAAA,aAAA,KACLsG,UAAU,CAACC,KAAK,CAAC;IACpBuB,oBAAoB,EAClB,CAACH,eAAe,IAAI,EAAE,MAAM,EAAE,GAAGA,eAAe,GAAGC,uBAAuB;IAC5EC,IAAI,EAAJA;EAAI,EACL;EAED,IAAMxD,QAAQ,GAAG,IAAIH,YAAI,CAAC,CAAC,IAAA6D,8BAAe,EAAC/B,IAAI,CAAC,CAAC,EAAE;IAAC7B,IAAI,EAAE;EAAW,CAAC,CAAC;EACvEC,YAAY,CACVC,QAAQ,EACRkC,KAAK,CAACiB,OAAO,MAAAN,MAAA,CAAMX,KAAK,CAACiB,OAAO,aAAU,IAAA7B,uCAAoB,EAAC,CAAC,CAACqC,eACnE,CAAC;AACH;AAEO,SAASC,SAASA,CAAC1B,KAAK,EAA8D;EAAA,IAA5DpD,OAAO,GAAAlD,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAkB,SAAA,GAAAlB,SAAA,MAAG,IAAA0F,uCAAoB,EAAC,CAAC,CAACa,yBAAyB;EACzF,IAAOX,YAAY,GAAIU,KAAK,CAAC2B,OAAO,CAAC1C,WAAW,CAAzCK,YAAY;EACnB,IAAMsC,SAAsB,GAAGtC,YAAY,GAAGvC,aAAa,CAACuC,YAAY,CAAC,GAAG,IAAI;EAChF,IAAMgB,SAAS,GAAGP,UAAU,CAACC,KAAK,EAAEpD,OAAO,CAAC;EAE5C,OAAO;IACLkE,GAAG,EAAER,SAAS;IACdsB,SAAS,EAATA;EACF,CAAC;AACH;AAEA,IAAMC,SAAS,GAAG;EAChB5C,WAAW,EAAXA,WAAW;EACX4B,UAAU,EAAVA,UAAU;EACVM,UAAU,EAAVA;AACF,CAAC;AAAC,IAAAW,QAAA,GAAAC,OAAA,cAEaF,SAAS","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kepler.gl/utils",
|
|
3
3
|
"author": "Shan He <shan@uber.com>",
|
|
4
|
-
"version": "3.2.
|
|
4
|
+
"version": "3.2.6",
|
|
5
5
|
"description": "kepler.gl constants used by kepler.gl components, actions and reducers",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"main": "dist/index.js",
|
|
@@ -31,9 +31,9 @@
|
|
|
31
31
|
],
|
|
32
32
|
"dependencies": {
|
|
33
33
|
"@deck.gl/core": "^8.9.27",
|
|
34
|
-
"@kepler.gl/common-utils": "3.2.
|
|
35
|
-
"@kepler.gl/constants": "3.2.
|
|
36
|
-
"@kepler.gl/types": "3.2.
|
|
34
|
+
"@kepler.gl/common-utils": "3.2.6",
|
|
35
|
+
"@kepler.gl/constants": "3.2.6",
|
|
36
|
+
"@kepler.gl/types": "3.2.6",
|
|
37
37
|
"@loaders.gl/arrow": "^4.3.2",
|
|
38
38
|
"@luma.gl/constants": "^8.5.20",
|
|
39
39
|
"@luma.gl/core": "^8.5.20",
|
|
@@ -56,7 +56,6 @@
|
|
|
56
56
|
"mapbox-gl": "^1.13.1",
|
|
57
57
|
"maplibre-gl": "^3.6.2",
|
|
58
58
|
"maplibregl-mapbox-request-transformer": "^0.0.2",
|
|
59
|
-
"mini-svg-data-uri": "^1.0.3",
|
|
60
59
|
"moment": "^2.10.6",
|
|
61
60
|
"moment-timezone": "^0.5.35",
|
|
62
61
|
"react": "^18.2.0",
|