UNPKG

kepler.gl

Version:

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

149 lines (143 loc) 23.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getArrowTextVector = exports.formatTextLabelData = exports.defaultPadding = void 0; exports.getTextOffsetByRadius = getTextOffsetByRadius; exports.textLabelAccessor = void 0; var arrow = _interopRequireWildcard(require("apache-arrow")); var _viewportMercatorProject = require("viewport-mercator-project"); var _utils = require("@kepler.gl/utils"); var _commonUtils = require("@kepler.gl/common-utils"); var _lodash = _interopRequireDefault(require("lodash.uniq")); 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); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(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 // Copyright contributors to the kepler.gl project var defaultPadding = exports.defaultPadding = 20; function getTextOffsetByRadius(radiusScale, getRadius, mapState) { return function (textLabel) { var distanceScale = (0, _viewportMercatorProject.getDistanceScales)(mapState); var xMult = textLabel.anchor === 'middle' ? 0 : textLabel.anchor === 'start' ? 1 : -1; var yMult = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? 1 : -1; var sizeOffset = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? textLabel.size : textLabel.size; var pixelRadius = radiusScale * distanceScale.pixelsPerMeter[0]; var padding = defaultPadding; return typeof getRadius === 'function' ? function (d) { return [xMult * (getRadius(d) * pixelRadius + padding), yMult * (getRadius(d) * pixelRadius + padding + sizeOffset)]; } : [xMult * (getRadius * pixelRadius + padding), yMult * (getRadius * pixelRadius + padding + sizeOffset)]; }; } // eslint-disable-next-line @typescript-eslint/no-unused-vars var textLabelAccessor = exports.textLabelAccessor = function textLabelAccessor(textLabel) { return function (dc) { return function (d) { var val = textLabel.field.valueAccessor(d); return (0, _commonUtils.notNullorUndefined)(val) ? String(val) : ''; }; }; }; var formatTextLabelData = exports.formatTextLabelData = function formatTextLabelData(_ref) { var textLabel = _ref.textLabel, triggerChanged = _ref.triggerChanged, oldLayerData = _ref.oldLayerData, data = _ref.data, dataContainer = _ref.dataContainer, filteredIndex = _ref.filteredIndex; return textLabel.map(function (tl, i) { if (!tl.field) { // if no field selected, return { getText: null, characterSet: [] }; } var getTextAccessor = textLabelAccessor(tl)(dataContainer); var characterSet; var getText = getTextAccessor; var rebuildArrowTextVector = true; if (!(triggerChanged !== null && triggerChanged !== void 0 && triggerChanged["getLabelCharacterSet-".concat(i)]) && oldLayerData && oldLayerData.textLabels && oldLayerData.textLabels[i]) { characterSet = oldLayerData.textLabels[i].characterSet; getText = oldLayerData.textLabels[i].getText; rebuildArrowTextVector = false; } else { if (data instanceof arrow.Table) { // we don't filter out arrow tables, // so we use filteredIndex array instead var allLabels = []; if (tl.field) { if (filteredIndex) { filteredIndex.forEach(function (value, index) { if (value > 0) allLabels.push(getTextAccessor({ index: index })); }); } else { for (var index = 0; index < dataContainer.numRows(); ++index) { allLabels.push(getTextAccessor({ index: index })); } } } characterSet = (0, _lodash["default"])(allLabels.join('')); } else { var _allLabels = tl.field ? data.map(getTextAccessor) : []; characterSet = (0, _lodash["default"])(_allLabels.join('')); } } // For Arrow Layers getText has to be an arrow vector. // For now check here for ArrowTable, not ArrowDataContainer. if (rebuildArrowTextVector && data instanceof arrow.Table && dataContainer instanceof _utils.ArrowDataContainer) { getText = dataContainer.getColumn(tl.field.fieldIdx); try { getText = getArrowTextVector(getText, getTextAccessor); } catch (error) { // empty text labels getText = getArrowTextVector(getText, function () { return ' '; }); } } return { characterSet: characterSet, getText: getText }; }); }; /** * Get an arrow vector suitable to render text labels with arrow layers. * @param getText A candidate arrow vector to use for text labels. * @param getTextAccessor Text label accessor. */ var getArrowTextVector = exports.getArrowTextVector = function getArrowTextVector(candidateTextVector, getTextAccessor) { // if the passed vector is suitable for text labels if (arrow.DataType.isUtf8(candidateTextVector === null || candidateTextVector === void 0 ? void 0 : candidateTextVector.type)) { return candidateTextVector; } // create utf8 vector from source vector with the same number of batches. // @ts-expect-error var offsets = candidateTextVector._offsets; var numOffsets = offsets.length; var batchVectors = []; var datum = { index: 0 }; for (var batchIndex = 0; batchIndex < numOffsets - 1; batchIndex++) { var batchStart = offsets[batchIndex]; var batchEnd = offsets[batchIndex + 1]; var batchLabels = []; for (var rowIndex = batchStart; rowIndex < batchEnd; ++rowIndex) { datum.index = rowIndex; batchLabels.push(getTextAccessor(datum)); } batchVectors.push(arrow.vectorFromArray(batchLabels, new arrow.Utf8())); } var input = batchVectors.flatMap(function (x) { return x.data; }).flat(Number.POSITIVE_INFINITY); return new arrow.Vector(input); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["arrow","_interopRequireWildcard","require","_viewportMercatorProject","_utils","_commonUtils","_lodash","_interopRequireDefault","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","defaultPadding","exports","getTextOffsetByRadius","radiusScale","getRadius","mapState","textLabel","distanceScale","getDistanceScales","xMult","anchor","yMult","alignment","sizeOffset","size","pixelRadius","pixelsPerMeter","padding","d","textLabelAccessor","dc","val","field","valueAccessor","notNullorUndefined","String","formatTextLabelData","_ref","triggerChanged","oldLayerData","data","dataContainer","filteredIndex","map","tl","getText","characterSet","getTextAccessor","rebuildArrowTextVector","concat","textLabels","Table","allLabels","forEach","value","index","push","numRows","uniq","join","ArrowDataContainer","getColumn","fieldIdx","getArrowTextVector","error","candidateTextVector","DataType","isUtf8","type","offsets","_offsets","numOffsets","length","batchVectors","datum","batchIndex","batchStart","batchEnd","batchLabels","rowIndex","vectorFromArray","Utf8","input","flatMap","x","flat","Number","POSITIVE_INFINITY","Vector"],"sources":["../src/layer-text-label.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport {getDistanceScales} from 'viewport-mercator-project';\nimport {DataContainerInterface, ArrowDataContainer} from '@kepler.gl/utils';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport uniq from 'lodash.uniq';\n\nexport const defaultPadding = 20;\n\nexport function getTextOffsetByRadius(radiusScale, getRadius, mapState) {\n  return textLabel => {\n    const distanceScale = getDistanceScales(mapState);\n    const xMult = textLabel.anchor === 'middle' ? 0 : textLabel.anchor === 'start' ? 1 : -1;\n    const yMult = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? 1 : -1;\n\n    const sizeOffset =\n      textLabel.alignment === 'center'\n        ? 0\n        : textLabel.alignment === 'bottom'\n        ? textLabel.size\n        : textLabel.size;\n\n    const pixelRadius = radiusScale * distanceScale.pixelsPerMeter[0];\n    const padding = defaultPadding;\n\n    return typeof getRadius === 'function'\n      ? d => [\n          xMult * (getRadius(d) * pixelRadius + padding),\n          yMult * (getRadius(d) * pixelRadius + padding + sizeOffset)\n        ]\n      : [\n          xMult * (getRadius * pixelRadius + padding),\n          yMult * (getRadius * pixelRadius + padding + sizeOffset)\n        ];\n  };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport const textLabelAccessor = textLabel => dc => d => {\n  const val = textLabel.field.valueAccessor(d);\n  return notNullorUndefined(val) ? String(val) : '';\n};\n\nexport const formatTextLabelData = ({\n  textLabel,\n  triggerChanged,\n  oldLayerData,\n  data,\n  dataContainer,\n  filteredIndex\n}: {\n  textLabel: any;\n  triggerChanged?: boolean | {[key: string]: boolean};\n  oldLayerData: any;\n  data: any;\n  dataContainer: DataContainerInterface;\n  filteredIndex?: Uint8ClampedArray | null;\n}) => {\n  return textLabel.map((tl, i) => {\n    if (!tl.field) {\n      // if no field selected,\n      return {\n        getText: null,\n        characterSet: []\n      };\n    }\n\n    const getTextAccessor: (d: {index: number}) => string = textLabelAccessor(tl)(dataContainer);\n    let characterSet;\n    let getText: typeof getTextAccessor | arrow.Vector = getTextAccessor;\n\n    let rebuildArrowTextVector = true;\n    if (\n      !triggerChanged?.[`getLabelCharacterSet-${i}`] &&\n      oldLayerData &&\n      oldLayerData.textLabels &&\n      oldLayerData.textLabels[i]\n    ) {\n      characterSet = oldLayerData.textLabels[i].characterSet;\n      getText = oldLayerData.textLabels[i].getText;\n      rebuildArrowTextVector = false;\n    } else {\n      if (data instanceof arrow.Table) {\n        // we don't filter out arrow tables,\n        // so we use filteredIndex array instead\n        const allLabels: string[] = [];\n        if (tl.field) {\n          if (filteredIndex) {\n            filteredIndex.forEach((value, index) => {\n              if (value > 0) allLabels.push(getTextAccessor({index}));\n            });\n          } else {\n            for (let index = 0; index < dataContainer.numRows(); ++index) {\n              allLabels.push(getTextAccessor({index}));\n            }\n          }\n        }\n        characterSet = uniq(allLabels.join(''));\n      } else {\n        const allLabels = tl.field ? data.map(getTextAccessor) : [];\n        characterSet = uniq(allLabels.join(''));\n      }\n    }\n\n    // For Arrow Layers getText has to be an arrow vector.\n    // For now check here for ArrowTable, not ArrowDataContainer.\n    if (\n      rebuildArrowTextVector &&\n      data instanceof arrow.Table &&\n      dataContainer instanceof ArrowDataContainer\n    ) {\n      getText = dataContainer.getColumn(tl.field.fieldIdx);\n      try {\n        getText = getArrowTextVector(getText as arrow.Vector, getTextAccessor);\n      } catch (error) {\n        // empty text labels\n        getText = getArrowTextVector(getText, () => ' ');\n      }\n    }\n\n    return {\n      characterSet,\n      getText\n    };\n  });\n};\n\n/**\n * Get an arrow vector suitable to render text labels with arrow layers.\n * @param getText A candidate arrow vector to use for text labels.\n * @param getTextAccessor Text label accessor.\n */\nexport const getArrowTextVector = (\n  candidateTextVector: arrow.Vector,\n  getTextAccessor: ({index}: {index: number}) => string\n): arrow.Vector => {\n  // if the passed vector is suitable for text labels\n  if (arrow.DataType.isUtf8(candidateTextVector?.type)) {\n    return candidateTextVector;\n  }\n\n  // create utf8 vector from source vector with the same number of batches.\n  // @ts-expect-error\n  const offsets = candidateTextVector._offsets;\n  const numOffsets = offsets.length;\n  const batchVectors: arrow.Vector[] = [];\n  const datum = {index: 0};\n  for (let batchIndex = 0; batchIndex < numOffsets - 1; batchIndex++) {\n    const batchStart = offsets[batchIndex];\n    const batchEnd = offsets[batchIndex + 1];\n\n    const batchLabels: string[] = [];\n    for (let rowIndex = batchStart; rowIndex < batchEnd; ++rowIndex) {\n      datum.index = rowIndex;\n      batchLabels.push(getTextAccessor(datum));\n    }\n\n    batchVectors.push(arrow.vectorFromArray(batchLabels, new arrow.Utf8()));\n  }\n\n  const input = batchVectors.flatMap(x => x.data).flat(Number.POSITIVE_INFINITY);\n\n  return new arrow.Vector(input);\n};\n"],"mappings":";;;;;;;;;;AAGA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,wBAAA,GAAAD,OAAA;AACA,IAAAE,MAAA,GAAAF,OAAA;AACA,IAAAG,YAAA,GAAAH,OAAA;AACA,IAAAI,OAAA,GAAAC,sBAAA,CAAAL,OAAA;AAA+B,SAAAM,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAR,wBAAAQ,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAP/B;AACA;;AAQO,IAAMW,cAAc,GAAAC,OAAA,CAAAD,cAAA,GAAG,EAAE;AAEzB,SAASE,qBAAqBA,CAACC,WAAW,EAAEC,SAAS,EAAEC,QAAQ,EAAE;EACtE,OAAO,UAAAC,SAAS,EAAI;IAClB,IAAMC,aAAa,GAAG,IAAAC,0CAAiB,EAACH,QAAQ,CAAC;IACjD,IAAMI,KAAK,GAAGH,SAAS,CAACI,MAAM,KAAK,QAAQ,GAAG,CAAC,GAAGJ,SAAS,CAACI,MAAM,KAAK,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;IACvF,IAAMC,KAAK,GAAGL,SAAS,CAACM,SAAS,KAAK,QAAQ,GAAG,CAAC,GAAGN,SAAS,CAACM,SAAS,KAAK,QAAQ,GAAG,CAAC,GAAG,CAAC,CAAC;IAE9F,IAAMC,UAAU,GACdP,SAAS,CAACM,SAAS,KAAK,QAAQ,GAC5B,CAAC,GACDN,SAAS,CAACM,SAAS,KAAK,QAAQ,GAChCN,SAAS,CAACQ,IAAI,GACdR,SAAS,CAACQ,IAAI;IAEpB,IAAMC,WAAW,GAAGZ,WAAW,GAAGI,aAAa,CAACS,cAAc,CAAC,CAAC,CAAC;IACjE,IAAMC,OAAO,GAAGjB,cAAc;IAE9B,OAAO,OAAOI,SAAS,KAAK,UAAU,GAClC,UAAAc,CAAC;MAAA,OAAI,CACHT,KAAK,IAAIL,SAAS,CAACc,CAAC,CAAC,GAAGH,WAAW,GAAGE,OAAO,CAAC,EAC9CN,KAAK,IAAIP,SAAS,CAACc,CAAC,CAAC,GAAGH,WAAW,GAAGE,OAAO,GAAGJ,UAAU,CAAC,CAC5D;IAAA,IACD,CACEJ,KAAK,IAAIL,SAAS,GAAGW,WAAW,GAAGE,OAAO,CAAC,EAC3CN,KAAK,IAAIP,SAAS,GAAGW,WAAW,GAAGE,OAAO,GAAGJ,UAAU,CAAC,CACzD;EACP,CAAC;AACH;;AAEA;AACO,IAAMM,iBAAiB,GAAAlB,OAAA,CAAAkB,iBAAA,GAAG,SAApBA,iBAAiBA,CAAGb,SAAS;EAAA,OAAI,UAAAc,EAAE;IAAA,OAAI,UAAAF,CAAC,EAAI;MACvD,IAAMG,GAAG,GAAGf,SAAS,CAACgB,KAAK,CAACC,aAAa,CAACL,CAAC,CAAC;MAC5C,OAAO,IAAAM,+BAAkB,EAACH,GAAG,CAAC,GAAGI,MAAM,CAACJ,GAAG,CAAC,GAAG,EAAE;IACnD,CAAC;EAAA;AAAA;AAEM,IAAMK,mBAAmB,GAAAzB,OAAA,CAAAyB,mBAAA,GAAG,SAAtBA,mBAAmBA,CAAAC,IAAA,EAc1B;EAAA,IAbJrB,SAAS,GAAAqB,IAAA,CAATrB,SAAS;IACTsB,cAAc,GAAAD,IAAA,CAAdC,cAAc;IACdC,YAAY,GAAAF,IAAA,CAAZE,YAAY;IACZC,IAAI,GAAAH,IAAA,CAAJG,IAAI;IACJC,aAAa,GAAAJ,IAAA,CAAbI,aAAa;IACbC,aAAa,GAAAL,IAAA,CAAbK,aAAa;EASb,OAAO1B,SAAS,CAAC2B,GAAG,CAAC,UAACC,EAAE,EAAEpC,CAAC,EAAK;IAC9B,IAAI,CAACoC,EAAE,CAACZ,KAAK,EAAE;MACb;MACA,OAAO;QACLa,OAAO,EAAE,IAAI;QACbC,YAAY,EAAE;MAChB,CAAC;IACH;IAEA,IAAMC,eAA+C,GAAGlB,iBAAiB,CAACe,EAAE,CAAC,CAACH,aAAa,CAAC;IAC5F,IAAIK,YAAY;IAChB,IAAID,OAA8C,GAAGE,eAAe;IAEpE,IAAIC,sBAAsB,GAAG,IAAI;IACjC,IACE,EAACV,cAAc,aAAdA,cAAc,eAAdA,cAAc,yBAAAW,MAAA,CAA2BzC,CAAC,EAAG,KAC9C+B,YAAY,IACZA,YAAY,CAACW,UAAU,IACvBX,YAAY,CAACW,UAAU,CAAC1C,CAAC,CAAC,EAC1B;MACAsC,YAAY,GAAGP,YAAY,CAACW,UAAU,CAAC1C,CAAC,CAAC,CAACsC,YAAY;MACtDD,OAAO,GAAGN,YAAY,CAACW,UAAU,CAAC1C,CAAC,CAAC,CAACqC,OAAO;MAC5CG,sBAAsB,GAAG,KAAK;IAChC,CAAC,MAAM;MACL,IAAIR,IAAI,YAAY1D,KAAK,CAACqE,KAAK,EAAE;QAC/B;QACA;QACA,IAAMC,SAAmB,GAAG,EAAE;QAC9B,IAAIR,EAAE,CAACZ,KAAK,EAAE;UACZ,IAAIU,aAAa,EAAE;YACjBA,aAAa,CAACW,OAAO,CAAC,UAACC,KAAK,EAAEC,KAAK,EAAK;cACtC,IAAID,KAAK,GAAG,CAAC,EAAEF,SAAS,CAACI,IAAI,CAACT,eAAe,CAAC;gBAACQ,KAAK,EAALA;cAAK,CAAC,CAAC,CAAC;YACzD,CAAC,CAAC;UACJ,CAAC,MAAM;YACL,KAAK,IAAIA,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAGd,aAAa,CAACgB,OAAO,CAAC,CAAC,EAAE,EAAEF,KAAK,EAAE;cAC5DH,SAAS,CAACI,IAAI,CAACT,eAAe,CAAC;gBAACQ,KAAK,EAALA;cAAK,CAAC,CAAC,CAAC;YAC1C;UACF;QACF;QACAT,YAAY,GAAG,IAAAY,kBAAI,EAACN,SAAS,CAACO,IAAI,CAAC,EAAE,CAAC,CAAC;MACzC,CAAC,MAAM;QACL,IAAMP,UAAS,GAAGR,EAAE,CAACZ,KAAK,GAAGQ,IAAI,CAACG,GAAG,CAACI,eAAe,CAAC,GAAG,EAAE;QAC3DD,YAAY,GAAG,IAAAY,kBAAI,EAACN,UAAS,CAACO,IAAI,CAAC,EAAE,CAAC,CAAC;MACzC;IACF;;IAEA;IACA;IACA,IACEX,sBAAsB,IACtBR,IAAI,YAAY1D,KAAK,CAACqE,KAAK,IAC3BV,aAAa,YAAYmB,yBAAkB,EAC3C;MACAf,OAAO,GAAGJ,aAAa,CAACoB,SAAS,CAACjB,EAAE,CAACZ,KAAK,CAAC8B,QAAQ,CAAC;MACpD,IAAI;QACFjB,OAAO,GAAGkB,kBAAkB,CAAClB,OAAO,EAAkBE,eAAe,CAAC;MACxE,CAAC,CAAC,OAAOiB,KAAK,EAAE;QACd;QACAnB,OAAO,GAAGkB,kBAAkB,CAAClB,OAAO,EAAE;UAAA,OAAM,GAAG;QAAA,EAAC;MAClD;IACF;IAEA,OAAO;MACLC,YAAY,EAAZA,YAAY;MACZD,OAAO,EAAPA;IACF,CAAC;EACH,CAAC,CAAC;AACJ,CAAC;;AAED;AACA;AACA;AACA;AACA;AACO,IAAMkB,kBAAkB,GAAApD,OAAA,CAAAoD,kBAAA,GAAG,SAArBA,kBAAkBA,CAC7BE,mBAAiC,EACjClB,eAAqD,EACpC;EACjB;EACA,IAAIjE,KAAK,CAACoF,QAAQ,CAACC,MAAM,CAACF,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAEG,IAAI,CAAC,EAAE;IACpD,OAAOH,mBAAmB;EAC5B;;EAEA;EACA;EACA,IAAMI,OAAO,GAAGJ,mBAAmB,CAACK,QAAQ;EAC5C,IAAMC,UAAU,GAAGF,OAAO,CAACG,MAAM;EACjC,IAAMC,YAA4B,GAAG,EAAE;EACvC,IAAMC,KAAK,GAAG;IAACnB,KAAK,EAAE;EAAC,CAAC;EACxB,KAAK,IAAIoB,UAAU,GAAG,CAAC,EAAEA,UAAU,GAAGJ,UAAU,GAAG,CAAC,EAAEI,UAAU,EAAE,EAAE;IAClE,IAAMC,UAAU,GAAGP,OAAO,CAACM,UAAU,CAAC;IACtC,IAAME,QAAQ,GAAGR,OAAO,CAACM,UAAU,GAAG,CAAC,CAAC;IAExC,IAAMG,WAAqB,GAAG,EAAE;IAChC,KAAK,IAAIC,QAAQ,GAAGH,UAAU,EAAEG,QAAQ,GAAGF,QAAQ,EAAE,EAAEE,QAAQ,EAAE;MAC/DL,KAAK,CAACnB,KAAK,GAAGwB,QAAQ;MACtBD,WAAW,CAACtB,IAAI,CAACT,eAAe,CAAC2B,KAAK,CAAC,CAAC;IAC1C;IAEAD,YAAY,CAACjB,IAAI,CAAC1E,KAAK,CAACkG,eAAe,CAACF,WAAW,EAAE,IAAIhG,KAAK,CAACmG,IAAI,CAAC,CAAC,CAAC,CAAC;EACzE;EAEA,IAAMC,KAAK,GAAGT,YAAY,CAACU,OAAO,CAAC,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAAC5C,IAAI;EAAA,EAAC,CAAC6C,IAAI,CAACC,MAAM,CAACC,iBAAiB,CAAC;EAE9E,OAAO,IAAIzG,KAAK,CAAC0G,MAAM,CAACN,KAAK,CAAC;AAChC,CAAC","ignoreList":[]}