UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

425 lines (342 loc) 41.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.processClone = processClone; exports.asArray = asArray; exports.fourRandomChars = fourRandomChars; exports.uid = uid; exports.makeImage = makeImage; exports.isDataUrl = isDataUrl; exports.mimeType = mimeType; exports.dataAsUrl = dataAsUrl; exports.escape = escape; exports.delay = delay; exports.isSrcAsDataUrl = isSrcAsDataUrl; exports.canvasToBlob = canvasToBlob; exports.escapeXhtml = escapeXhtml; exports.getWidth = getWidth; exports.getHeight = getHeight; exports.resolveUrl = resolveUrl; exports.getAndEncode = getAndEncode; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _console = _interopRequireDefault(require("global/console")); var _window = _interopRequireDefault(require("global/window")); var _document = _interopRequireDefault(require("global/document")); var _userFeedbacks = require("../constants/user-feedbacks"); // Copyright (c) 2020 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. function processClone(original, clone) { if (!(clone instanceof _window["default"].Element)) { return clone; } function copyProperties(sourceStyle, targetStyle) { var propertyKeys = asArray(sourceStyle); propertyKeys.forEach(function (name) { targetStyle.setProperty(name, sourceStyle.getPropertyValue(name), sourceStyle.getPropertyPriority(name)); }); } function copyStyle(source, target) { if (source.cssText) { target.cssText = source.cssText; // add additional copy of composite styles if (source.font) { target.font = source.font; } } else { copyProperties(source, target); } } function cloneStyle(og, cln) { var originalStyle = _window["default"].getComputedStyle(og); copyStyle(originalStyle, cln.style); } function formatPseudoElementStyle(cln, elm, stl) { var formatCssText = function formatCssText(stl1) { var cnt = stl1.getPropertyValue('content'); return "".concat(stl.cssText, " content: ").concat(cnt, ";"); }; var formatProperty = function formatProperty(name) { return "".concat(name, ":").concat(stl.getPropertyValue(name)).concat(stl.getPropertyPriority(name) ? ' !important' : ''); }; var formatCssProperties = function formatCssProperties(stl2) { return "".concat(asArray(stl2).map(formatProperty).join('; '), ";"); }; var selector = ".".concat(cln, ":").concat(elm); var cssText = stl.cssText ? formatCssText(stl) : formatCssProperties(stl); return _document["default"].createTextNode("".concat(selector, "{").concat(cssText, "}")); } function clonePseudoElement(org, cln, element) { var style = _window["default"].getComputedStyle(org, element); var content = style.getPropertyValue('content'); if (content === '' || content === 'none') { return; } var className = uid(); cln.className = "".concat(cln.className, " ").concat(className); var styleElement = _document["default"].createElement('style'); styleElement.appendChild(formatPseudoElementStyle(className, element, style)); cln.appendChild(styleElement); } function clonePseudoElements(_ref) { var _ref2 = (0, _slicedToArray2["default"])(_ref, 2), og = _ref2[0], cln = _ref2[1]; [':before', ':after'].forEach(function (element) { return clonePseudoElement(og, cln, element); }); } function copyUserInput(_ref3) { var _ref4 = (0, _slicedToArray2["default"])(_ref3, 2), og = _ref4[0], cln = _ref4[1]; if (og instanceof _window["default"].HTMLTextAreaElement) cln.innerHTML = og.value; if (og instanceof _window["default"].HTMLInputElement) cln.setAttribute('value', og.value); } function fixSvg(cln) { if (!(cln instanceof _window["default"].SVGElement)) return; cln.setAttribute('xmlns', 'http://www.w3.org/2000/svg'); if (!(cln instanceof _window["default"].SVGRectElement)) return; ['width', 'height'].forEach(function (attribute) { var value = cln.getAttribute(attribute); if (!value) return; cln.style.setProperty(attribute, value); }); } return Promise.resolve([original, clone]).then(function (_ref5) { var _ref6 = (0, _slicedToArray2["default"])(_ref5, 2), og = _ref6[0], cln = _ref6[1]; cloneStyle(og, cln); return [og, cln]; }).then(function (_ref7) { var _ref8 = (0, _slicedToArray2["default"])(_ref7, 2), og = _ref8[0], cln = _ref8[1]; clonePseudoElements([og, cln]); return [og, cln]; }).then(function (_ref9) { var _ref10 = (0, _slicedToArray2["default"])(_ref9, 2), og = _ref10[0], cln = _ref10[1]; copyUserInput([og, cln]); return [og, cln]; }).then(function (_ref11) { var _ref12 = (0, _slicedToArray2["default"])(_ref11, 2), og = _ref12[0], cln = _ref12[1]; fixSvg(cln); return [og, cln]; }).then(function (_ref13) { var _ref14 = (0, _slicedToArray2["default"])(_ref13, 2), og = _ref14[0], cln = _ref14[1]; return cln; }); } /**** * UTILS ****/ function asArray(arrayLike) { var array = []; var length = arrayLike.length; for (var i = 0; i < length; i++) { array.push(arrayLike[i]); } return array; } function fourRandomChars() { /* see http://stackoverflow.com/a/6248722/2519373 */ return "0000".concat((Math.random() * Math.pow(36, 4) << 0).toString(36)).slice(-4); } function uid() { var index = 0; return "u".concat(fourRandomChars()).concat(index++); } function makeImage(uri) { return new Promise(function (resolve, reject) { var image = new _window["default"].Image(); image.onload = function () { resolve(image); }; image.onerror = function (err) { var message = _userFeedbacks.IMAGE_EXPORT_ERRORS.dataUri; _console["default"].log(uri); // error is an Event Object // https://www.w3schools.com/jsref/obj_event.asp reject({ event: err, message: message }); }; image.src = uri; }); } function isDataUrl(url) { return url.search(/^(data:)/) !== -1; } function parseExtension(url) { var match = /\.([^\.\/]*?)$/g.exec(url); if (match) { return match[1]; } return ''; } function mimes() { /* * Only WOFF and EOT mime types for fonts are 'real' * see http://www.iana.org/assignments/media-types/media-types.xhtml */ var WOFF = 'application/font-woff'; var JPEG = 'image/jpeg'; return { woff: WOFF, woff2: WOFF, ttf: 'application/font-truetype', eot: 'application/vnd.ms-fontobject', png: 'image/png', jpg: JPEG, jpeg: JPEG, gif: 'image/gif', tiff: 'image/tiff', svg: 'image/svg+xml' }; } function mimeType(url) { var extension = parseExtension(url).toLowerCase(); return mimes()[extension] || ''; } function dataAsUrl(content, type) { return "data:".concat(type, ";base64,").concat(content); } function escape(string) { return string.replace(/([.*+?^${}()|\[\]\/\\])/g, '\\$1'); } function delay(ms) { return function (arg) { return new Promise(function (resolve) { _window["default"].setTimeout(function () { resolve(arg); }, ms); }); }; } function isSrcAsDataUrl(text) { var DATA_URL_REGEX = /url\(['"]?(data:)([^'"]+?)['"]?\)/; return text.search(DATA_URL_REGEX) !== -1; } function cvToBlob(canvas) { return new Promise(function (resolve) { var binaryString = _window["default"].atob(canvas.toDataURL().split(',')[1]); var length = binaryString.length; var binaryArray = new Uint8Array(length); for (var i = 0; i < length; i++) { binaryArray[i] = binaryString.charCodeAt(i); } resolve(new _window["default"].Blob([binaryArray], { type: 'image/png' })); }); } function canvasToBlob(canvas) { if (canvas.toBlob) return new Promise(function (resolve) { canvas.toBlob(resolve); }); return cvToBlob(canvas); } function escapeXhtml(string) { return string.replace(/#/g, '%23').replace(/\n/g, '%0A'); } function getWidth(node) { var leftBorder = px(node, 'border-left-width'); var rightBorder = px(node, 'border-right-width'); return node.scrollWidth + leftBorder + rightBorder; } function getHeight(node) { var topBorder = px(node, 'border-top-width'); var bottomBorder = px(node, 'border-bottom-width'); return node.scrollHeight + topBorder + bottomBorder; } function px(node, styleProperty) { var value = _window["default"].getComputedStyle(node).getPropertyValue(styleProperty); return parseFloat(value.replace('px', '')); } function resolveUrl(url, baseUrl) { var doc = _document["default"].implementation.createHTMLDocument(); var base = doc.createElement('base'); doc.head.appendChild(base); var a = doc.createElement('a'); doc.body.appendChild(a); base.href = baseUrl; a.href = url; return a.href; } function getAndEncode(url, options) { var TIMEOUT = 30000; if (options.cacheBust) { // Cache bypass so we dont have CORS issues with cached images // Source: https://developer.mozilla.org/en/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest#Bypassing_the_cache url += (/\?/.test(url) ? '&' : '?') + new Date().getTime(); } return new Promise(function (resolve) { var request = new _window["default"].XMLHttpRequest(); request.onreadystatechange = done; request.ontimeout = timeout; request.responseType = 'blob'; request.timeout = TIMEOUT; request.open('GET', url, true); request.send(); var placeholder; if (options.imagePlaceholder) { var split = options.imagePlaceholder.split(/,/); if (split && split[1]) { placeholder = split[1]; } } function done() { if (request.readyState !== 4) return; if (request.status !== 200) { if (placeholder) { resolve(placeholder); } else { fail("cannot fetch resource: ".concat(url, ", status: ").concat(request.status)); } return; } var encoder = new _window["default"].FileReader(); encoder.onloadend = function () { var content = encoder.result.split(/,/)[1]; resolve(content); }; encoder.readAsDataURL(request.response); } function timeout() { if (placeholder) { resolve(placeholder); } else { fail("timeout of ".concat(TIMEOUT, "ms occurred while fetching resource: ").concat(url)); } } function fail(message) { _console["default"].error(message); resolve(''); } }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/dom-utils.js"],"names":["processClone","original","clone","window","Element","copyProperties","sourceStyle","targetStyle","propertyKeys","asArray","forEach","name","setProperty","getPropertyValue","getPropertyPriority","copyStyle","source","target","cssText","font","cloneStyle","og","cln","originalStyle","getComputedStyle","style","formatPseudoElementStyle","elm","stl","formatCssText","stl1","cnt","formatProperty","formatCssProperties","stl2","map","join","selector","document","createTextNode","clonePseudoElement","org","element","content","className","uid","styleElement","createElement","appendChild","clonePseudoElements","copyUserInput","HTMLTextAreaElement","innerHTML","value","HTMLInputElement","setAttribute","fixSvg","SVGElement","SVGRectElement","attribute","getAttribute","Promise","resolve","then","arrayLike","array","length","i","push","fourRandomChars","Math","random","pow","toString","slice","index","makeImage","uri","reject","image","Image","onload","onerror","err","message","IMAGE_EXPORT_ERRORS","dataUri","console","log","event","src","isDataUrl","url","search","parseExtension","match","exec","mimes","WOFF","JPEG","woff","woff2","ttf","eot","png","jpg","jpeg","gif","tiff","svg","mimeType","extension","toLowerCase","dataAsUrl","type","escape","string","replace","delay","ms","arg","setTimeout","isSrcAsDataUrl","text","DATA_URL_REGEX","cvToBlob","canvas","binaryString","atob","toDataURL","split","binaryArray","Uint8Array","charCodeAt","Blob","canvasToBlob","toBlob","escapeXhtml","getWidth","node","leftBorder","px","rightBorder","scrollWidth","getHeight","topBorder","bottomBorder","scrollHeight","styleProperty","parseFloat","resolveUrl","baseUrl","doc","implementation","createHTMLDocument","base","head","a","body","href","getAndEncode","options","TIMEOUT","cacheBust","test","Date","getTime","request","XMLHttpRequest","onreadystatechange","done","ontimeout","timeout","responseType","open","send","placeholder","imagePlaceholder","readyState","status","fail","encoder","FileReader","onloadend","result","readAsDataURL","response","error"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport console from 'global/console';\nimport window from 'global/window';\nimport document from 'global/document';\nimport {IMAGE_EXPORT_ERRORS} from 'constants/user-feedbacks';\n\nexport function processClone(original, clone) {\n  if (!(clone instanceof window.Element)) {\n    return clone;\n  }\n\n  function copyProperties(sourceStyle, targetStyle) {\n    const propertyKeys = asArray(sourceStyle);\n    propertyKeys.forEach(name => {\n      targetStyle.setProperty(\n        name,\n        sourceStyle.getPropertyValue(name),\n        sourceStyle.getPropertyPriority(name)\n      );\n    });\n  }\n\n  function copyStyle(source, target) {\n    if (source.cssText) {\n      target.cssText = source.cssText;\n      // add additional copy of composite styles\n      if (source.font) {\n        target.font = source.font;\n      }\n    } else {\n      copyProperties(source, target);\n    }\n  }\n\n  function cloneStyle(og, cln) {\n    const originalStyle = window.getComputedStyle(og);\n    copyStyle(originalStyle, cln.style);\n  }\n\n  function formatPseudoElementStyle(cln, elm, stl) {\n    const formatCssText = stl1 => {\n      const cnt = stl1.getPropertyValue('content');\n      return `${stl.cssText} content: ${cnt};`;\n    };\n\n    const formatProperty = name => {\n      return `${name}:${stl.getPropertyValue(name)}${\n        stl.getPropertyPriority(name) ? ' !important' : ''\n      }`;\n    };\n\n    const formatCssProperties = stl2 => {\n      return `${asArray(stl2)\n        .map(formatProperty)\n        .join('; ')};`;\n    };\n\n    const selector = `.${cln}:${elm}`;\n    const cssText = stl.cssText ? formatCssText(stl) : formatCssProperties(stl);\n\n    return document.createTextNode(`${selector}{${cssText}}`);\n  }\n\n  function clonePseudoElement(org, cln, element) {\n    const style = window.getComputedStyle(org, element);\n    const content = style.getPropertyValue('content');\n\n    if (content === '' || content === 'none') {\n      return;\n    }\n\n    const className = uid();\n    cln.className = `${cln.className} ${className}`;\n    const styleElement = document.createElement('style');\n    styleElement.appendChild(formatPseudoElementStyle(className, element, style));\n    cln.appendChild(styleElement);\n  }\n\n  function clonePseudoElements([og, cln]) {\n    [':before', ':after'].forEach(element => clonePseudoElement(og, cln, element));\n  }\n\n  function copyUserInput([og, cln]) {\n    if (og instanceof window.HTMLTextAreaElement) cln.innerHTML = og.value;\n    if (og instanceof window.HTMLInputElement) cln.setAttribute('value', og.value);\n  }\n\n  function fixSvg(cln) {\n    if (!(cln instanceof window.SVGElement)) return;\n    cln.setAttribute('xmlns', 'http://www.w3.org/2000/svg');\n\n    if (!(cln instanceof window.SVGRectElement)) return;\n    ['width', 'height'].forEach(attribute => {\n      const value = cln.getAttribute(attribute);\n      if (!value) return;\n\n      cln.style.setProperty(attribute, value);\n    });\n  }\n\n  return Promise.resolve([original, clone])\n    .then(([og, cln]) => {\n      cloneStyle(og, cln);\n      return [og, cln];\n    })\n    .then(([og, cln]) => {\n      clonePseudoElements([og, cln]);\n      return [og, cln];\n    })\n    .then(([og, cln]) => {\n      copyUserInput([og, cln]);\n      return [og, cln];\n    })\n    .then(([og, cln]) => {\n      fixSvg(cln);\n      return [og, cln];\n    })\n    .then(([og, cln]) => cln);\n}\n\n/****\n * UTILS\n ****/\nexport function asArray(arrayLike) {\n  const array = [];\n  const length = arrayLike.length;\n  for (let i = 0; i < length; i++) array.push(arrayLike[i]);\n  return array;\n}\n\nexport function fourRandomChars() {\n  /* see http://stackoverflow.com/a/6248722/2519373 */\n  return `0000${((Math.random() * Math.pow(36, 4)) << 0).toString(36)}`.slice(-4);\n}\n\nexport function uid() {\n  let index = 0;\n\n  return `u${fourRandomChars()}${index++}`;\n}\n\nexport function makeImage(uri) {\n  return new Promise((resolve, reject) => {\n    const image = new window.Image();\n    image.onload = () => {\n      resolve(image);\n    };\n    image.onerror = err => {\n      const message = IMAGE_EXPORT_ERRORS.dataUri;\n      console.log(uri);\n      // error is an Event Object\n      // https://www.w3schools.com/jsref/obj_event.asp\n      reject({event: err, message});\n    };\n    image.src = uri;\n  });\n}\n\nexport function isDataUrl(url) {\n  return url.search(/^(data:)/) !== -1;\n}\n\nfunction parseExtension(url) {\n  const match = /\\.([^\\.\\/]*?)$/g.exec(url);\n  if (match) {\n    return match[1];\n  }\n  return '';\n}\n\nfunction mimes() {\n  /*\n   * Only WOFF and EOT mime types for fonts are 'real'\n   * see http://www.iana.org/assignments/media-types/media-types.xhtml\n   */\n  const WOFF = 'application/font-woff';\n  const JPEG = 'image/jpeg';\n\n  return {\n    woff: WOFF,\n    woff2: WOFF,\n    ttf: 'application/font-truetype',\n    eot: 'application/vnd.ms-fontobject',\n    png: 'image/png',\n    jpg: JPEG,\n    jpeg: JPEG,\n    gif: 'image/gif',\n    tiff: 'image/tiff',\n    svg: 'image/svg+xml'\n  };\n}\n\nexport function mimeType(url) {\n  const extension = parseExtension(url).toLowerCase();\n  return mimes()[extension] || '';\n}\n\nexport function dataAsUrl(content, type) {\n  return `data:${type};base64,${content}`;\n}\n\nexport function escape(string) {\n  return string.replace(/([.*+?^${}()|\\[\\]\\/\\\\])/g, '\\\\$1');\n}\n\nexport function delay(ms) {\n  return arg => {\n    return new Promise(resolve => {\n      window.setTimeout(() => {\n        resolve(arg);\n      }, ms);\n    });\n  };\n}\n\nexport function isSrcAsDataUrl(text) {\n  const DATA_URL_REGEX = /url\\(['\"]?(data:)([^'\"]+?)['\"]?\\)/;\n\n  return text.search(DATA_URL_REGEX) !== -1;\n}\n\nfunction cvToBlob(canvas) {\n  return new Promise(resolve => {\n    const binaryString = window.atob(canvas.toDataURL().split(',')[1]);\n    const length = binaryString.length;\n    const binaryArray = new Uint8Array(length);\n\n    for (let i = 0; i < length; i++) binaryArray[i] = binaryString.charCodeAt(i);\n\n    resolve(new window.Blob([binaryArray], {type: 'image/png'}));\n  });\n}\n\nexport function canvasToBlob(canvas) {\n  if (canvas.toBlob)\n    return new Promise(resolve => {\n      canvas.toBlob(resolve);\n    });\n\n  return cvToBlob(canvas);\n}\n\nexport function escapeXhtml(string) {\n  return string.replace(/#/g, '%23').replace(/\\n/g, '%0A');\n}\n\nexport function getWidth(node) {\n  const leftBorder = px(node, 'border-left-width');\n  const rightBorder = px(node, 'border-right-width');\n  return node.scrollWidth + leftBorder + rightBorder;\n}\n\nexport function getHeight(node) {\n  const topBorder = px(node, 'border-top-width');\n  const bottomBorder = px(node, 'border-bottom-width');\n  return node.scrollHeight + topBorder + bottomBorder;\n}\n\nfunction px(node, styleProperty) {\n  const value = window.getComputedStyle(node).getPropertyValue(styleProperty);\n  return parseFloat(value.replace('px', ''));\n}\n\nexport function resolveUrl(url, baseUrl) {\n  const doc = document.implementation.createHTMLDocument();\n  const base = doc.createElement('base');\n  doc.head.appendChild(base);\n  const a = doc.createElement('a');\n  doc.body.appendChild(a);\n  base.href = baseUrl;\n  a.href = url;\n  return a.href;\n}\n\nexport function getAndEncode(url, options) {\n  const TIMEOUT = 30000;\n  if (options.cacheBust) {\n    // Cache bypass so we dont have CORS issues with cached images\n    // Source: https://developer.mozilla.org/en/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest#Bypassing_the_cache\n    url += (/\\?/.test(url) ? '&' : '?') + new Date().getTime();\n  }\n\n  return new Promise(resolve => {\n    const request = new window.XMLHttpRequest();\n\n    request.onreadystatechange = done;\n    request.ontimeout = timeout;\n    request.responseType = 'blob';\n    request.timeout = TIMEOUT;\n    request.open('GET', url, true);\n    request.send();\n\n    let placeholder;\n    if (options.imagePlaceholder) {\n      const split = options.imagePlaceholder.split(/,/);\n      if (split && split[1]) {\n        placeholder = split[1];\n      }\n    }\n\n    function done() {\n      if (request.readyState !== 4) return;\n\n      if (request.status !== 200) {\n        if (placeholder) {\n          resolve(placeholder);\n        } else {\n          fail(`cannot fetch resource: ${url}, status: ${request.status}`);\n        }\n\n        return;\n      }\n\n      const encoder = new window.FileReader();\n      encoder.onloadend = () => {\n        const content = encoder.result.split(/,/)[1];\n        resolve(content);\n      };\n      encoder.readAsDataURL(request.response);\n    }\n\n    function timeout() {\n      if (placeholder) {\n        resolve(placeholder);\n      } else {\n        fail(`timeout of ${TIMEOUT}ms occurred while fetching resource: ${url}`);\n      }\n    }\n\n    function fail(message) {\n      console.error(message);\n      resolve('');\n    }\n  });\n}\n"]}