kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
162 lines (140 loc) • 18 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _deck = require("deck.gl");
var _constants = _interopRequireDefault(require("luma.gl/constants"));
var _shaderUtils = require("../layer-utils/shader-utils");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var defaultProps = _objectSpread({}, _deck.LineLayer.defaultProps, {
// show arc if source is in brush
brushSource: true,
// show arc if target is in brush
brushTarget: true,
enableBrushing: true,
getStrokeWidth: function getStrokeWidth(d) {
return d.strokeWidth;
},
getTargetColor: function getTargetColor(x) {
return x.color || [0, 0, 0, 255];
},
strokeScale: 1,
// brush radius in meters
brushRadius: 100000,
mousePosition: [0, 0]
});
function addBrushingVsShader(vs) {
var targetColorVs = (0, _shaderUtils.editShader)(vs, 'line target color vs', 'attribute vec4 instanceColors;', 'attribute vec4 instanceColors; attribute vec4 instanceTargetColors;');
var brushingVs = (0, _shaderUtils.editShader)(targetColorVs, 'line brushing vs', 'vec2 offset = getExtrusionOffset(target.xy - source.xy, positions.y);', 'vec2 offset = brushing_getExtrusionOffset(target.xy - source.xy, positions.y, project_uViewportSize, vec4(instanceSourcePositions.xy, instanceTargetPositions.xy), instanceWidths);');
return (0, _shaderUtils.editShader)(brushingVs, 'line color vs', 'vColor = vec4(instanceColors.rgb, instanceColors.a * opacity) / 255.;', "vec4 color = mix(instanceColors, instanceTargetColors, positions.x) / 255.;" + "vColor = vec4(color.rgb, color.a * opacity);");
}
var LineBrushingLayer =
/*#__PURE__*/
function (_LineLayer) {
(0, _inherits2["default"])(LineBrushingLayer, _LineLayer);
function LineBrushingLayer() {
(0, _classCallCheck2["default"])(this, LineBrushingLayer);
return (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(LineBrushingLayer).apply(this, arguments));
}
(0, _createClass2["default"])(LineBrushingLayer, [{
key: "getShaders",
value: function getShaders() {
var shaders = (0, _get2["default"])((0, _getPrototypeOf2["default"])(LineBrushingLayer.prototype), "getShaders", this).call(this); // const addons = getExtrusion + isPicked + isPtInRange;
return {
// ...shaders,
vs: addBrushingVsShader(shaders.vs),
fs: shaders.fs,
// vs: this.props.fp64 ? addons + vs64 : addons + vs,
modules: shaders.modules.concat(['brushing'])
};
}
}, {
key: "initializeState",
value: function initializeState() {
(0, _get2["default"])((0, _getPrototypeOf2["default"])(LineBrushingLayer.prototype), "initializeState", this).call(this);
var attributeManager = this.state.attributeManager;
attributeManager.addInstanced({
instanceTargetColors: {
size: 4,
type: _constants["default"].UNSIGNED_BYTE,
accessor: 'getTargetColor',
update: this.calculateInstanceTargetColors
}
});
}
}, {
key: "draw",
value: function draw(_ref) {
var uniforms = _ref.uniforms;
var _this$props = this.props,
brushSource = _this$props.brushSource,
brushTarget = _this$props.brushTarget,
brushRadius = _this$props.brushRadius,
enableBrushing = _this$props.enableBrushing,
mousePosition = _this$props.mousePosition,
strokeScale = _this$props.strokeScale;
(0, _get2["default"])((0, _getPrototypeOf2["default"])(LineBrushingLayer.prototype), "draw", this).call(this, {
uniforms: _objectSpread({}, uniforms, {
brushing_uBrushSource: brushSource ? 1 : 0,
brushing_uBrushTarget: brushTarget ? 1 : 0,
brushing_uBrushRadius: brushRadius,
brushing_uEnableBrushing: enableBrushing ? 1 : 0,
brushing_uStrokeScale: strokeScale,
brushing_uMousePosition: mousePosition ? new Float32Array(this.unproject(mousePosition)) : defaultProps.mousePosition
})
});
}
}, {
key: "calculateInstanceTargetColors",
value: function calculateInstanceTargetColors(attribute) {
var _this$props2 = this.props,
data = _this$props2.data,
getTargetColor = _this$props2.getTargetColor;
var value = attribute.value,
size = attribute.size;
var i = 0;
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = data[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var object = _step.value;
var color = getTargetColor(object);
value[i + 0] = color[0];
value[i + 1] = color[1];
value[i + 2] = color[2];
value[i + 3] = isNaN(color[3]) ? 255 : color[3];
i += size;
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator["return"] != null) {
_iterator["return"]();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
}
}]);
return LineBrushingLayer;
}(_deck.LineLayer);
exports["default"] = LineBrushingLayer;
LineBrushingLayer.layerName = 'LineBrushingLayer';
LineBrushingLayer.defaultProps = defaultProps;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kZWNrZ2wtbGF5ZXJzL2xpbmUtbGF5ZXIvbGluZS1sYXllci5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0UHJvcHMiLCJMaW5lTGF5ZXIiLCJicnVzaFNvdXJjZSIsImJydXNoVGFyZ2V0IiwiZW5hYmxlQnJ1c2hpbmciLCJnZXRTdHJva2VXaWR0aCIsImQiLCJzdHJva2VXaWR0aCIsImdldFRhcmdldENvbG9yIiwieCIsImNvbG9yIiwic3Ryb2tlU2NhbGUiLCJicnVzaFJhZGl1cyIsIm1vdXNlUG9zaXRpb24iLCJhZGRCcnVzaGluZ1ZzU2hhZGVyIiwidnMiLCJ0YXJnZXRDb2xvclZzIiwiYnJ1c2hpbmdWcyIsIkxpbmVCcnVzaGluZ0xheWVyIiwic2hhZGVycyIsImZzIiwibW9kdWxlcyIsImNvbmNhdCIsImF0dHJpYnV0ZU1hbmFnZXIiLCJzdGF0ZSIsImFkZEluc3RhbmNlZCIsImluc3RhbmNlVGFyZ2V0Q29sb3JzIiwic2l6ZSIsInR5cGUiLCJHTCIsIlVOU0lHTkVEX0JZVEUiLCJhY2Nlc3NvciIsInVwZGF0ZSIsImNhbGN1bGF0ZUluc3RhbmNlVGFyZ2V0Q29sb3JzIiwidW5pZm9ybXMiLCJwcm9wcyIsImJydXNoaW5nX3VCcnVzaFNvdXJjZSIsImJydXNoaW5nX3VCcnVzaFRhcmdldCIsImJydXNoaW5nX3VCcnVzaFJhZGl1cyIsImJydXNoaW5nX3VFbmFibGVCcnVzaGluZyIsImJydXNoaW5nX3VTdHJva2VTY2FsZSIsImJydXNoaW5nX3VNb3VzZVBvc2l0aW9uIiwiRmxvYXQzMkFycmF5IiwidW5wcm9qZWN0IiwiYXR0cmlidXRlIiwiZGF0YSIsInZhbHVlIiwiaSIsIm9iamVjdCIsImlzTmFOIiwibGF5ZXJOYW1lIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW9CQTs7QUFDQTs7QUFDQTs7Ozs7O0FBRUEsSUFBTUEsWUFBWSxxQkFDYkMsZ0JBQVVELFlBREc7QUFFaEI7QUFDQUUsRUFBQUEsV0FBVyxFQUFFLElBSEc7QUFJaEI7QUFDQUMsRUFBQUEsV0FBVyxFQUFFLElBTEc7QUFNaEJDLEVBQUFBLGNBQWMsRUFBRSxJQU5BO0FBT2hCQyxFQUFBQSxjQUFjLEVBQUUsd0JBQUFDLENBQUM7QUFBQSxXQUFJQSxDQUFDLENBQUNDLFdBQU47QUFBQSxHQVBEO0FBUWhCQyxFQUFBQSxjQUFjLEVBQUUsd0JBQUFDLENBQUM7QUFBQSxXQUFJQSxDQUFDLENBQUNDLEtBQUYsSUFBVyxDQUFDLENBQUQsRUFBSSxDQUFKLEVBQU8sQ0FBUCxFQUFVLEdBQVYsQ0FBZjtBQUFBLEdBUkQ7QUFTaEJDLEVBQUFBLFdBQVcsRUFBRSxDQVRHO0FBV2hCO0FBQ0FDLEVBQUFBLFdBQVcsRUFBRSxNQVpHO0FBYWhCQyxFQUFBQSxhQUFhLEVBQUUsQ0FBQyxDQUFELEVBQUksQ0FBSjtBQWJDLEVBQWxCOztBQWdCQSxTQUFTQyxtQkFBVCxDQUE2QkMsRUFBN0IsRUFBaUM7QUFDL0IsTUFBTUMsYUFBYSxHQUFHLDZCQUNwQkQsRUFEb0IsRUFFcEIsc0JBRm9CLEVBR3BCLGdDQUhvQixFQUlwQixxRUFKb0IsQ0FBdEI7QUFPQSxNQUFNRSxVQUFVLEdBQUcsNkJBQ2pCRCxhQURpQixFQUVqQixrQkFGaUIsRUFHakIsdUVBSGlCLEVBSWpCLHFMQUppQixDQUFuQjtBQU9BLFNBQU8sNkJBQ0xDLFVBREssRUFFTCxlQUZLLEVBR0wsdUVBSEssRUFJTCw4SEFKSyxDQUFQO0FBT0Q7O0lBRW9CQyxpQjs7Ozs7Ozs7Ozs7O2lDQUNOO0FBQ1gsVUFBTUMsT0FBTyxzSEFBYixDQURXLENBRVg7O0FBRUEsYUFBTztBQUNMO0FBQ0FKLFFBQUFBLEVBQUUsRUFBRUQsbUJBQW1CLENBQUNLLE9BQU8sQ0FBQ0osRUFBVCxDQUZsQjtBQUdMSyxRQUFBQSxFQUFFLEVBQUVELE9BQU8sQ0FBQ0MsRUFIUDtBQUlMO0FBQ0FDLFFBQUFBLE9BQU8sRUFBRUYsT0FBTyxDQUFDRSxPQUFSLENBQWdCQyxNQUFoQixDQUF1QixDQUFDLFVBQUQsQ0FBdkI7QUFMSixPQUFQO0FBT0Q7OztzQ0FFaUI7QUFDaEI7QUFEZ0IsVUFFVEMsZ0JBRlMsR0FFVyxLQUFLQyxLQUZoQixDQUVURCxnQkFGUztBQUdoQkEsTUFBQUEsZ0JBQWdCLENBQUNFLFlBQWpCLENBQThCO0FBQzVCQyxRQUFBQSxvQkFBb0IsRUFBRTtBQUNwQkMsVUFBQUEsSUFBSSxFQUFFLENBRGM7QUFFcEJDLFVBQUFBLElBQUksRUFBRUMsc0JBQUdDLGFBRlc7QUFHcEJDLFVBQUFBLFFBQVEsRUFBRSxnQkFIVTtBQUlwQkMsVUFBQUEsTUFBTSxFQUFFLEtBQUtDO0FBSk87QUFETSxPQUE5QjtBQVFEOzs7K0JBRWdCO0FBQUEsVUFBWEMsUUFBVyxRQUFYQSxRQUFXO0FBQUEsd0JBUVgsS0FBS0MsS0FSTTtBQUFBLFVBRWJqQyxXQUZhLGVBRWJBLFdBRmE7QUFBQSxVQUdiQyxXQUhhLGVBR2JBLFdBSGE7QUFBQSxVQUliUyxXQUphLGVBSWJBLFdBSmE7QUFBQSxVQUtiUixjQUxhLGVBS2JBLGNBTGE7QUFBQSxVQU1iUyxhQU5hLGVBTWJBLGFBTmE7QUFBQSxVQU9iRixXQVBhLGVBT2JBLFdBUGE7QUFVZixvSEFBVztBQUNUdUIsUUFBQUEsUUFBUSxvQkFDSEEsUUFERztBQUVORSxVQUFBQSxxQkFBcUIsRUFBRWxDLFdBQVcsR0FBRyxDQUFILEdBQU8sQ0FGbkM7QUFHTm1DLFVBQUFBLHFCQUFxQixFQUFFbEMsV0FBVyxHQUFHLENBQUgsR0FBTyxDQUhuQztBQUlObUMsVUFBQUEscUJBQXFCLEVBQUUxQixXQUpqQjtBQUtOMkIsVUFBQUEsd0JBQXdCLEVBQUVuQyxjQUFjLEdBQUcsQ0FBSCxHQUFPLENBTHpDO0FBTU5vQyxVQUFBQSxxQkFBcUIsRUFBRTdCLFdBTmpCO0FBT044QixVQUFBQSx1QkFBdUIsRUFBRTVCLGFBQWEsR0FDbEMsSUFBSTZCLFlBQUosQ0FBaUIsS0FBS0MsU0FBTCxDQUFlOUIsYUFBZixDQUFqQixDQURrQyxHQUVsQ2IsWUFBWSxDQUFDYTtBQVRYO0FBREMsT0FBWDtBQWFEOzs7a0RBRTZCK0IsUyxFQUFXO0FBQUEseUJBQ1IsS0FBS1QsS0FERztBQUFBLFVBQ2hDVSxJQURnQyxnQkFDaENBLElBRGdDO0FBQUEsVUFDMUJyQyxjQUQwQixnQkFDMUJBLGNBRDBCO0FBQUEsVUFFaENzQyxLQUZnQyxHQUVqQkYsU0FGaUIsQ0FFaENFLEtBRmdDO0FBQUEsVUFFekJuQixJQUZ5QixHQUVqQmlCLFNBRmlCLENBRXpCakIsSUFGeUI7QUFHdkMsVUFBSW9CLENBQUMsR0FBRyxDQUFSO0FBSHVDO0FBQUE7QUFBQTs7QUFBQTtBQUl2Qyw2QkFBcUJGLElBQXJCLDhIQUEyQjtBQUFBLGNBQWhCRyxNQUFnQjtBQUN6QixjQUFNdEMsS0FBSyxHQUFHRixjQUFjLENBQUN3QyxNQUFELENBQTVCO0FBQ0FGLFVBQUFBLEtBQUssQ0FBQ0MsQ0FBQyxHQUFHLENBQUwsQ0FBTCxHQUFlckMsS0FBSyxDQUFDLENBQUQsQ0FBcEI7QUFDQW9DLFVBQUFBLEtBQUssQ0FBQ0MsQ0FBQyxHQUFHLENBQUwsQ0FBTCxHQUFlckMsS0FBSyxDQUFDLENBQUQsQ0FBcEI7QUFDQW9DLFVBQUFBLEtBQUssQ0FBQ0MsQ0FBQyxHQUFHLENBQUwsQ0FBTCxHQUFlckMsS0FBSyxDQUFDLENBQUQsQ0FBcEI7QUFDQW9DLFVBQUFBLEtBQUssQ0FBQ0MsQ0FBQyxHQUFHLENBQUwsQ0FBTCxHQUFlRSxLQUFLLENBQUN2QyxLQUFLLENBQUMsQ0FBRCxDQUFOLENBQUwsR0FBa0IsR0FBbEIsR0FBd0JBLEtBQUssQ0FBQyxDQUFELENBQTVDO0FBQ0FxQyxVQUFBQSxDQUFDLElBQUlwQixJQUFMO0FBQ0Q7QUFYc0M7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVl4Qzs7O0VBaEU0QzFCLGU7OztBQW1FL0NpQixpQkFBaUIsQ0FBQ2dDLFNBQWxCLEdBQThCLG1CQUE5QjtBQUNBaEMsaUJBQWlCLENBQUNsQixZQUFsQixHQUFpQ0EsWUFBakMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgKGMpIDIwMTkgVWJlciBUZWNobm9sb2dpZXMsIEluYy5cbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW5cbi8vIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTlxuLy8gVEhFIFNPRlRXQVJFLlxuXG5pbXBvcnQge0xpbmVMYXllcn0gZnJvbSAnZGVjay5nbCc7XG5pbXBvcnQgR0wgZnJvbSAnbHVtYS5nbC9jb25zdGFudHMnO1xuaW1wb3J0IHtlZGl0U2hhZGVyfSBmcm9tICdkZWNrZ2wtbGF5ZXJzL2xheWVyLXV0aWxzL3NoYWRlci11dGlscyc7XG5cbmNvbnN0IGRlZmF1bHRQcm9wcyA9IHtcbiAgLi4uTGluZUxheWVyLmRlZmF1bHRQcm9wcyxcbiAgLy8gc2hvdyBhcmMgaWYgc291cmNlIGlzIGluIGJydXNoXG4gIGJydXNoU291cmNlOiB0cnVlLFxuICAvLyBzaG93IGFyYyBpZiB0YXJnZXQgaXMgaW4gYnJ1c2hcbiAgYnJ1c2hUYXJnZXQ6IHRydWUsXG4gIGVuYWJsZUJydXNoaW5nOiB0cnVlLFxuICBnZXRTdHJva2VXaWR0aDogZCA9PiBkLnN0cm9rZVdpZHRoLFxuICBnZXRUYXJnZXRDb2xvcjogeCA9PiB4LmNvbG9yIHx8IFswLCAwLCAwLCAyNTVdLFxuICBzdHJva2VTY2FsZTogMSxcblxuICAvLyBicnVzaCByYWRpdXMgaW4gbWV0ZXJzXG4gIGJydXNoUmFkaXVzOiAxMDAwMDAsXG4gIG1vdXNlUG9zaXRpb246IFswLCAwXVxufTtcblxuZnVuY3Rpb24gYWRkQnJ1c2hpbmdWc1NoYWRlcih2cykge1xuICBjb25zdCB0YXJnZXRDb2xvclZzID0gZWRpdFNoYWRlcihcbiAgICB2cyxcbiAgICAnbGluZSB0YXJnZXQgY29sb3IgdnMnLFxuICAgICdhdHRyaWJ1dGUgdmVjNCBpbnN0YW5jZUNvbG9yczsnLFxuICAgICdhdHRyaWJ1dGUgdmVjNCBpbnN0YW5jZUNvbG9yczsgYXR0cmlidXRlIHZlYzQgaW5zdGFuY2VUYXJnZXRDb2xvcnM7J1xuICApO1xuXG4gIGNvbnN0IGJydXNoaW5nVnMgPSBlZGl0U2hhZGVyKFxuICAgIHRhcmdldENvbG9yVnMsXG4gICAgJ2xpbmUgYnJ1c2hpbmcgdnMnLFxuICAgICd2ZWMyIG9mZnNldCA9IGdldEV4dHJ1c2lvbk9mZnNldCh0YXJnZXQueHkgLSBzb3VyY2UueHksIHBvc2l0aW9ucy55KTsnLFxuICAgICd2ZWMyIG9mZnNldCA9IGJydXNoaW5nX2dldEV4dHJ1c2lvbk9mZnNldCh0YXJnZXQueHkgLSBzb3VyY2UueHksIHBvc2l0aW9ucy55LCBwcm9qZWN0X3VWaWV3cG9ydFNpemUsIHZlYzQoaW5zdGFuY2VTb3VyY2VQb3NpdGlvbnMueHksIGluc3RhbmNlVGFyZ2V0UG9zaXRpb25zLnh5KSwgaW5zdGFuY2VXaWR0aHMpOydcbiAgKTtcblxuICByZXR1cm4gZWRpdFNoYWRlcihcbiAgICBicnVzaGluZ1ZzLFxuICAgICdsaW5lIGNvbG9yIHZzJyxcbiAgICAndkNvbG9yID0gdmVjNChpbnN0YW5jZUNvbG9ycy5yZ2IsIGluc3RhbmNlQ29sb3JzLmEgKiBvcGFjaXR5KSAvIDI1NS47JyxcbiAgICBgdmVjNCBjb2xvciA9IG1peChpbnN0YW5jZUNvbG9ycywgaW5zdGFuY2VUYXJnZXRDb2xvcnMsIHBvc2l0aW9ucy54KSAvIDI1NS47YCArXG4gICAgYHZDb2xvciA9IHZlYzQoY29sb3IucmdiLCBjb2xvci5hICogb3BhY2l0eSk7YFxuICApXG59XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIExpbmVCcnVzaGluZ0xheWVyIGV4dGVuZHMgTGluZUxheWVyIHtcbiAgZ2V0U2hhZGVycygpIHtcbiAgICBjb25zdCBzaGFkZXJzID0gc3VwZXIuZ2V0U2hhZGVycygpO1xuICAgIC8vIGNvbnN0IGFkZG9ucyA9IGdldEV4dHJ1c2lvbiArIGlzUGlja2VkICsgaXNQdEluUmFuZ2U7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLy8gLi4uc2hhZGVycyxcbiAgICAgIHZzOiBhZGRCcnVzaGluZ1ZzU2hhZGVyKHNoYWRlcnMudnMpLFxuICAgICAgZnM6IHNoYWRlcnMuZnMsXG4gICAgICAvLyB2czogdGhpcy5wcm9wcy5mcDY0ID8gYWRkb25zICsgdnM2NCA6IGFkZG9ucyArIHZzLFxuICAgICAgbW9kdWxlczogc2hhZGVycy5tb2R1bGVzLmNvbmNhdChbJ2JydXNoaW5nJ10pXG4gICAgfTtcbiAgfVxuXG4gIGluaXRpYWxpemVTdGF0ZSgpIHtcbiAgICBzdXBlci5pbml0aWFsaXplU3RhdGUoKTtcbiAgICBjb25zdCB7YXR0cmlidXRlTWFuYWdlcn0gPSB0aGlzLnN0YXRlO1xuICAgIGF0dHJpYnV0ZU1hbmFnZXIuYWRkSW5zdGFuY2VkKHtcbiAgICAgIGluc3RhbmNlVGFyZ2V0Q29sb3JzOiB7XG4gICAgICAgIHNpemU6IDQsXG4gICAgICAgIHR5cGU6IEdMLlVOU0lHTkVEX0JZVEUsXG4gICAgICAgIGFjY2Vzc29yOiAnZ2V0VGFyZ2V0Q29sb3InLFxuICAgICAgICB1cGRhdGU6IHRoaXMuY2FsY3VsYXRlSW5zdGFuY2VUYXJnZXRDb2xvcnNcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIGRyYXcoe3VuaWZvcm1zfSkge1xuICAgIGNvbnN0IHtcbiAgICAgIGJydXNoU291cmNlLFxuICAgICAgYnJ1c2hUYXJnZXQsXG4gICAgICBicnVzaFJhZGl1cyxcbiAgICAgIGVuYWJsZUJydXNoaW5nLFxuICAgICAgbW91c2VQb3NpdGlvbixcbiAgICAgIHN0cm9rZVNjYWxlXG4gICAgfSA9IHRoaXMucHJvcHM7XG5cbiAgICBzdXBlci5kcmF3KHtcbiAgICAgIHVuaWZvcm1zOiB7XG4gICAgICAgIC4uLnVuaWZvcm1zLFxuICAgICAgICBicnVzaGluZ191QnJ1c2hTb3VyY2U6IGJydXNoU291cmNlID8gMSA6IDAsXG4gICAgICAgIGJydXNoaW5nX3VCcnVzaFRhcmdldDogYnJ1c2hUYXJnZXQgPyAxIDogMCxcbiAgICAgICAgYnJ1c2hpbmdfdUJydXNoUmFkaXVzOiBicnVzaFJhZGl1cyxcbiAgICAgICAgYnJ1c2hpbmdfdUVuYWJsZUJydXNoaW5nOiBlbmFibGVCcnVzaGluZyA/IDEgOiAwLFxuICAgICAgICBicnVzaGluZ191U3Ryb2tlU2NhbGU6IHN0cm9rZVNjYWxlLFxuICAgICAgICBicnVzaGluZ191TW91c2VQb3NpdGlvbjogbW91c2VQb3NpdGlvblxuICAgICAgICAgID8gbmV3IEZsb2F0MzJBcnJheSh0aGlzLnVucHJvamVjdChtb3VzZVBvc2l0aW9uKSlcbiAgICAgICAgICA6IGRlZmF1bHRQcm9wcy5tb3VzZVBvc2l0aW9uXG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBjYWxjdWxhdGVJbnN0YW5jZVRhcmdldENvbG9ycyhhdHRyaWJ1dGUpIHtcbiAgICBjb25zdCB7ZGF0YSwgZ2V0VGFyZ2V0Q29sb3J9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCB7dmFsdWUsIHNpemV9ID0gYXR0cmlidXRlO1xuICAgIGxldCBpID0gMDtcbiAgICBmb3IgKGNvbnN0IG9iamVjdCBvZiBkYXRhKSB7XG4gICAgICBjb25zdCBjb2xvciA9IGdldFRhcmdldENvbG9yKG9iamVjdCk7XG4gICAgICB2YWx1ZVtpICsgMF0gPSBjb2xvclswXTtcbiAgICAgIHZhbHVlW2kgKyAxXSA9IGNvbG9yWzFdO1xuICAgICAgdmFsdWVbaSArIDJdID0gY29sb3JbMl07XG4gICAgICB2YWx1ZVtpICsgM10gPSBpc05hTihjb2xvclszXSkgPyAyNTUgOiBjb2xvclszXTtcbiAgICAgIGkgKz0gc2l6ZTtcbiAgICB9XG4gIH1cbn1cblxuTGluZUJydXNoaW5nTGF5ZXIubGF5ZXJOYW1lID0gJ0xpbmVCcnVzaGluZ0xheWVyJztcbkxpbmVCcnVzaGluZ0xheWVyLmRlZmF1bHRQcm9wcyA9IGRlZmF1bHRQcm9wcztcbiJdfQ==